From 23b6193024b4a10ba3a931901b353fa6f2e6a5ea Mon Sep 17 00:00:00 2001 From: Jeremy Penner Date: Sun, 7 Feb 2021 16:56:19 -0500 Subject: [PATCH] Initial checkin --- conf.lua | 5 + editor/editmode.fnl | 17 + editor/imstate.fnl | 215 + editor/init.fnl | 17 + editor/lovemode.fnl | 44 + editor/modeview.fnl | 25 + game/entities/bomberman.fnl | 12 + game/entities/pacman.fnl | 9 + game/entity.fnl | 24 + game/helpers.fnl | 12 + game/init.fnl | 21 + game/mode.fnl | 12 + game/rules.fnl | 8 + game/state.fnl | 1 + game/tiles.fnl | 16 + lib/bencode.lua | 89 + lib/dkjson.lua | 714 + lib/fennel.lua | 3882 ++++++ lib/lume.lua | 780 ++ lib/spawn.lua | 44 + lib/stdio.fnl | 46 + lib/util.fnl | 83 + main.lua | 19 + support/lite/plugins/betterfind.lua | 25 + support/lite/plugins/rainbowparen.lua | 58 + todo.txt | 3 + vendor/jeejah/.gitrepo | 12 + vendor/jeejah/Changelog.md | 31 + vendor/jeejah/LICENSE | 19 + vendor/jeejah/Makefile | 1 + vendor/jeejah/Readme.md | 94 + vendor/jeejah/bencode.lua | 78 + vendor/jeejah/bin/jeejah | 35 + vendor/jeejah/fennel.lua | 3319 +++++ vendor/jeejah/fennelview.fnl | 202 + vendor/jeejah/jeejah.lua | 357 + vendor/jeejah/jeejah/fenneleval.lua | 77 + vendor/jeejah/monroe-lua-complete.el | 89 + .../jeejah/rockspecs/jeejah-0.1.0-1.rockspec | 28 + .../jeejah/rockspecs/jeejah-0.2.1-1.rockspec | 28 + .../jeejah/rockspecs/jeejah-0.2.1-4.rockspec | 28 + .../jeejah/rockspecs/jeejah-0.3.0-1.rockspec | 28 + .../jeejah/rockspecs/jeejah-0.3.1-1.rockspec | 28 + .../jeejah/rockspecs/jeejah-0.3.1-2.rockspec | 29 + .../jeejah/rockspecs/jeejah-0.3.1-4.rockspec | 30 + vendor/jeejah/serpent.lua | 125 + vendor/lite-plugins/.gitrepo | 12 + vendor/lite-plugins/README.md | 86 + vendor/lite-plugins/plugins/autoinsert.lua | 114 + vendor/lite-plugins/plugins/autowrap.lua | 35 + vendor/lite-plugins/plugins/bigclock.lua | 72 + vendor/lite-plugins/plugins/bracketmatch.lua | 117 + vendor/lite-plugins/plugins/centerdoc.lua | 19 + vendor/lite-plugins/plugins/colorpreview.lua | 53 + .../lite-plugins/plugins/copyfilelocation.lua | 17 + .../lite-plugins/plugins/datetimestamps.lua | 60 + vendor/lite-plugins/plugins/detectindent.lua | 64 + .../lite-plugins/plugins/dragdropselected.lua | 112 + .../lite-plugins/plugins/drawwhitespace.lua | 37 + vendor/lite-plugins/plugins/eval.lua | 23 + vendor/lite-plugins/plugins/exec.lua | 45 + vendor/lite-plugins/plugins/ghmarkdown.lua | 73 + vendor/lite-plugins/plugins/gitstatus.lua | 69 + vendor/lite-plugins/plugins/gofmt.lua | 49 + .../lite-plugins/plugins/hidelinenumbers.lua | 5 + vendor/lite-plugins/plugins/hidestatus.lua | 18 + vendor/lite-plugins/plugins/inanimate.lua | 12 + vendor/lite-plugins/plugins/indentguide.lua | 45 + .../plugins/language_angelscript.lua | 86 + .../lite-plugins/plugins/language_batch.lua | 61 + .../lite-plugins/plugins/language_cmake.lua | 15 + vendor/lite-plugins/plugins/language_cpp.lua | 121 + .../lite-plugins/plugins/language_csharp.lua | 112 + vendor/lite-plugins/plugins/language_d.lua | 135 + .../lite-plugins/plugins/language_elixir.lua | 92 + vendor/lite-plugins/plugins/language_elm.lua | 47 + vendor/lite-plugins/plugins/language_fe.lua | 33 + .../lite-plugins/plugins/language_fennel.lua | 100 + .../plugins/language_gdscript.lua | 99 + vendor/lite-plugins/plugins/language_glsl.lua | 387 + vendor/lite-plugins/plugins/language_go.lua | 71 + vendor/lite-plugins/plugins/language_hlsl.lua | 275 + vendor/lite-plugins/plugins/language_hs.lua | 45 + vendor/lite-plugins/plugins/language_java.lua | 75 + vendor/lite-plugins/plugins/language_jiyu.lua | 91 + vendor/lite-plugins/plugins/language_make.lua | 17 + .../lite-plugins/plugins/language_meson.lua | 35 + vendor/lite-plugins/plugins/language_odin.lua | 157 + vendor/lite-plugins/plugins/language_php.lua | 99 + .../lite-plugins/plugins/language_pico8.lua | 51 + .../plugins/language_powershell.lua | 72 + vendor/lite-plugins/plugins/language_psql.lua | 90 + vendor/lite-plugins/plugins/language_rust.lua | 84 + vendor/lite-plugins/plugins/language_sh.lua | 42 + vendor/lite-plugins/plugins/language_tex.lua | 16 + vendor/lite-plugins/plugins/language_wren.lua | 43 + vendor/lite-plugins/plugins/lastproject.lua | 26 + vendor/lite-plugins/plugins/lfautoinsert.lua | 64 + vendor/lite-plugins/plugins/linecopypaste.lua | 45 + vendor/lite-plugins/plugins/lineguide.lua | 18 + vendor/lite-plugins/plugins/macmodkeys.lua | 18 + vendor/lite-plugins/plugins/markers.lua | 103 + vendor/lite-plugins/plugins/motiontrail.lua | 46 + .../lite-plugins/plugins/openfilelocation.lua | 30 + vendor/lite-plugins/plugins/openselected.lua | 26 + .../lite-plugins/plugins/projectmanager.lua | 128 + vendor/lite-plugins/plugins/scale.lua | 110 + vendor/lite-plugins/plugins/scalestatus.lua | 41 + .../plugins/selectionhighlight.lua | 37 + vendor/lite-plugins/plugins/sort.lua | 30 + vendor/lite-plugins/plugins/spellcheck.lua | 179 + vendor/lite-plugins/plugins/titleize.lua | 11 + .../lite-plugins/plugins/togglesnakecamel.lua | 32 + .../lite-plugins/plugins/unboundedscroll.lua | 5 + vendor/lite-plugins/plugins/workspace.lua | 164 + vendor/lite/.gitattributes | 3 + vendor/lite/.github/FUNDING.yml | 3 + vendor/lite/.gitrepo | 12 + vendor/lite/LICENSE | 19 + vendor/lite/README.md | 53 + vendor/lite/build.sh | 43 + vendor/lite/build_release.sh | 10 + vendor/lite/conf.lua | 6 + vendor/lite/data/core/command.lua | 69 + vendor/lite/data/core/commands/command.lua | 30 + vendor/lite/data/core/commands/core.lua | 101 + vendor/lite/data/core/commands/doc.lua | 363 + .../lite/data/core/commands/findreplace.lua | 170 + vendor/lite/data/core/commands/root.lua | 105 + vendor/lite/data/core/commandview.lua | 256 + vendor/lite/data/core/common.lua | 140 + vendor/lite/data/core/config.lua | 20 + vendor/lite/data/core/doc/highlighter.lua | 80 + vendor/lite/data/core/doc/init.lua | 393 + vendor/lite/data/core/doc/search.lua | 52 + vendor/lite/data/core/doc/translate.lua | 136 + vendor/lite/data/core/docview.lua | 383 + vendor/lite/data/core/init.lua | 487 + vendor/lite/data/core/keymap.lua | 186 + vendor/lite/data/core/logview.lua | 74 + vendor/lite/data/core/object.lua | 58 + vendor/lite/data/core/rootview.lua | 508 + vendor/lite/data/core/statusview.lua | 141 + vendor/lite/data/core/strict.lua | 26 + vendor/lite/data/core/style.lua | 42 + vendor/lite/data/core/syntax.lua | 30 + vendor/lite/data/core/tokenizer.lua | 112 + vendor/lite/data/core/view.lua | 151 + vendor/lite/data/fonts/font.ttf | Bin 0 -> 171272 bytes vendor/lite/data/fonts/icons.ttf | Bin 0 -> 7644 bytes vendor/lite/data/fonts/monospace.ttf | Bin 0 -> 109212 bytes vendor/lite/data/plugins/autocomplete.lua | 284 + vendor/lite/data/plugins/autoinsert.lua | 1 + vendor/lite/data/plugins/autoreload.lua | 61 + vendor/lite/data/plugins/betterfind.lua | 1 + vendor/lite/data/plugins/bracketmatch.lua | 1 + vendor/lite/data/plugins/language_c.lua | 59 + vendor/lite/data/plugins/language_css.lua | 23 + vendor/lite/data/plugins/language_fennel.lua | 1 + vendor/lite/data/plugins/language_js.lua | 67 + vendor/lite/data/plugins/language_lua.lua | 50 + vendor/lite/data/plugins/language_md.lua | 21 + vendor/lite/data/plugins/language_python.lua | 55 + vendor/lite/data/plugins/language_xml.lua | 21 + vendor/lite/data/plugins/macro.lua | 69 + vendor/lite/data/plugins/projectsearch.lua | 271 + vendor/lite/data/plugins/quote.lua | 30 + vendor/lite/data/plugins/rainbowparen.lua | 1 + vendor/lite/data/plugins/reflow.lua | 63 + .../lite/data/plugins/selectionhighlight.lua | 1 + vendor/lite/data/plugins/tabularize.lua | 60 + vendor/lite/data/plugins/treeview.lua | 197 + vendor/lite/data/plugins/trimwhitespace.lua | 36 + vendor/lite/data/user/colors/fall.lua | 28 + vendor/lite/data/user/colors/summer.lua | 28 + vendor/lite/data/user/init.lua | 13 + vendor/lite/doc/usage.md | 146 + vendor/lite/icon.ico | Bin 0 -> 32038 bytes vendor/lite/icon.inl | 1369 ++ vendor/lite/main.lua | 318 + vendor/lite/res.rc | 2 + vendor/lite/src/api/api.c | 18 + vendor/lite/src/api/api.h | 12 + vendor/lite/src/api/renderer.c | 106 + vendor/lite/src/api/renderer_font.c | 62 + vendor/lite/src/api/system.c | 407 + vendor/lite/src/lib/lua52/lapi.c | 1284 ++ vendor/lite/src/lib/lua52/lapi.h | 24 + vendor/lite/src/lib/lua52/lauxlib.c | 959 ++ vendor/lite/src/lib/lua52/lauxlib.h | 212 + vendor/lite/src/lib/lua52/lbaselib.c | 458 + vendor/lite/src/lib/lua52/lbitlib.c | 212 + vendor/lite/src/lib/lua52/lcode.c | 881 ++ vendor/lite/src/lib/lua52/lcode.h | 83 + vendor/lite/src/lib/lua52/lcorolib.c | 155 + vendor/lite/src/lib/lua52/lctype.c | 52 + vendor/lite/src/lib/lua52/lctype.h | 95 + vendor/lite/src/lib/lua52/ldblib.c | 408 + vendor/lite/src/lib/lua52/ldebug.c | 610 + vendor/lite/src/lib/lua52/ldebug.h | 34 + vendor/lite/src/lib/lua52/ldo.c | 681 + vendor/lite/src/lib/lua52/ldo.h | 46 + vendor/lite/src/lib/lua52/ldump.c | 173 + vendor/lite/src/lib/lua52/lfunc.c | 161 + vendor/lite/src/lib/lua52/lfunc.h | 33 + vendor/lite/src/lib/lua52/lgc.c | 1220 ++ vendor/lite/src/lib/lua52/lgc.h | 157 + vendor/lite/src/lib/lua52/linit.c | 67 + vendor/lite/src/lib/lua52/liolib.c | 666 + vendor/lite/src/lib/lua52/llex.c | 530 + vendor/lite/src/lib/lua52/llex.h | 78 + vendor/lite/src/lib/lua52/llimits.h | 309 + vendor/lite/src/lib/lua52/lmathlib.c | 279 + vendor/lite/src/lib/lua52/lmem.c | 99 + vendor/lite/src/lib/lua52/lmem.h | 57 + vendor/lite/src/lib/lua52/loadlib.c | 725 + vendor/lite/src/lib/lua52/lobject.c | 287 + vendor/lite/src/lib/lua52/lobject.h | 607 + vendor/lite/src/lib/lua52/lopcodes.c | 107 + vendor/lite/src/lib/lua52/lopcodes.h | 288 + vendor/lite/src/lib/lua52/loslib.c | 323 + vendor/lite/src/lib/lua52/lparser.c | 1638 +++ vendor/lite/src/lib/lua52/lparser.h | 119 + vendor/lite/src/lib/lua52/lstate.c | 323 + vendor/lite/src/lib/lua52/lstate.h | 228 + vendor/lite/src/lib/lua52/lstring.c | 185 + vendor/lite/src/lib/lua52/lstring.h | 46 + vendor/lite/src/lib/lua52/lstrlib.c | 1019 ++ vendor/lite/src/lib/lua52/ltable.c | 588 + vendor/lite/src/lib/lua52/ltable.h | 45 + vendor/lite/src/lib/lua52/ltablib.c | 285 + vendor/lite/src/lib/lua52/ltm.c | 77 + vendor/lite/src/lib/lua52/ltm.h | 57 + vendor/lite/src/lib/lua52/lua.c_ | 497 + vendor/lite/src/lib/lua52/lua.h | 444 + vendor/lite/src/lib/lua52/lua.hpp | 9 + vendor/lite/src/lib/lua52/luac.c_ | 432 + vendor/lite/src/lib/lua52/luaconf.h | 551 + vendor/lite/src/lib/lua52/lualib.h | 55 + vendor/lite/src/lib/lua52/lundump.c | 258 + vendor/lite/src/lib/lua52/lundump.h | 28 + vendor/lite/src/lib/lua52/lvm.c | 867 ++ vendor/lite/src/lib/lua52/lvm.h | 44 + vendor/lite/src/lib/lua52/lzio.c | 76 + vendor/lite/src/lib/lua52/lzio.h | 65 + vendor/lite/src/lib/stb/stb_truetype.c | 2 + vendor/lite/src/lib/stb/stb_truetype.h | 4853 +++++++ vendor/lite/src/main.c | 145 + vendor/lite/src/rencache.c | 291 + vendor/lite/src/rencache.h | 16 + vendor/lite/src/renderer.c | 352 + vendor/lite/src/renderer.h | 33 + vendor/lite/winlib/SDL2-2.0.10/BUGS.txt | 16 + vendor/lite/winlib/SDL2-2.0.10/COPYING.txt | 20 + vendor/lite/winlib/SDL2-2.0.10/CREDITS.txt | 53 + vendor/lite/winlib/SDL2-2.0.10/INSTALL.txt | 18 + vendor/lite/winlib/SDL2-2.0.10/Makefile | 30 + vendor/lite/winlib/SDL2-2.0.10/README-SDL.txt | 13 + vendor/lite/winlib/SDL2-2.0.10/README.txt | 21 + vendor/lite/winlib/SDL2-2.0.10/WhatsNew.txt | 466 + .../winlib/SDL2-2.0.10/docs/README-android.md | 435 + .../winlib/SDL2-2.0.10/docs/README-cmake.md | 32 + .../SDL2-2.0.10/docs/README-directfb.md | 107 + .../winlib/SDL2-2.0.10/docs/README-dynapi.md | 130 + .../SDL2-2.0.10/docs/README-emscripten.md | 35 + .../winlib/SDL2-2.0.10/docs/README-gesture.md | 71 + .../lite/winlib/SDL2-2.0.10/docs/README-hg.md | 22 + .../winlib/SDL2-2.0.10/docs/README-ios.md | 284 + .../winlib/SDL2-2.0.10/docs/README-linux.md | 87 + .../winlib/SDL2-2.0.10/docs/README-macosx.md | 240 + .../winlib/SDL2-2.0.10/docs/README-nacl.md | 103 + .../winlib/SDL2-2.0.10/docs/README-pandora.md | 17 + .../SDL2-2.0.10/docs/README-platforms.md | 8 + .../winlib/SDL2-2.0.10/docs/README-porting.md | 68 + .../winlib/SDL2-2.0.10/docs/README-psp.md | 19 + .../SDL2-2.0.10/docs/README-raspberrypi.md | 188 + .../winlib/SDL2-2.0.10/docs/README-touch.md | 86 + .../winlib/SDL2-2.0.10/docs/README-wince.md | 10 + .../winlib/SDL2-2.0.10/docs/README-windows.md | 45 + .../winlib/SDL2-2.0.10/docs/README-winrt.md | 547 + vendor/lite/winlib/SDL2-2.0.10/docs/README.md | 63 + vendor/lite/winlib/SDL2-2.0.10/docs/doxyfile | 1560 +++ .../SDL2-2.0.10/i686-w64-mingw32/bin/SDL2.dll | Bin 0 -> 1156096 bytes .../i686-w64-mingw32/bin/sdl2-config | 60 + .../i686-w64-mingw32/include/SDL2/SDL.h | 135 + .../include/SDL2/SDL_assert.h | 291 + .../include/SDL2/SDL_atomic.h | 295 + .../i686-w64-mingw32/include/SDL2/SDL_audio.h | 859 ++ .../i686-w64-mingw32/include/SDL2/SDL_bits.h | 121 + .../include/SDL2/SDL_blendmode.h | 120 + .../include/SDL2/SDL_clipboard.h | 71 + .../include/SDL2/SDL_config.h | 257 + .../include/SDL2/SDL_cpuinfo.h | 270 + .../i686-w64-mingw32/include/SDL2/SDL_egl.h | 1673 +++ .../include/SDL2/SDL_endian.h | 260 + .../i686-w64-mingw32/include/SDL2/SDL_error.h | 76 + .../include/SDL2/SDL_events.h | 791 ++ .../include/SDL2/SDL_filesystem.h | 136 + .../include/SDL2/SDL_gamecontroller.h | 390 + .../include/SDL2/SDL_gesture.h | 87 + .../include/SDL2/SDL_haptic.h | 1238 ++ .../i686-w64-mingw32/include/SDL2/SDL_hints.h | 1266 ++ .../include/SDL2/SDL_joystick.h | 408 + .../include/SDL2/SDL_keyboard.h | 217 + .../include/SDL2/SDL_keycode.h | 349 + .../include/SDL2/SDL_loadso.h | 81 + .../i686-w64-mingw32/include/SDL2/SDL_log.h | 211 + .../i686-w64-mingw32/include/SDL2/SDL_main.h | 180 + .../include/SDL2/SDL_messagebox.h | 144 + .../i686-w64-mingw32/include/SDL2/SDL_mouse.h | 302 + .../i686-w64-mingw32/include/SDL2/SDL_mutex.h | 251 + .../i686-w64-mingw32/include/SDL2/SDL_name.h | 33 + .../include/SDL2/SDL_opengl.h | 2183 +++ .../include/SDL2/SDL_opengl_glext.h | 11177 ++++++++++++++++ .../include/SDL2/SDL_opengles.h | 39 + .../include/SDL2/SDL_opengles2.h | 52 + .../include/SDL2/SDL_opengles2_gl2.h | 621 + .../include/SDL2/SDL_opengles2_gl2ext.h | 2050 +++ .../include/SDL2/SDL_opengles2_gl2platform.h | 30 + .../include/SDL2/SDL_opengles2_khrplatform.h | 282 + .../include/SDL2/SDL_pixels.h | 470 + .../include/SDL2/SDL_platform.h | 198 + .../i686-w64-mingw32/include/SDL2/SDL_power.h | 75 + .../i686-w64-mingw32/include/SDL2/SDL_quit.h | 58 + .../i686-w64-mingw32/include/SDL2/SDL_rect.h | 174 + .../include/SDL2/SDL_render.h | 1098 ++ .../include/SDL2/SDL_revision.h | 2 + .../i686-w64-mingw32/include/SDL2/SDL_rwops.h | 291 + .../include/SDL2/SDL_scancode.h | 413 + .../include/SDL2/SDL_sensor.h | 251 + .../i686-w64-mingw32/include/SDL2/SDL_shape.h | 144 + .../include/SDL2/SDL_stdinc.h | 607 + .../include/SDL2/SDL_surface.h | 554 + .../include/SDL2/SDL_system.h | 279 + .../i686-w64-mingw32/include/SDL2/SDL_syswm.h | 327 + .../i686-w64-mingw32/include/SDL2/SDL_test.h | 69 + .../include/SDL2/SDL_test_assert.h | 105 + .../include/SDL2/SDL_test_common.h | 205 + .../include/SDL2/SDL_test_compare.h | 69 + .../include/SDL2/SDL_test_crc32.h | 124 + .../include/SDL2/SDL_test_font.h | 81 + .../include/SDL2/SDL_test_fuzzer.h | 384 + .../include/SDL2/SDL_test_harness.h | 134 + .../include/SDL2/SDL_test_images.h | 78 + .../include/SDL2/SDL_test_log.h | 67 + .../include/SDL2/SDL_test_md5.h | 129 + .../include/SDL2/SDL_test_memory.h | 63 + .../include/SDL2/SDL_test_random.h | 115 + .../include/SDL2/SDL_thread.h | 343 + .../i686-w64-mingw32/include/SDL2/SDL_timer.h | 115 + .../i686-w64-mingw32/include/SDL2/SDL_touch.h | 102 + .../i686-w64-mingw32/include/SDL2/SDL_types.h | 29 + .../include/SDL2/SDL_version.h | 162 + .../i686-w64-mingw32/include/SDL2/SDL_video.h | 1276 ++ .../include/SDL2/SDL_vulkan.h | 278 + .../include/SDL2/begin_code.h | 170 + .../include/SDL2/close_code.h | 40 + .../lib/cmake/SDL2/sdl2-config.cmake | 11 + .../i686-w64-mingw32/lib/libSDL2.a | Bin 0 -> 9317630 bytes .../i686-w64-mingw32/lib/libSDL2.dll.a | Bin 0 -> 437476 bytes .../i686-w64-mingw32/lib/libSDL2.la | 41 + .../i686-w64-mingw32/lib/libSDL2_test.a | Bin 0 -> 498850 bytes .../i686-w64-mingw32/lib/libSDL2_test.la | 41 + .../i686-w64-mingw32/lib/libSDL2main.a | Bin 0 -> 16946 bytes .../i686-w64-mingw32/lib/libSDL2main.la | 41 + .../i686-w64-mingw32/lib/pkgconfig/sdl2.pc | 15 + .../i686-w64-mingw32/share/aclocal/sdl2.m4 | 234 + .../winlib/SDL2-2.0.10/test/CMakeLists.txt | 122 + vendor/lite/winlib/SDL2-2.0.10/test/COPYING | 8 + .../lite/winlib/SDL2-2.0.10/test/Makefile.in | 336 + .../lite/winlib/SDL2-2.0.10/test/Makefile.os2 | 91 + vendor/lite/winlib/SDL2-2.0.10/test/README | 47 + .../lite/winlib/SDL2-2.0.10/test/acinclude.m4 | 359 + .../lite/winlib/SDL2-2.0.10/test/aclocal.m4 | 359 + .../lite/winlib/SDL2-2.0.10/test/autogen.sh | 12 + vendor/lite/winlib/SDL2-2.0.10/test/axis.bmp | Bin 0 -> 10138 bytes .../lite/winlib/SDL2-2.0.10/test/button.bmp | Bin 0 -> 3746 bytes .../lite/winlib/SDL2-2.0.10/test/checkkeys.c | 248 + vendor/lite/winlib/SDL2-2.0.10/test/configure | 5136 +++++++ .../lite/winlib/SDL2-2.0.10/test/configure.ac | 200 + .../winlib/SDL2-2.0.10/test/controllermap.bmp | Bin 0 -> 163450 bytes .../winlib/SDL2-2.0.10/test/controllermap.c | 781 ++ .../test/emscripten/joystick-pre.js | 25 + .../lite/winlib/SDL2-2.0.10/test/gcc-fat.sh | 110 + vendor/lite/winlib/SDL2-2.0.10/test/icon.bmp | Bin 0 -> 578 bytes .../lite/winlib/SDL2-2.0.10/test/loopwave.c | 179 + .../winlib/SDL2-2.0.10/test/loopwavequeue.c | 149 + vendor/lite/winlib/SDL2-2.0.10/test/moose.dat | Bin 0 -> 56320 bytes .../winlib/SDL2-2.0.10/test/nacl/Makefile | 63 + .../SDL2-2.0.10/test/nacl/background.js | 40 + .../winlib/SDL2-2.0.10/test/nacl/common.js | 474 + .../winlib/SDL2-2.0.10/test/nacl/index.html | 21 + .../SDL2-2.0.10/test/nacl/manifest.json | 22 + .../lite/winlib/SDL2-2.0.10/test/picture.xbm | 14 + .../SDL2-2.0.10/test/relative_mode.markdown | 58 + .../lite/winlib/SDL2-2.0.10/test/sample.bmp | Bin 0 -> 69202 bytes .../lite/winlib/SDL2-2.0.10/test/sample.wav | Bin 0 -> 121946 bytes .../SDL2-2.0.10/test/shapes/p01_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p01_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p01_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p02_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p02_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p02_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p03_shape24.bmp | Bin 0 -> 1228938 bytes .../SDL2-2.0.10/test/shapes/p03_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p04_shape1.bmp | Bin 0 -> 51346 bytes .../SDL2-2.0.10/test/shapes/p04_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p04_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p04_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p05_shape8.bmp | Bin 0 -> 410678 bytes .../test/shapes/p06_shape1alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p06_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p06_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p06_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p07_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p07_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p07_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p08_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p08_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p08_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p09_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p09_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p09_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p10_shape1.bmp | Bin 0 -> 51346 bytes .../SDL2-2.0.10/test/shapes/p10_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p10_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p10_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p11_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p11_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p11_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p12_shape24.bmp | Bin 0 -> 1228938 bytes .../SDL2-2.0.10/test/shapes/p12_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p13_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p13_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p13_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p14_shape24.bmp | Bin 0 -> 1228938 bytes .../SDL2-2.0.10/test/shapes/p14_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p15_shape24.bmp | Bin 0 -> 1228938 bytes .../test/shapes/p15_shape32alpha.bmp | Bin 0 -> 1638538 bytes .../SDL2-2.0.10/test/shapes/p15_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/p16_shape1.bmp | Bin 0 -> 51346 bytes .../SDL2-2.0.10/test/shapes/p16_shape24.bmp | Bin 0 -> 1228938 bytes .../SDL2-2.0.10/test/shapes/p16_shape8.bmp | Bin 0 -> 410678 bytes .../SDL2-2.0.10/test/shapes/trollface_24.bmp | Bin 0 -> 196662 bytes .../test/shapes/trollface_32alpha.bmp | Bin 0 -> 262198 bytes .../lite/winlib/SDL2-2.0.10/test/testatomic.c | 727 + .../SDL2-2.0.10/test/testaudiocapture.c | 165 + .../SDL2-2.0.10/test/testaudiohotplug.c | 203 + .../winlib/SDL2-2.0.10/test/testaudioinfo.c | 74 + .../winlib/SDL2-2.0.10/test/testautomation.c | 124 + .../SDL2-2.0.10/test/testautomation_audio.c | 1038 ++ .../test/testautomation_clipboard.c | 184 + .../SDL2-2.0.10/test/testautomation_events.c | 201 + .../SDL2-2.0.10/test/testautomation_hints.c | 168 + .../test/testautomation_keyboard.c | 713 + .../SDL2-2.0.10/test/testautomation_main.c | 157 + .../SDL2-2.0.10/test/testautomation_mouse.c | 606 + .../SDL2-2.0.10/test/testautomation_pixels.c | 529 + .../test/testautomation_platform.c | 584 + .../SDL2-2.0.10/test/testautomation_rect.c | 1696 +++ .../SDL2-2.0.10/test/testautomation_render.c | 1099 ++ .../SDL2-2.0.10/test/testautomation_rwops.c | 748 ++ .../SDL2-2.0.10/test/testautomation_sdltest.c | 1319 ++ .../SDL2-2.0.10/test/testautomation_stdlib.c | 319 + .../SDL2-2.0.10/test/testautomation_suites.h | 54 + .../SDL2-2.0.10/test/testautomation_surface.c | 647 + .../SDL2-2.0.10/test/testautomation_syswm.c | 61 + .../SDL2-2.0.10/test/testautomation_timer.c | 201 + .../SDL2-2.0.10/test/testautomation_video.c | 1811 +++ .../lite/winlib/SDL2-2.0.10/test/testbounds.c | 40 + .../SDL2-2.0.10/test/testcustomcursor.c | 259 + .../winlib/SDL2-2.0.10/test/testdisplayinfo.c | 96 + .../lite/winlib/SDL2-2.0.10/test/testdraw2.c | 305 + .../SDL2-2.0.10/test/testdrawchessboard.c | 147 + .../winlib/SDL2-2.0.10/test/testdropfile.c | 99 + .../lite/winlib/SDL2-2.0.10/test/testerror.c | 76 + .../lite/winlib/SDL2-2.0.10/test/testfile.c | 283 + .../winlib/SDL2-2.0.10/test/testfilesystem.c | 60 + .../SDL2-2.0.10/test/testgamecontroller.c | 375 + .../winlib/SDL2-2.0.10/test/testgesture.c | 297 + vendor/lite/winlib/SDL2-2.0.10/test/testgl2.c | 440 + .../lite/winlib/SDL2-2.0.10/test/testgles.c | 355 + .../lite/winlib/SDL2-2.0.10/test/testgles2.c | 732 + .../lite/winlib/SDL2-2.0.10/test/testhaptic.c | 369 + .../winlib/SDL2-2.0.10/test/testhittesting.c | 134 + .../winlib/SDL2-2.0.10/test/testhotplug.c | 162 + .../lite/winlib/SDL2-2.0.10/test/testiconv.c | 88 + vendor/lite/winlib/SDL2-2.0.10/test/testime.c | 801 ++ .../SDL2-2.0.10/test/testintersections.c | 363 + .../winlib/SDL2-2.0.10/test/testjoystick.c | 387 + .../lite/winlib/SDL2-2.0.10/test/testkeys.c | 40 + .../lite/winlib/SDL2-2.0.10/test/testloadso.c | 82 + .../lite/winlib/SDL2-2.0.10/test/testlock.c | 128 + .../winlib/SDL2-2.0.10/test/testmessage.c | 193 + .../winlib/SDL2-2.0.10/test/testmultiaudio.c | 199 + .../lite/winlib/SDL2-2.0.10/test/testnative.c | 237 + .../lite/winlib/SDL2-2.0.10/test/testnative.h | 46 + .../winlib/SDL2-2.0.10/test/testnativecocoa.m | 51 + .../winlib/SDL2-2.0.10/test/testnativew32.c | 86 + .../winlib/SDL2-2.0.10/test/testnativex11.c | 53 + .../winlib/SDL2-2.0.10/test/testoverlay2.c | 408 + .../winlib/SDL2-2.0.10/test/testplatform.c | 442 + .../lite/winlib/SDL2-2.0.10/test/testpower.c | 80 + .../lite/winlib/SDL2-2.0.10/test/testqsort.c | 108 + .../winlib/SDL2-2.0.10/test/testrelative.c | 126 + .../SDL2-2.0.10/test/testrendercopyex.c | 225 + .../SDL2-2.0.10/test/testrendertarget.c | 335 + .../winlib/SDL2-2.0.10/test/testresample.c | 120 + .../lite/winlib/SDL2-2.0.10/test/testrumble.c | 153 + .../lite/winlib/SDL2-2.0.10/test/testscale.c | 216 + vendor/lite/winlib/SDL2-2.0.10/test/testsem.c | 130 + .../lite/winlib/SDL2-2.0.10/test/testsensor.c | 117 + .../lite/winlib/SDL2-2.0.10/test/testshader.c | 500 + .../lite/winlib/SDL2-2.0.10/test/testshape.c | 200 + .../winlib/SDL2-2.0.10/test/testsprite2.c | 416 + .../SDL2-2.0.10/test/testspriteminimal.c | 194 + .../winlib/SDL2-2.0.10/test/teststreaming.c | 190 + .../lite/winlib/SDL2-2.0.10/test/testthread.c | 130 + .../lite/winlib/SDL2-2.0.10/test/testtimer.c | 122 + vendor/lite/winlib/SDL2-2.0.10/test/testver.c | 47 + .../winlib/SDL2-2.0.10/test/testviewport.c | 217 + .../lite/winlib/SDL2-2.0.10/test/testvulkan.c | 1189 ++ vendor/lite/winlib/SDL2-2.0.10/test/testwm2.c | 163 + .../lite/winlib/SDL2-2.0.10/test/testyuv.bmp | Bin 0 -> 739398 bytes vendor/lite/winlib/SDL2-2.0.10/test/testyuv.c | 455 + .../winlib/SDL2-2.0.10/test/testyuv_cvt.c | 300 + .../winlib/SDL2-2.0.10/test/testyuv_cvt.h | 16 + .../winlib/SDL2-2.0.10/test/torturethread.c | 113 + vendor/lite/winlib/SDL2-2.0.10/test/utf8.txt | 287 + .../x86_64-w64-mingw32/bin/SDL2.dll | Bin 0 -> 1401344 bytes .../x86_64-w64-mingw32/bin/sdl2-config | 60 + .../x86_64-w64-mingw32/include/SDL2/SDL.h | 135 + .../include/SDL2/SDL_assert.h | 291 + .../include/SDL2/SDL_atomic.h | 295 + .../include/SDL2/SDL_audio.h | 859 ++ .../include/SDL2/SDL_bits.h | 121 + .../include/SDL2/SDL_blendmode.h | 120 + .../include/SDL2/SDL_clipboard.h | 71 + .../include/SDL2/SDL_config.h | 257 + .../include/SDL2/SDL_cpuinfo.h | 270 + .../x86_64-w64-mingw32/include/SDL2/SDL_egl.h | 1673 +++ .../include/SDL2/SDL_endian.h | 260 + .../include/SDL2/SDL_error.h | 76 + .../include/SDL2/SDL_events.h | 791 ++ .../include/SDL2/SDL_filesystem.h | 136 + .../include/SDL2/SDL_gamecontroller.h | 390 + .../include/SDL2/SDL_gesture.h | 87 + .../include/SDL2/SDL_haptic.h | 1238 ++ .../include/SDL2/SDL_hints.h | 1266 ++ .../include/SDL2/SDL_joystick.h | 408 + .../include/SDL2/SDL_keyboard.h | 217 + .../include/SDL2/SDL_keycode.h | 349 + .../include/SDL2/SDL_loadso.h | 81 + .../x86_64-w64-mingw32/include/SDL2/SDL_log.h | 211 + .../include/SDL2/SDL_main.h | 180 + .../include/SDL2/SDL_messagebox.h | 144 + .../include/SDL2/SDL_mouse.h | 302 + .../include/SDL2/SDL_mutex.h | 251 + .../include/SDL2/SDL_name.h | 33 + .../include/SDL2/SDL_opengl.h | 2183 +++ .../include/SDL2/SDL_opengl_glext.h | 11177 ++++++++++++++++ .../include/SDL2/SDL_opengles.h | 39 + .../include/SDL2/SDL_opengles2.h | 52 + .../include/SDL2/SDL_opengles2_gl2.h | 621 + .../include/SDL2/SDL_opengles2_gl2ext.h | 2050 +++ .../include/SDL2/SDL_opengles2_gl2platform.h | 30 + .../include/SDL2/SDL_opengles2_khrplatform.h | 282 + .../include/SDL2/SDL_pixels.h | 470 + .../include/SDL2/SDL_platform.h | 198 + .../include/SDL2/SDL_power.h | 75 + .../include/SDL2/SDL_quit.h | 58 + .../include/SDL2/SDL_rect.h | 174 + .../include/SDL2/SDL_render.h | 1098 ++ .../include/SDL2/SDL_revision.h | 2 + .../include/SDL2/SDL_rwops.h | 291 + .../include/SDL2/SDL_scancode.h | 413 + .../include/SDL2/SDL_sensor.h | 251 + .../include/SDL2/SDL_shape.h | 144 + .../include/SDL2/SDL_stdinc.h | 607 + .../include/SDL2/SDL_surface.h | 554 + .../include/SDL2/SDL_system.h | 279 + .../include/SDL2/SDL_syswm.h | 327 + .../include/SDL2/SDL_test.h | 69 + .../include/SDL2/SDL_test_assert.h | 105 + .../include/SDL2/SDL_test_common.h | 205 + .../include/SDL2/SDL_test_compare.h | 69 + .../include/SDL2/SDL_test_crc32.h | 124 + .../include/SDL2/SDL_test_font.h | 81 + .../include/SDL2/SDL_test_fuzzer.h | 384 + .../include/SDL2/SDL_test_harness.h | 134 + .../include/SDL2/SDL_test_images.h | 78 + .../include/SDL2/SDL_test_log.h | 67 + .../include/SDL2/SDL_test_md5.h | 129 + .../include/SDL2/SDL_test_memory.h | 63 + .../include/SDL2/SDL_test_random.h | 115 + .../include/SDL2/SDL_thread.h | 343 + .../include/SDL2/SDL_timer.h | 115 + .../include/SDL2/SDL_touch.h | 102 + .../include/SDL2/SDL_types.h | 29 + .../include/SDL2/SDL_version.h | 162 + .../include/SDL2/SDL_video.h | 1276 ++ .../include/SDL2/SDL_vulkan.h | 278 + .../include/SDL2/begin_code.h | 170 + .../include/SDL2/close_code.h | 40 + .../lib/cmake/SDL2/sdl2-config.cmake | 11 + .../x86_64-w64-mingw32/lib/libSDL2.a | Bin 0 -> 13687676 bytes .../x86_64-w64-mingw32/lib/libSDL2.dll.a | Bin 0 -> 427788 bytes .../x86_64-w64-mingw32/lib/libSDL2.la | 41 + .../x86_64-w64-mingw32/lib/libSDL2_test.a | Bin 0 -> 537396 bytes .../x86_64-w64-mingw32/lib/libSDL2_test.la | 41 + .../x86_64-w64-mingw32/lib/libSDL2main.a | Bin 0 -> 18782 bytes .../x86_64-w64-mingw32/lib/libSDL2main.la | 41 + .../x86_64-w64-mingw32/lib/pkgconfig/sdl2.pc | 15 + .../x86_64-w64-mingw32/share/aclocal/sdl2.m4 | 234 + wrap.fnl | 28 + 615 files changed, 163774 insertions(+) create mode 100644 conf.lua create mode 100644 editor/editmode.fnl create mode 100644 editor/imstate.fnl create mode 100644 editor/init.fnl create mode 100644 editor/lovemode.fnl create mode 100644 editor/modeview.fnl create mode 100644 game/entities/bomberman.fnl create mode 100644 game/entities/pacman.fnl create mode 100644 game/entity.fnl create mode 100644 game/helpers.fnl create mode 100644 game/init.fnl create mode 100644 game/mode.fnl create mode 100644 game/rules.fnl create mode 100644 game/state.fnl create mode 100644 game/tiles.fnl create mode 100644 lib/bencode.lua create mode 100644 lib/dkjson.lua create mode 100644 lib/fennel.lua create mode 100644 lib/lume.lua create mode 100644 lib/spawn.lua create mode 100644 lib/stdio.fnl create mode 100644 lib/util.fnl create mode 100644 main.lua create mode 100644 support/lite/plugins/betterfind.lua create mode 100644 support/lite/plugins/rainbowparen.lua create mode 100644 todo.txt create mode 100644 vendor/jeejah/.gitrepo create mode 100644 vendor/jeejah/Changelog.md create mode 100644 vendor/jeejah/LICENSE create mode 100644 vendor/jeejah/Makefile create mode 100644 vendor/jeejah/Readme.md create mode 100644 vendor/jeejah/bencode.lua create mode 100755 vendor/jeejah/bin/jeejah create mode 100644 vendor/jeejah/fennel.lua create mode 100644 vendor/jeejah/fennelview.fnl create mode 100644 vendor/jeejah/jeejah.lua create mode 100644 vendor/jeejah/jeejah/fenneleval.lua create mode 100644 vendor/jeejah/monroe-lua-complete.el create mode 100644 vendor/jeejah/rockspecs/jeejah-0.1.0-1.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.2.1-1.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.2.1-4.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.3.0-1.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.3.1-1.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.3.1-2.rockspec create mode 100644 vendor/jeejah/rockspecs/jeejah-0.3.1-4.rockspec create mode 100644 vendor/jeejah/serpent.lua create mode 100644 vendor/lite-plugins/.gitrepo create mode 100644 vendor/lite-plugins/README.md create mode 100644 vendor/lite-plugins/plugins/autoinsert.lua create mode 100644 vendor/lite-plugins/plugins/autowrap.lua create mode 100644 vendor/lite-plugins/plugins/bigclock.lua create mode 100644 vendor/lite-plugins/plugins/bracketmatch.lua create mode 100644 vendor/lite-plugins/plugins/centerdoc.lua create mode 100644 vendor/lite-plugins/plugins/colorpreview.lua create mode 100644 vendor/lite-plugins/plugins/copyfilelocation.lua create mode 100644 vendor/lite-plugins/plugins/datetimestamps.lua create mode 100644 vendor/lite-plugins/plugins/detectindent.lua create mode 100644 vendor/lite-plugins/plugins/dragdropselected.lua create mode 100644 vendor/lite-plugins/plugins/drawwhitespace.lua create mode 100644 vendor/lite-plugins/plugins/eval.lua create mode 100644 vendor/lite-plugins/plugins/exec.lua create mode 100644 vendor/lite-plugins/plugins/ghmarkdown.lua create mode 100644 vendor/lite-plugins/plugins/gitstatus.lua create mode 100644 vendor/lite-plugins/plugins/gofmt.lua create mode 100644 vendor/lite-plugins/plugins/hidelinenumbers.lua create mode 100644 vendor/lite-plugins/plugins/hidestatus.lua create mode 100644 vendor/lite-plugins/plugins/inanimate.lua create mode 100644 vendor/lite-plugins/plugins/indentguide.lua create mode 100644 vendor/lite-plugins/plugins/language_angelscript.lua create mode 100644 vendor/lite-plugins/plugins/language_batch.lua create mode 100644 vendor/lite-plugins/plugins/language_cmake.lua create mode 100644 vendor/lite-plugins/plugins/language_cpp.lua create mode 100644 vendor/lite-plugins/plugins/language_csharp.lua create mode 100644 vendor/lite-plugins/plugins/language_d.lua create mode 100644 vendor/lite-plugins/plugins/language_elixir.lua create mode 100644 vendor/lite-plugins/plugins/language_elm.lua create mode 100644 vendor/lite-plugins/plugins/language_fe.lua create mode 100644 vendor/lite-plugins/plugins/language_fennel.lua create mode 100644 vendor/lite-plugins/plugins/language_gdscript.lua create mode 100644 vendor/lite-plugins/plugins/language_glsl.lua create mode 100644 vendor/lite-plugins/plugins/language_go.lua create mode 100644 vendor/lite-plugins/plugins/language_hlsl.lua create mode 100644 vendor/lite-plugins/plugins/language_hs.lua create mode 100644 vendor/lite-plugins/plugins/language_java.lua create mode 100644 vendor/lite-plugins/plugins/language_jiyu.lua create mode 100644 vendor/lite-plugins/plugins/language_make.lua create mode 100644 vendor/lite-plugins/plugins/language_meson.lua create mode 100644 vendor/lite-plugins/plugins/language_odin.lua create mode 100644 vendor/lite-plugins/plugins/language_php.lua create mode 100644 vendor/lite-plugins/plugins/language_pico8.lua create mode 100644 vendor/lite-plugins/plugins/language_powershell.lua create mode 100644 vendor/lite-plugins/plugins/language_psql.lua create mode 100644 vendor/lite-plugins/plugins/language_rust.lua create mode 100644 vendor/lite-plugins/plugins/language_sh.lua create mode 100644 vendor/lite-plugins/plugins/language_tex.lua create mode 100644 vendor/lite-plugins/plugins/language_wren.lua create mode 100644 vendor/lite-plugins/plugins/lastproject.lua create mode 100644 vendor/lite-plugins/plugins/lfautoinsert.lua create mode 100755 vendor/lite-plugins/plugins/linecopypaste.lua create mode 100644 vendor/lite-plugins/plugins/lineguide.lua create mode 100644 vendor/lite-plugins/plugins/macmodkeys.lua create mode 100644 vendor/lite-plugins/plugins/markers.lua create mode 100644 vendor/lite-plugins/plugins/motiontrail.lua create mode 100644 vendor/lite-plugins/plugins/openfilelocation.lua create mode 100644 vendor/lite-plugins/plugins/openselected.lua create mode 100644 vendor/lite-plugins/plugins/projectmanager.lua create mode 100644 vendor/lite-plugins/plugins/scale.lua create mode 100644 vendor/lite-plugins/plugins/scalestatus.lua create mode 100644 vendor/lite-plugins/plugins/selectionhighlight.lua create mode 100644 vendor/lite-plugins/plugins/sort.lua create mode 100644 vendor/lite-plugins/plugins/spellcheck.lua create mode 100644 vendor/lite-plugins/plugins/titleize.lua create mode 100644 vendor/lite-plugins/plugins/togglesnakecamel.lua create mode 100644 vendor/lite-plugins/plugins/unboundedscroll.lua create mode 100644 vendor/lite-plugins/plugins/workspace.lua create mode 100644 vendor/lite/.gitattributes create mode 100644 vendor/lite/.github/FUNDING.yml create mode 100644 vendor/lite/.gitrepo create mode 100644 vendor/lite/LICENSE create mode 100644 vendor/lite/README.md create mode 100755 vendor/lite/build.sh create mode 100755 vendor/lite/build_release.sh create mode 100644 vendor/lite/conf.lua create mode 100644 vendor/lite/data/core/command.lua create mode 100644 vendor/lite/data/core/commands/command.lua create mode 100644 vendor/lite/data/core/commands/core.lua create mode 100644 vendor/lite/data/core/commands/doc.lua create mode 100644 vendor/lite/data/core/commands/findreplace.lua create mode 100644 vendor/lite/data/core/commands/root.lua create mode 100644 vendor/lite/data/core/commandview.lua create mode 100644 vendor/lite/data/core/common.lua create mode 100644 vendor/lite/data/core/config.lua create mode 100644 vendor/lite/data/core/doc/highlighter.lua create mode 100644 vendor/lite/data/core/doc/init.lua create mode 100644 vendor/lite/data/core/doc/search.lua create mode 100644 vendor/lite/data/core/doc/translate.lua create mode 100644 vendor/lite/data/core/docview.lua create mode 100644 vendor/lite/data/core/init.lua create mode 100644 vendor/lite/data/core/keymap.lua create mode 100644 vendor/lite/data/core/logview.lua create mode 100644 vendor/lite/data/core/object.lua create mode 100644 vendor/lite/data/core/rootview.lua create mode 100644 vendor/lite/data/core/statusview.lua create mode 100644 vendor/lite/data/core/strict.lua create mode 100644 vendor/lite/data/core/style.lua create mode 100644 vendor/lite/data/core/syntax.lua create mode 100644 vendor/lite/data/core/tokenizer.lua create mode 100644 vendor/lite/data/core/view.lua create mode 100644 vendor/lite/data/fonts/font.ttf create mode 100644 vendor/lite/data/fonts/icons.ttf create mode 100644 vendor/lite/data/fonts/monospace.ttf create mode 100644 vendor/lite/data/plugins/autocomplete.lua create mode 120000 vendor/lite/data/plugins/autoinsert.lua create mode 100644 vendor/lite/data/plugins/autoreload.lua create mode 120000 vendor/lite/data/plugins/betterfind.lua create mode 120000 vendor/lite/data/plugins/bracketmatch.lua create mode 100644 vendor/lite/data/plugins/language_c.lua create mode 100644 vendor/lite/data/plugins/language_css.lua create mode 120000 vendor/lite/data/plugins/language_fennel.lua create mode 100644 vendor/lite/data/plugins/language_js.lua create mode 100644 vendor/lite/data/plugins/language_lua.lua create mode 100644 vendor/lite/data/plugins/language_md.lua create mode 100644 vendor/lite/data/plugins/language_python.lua create mode 100644 vendor/lite/data/plugins/language_xml.lua create mode 100644 vendor/lite/data/plugins/macro.lua create mode 100644 vendor/lite/data/plugins/projectsearch.lua create mode 100644 vendor/lite/data/plugins/quote.lua create mode 120000 vendor/lite/data/plugins/rainbowparen.lua create mode 100644 vendor/lite/data/plugins/reflow.lua create mode 120000 vendor/lite/data/plugins/selectionhighlight.lua create mode 100644 vendor/lite/data/plugins/tabularize.lua create mode 100644 vendor/lite/data/plugins/treeview.lua create mode 100644 vendor/lite/data/plugins/trimwhitespace.lua create mode 100644 vendor/lite/data/user/colors/fall.lua create mode 100644 vendor/lite/data/user/colors/summer.lua create mode 100644 vendor/lite/data/user/init.lua create mode 100644 vendor/lite/doc/usage.md create mode 100644 vendor/lite/icon.ico create mode 100644 vendor/lite/icon.inl create mode 100644 vendor/lite/main.lua create mode 100644 vendor/lite/res.rc create mode 100644 vendor/lite/src/api/api.c create mode 100644 vendor/lite/src/api/api.h create mode 100644 vendor/lite/src/api/renderer.c create mode 100644 vendor/lite/src/api/renderer_font.c create mode 100644 vendor/lite/src/api/system.c create mode 100644 vendor/lite/src/lib/lua52/lapi.c create mode 100644 vendor/lite/src/lib/lua52/lapi.h create mode 100644 vendor/lite/src/lib/lua52/lauxlib.c create mode 100644 vendor/lite/src/lib/lua52/lauxlib.h create mode 100644 vendor/lite/src/lib/lua52/lbaselib.c create mode 100644 vendor/lite/src/lib/lua52/lbitlib.c create mode 100644 vendor/lite/src/lib/lua52/lcode.c create mode 100644 vendor/lite/src/lib/lua52/lcode.h create mode 100644 vendor/lite/src/lib/lua52/lcorolib.c create mode 100644 vendor/lite/src/lib/lua52/lctype.c create mode 100644 vendor/lite/src/lib/lua52/lctype.h create mode 100644 vendor/lite/src/lib/lua52/ldblib.c create mode 100644 vendor/lite/src/lib/lua52/ldebug.c create mode 100644 vendor/lite/src/lib/lua52/ldebug.h create mode 100644 vendor/lite/src/lib/lua52/ldo.c create mode 100644 vendor/lite/src/lib/lua52/ldo.h create mode 100644 vendor/lite/src/lib/lua52/ldump.c create mode 100644 vendor/lite/src/lib/lua52/lfunc.c create mode 100644 vendor/lite/src/lib/lua52/lfunc.h create mode 100644 vendor/lite/src/lib/lua52/lgc.c create mode 100644 vendor/lite/src/lib/lua52/lgc.h create mode 100644 vendor/lite/src/lib/lua52/linit.c create mode 100644 vendor/lite/src/lib/lua52/liolib.c create mode 100644 vendor/lite/src/lib/lua52/llex.c create mode 100644 vendor/lite/src/lib/lua52/llex.h create mode 100644 vendor/lite/src/lib/lua52/llimits.h create mode 100644 vendor/lite/src/lib/lua52/lmathlib.c create mode 100644 vendor/lite/src/lib/lua52/lmem.c create mode 100644 vendor/lite/src/lib/lua52/lmem.h create mode 100644 vendor/lite/src/lib/lua52/loadlib.c create mode 100644 vendor/lite/src/lib/lua52/lobject.c create mode 100644 vendor/lite/src/lib/lua52/lobject.h create mode 100644 vendor/lite/src/lib/lua52/lopcodes.c create mode 100644 vendor/lite/src/lib/lua52/lopcodes.h create mode 100644 vendor/lite/src/lib/lua52/loslib.c create mode 100644 vendor/lite/src/lib/lua52/lparser.c create mode 100644 vendor/lite/src/lib/lua52/lparser.h create mode 100644 vendor/lite/src/lib/lua52/lstate.c create mode 100644 vendor/lite/src/lib/lua52/lstate.h create mode 100644 vendor/lite/src/lib/lua52/lstring.c create mode 100644 vendor/lite/src/lib/lua52/lstring.h create mode 100644 vendor/lite/src/lib/lua52/lstrlib.c create mode 100644 vendor/lite/src/lib/lua52/ltable.c create mode 100644 vendor/lite/src/lib/lua52/ltable.h create mode 100644 vendor/lite/src/lib/lua52/ltablib.c create mode 100644 vendor/lite/src/lib/lua52/ltm.c create mode 100644 vendor/lite/src/lib/lua52/ltm.h create mode 100644 vendor/lite/src/lib/lua52/lua.c_ create mode 100644 vendor/lite/src/lib/lua52/lua.h create mode 100644 vendor/lite/src/lib/lua52/lua.hpp create mode 100644 vendor/lite/src/lib/lua52/luac.c_ create mode 100644 vendor/lite/src/lib/lua52/luaconf.h create mode 100644 vendor/lite/src/lib/lua52/lualib.h create mode 100644 vendor/lite/src/lib/lua52/lundump.c create mode 100644 vendor/lite/src/lib/lua52/lundump.h create mode 100644 vendor/lite/src/lib/lua52/lvm.c create mode 100644 vendor/lite/src/lib/lua52/lvm.h create mode 100644 vendor/lite/src/lib/lua52/lzio.c create mode 100644 vendor/lite/src/lib/lua52/lzio.h create mode 100644 vendor/lite/src/lib/stb/stb_truetype.c create mode 100644 vendor/lite/src/lib/stb/stb_truetype.h create mode 100644 vendor/lite/src/main.c create mode 100644 vendor/lite/src/rencache.c create mode 100644 vendor/lite/src/rencache.h create mode 100644 vendor/lite/src/renderer.c create mode 100644 vendor/lite/src/renderer.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/BUGS.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/COPYING.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/CREDITS.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/INSTALL.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/Makefile create mode 100644 vendor/lite/winlib/SDL2-2.0.10/README-SDL.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/README.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/WhatsNew.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-android.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-cmake.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-directfb.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-dynapi.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-emscripten.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-gesture.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-hg.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-ios.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-linux.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-macosx.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-nacl.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-pandora.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-platforms.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-porting.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-psp.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-raspberrypi.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-touch.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-wince.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-windows.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README-winrt.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/README.md create mode 100644 vendor/lite/winlib/SDL2-2.0.10/docs/doxyfile create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/SDL2.dll create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/sdl2-config create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_assert.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_atomic.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_audio.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_bits.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_blendmode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_clipboard.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_config.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_cpuinfo.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_egl.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_endian.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_error.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_events.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_filesystem.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gamecontroller.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gesture.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_haptic.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_hints.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_joystick.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keyboard.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keycode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_loadso.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_log.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_main.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_messagebox.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mouse.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mutex.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_name.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl_glext.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2ext.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2platform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_khrplatform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_pixels.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_platform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_power.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_quit.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rect.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_render.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_revision.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rwops.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_scancode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_sensor.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_shape.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_stdinc.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_surface.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_system.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_syswm.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_assert.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_common.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_compare.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_crc32.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_font.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_fuzzer.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_harness.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_images.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_log.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_md5.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_memory.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_random.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_thread.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_timer.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_touch.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_types.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_version.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_video.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_vulkan.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/begin_code.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/close_code.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/cmake/SDL2/sdl2-config.cmake create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2.dll.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2_test.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2_test.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2main.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/libSDL2main.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/lib/pkgconfig/sdl2.pc create mode 100644 vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/share/aclocal/sdl2.m4 create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/CMakeLists.txt create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/COPYING create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/Makefile.in create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/Makefile.os2 create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/README create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/acinclude.m4 create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/aclocal.m4 create mode 100755 vendor/lite/winlib/SDL2-2.0.10/test/autogen.sh create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/axis.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/button.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/checkkeys.c create mode 100755 vendor/lite/winlib/SDL2-2.0.10/test/configure create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/configure.ac create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/controllermap.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/controllermap.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/emscripten/joystick-pre.js create mode 100755 vendor/lite/winlib/SDL2-2.0.10/test/gcc-fat.sh create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/icon.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/loopwave.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/loopwavequeue.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/moose.dat create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/nacl/Makefile create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/nacl/background.js create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/nacl/common.js create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/nacl/index.html create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/nacl/manifest.json create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/picture.xbm create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/relative_mode.markdown create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/sample.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/sample.wav create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p01_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p01_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p01_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p02_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p02_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p02_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p03_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p03_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p04_shape1.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p04_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p04_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p04_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p05_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p06_shape1alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p06_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p06_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p06_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p07_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p07_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p07_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p08_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p08_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p08_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p09_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p09_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p09_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p10_shape1.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p10_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p10_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p10_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p11_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p11_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p11_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p12_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p12_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p13_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p13_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p13_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p14_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p14_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p15_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p15_shape32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p15_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p16_shape1.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p16_shape24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/p16_shape8.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/trollface_24.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/shapes/trollface_32alpha.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testatomic.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testaudiocapture.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testaudiohotplug.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testaudioinfo.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_audio.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_clipboard.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_events.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_hints.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_keyboard.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_main.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_mouse.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_pixels.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_platform.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_rect.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_render.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_rwops.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_sdltest.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_stdlib.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_suites.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_surface.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_syswm.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_timer.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testautomation_video.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testbounds.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testcustomcursor.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testdisplayinfo.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testdraw2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testdrawchessboard.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testdropfile.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testerror.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testfile.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testfilesystem.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testgamecontroller.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testgesture.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testgl2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testgles.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testgles2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testhaptic.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testhittesting.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testhotplug.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testiconv.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testime.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testintersections.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testjoystick.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testkeys.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testloadso.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testlock.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testmessage.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testmultiaudio.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testnative.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testnative.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testnativecocoa.m create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testnativew32.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testnativex11.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testoverlay2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testplatform.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testpower.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testqsort.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testrelative.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testrendercopyex.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testrendertarget.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testresample.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testrumble.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testscale.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testsem.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testsensor.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testshader.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testshape.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testsprite2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testspriteminimal.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/teststreaming.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testthread.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testtimer.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testver.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testviewport.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testvulkan.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testwm2.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testyuv.bmp create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testyuv.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testyuv_cvt.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/testyuv_cvt.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/torturethread.c create mode 100644 vendor/lite/winlib/SDL2-2.0.10/test/utf8.txt create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/bin/SDL2.dll create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/bin/sdl2-config create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_assert.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_atomic.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_audio.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_bits.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_blendmode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_clipboard.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_config.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_cpuinfo.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_egl.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_endian.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_error.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_events.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_filesystem.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_gamecontroller.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_gesture.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_haptic.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_hints.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_joystick.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_keyboard.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_keycode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_loadso.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_log.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_main.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_messagebox.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_mouse.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_mutex.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_name.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengl.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengl_glext.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles2.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles2_gl2.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles2_gl2ext.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles2_gl2platform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_opengles2_khrplatform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_pixels.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_platform.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_power.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_quit.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_rect.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_render.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_revision.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_rwops.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_scancode.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_sensor.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_shape.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_stdinc.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_surface.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_system.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_syswm.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_assert.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_common.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_compare.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_crc32.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_font.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_fuzzer.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_harness.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_images.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_log.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_md5.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_memory.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_test_random.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_thread.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_timer.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_touch.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_types.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_version.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_video.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/SDL_vulkan.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/begin_code.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/include/SDL2/close_code.h create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/cmake/SDL2/sdl2-config.cmake create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2.dll.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2_test.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2_test.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2main.a create mode 100755 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/libSDL2main.la create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/lib/pkgconfig/sdl2.pc create mode 100644 vendor/lite/winlib/SDL2-2.0.10/x86_64-w64-mingw32/share/aclocal/sdl2.m4 create mode 100644 wrap.fnl diff --git a/conf.lua b/conf.lua new file mode 100644 index 0000000..d8ef236 --- /dev/null +++ b/conf.lua @@ -0,0 +1,5 @@ +function love.conf(t) + t.window.width = 1280 + t.window.height = 1000 + t.window.resizable = true +end diff --git a/editor/editmode.fnl b/editor/editmode.fnl new file mode 100644 index 0000000..83af2f4 --- /dev/null +++ b/editor/editmode.fnl @@ -0,0 +1,17 @@ +(local modes (require :editor.lovemode)) +(local core (require :core)) + +(local events []) +(local editor-mode + {:draw system.draw_love_frame + :update (fn [...] + (when (and core.active_view core.active_view.handle-love-update) + (core.active_view:handle-love-update ...))) + :handler (fn [...] + (system.enqueue_love_event ...) + (when (and core.active_view core.active_view.handle-love-event) + (core.active_view:handle-love-event ...)))}) + +(modes:register :editor editor-mode) + +{: editor-mode : events} diff --git a/editor/imstate.fnl b/editor/imstate.fnl new file mode 100644 index 0000000..bbbcafa --- /dev/null +++ b/editor/imstate.fnl @@ -0,0 +1,215 @@ +(local core (require :core)) +(local config (require :core.config)) +(local command (require :core.command)) +(local keymap (require :core.keymap)) +(local style (require :core.style)) +(local lume (require :lib.lume)) + +(fn attach-imstate [view] + (set view.imstate {}) + (fn view.on_mouse_pressed [self button x y clicks] + (tset self.imstate button :pressed) + (self.__index.on_mouse_pressed self button x y clicks)) + (fn view.on_mouse_released [self button x y] + (tset self.imstate button :released) + (self.__index.on_mouse_released self button x y)) + (fn view.on_key_pressed [self key] + (when (= self.imstate.keys nil) + (set self.imstate.keys [])) + (table.insert self.imstate.keys key)) + (fn view.on_text_input [self text] + (set self.imstate.text (.. (or self.imstate.text "") text)) + (self.__index.on_text_input self text)) + (fn view.draw [self] + (set self.cursor nil) + (self.__index.draw self) + (when (= self.cursor nil) (set self.cursor :arrow)) + (set self.imstate.keys nil) + (set self.imstate.text nil) + (when (= self.imstate.left :released) + (set self.imstate.active nil)) + (each [_ button (pairs [:left :middle :right])] + (tset self.imstate button + (match (. self.imstate button) + :pressed :down + :down :down + :released nil))))) + +(fn register-keys [keys] + (local commands {}) + (local keymaps {}) + (each [_ key (ipairs keys)] + (local command-name (.. "imstate:" key)) + (tset commands command-name #(core.active_view:on_key_pressed key)) + (tset keymaps key command-name)) + (command.add #(not= (-?> core.active_view.imstate (. :focus)) nil) commands) + (keymap.add keymaps)) + +(register-keys [:backspace :delete :left :right :shift+left :shift+right :home :end :shift+home :shift+end + :ctrl+left :ctrl+right :ctrl+shift+left :ctrl+shift+right :ctrl+c :ctrl+v]) + +(fn cmd-predicate [p] + (var p-fn p) + (when (= (type p-fn) :string) (set p-fn (require p-fn))) + (when (= (type p-fn) :table) + (local cls p-fn) + (set p-fn (fn [] (core.active_view:is cls)))) + (fn [] (when (= (-?> core.active_view.imstate (. :focus)) nil) + (p-fn)))) + +(fn make-tag [tag] + (match (type tag) + :string tag + :table (table.concat tag "::") + _ (tostring tag))) + +(fn mouse-inside [x y w h] + (local (mx my) (values (love.mouse.getX) (love.mouse.getY))) + (and (>= mx x) (<= mx (+ x w)) (>= my y) (<= my (+ y h)))) + +(fn activate [view tag x y w h] + (when (and (= view.imstate.left :pressed) (mouse-inside x y w h)) + (set view.imstate.active (make-tag tag)) + true)) +(fn active? [view tag] (= view.imstate.active (make-tag tag))) +(fn button [view tag x y w h] + (when (mouse-inside x y w h) (set view.cursor :hand)) + (activate view tag x y w h) + (and (active? view tag) (= view.imstate.left :released) (mouse-inside x y w h))) + +(fn textbutton [view label x y] + (local (w h) (values (+ (style.font:get_width label) 8) 24)) + (renderer.draw_rect x y w h style.selection) + (renderer.draw_text style.font label (+ x 4) (+ y 4) style.text) + (values (button view label x y w h) (+ y h))) + +(fn checkbox [view name isset x y ?tag] + (love.graphics.rectangle (if isset :fill :line) x y 12 12) + (local xEnd (renderer.draw_text style.font name (+ x 16) y style.text)) + (love.graphics.setColor 1 1 1 1) + (button view (or ?tag name) x y (- xEnd x) 12)) + +(fn focused? [view tag] (= tag (-?> view.imstate.focus (. :tag)))) +(fn focus [view tag x y w h opts] + (if (activate view tag x y w h) + (set view.imstate.focus + (doto (lume.clone (or opts {})) + (tset :tag tag))) + + (and (= view.imstate.left :released) (focused? view tag) (not (active? view tag))) + (set view.imstate.focus nil)) + (focused? view tag)) + +(local blink_period 0.8) +(fn x-from-i [s i xLeft font] + (if (or (<= i 1) (= s "")) xLeft + (x-from-i (s:sub 2) (- i 1) (+ xLeft (font:get_width (s:sub 1 1))) font))) +(fn i-from-x [s x xLeft font ?i] + (local i (or ?i 1)) + (local w (font:get_width (s:sub 1 1))) + (local xMid (+ xLeft (/ w 2))) + (if (or (<= x xMid) (= s "")) i + (i-from-x (s:sub 2) x (+ xLeft w) font (+ i 1)))) + +(fn next-match [text i di pred] + (local imax (+ (length text) 1)) + (local inext (+ i di)) + (if (<= inext 1) 1 + (> inext imax) imax + (pred (text:sub inext inext)) (if (< di 0) i inext) + (next-match text inext di pred))) +(fn is-nonword-char [char] (config.non_word_chars:find char nil true)) +(fn next-word [text i di] + (let [iwordboundary (next-match text i di #(is-nonword-char $1))] + (next-match text iwordboundary di #(not (is-nonword-char $1))))) + +(fn textnav [key i text] + (local imax (+ (length text) 1)) + (match key + :left (math.max 1 (- i 1)) + :right (math.min imax (+ i 1)) + :ctrl+left (next-word text i -1) + :ctrl+right (next-word text i 1) + :home 1 + :end imax)) + +(fn selection-span [view] + (let [f view.imstate.focus + iStart (math.min f.i f.iAnchor) + iLim (math.max f.i f.iAnchor)] + (values iStart iLim))) +(fn selection-text [view text] + (local (iStart iLim) (selection-span view)) + (text:sub iStart (- iLim 1))) + +(fn replace-selection [view s replacement ?iStart ?iLim] + (local (iStart iLim) (if ?iLim (values ?iStart ?iLim) (selection-span view))) + (local text + (.. (s:sub 1 (- iStart 1)) + replacement + (s:sub iLim))) + (local iNew (+ iStart (length replacement))) + (set view.imstate.focus.i iNew) + (set view.imstate.focus.iAnchor iNew) + text) + +(fn textbox [view tag text x y w] + (var textNew (or text "")) + (local (h hText xText yText) (values 20 16 (+ x 2) (+ y 2))) + + ; handle key events + (when (focus view tag x y w h {:i 1 :iAnchor 1 :blink (love.timer.getTime)}) + (local f view.imstate.focus) + (when view.imstate.text + (set textNew (replace-selection view textNew view.imstate.text))) + (each [_ key (ipairs (or view.imstate.keys []))] + (set view.imstate.focus.blink (love.timer.getTime)) + (if (= key :ctrl+c) (system.set_clipboard (selection-text view textNew)) + (= key :ctrl+v) (set textNew (replace-selection view textNew (system.get_clipboard))) + (key:find "shift%+") (set f.i (or (textnav (key:gsub "shift%+" "") f.i textNew) f.i)) + (let [iNav (textnav key f.i textNew)] + (when iNav + (set f.i iNav) + (set f.iAnchor iNav)) + (when (or (= key :delete) (= key :backspace)) + (local (iStartDel iLimDel) + (if (not= f.i f.iAnchor) (selection-span view) + (= key :delete) (values f.i (+ f.i 1)) + (= key :backspace) (values (math.max 1 (- f.i 1)) f.i))) + (set textNew (replace-selection view textNew "" iStartDel iLimDel))))))) + + ; handle mouse events + (when (mouse-inside x y w h) (set view.cursor :ibeam)) + (when (and (focused? view tag) (active? view tag) (mouse-inside x y w h)) + (local mouse-i (i-from-x textNew (love.mouse.getX) x style.font)) + (when (= view.imstate.left :pressed) + (set view.imstate.focus.iAnchor mouse-i)) + (set view.imstate.focus.i mouse-i)) + + ; draw box + (love.graphics.setLineWidth 1) + (love.graphics.rectangle :line x y w h) + (if (focused? view tag) + ; draw text with selection + caret + (let [(iStart iLim) (selection-span view) + xSelect (renderer.draw_text style.font (textNew:sub 1 (- iStart 1)) xText yText style.text) + sSelect (textNew:sub iStart (- iLim 1)) + wSelect (style.font:get_width sSelect) + xTail (+ xSelect wSelect)] + (when (> wSelect 0) + (renderer.draw_rect xSelect yText wSelect hText style.selection) + (renderer.draw_text style.font sSelect xSelect yText style.text)) + (renderer.draw_text style.font (textNew:sub iLim) xTail yText style.text) + (when (or (active? view tag) + (< (% (- (love.timer.getTime) view.imstate.focus.blink) (* blink_period 2)) blink_period)) + (renderer.draw_rect (x-from-i textNew view.imstate.focus.i xText style.font) yText style.caret_width hText style.caret))) + ; just draw the text + (renderer.draw_text style.font textNew xText yText style.text)) + (love.graphics.setColor 1 1 1) + (values textNew (+ y h))) + +(fn textfield [view label text x y wLabel wText] + (renderer.draw_text style.font label x y style.text) + (textbox view label text (+ x wLabel) y wText)) + +{: attach-imstate : cmd-predicate : mouse-inside : activate : active? : button : checkbox : textbox : textfield : textbutton} diff --git a/editor/init.fnl b/editor/init.fnl new file mode 100644 index 0000000..6703c70 --- /dev/null +++ b/editor/init.fnl @@ -0,0 +1,17 @@ +(local util (require :lib.util)) +(local core (require :core)) +(local command (require :core.command)) +(local keymap (require :core.keymap)) +(local common (require :core.common)) + +(fn inline-eval [eval] + (let [ldoc core.active_view.doc + (aline acol bline bcol) (ldoc:get_selection) + inject #(ldoc:insert bline bcol (eval $1))] + (if (and (= aline bline) (= acol bcol)) + (inject (ldoc:get_text aline 1 aline 10000000)) + (inject (ldoc:get_text aline acol bline bcol))))) + +(require :editor.editmode) + +{: inline-eval} diff --git a/editor/lovemode.fnl b/editor/lovemode.fnl new file mode 100644 index 0000000..86ab08b --- /dev/null +++ b/editor/lovemode.fnl @@ -0,0 +1,44 @@ +(local lume (require :lib.lume)) +(local common (require :core.common)) +(local style (require :core.style)) + +(local std-handlers love.handlers) +(local modes {:name-to-mode {} + :mode-index 1 + :names [] + : std-handlers}) + +(fn modes.cycle [self] + (set self.mode-index (+ self.mode-index 1)) + (when (> self.mode-index (length self.names)) + (set self.mode-index 1)) + (self:switch (self:current))) + +(fn modes.current [self] + (. self.name-to-mode (. self.names self.mode-index))) + +(fn add-mode-cycler [handlers] + (fn mode-cycler [ev key ...] + (when (and (= ev :keyreleased) (= key :f1)) + (modes:cycle)) + (when (rawget handlers :any) (handlers.any ev key ...))) + (setmetatable {:any mode-cycler} {:__index handlers})) + +(fn modes.switch [self mode] + (set love.handlers (add-mode-cycler (if mode.handler {:any mode.handler} std-handlers))) + (set love.update mode.update) + (set love.draw (fn [] + (xpcall mode.draw (fn [msg] + (love.graphics.reset) + (love.graphics.setColor 1 0 0 1) + (love.graphics.setNewFont 14) + (love.graphics.printf (.. msg "\n" (debug.traceback)) + 20 20 (- (love.graphics.getWidth) 40))))))) + +(fn modes.register [self name mode] + (tset self.name-to-mode name mode) + (when (not (lume.any self.names #(= $1 name))) + (table.insert self.names name)) + (when (= (length self.names) 1) (self:cycle))) + +modes diff --git a/editor/modeview.fnl b/editor/modeview.fnl new file mode 100644 index 0000000..515c5a3 --- /dev/null +++ b/editor/modeview.fnl @@ -0,0 +1,25 @@ +(local modes (require :editor.lovemode)) +(local View (require :core.view)) + +(local ModeView (View:extend)) + +(fn ModeView.new [self mode] + (ModeView.super.new self) + (set self.mode mode)) + +(fn ModeView.draw [self] + (love.graphics.push :all) + (love.graphics.translate self.position.x self.position.y) + (xpcall self.mode.draw (fn [...] (love.graphics.pop) (error ...))) + (love.graphics.pop)) + +(fn ModeView.handle-love-update [self ...] + (when self.mode.update (self.mode.update ...))) + +(fn ModeView.handle-love-event [self ev ...] + (if self.mode.handler + (self.mode.handler ev ...) + ((. modes.std-handlers ev) ...))) + +ModeView + diff --git a/game/entities/bomberman.fnl b/game/entities/bomberman.fnl new file mode 100644 index 0000000..d1de3c4 --- /dev/null +++ b/game/entities/bomberman.fnl @@ -0,0 +1,12 @@ +(local Entity (require :game.entity)) +(local rules (require :game.rules)) + +(local Bomberman (Entity:extend)) +(set Bomberman.keymap {:up :w :down :s :left :a :right :d :bomb :x}) +(set Bomberman.color [0.2 0.2 0.2]) +(fn Bomberman.update [self dt] + (Bomberman.super.update self dt) + (when (love.keyboard.isDown self.keymap.bomb) + (rules.place-bomb self.x self.y))) + +Bomberman diff --git a/game/entities/pacman.fnl b/game/entities/pacman.fnl new file mode 100644 index 0000000..ed6d431 --- /dev/null +++ b/game/entities/pacman.fnl @@ -0,0 +1,9 @@ +(local Entity (require :game.entity)) +(local rules (require :game.rules)) + +(local Pacman (Entity:extend)) +(set Pacman.keymap {:up :up :down :down :left :left :right :right}) +(set Pacman.color [1 1 0]) + +Pacman + diff --git a/game/entity.fnl b/game/entity.fnl new file mode 100644 index 0000000..0b8dd17 --- /dev/null +++ b/game/entity.fnl @@ -0,0 +1,24 @@ +(local util (require :lib.util)) +(local {: vec* : dir-from-key} (util.require :game.helpers)) +(local rules (require :game.rules)) +(local Object (require :core.object)) + +(local Entity (Object:extend)) +(fn Entity.new [self x y] + (set self.x x) + (set self.y y) + (set self.velocity [0 0])) +(fn Entity.draw [self] + (when (= self.color nil) + (set self.color [(math.random) (math.random) (math.random)])) + (love.graphics.setColor (table.unpack self.color)) + (love.graphics.circle :fill self.x self.y 16)) +(fn Entity.move [self [dx dy]] + (set self.velocity [dx dy]) + (set self.x (rules.collide :x self dx)) + (set self.y (rules.collide :y self dy))) +(fn Entity.update [self dt] + (self:move (vec* (dir-from-key self.keymap) (* self.speed dt)))) +(set Entity.speed 64) + +Entity diff --git a/game/helpers.fnl b/game/helpers.fnl new file mode 100644 index 0000000..2ce9621 --- /dev/null +++ b/game/helpers.fnl @@ -0,0 +1,12 @@ +(fn dir-from-key [keymap] + (var (dx dy) (values 0 0)) + (when (love.keyboard.isDown keymap.up) (set dy -1)) + (when (love.keyboard.isDown keymap.down) (set dy 1)) + (when (love.keyboard.isDown keymap.left) (set dx -1)) + (when (love.keyboard.isDown keymap.right) (set dx 1)) + [dx dy]) + +(fn vec* [vec scalar] + (icollect [_ v (ipairs vec)] (* v scalar))) + +{: dir-from-key : vec*} diff --git a/game/init.fnl b/game/init.fnl new file mode 100644 index 0000000..da1355a --- /dev/null +++ b/game/init.fnl @@ -0,0 +1,21 @@ +(local util (require :lib.util)) +(local modes (require :editor.lovemode)) +(local ModeView (require :editor.modeview)) +(local state (require :game.state)) +(local core (require :core)) +(local command (require :core.command)) + +(local gamemode (require :game.mode)) +(modes:register :game gamemode) + +(set state.entities + [((require :game.entities.bomberman) 20 20) + ((require :game.entities.pacman) 350 350)]) + +(command.add nil { + "love:game" (fn [] + (let [node (core.root_view:get_active_node)] + (node:add_view (ModeView gamemode)))) +}) + +{} diff --git a/game/mode.fnl b/game/mode.fnl new file mode 100644 index 0000000..bac0e5e --- /dev/null +++ b/game/mode.fnl @@ -0,0 +1,12 @@ +(local state (require :game.state)) + +(fn update [dt] + (each [_ entity (ipairs state.entities)] + (entity:update dt))) + +(fn draw [] + (each [_ entity (ipairs state.entities)] + (entity:draw))) + +{: update : draw} + diff --git a/game/rules.fnl b/game/rules.fnl new file mode 100644 index 0000000..a158681 --- /dev/null +++ b/game/rules.fnl @@ -0,0 +1,8 @@ +(local state (require :game.state)) + +(fn collide [axis entity d] + (+ (. entity axis) d)) + +(fn place-bomb [x y]) +{: collide : place-bomb} + diff --git a/game/state.fnl b/game/state.fnl new file mode 100644 index 0000000..0967ef4 --- /dev/null +++ b/game/state.fnl @@ -0,0 +1 @@ +{} diff --git a/game/tiles.fnl b/game/tiles.fnl new file mode 100644 index 0000000..2aa4de4 --- /dev/null +++ b/game/tiles.fnl @@ -0,0 +1,16 @@ +(local tiles + [{:name :empty + :draw (fn [])} + {:name :strongwall + :draw (fn [x y w h] + (love.graphics.setColor 0.4 0.4 0.4) + (love.graphics.rectangle :fill x y w h))} + {:name :weakwall + :draw (fn [x y w h] + (love.graphics.setColor 0.4 0.4 0.4) + (love.graphics.rectangle :fill x y w h))} + {:name :dot + :draw (fn [x y w h] + (love.graphics.setColor 1 1 1) + (love.graphics.circle :fill x y w 5))} + ]) diff --git a/lib/bencode.lua b/lib/bencode.lua new file mode 100644 index 0000000..de81e9b --- /dev/null +++ b/lib/bencode.lua @@ -0,0 +1,89 @@ +-- Based on bencode.lua from the jeejah project by Phil Hagelberg +-- Distributed under the MIT license +-- https://gitlab.com/technomancy/jeejah/ + +local encode, decode + +local function decode_list(str, t, total_len) + -- print("list", str, lume.serialize(t)) + if #str == 0 then error("Incomplete") end + if(str:sub(1,1) == "e") then return t, total_len + 1 end + local value, v_len = decode(str) + table.insert(t, value) + total_len = total_len + v_len + return decode_list(str:sub(v_len + 1), t, total_len) +end + +local function decode_table(str, t, total_len) + -- print("table", str, lume.serialize(t)) + if #str == 0 then error("Incomplete") end + if(str:sub(1,1) == "e") then return t, total_len + 1 end + local key, k_len = decode(str) + local value, v_len = decode(str:sub(k_len+1)) + local end_pos = 1 + k_len + v_len + t[key] = value + total_len = total_len + k_len + v_len + return decode_table(str:sub(end_pos), t, total_len) +end + +function decode(str) + -- print("decoding", str) + if #str == 0 then + error("Incomplete") + elseif(str:sub(1,1) == "l") then + return decode_list(str:sub(2), {}, 1) + elseif(str:sub(1,1) == "d") then + return decode_table(str:sub(2), {}, 1) + elseif(str:sub(1,1) == "i") then + local iend = str:find("e") + if iend == nil then error("Incomplete") end + return(tonumber(str:sub(2, iend - 1))), iend + elseif(str:match("[0-9]+:")) then + local num_str = str:match("[0-9]+") + local beginning_of_string = #num_str + 2 + local str_len = tonumber(num_str) + local total_len = beginning_of_string + str_len - 1 + if #str < total_len then error("Incomplete") end + return str:sub(beginning_of_string, total_len), total_len + else + error("Could not parse "..str) + end +end + +local function encode_str(s) return #s .. ":" .. s end +local function encode_int(n) return "i" .. tostring(n) .. "e" end + +local function encode_table(t) + local s = "d" + for k,v in pairs(t) do s = s .. encode(k) .. encode(v) end + return s .. "e" +end + +local function encode_list(l) + local s = "l" + for _,x in ipairs(l) do s = s .. encode(x) end + return s .. "e" +end + +local function count(tbl) + local i = 0 + for _ in pairs(tbl) do i = i + 1 end + return i +end + +function encode(x) + local unpack = unpack or table.unpack + if(type(x) == "table" and select("#", unpack(x)) == count(x)) then + return encode_list(x) + elseif(type(x) == "table") then + return encode_table(x) + elseif(type(x) == "number" and math.floor(x) == x) then + return encode_int(x) + elseif(type(x) == "string") then + return encode_str(x) + else + error("Could not encode " .. type(x) .. ": " .. tostring(x)) + end +end + +return {decode=decode, encode=encode} diff --git a/lib/dkjson.lua b/lib/dkjson.lua new file mode 100644 index 0000000..fa50b9f --- /dev/null +++ b/lib/dkjson.lua @@ -0,0 +1,714 @@ +-- Module options: +local always_try_using_lpeg = true +local register_global_module_table = false +local global_module_name = 'json' + +--[==[ + +David Kolf's JSON module for Lua 5.1/5.2 + +Version 2.5 + + +For the documentation see the corresponding readme.txt or visit +. + +You can contact the author by sending an e-mail to 'david' at the +domain 'dkolf.de'. + + +Copyright (C) 2010-2013 David Heiko Kolf + +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. + +--]==] + +-- global dependencies: +local pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset = + pairs, type, tostring, tonumber, getmetatable, setmetatable, rawset +local error, require, pcall, select = error, require, pcall, select +local floor, huge = math.floor, math.huge +local strrep, gsub, strsub, strbyte, strchar, strfind, strlen, strformat = + string.rep, string.gsub, string.sub, string.byte, string.char, + string.find, string.len, string.format +local strmatch = string.match +local concat = table.concat + +local json = { version = "dkjson 2.5" } + +if register_global_module_table then + _G[global_module_name] = json +end + +local _ENV = nil -- blocking globals in Lua 5.2 + +pcall (function() + -- Enable access to blocked metatables. + -- Don't worry, this module doesn't change anything in them. + local debmeta = require "debug".getmetatable + if debmeta then getmetatable = debmeta end +end) + +json.null = setmetatable ({}, { + __tojson = function () return "null" end +}) + +local function isarray (tbl) + local max, n, arraylen = 0, 0, 0 + for k,v in pairs (tbl) do + if k == 'n' and type(v) == 'number' then + arraylen = v + if v > max then + max = v + end + else + if type(k) ~= 'number' or k < 1 or floor(k) ~= k then + return false + end + if k > max then + max = k + end + n = n + 1 + end + end + if max > 10 and max > arraylen and max > n * 2 then + return false -- don't create an array with too many holes + end + return true, max +end + +local escapecodes = { + ["\""] = "\\\"", ["\\"] = "\\\\", ["\b"] = "\\b", ["\f"] = "\\f", + ["\n"] = "\\n", ["\r"] = "\\r", ["\t"] = "\\t" +} + +local function escapeutf8 (uchar) + local value = escapecodes[uchar] + if value then + return value + end + local a, b, c, d = strbyte (uchar, 1, 4) + a, b, c, d = a or 0, b or 0, c or 0, d or 0 + if a <= 0x7f then + value = a + elseif 0xc0 <= a and a <= 0xdf and b >= 0x80 then + value = (a - 0xc0) * 0x40 + b - 0x80 + elseif 0xe0 <= a and a <= 0xef and b >= 0x80 and c >= 0x80 then + value = ((a - 0xe0) * 0x40 + b - 0x80) * 0x40 + c - 0x80 + elseif 0xf0 <= a and a <= 0xf7 and b >= 0x80 and c >= 0x80 and d >= 0x80 then + value = (((a - 0xf0) * 0x40 + b - 0x80) * 0x40 + c - 0x80) * 0x40 + d - 0x80 + else + return "" + end + if value <= 0xffff then + return strformat ("\\u%.4x", value) + elseif value <= 0x10ffff then + -- encode as UTF-16 surrogate pair + value = value - 0x10000 + local highsur, lowsur = 0xD800 + floor (value/0x400), 0xDC00 + (value % 0x400) + return strformat ("\\u%.4x\\u%.4x", highsur, lowsur) + else + return "" + end +end + +local function fsub (str, pattern, repl) + -- gsub always builds a new string in a buffer, even when no match + -- exists. First using find should be more efficient when most strings + -- don't contain the pattern. + if strfind (str, pattern) then + return gsub (str, pattern, repl) + else + return str + end +end + +local function quotestring (value) + -- based on the regexp "escapable" in https://github.com/douglascrockford/JSON-js + value = fsub (value, "[%z\1-\31\"\\\127]", escapeutf8) + if strfind (value, "[\194\216\220\225\226\239]") then + value = fsub (value, "\194[\128-\159\173]", escapeutf8) + value = fsub (value, "\216[\128-\132]", escapeutf8) + value = fsub (value, "\220\143", escapeutf8) + value = fsub (value, "\225\158[\180\181]", escapeutf8) + value = fsub (value, "\226\128[\140-\143\168-\175]", escapeutf8) + value = fsub (value, "\226\129[\160-\175]", escapeutf8) + value = fsub (value, "\239\187\191", escapeutf8) + value = fsub (value, "\239\191[\176-\191]", escapeutf8) + end + return "\"" .. value .. "\"" +end +json.quotestring = quotestring + +local function replace(str, o, n) + local i, j = strfind (str, o, 1, true) + if i then + return strsub(str, 1, i-1) .. n .. strsub(str, j+1, -1) + else + return str + end +end + +-- locale independent num2str and str2num functions +local decpoint, numfilter + +local function updatedecpoint () + decpoint = strmatch(tostring(0.5), "([^05+])") + -- build a filter that can be used to remove group separators + numfilter = "[^0-9%-%+eE" .. gsub(decpoint, "[%^%$%(%)%%%.%[%]%*%+%-%?]", "%%%0") .. "]+" +end + +updatedecpoint() + +local function num2str (num) + return replace(fsub(tostring(num), numfilter, ""), decpoint, ".") +end + +local function str2num (str) + local num = tonumber(replace(str, ".", decpoint)) + if not num then + updatedecpoint() + num = tonumber(replace(str, ".", decpoint)) + end + return num +end + +local function addnewline2 (level, buffer, buflen) + buffer[buflen+1] = "\n" + buffer[buflen+2] = strrep (" ", level) + buflen = buflen + 2 + return buflen +end + +function json.addnewline (state) + if state.indent then + state.bufferlen = addnewline2 (state.level or 0, + state.buffer, state.bufferlen or #(state.buffer)) + end +end + +local encode2 -- forward declaration + +local function addpair (key, value, prev, indent, level, buffer, buflen, tables, globalorder, state) + local kt = type (key) + if kt ~= 'string' and kt ~= 'number' then + return nil, "type '" .. kt .. "' is not supported as a key by JSON." + end + if prev then + buflen = buflen + 1 + buffer[buflen] = "," + end + if indent then + buflen = addnewline2 (level, buffer, buflen) + end + buffer[buflen+1] = quotestring (key) + buffer[buflen+2] = ":" + return encode2 (value, indent, level, buffer, buflen + 2, tables, globalorder, state) +end + +local function appendcustom(res, buffer, state) + local buflen = state.bufferlen + if type (res) == 'string' then + buflen = buflen + 1 + buffer[buflen] = res + end + return buflen +end + +local function exception(reason, value, state, buffer, buflen, defaultmessage) + defaultmessage = defaultmessage or reason + local handler = state.exception + if not handler then + return nil, defaultmessage + else + state.bufferlen = buflen + local ret, msg = handler (reason, value, state, defaultmessage) + if not ret then return nil, msg or defaultmessage end + return appendcustom(ret, buffer, state) + end +end + +function json.encodeexception(reason, value, state, defaultmessage) + return quotestring("<" .. defaultmessage .. ">") +end + +encode2 = function (value, indent, level, buffer, buflen, tables, globalorder, state) + local valtype = type (value) + local valmeta = getmetatable (value) + valmeta = type (valmeta) == 'table' and valmeta -- only tables + local valtojson = valmeta and valmeta.__tojson + if valtojson then + if tables[value] then + return exception('reference cycle', value, state, buffer, buflen) + end + tables[value] = true + state.bufferlen = buflen + local ret, msg = valtojson (value, state) + if not ret then return exception('custom encoder failed', value, state, buffer, buflen, msg) end + tables[value] = nil + buflen = appendcustom(ret, buffer, state) + elseif value == nil then + buflen = buflen + 1 + buffer[buflen] = "null" + elseif valtype == 'number' then + local s + if value ~= value or value >= huge or -value >= huge then + -- This is the behaviour of the original JSON implementation. + s = "null" + else + s = num2str (value) + end + buflen = buflen + 1 + buffer[buflen] = s + elseif valtype == 'boolean' then + buflen = buflen + 1 + buffer[buflen] = value and "true" or "false" + elseif valtype == 'string' then + buflen = buflen + 1 + buffer[buflen] = quotestring (value) + elseif valtype == 'table' then + if tables[value] then + return exception('reference cycle', value, state, buffer, buflen) + end + tables[value] = true + level = level + 1 + local isa, n = isarray (value) + if n == 0 and valmeta and valmeta.__jsontype == 'object' then + isa = false + end + local msg + if isa then -- JSON array + buflen = buflen + 1 + buffer[buflen] = "[" + for i = 1, n do + buflen, msg = encode2 (value[i], indent, level, buffer, buflen, tables, globalorder, state) + if not buflen then return nil, msg end + if i < n then + buflen = buflen + 1 + buffer[buflen] = "," + end + end + buflen = buflen + 1 + buffer[buflen] = "]" + else -- JSON object + local prev = false + buflen = buflen + 1 + buffer[buflen] = "{" + local order = valmeta and valmeta.__jsonorder or globalorder + if order then + local used = {} + n = #order + for i = 1, n do + local k = order[i] + local v = value[k] + if v then + used[k] = true + buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state) + prev = true -- add a seperator before the next element + end + end + for k,v in pairs (value) do + if not used[k] then + buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state) + if not buflen then return nil, msg end + prev = true -- add a seperator before the next element + end + end + else -- unordered + for k,v in pairs (value) do + buflen, msg = addpair (k, v, prev, indent, level, buffer, buflen, tables, globalorder, state) + if not buflen then return nil, msg end + prev = true -- add a seperator before the next element + end + end + if indent then + buflen = addnewline2 (level - 1, buffer, buflen) + end + buflen = buflen + 1 + buffer[buflen] = "}" + end + tables[value] = nil + else + return exception ('unsupported type', value, state, buffer, buflen, + "type '" .. valtype .. "' is not supported by JSON.") + end + return buflen +end + +function json.encode (value, state) + state = state or {} + local oldbuffer = state.buffer + local buffer = oldbuffer or {} + state.buffer = buffer + updatedecpoint() + local ret, msg = encode2 (value, state.indent, state.level or 0, + buffer, state.bufferlen or 0, state.tables or {}, state.keyorder, state) + if not ret then + error (msg, 2) + elseif oldbuffer == buffer then + state.bufferlen = ret + return true + else + state.bufferlen = nil + state.buffer = nil + return concat (buffer) + end +end + +local function loc (str, where) + local line, pos, linepos = 1, 1, 0 + while true do + pos = strfind (str, "\n", pos, true) + if pos and pos < where then + line = line + 1 + linepos = pos + pos = pos + 1 + else + break + end + end + return "line " .. line .. ", column " .. (where - linepos) +end + +local function unterminated (str, what, where) + return nil, strlen (str) + 1, "unterminated " .. what .. " at " .. loc (str, where) +end + +local function scanwhite (str, pos) + while true do + pos = strfind (str, "%S", pos) + if not pos then return nil end + local sub2 = strsub (str, pos, pos + 1) + if sub2 == "\239\187" and strsub (str, pos + 2, pos + 2) == "\191" then + -- UTF-8 Byte Order Mark + pos = pos + 3 + elseif sub2 == "//" then + pos = strfind (str, "[\n\r]", pos + 2) + if not pos then return nil end + elseif sub2 == "/*" then + pos = strfind (str, "*/", pos + 2) + if not pos then return nil end + pos = pos + 2 + else + return pos + end + end +end + +local escapechars = { + ["\""] = "\"", ["\\"] = "\\", ["/"] = "/", ["b"] = "\b", ["f"] = "\f", + ["n"] = "\n", ["r"] = "\r", ["t"] = "\t" +} + +local function unichar (value) + if value < 0 then + return nil + elseif value <= 0x007f then + return strchar (value) + elseif value <= 0x07ff then + return strchar (0xc0 + floor(value/0x40), + 0x80 + (floor(value) % 0x40)) + elseif value <= 0xffff then + return strchar (0xe0 + floor(value/0x1000), + 0x80 + (floor(value/0x40) % 0x40), + 0x80 + (floor(value) % 0x40)) + elseif value <= 0x10ffff then + return strchar (0xf0 + floor(value/0x40000), + 0x80 + (floor(value/0x1000) % 0x40), + 0x80 + (floor(value/0x40) % 0x40), + 0x80 + (floor(value) % 0x40)) + else + return nil + end +end + +local function scanstring (str, pos) + local lastpos = pos + 1 + local buffer, n = {}, 0 + while true do + local nextpos = strfind (str, "[\"\\]", lastpos) + if not nextpos then + return unterminated (str, "string", pos) + end + if nextpos > lastpos then + n = n + 1 + buffer[n] = strsub (str, lastpos, nextpos - 1) + end + if strsub (str, nextpos, nextpos) == "\"" then + lastpos = nextpos + 1 + break + else + local escchar = strsub (str, nextpos + 1, nextpos + 1) + local value + if escchar == "u" then + value = tonumber (strsub (str, nextpos + 2, nextpos + 5), 16) + if value then + local value2 + if 0xD800 <= value and value <= 0xDBff then + -- we have the high surrogate of UTF-16. Check if there is a + -- low surrogate escaped nearby to combine them. + if strsub (str, nextpos + 6, nextpos + 7) == "\\u" then + value2 = tonumber (strsub (str, nextpos + 8, nextpos + 11), 16) + if value2 and 0xDC00 <= value2 and value2 <= 0xDFFF then + value = (value - 0xD800) * 0x400 + (value2 - 0xDC00) + 0x10000 + else + value2 = nil -- in case it was out of range for a low surrogate + end + end + end + value = value and unichar (value) + if value then + if value2 then + lastpos = nextpos + 12 + else + lastpos = nextpos + 6 + end + end + end + end + if not value then + value = escapechars[escchar] or escchar + lastpos = nextpos + 2 + end + n = n + 1 + buffer[n] = value + end + end + if n == 1 then + return buffer[1], lastpos + elseif n > 1 then + return concat (buffer), lastpos + else + return "", lastpos + end +end + +local scanvalue -- forward declaration + +local function scantable (what, closechar, str, startpos, nullval, objectmeta, arraymeta) + local len = strlen (str) + local tbl, n = {}, 0 + local pos = startpos + 1 + if what == 'object' then + setmetatable (tbl, objectmeta) + else + setmetatable (tbl, arraymeta) + end + while true do + pos = scanwhite (str, pos) + if not pos then return unterminated (str, what, startpos) end + local char = strsub (str, pos, pos) + if char == closechar then + return tbl, pos + 1 + end + local val1, err + val1, pos, err = scanvalue (str, pos, nullval, objectmeta, arraymeta) + if err then return nil, pos, err end + pos = scanwhite (str, pos) + if not pos then return unterminated (str, what, startpos) end + char = strsub (str, pos, pos) + if char == ":" then + if val1 == nil then + return nil, pos, "cannot use nil as table index (at " .. loc (str, pos) .. ")" + end + pos = scanwhite (str, pos + 1) + if not pos then return unterminated (str, what, startpos) end + local val2 + val2, pos, err = scanvalue (str, pos, nullval, objectmeta, arraymeta) + if err then return nil, pos, err end + tbl[val1] = val2 + pos = scanwhite (str, pos) + if not pos then return unterminated (str, what, startpos) end + char = strsub (str, pos, pos) + else + n = n + 1 + tbl[n] = val1 + end + if char == "," then + pos = pos + 1 + end + end +end + +scanvalue = function (str, pos, nullval, objectmeta, arraymeta) + pos = pos or 1 + pos = scanwhite (str, pos) + if not pos then + return nil, strlen (str) + 1, "no valid JSON value (reached the end)" + end + local char = strsub (str, pos, pos) + if char == "{" then + return scantable ('object', "}", str, pos, nullval, objectmeta, arraymeta) + elseif char == "[" then + return scantable ('array', "]", str, pos, nullval, objectmeta, arraymeta) + elseif char == "\"" then + return scanstring (str, pos) + else + local pstart, pend = strfind (str, "^%-?[%d%.]+[eE]?[%+%-]?%d*", pos) + if pstart then + local number = str2num (strsub (str, pstart, pend)) + if number then + return number, pend + 1 + end + end + pstart, pend = strfind (str, "^%a%w*", pos) + if pstart then + local name = strsub (str, pstart, pend) + if name == "true" then + return true, pend + 1 + elseif name == "false" then + return false, pend + 1 + elseif name == "null" then + return nullval, pend + 1 + end + end + return nil, pos, "no valid JSON value at " .. loc (str, pos) + end +end + +local function optionalmetatables(...) + if select("#", ...) > 0 then + return ... + else + return {__jsontype = 'object'}, {__jsontype = 'array'} + end +end + +function json.decode (str, pos, nullval, ...) + local objectmeta, arraymeta = optionalmetatables(...) + return scanvalue (str, pos, nullval, objectmeta, arraymeta) +end + +function json.use_lpeg () + local g = require ("lpeg") + + if g.version() == "0.11" then + error "due to a bug in LPeg 0.11, it cannot be used for JSON matching" + end + + local pegmatch = g.match + local P, S, R = g.P, g.S, g.R + + local function ErrorCall (str, pos, msg, state) + if not state.msg then + state.msg = msg .. " at " .. loc (str, pos) + state.pos = pos + end + return false + end + + local function Err (msg) + return g.Cmt (g.Cc (msg) * g.Carg (2), ErrorCall) + end + + local SingleLineComment = P"//" * (1 - S"\n\r")^0 + local MultiLineComment = P"/*" * (1 - P"*/")^0 * P"*/" + local Space = (S" \n\r\t" + P"\239\187\191" + SingleLineComment + MultiLineComment)^0 + + local PlainChar = 1 - S"\"\\\n\r" + local EscapeSequence = (P"\\" * g.C (S"\"\\/bfnrt" + Err "unsupported escape sequence")) / escapechars + local HexDigit = R("09", "af", "AF") + local function UTF16Surrogate (match, pos, high, low) + high, low = tonumber (high, 16), tonumber (low, 16) + if 0xD800 <= high and high <= 0xDBff and 0xDC00 <= low and low <= 0xDFFF then + return true, unichar ((high - 0xD800) * 0x400 + (low - 0xDC00) + 0x10000) + else + return false + end + end + local function UTF16BMP (hex) + return unichar (tonumber (hex, 16)) + end + local U16Sequence = (P"\\u" * g.C (HexDigit * HexDigit * HexDigit * HexDigit)) + local UnicodeEscape = g.Cmt (U16Sequence * U16Sequence, UTF16Surrogate) + U16Sequence/UTF16BMP + local Char = UnicodeEscape + EscapeSequence + PlainChar + local String = P"\"" * g.Cs (Char ^ 0) * (P"\"" + Err "unterminated string") + local Integer = P"-"^(-1) * (P"0" + (R"19" * R"09"^0)) + local Fractal = P"." * R"09"^0 + local Exponent = (S"eE") * (S"+-")^(-1) * R"09"^1 + local Number = (Integer * Fractal^(-1) * Exponent^(-1))/str2num + local Constant = P"true" * g.Cc (true) + P"false" * g.Cc (false) + P"null" * g.Carg (1) + local SimpleValue = Number + String + Constant + local ArrayContent, ObjectContent + + -- The functions parsearray and parseobject parse only a single value/pair + -- at a time and store them directly to avoid hitting the LPeg limits. + local function parsearray (str, pos, nullval, state) + local obj, cont + local npos + local t, nt = {}, 0 + repeat + obj, cont, npos = pegmatch (ArrayContent, str, pos, nullval, state) + if not npos then break end + pos = npos + nt = nt + 1 + t[nt] = obj + until cont == 'last' + return pos, setmetatable (t, state.arraymeta) + end + + local function parseobject (str, pos, nullval, state) + local obj, key, cont + local npos + local t = {} + repeat + key, obj, cont, npos = pegmatch (ObjectContent, str, pos, nullval, state) + if not npos then break end + pos = npos + t[key] = obj + until cont == 'last' + return pos, setmetatable (t, state.objectmeta) + end + + local Array = P"[" * g.Cmt (g.Carg(1) * g.Carg(2), parsearray) * Space * (P"]" + Err "']' expected") + local Object = P"{" * g.Cmt (g.Carg(1) * g.Carg(2), parseobject) * Space * (P"}" + Err "'}' expected") + local Value = Space * (Array + Object + SimpleValue) + local ExpectedValue = Value + Space * Err "value expected" + ArrayContent = Value * Space * (P"," * g.Cc'cont' + g.Cc'last') * g.Cp() + local Pair = g.Cg (Space * String * Space * (P":" + Err "colon expected") * ExpectedValue) + ObjectContent = Pair * Space * (P"," * g.Cc'cont' + g.Cc'last') * g.Cp() + local DecodeValue = ExpectedValue * g.Cp () + + function json.decode (str, pos, nullval, ...) + local state = {} + state.objectmeta, state.arraymeta = optionalmetatables(...) + local obj, retpos = pegmatch (DecodeValue, str, pos, nullval, state) + if state.msg then + return nil, state.pos, state.msg + else + return obj, retpos + end + end + + -- use this function only once: + json.use_lpeg = function () return json end + + json.using_lpeg = true + + return json -- so you can get the module using json = require "dkjson".use_lpeg() +end + +if always_try_using_lpeg then + pcall (json.use_lpeg) +end + +return json + diff --git a/lib/fennel.lua b/lib/fennel.lua new file mode 100644 index 0000000..7384b1e --- /dev/null +++ b/lib/fennel.lua @@ -0,0 +1,3882 @@ +package.preload["fennel.repl"] = package.preload["fennel.repl"] or function(...) + local utils = require("fennel.utils") + local parser = require("fennel.parser") + local compiler = require("fennel.compiler") + local specials = require("fennel.specials") + local function default_read_chunk(parser_state) + local function _0_() + if (0 < parser_state["stack-size"]) then + return ".." + else + return ">> " + end + end + io.write(_0_()) + io.flush() + local input = io.read() + return (input and (input .. "\n")) + end + local function default_on_values(xs) + io.write(table.concat(xs, "\9")) + return io.write("\n") + end + local function default_on_error(errtype, err, lua_source) + local function _1_() + local _0_0 = errtype + if (_0_0 == "Lua Compile") then + return ("Bad code generated - likely a bug with the compiler:\n" .. "--- Generated Lua Start ---\n" .. lua_source .. "--- Generated Lua End ---\n") + elseif (_0_0 == "Runtime") then + return (compiler.traceback(tostring(err), 4) .. "\n") + else + local _ = _0_0 + return ("%s error: %s\n"):format(errtype, tostring(err)) + end + end + return io.write(_1_()) + end + local save_source = table.concat({"local ___i___ = 1", "while true do", " local name, value = debug.getlocal(1, ___i___)", " if(name and name ~= \"___i___\") then", " ___replLocals___[name] = value", " ___i___ = ___i___ + 1", " else break end end"}, "\n") + local function splice_save_locals(env, lua_source) + env.___replLocals___ = (env.___replLocals___ or {}) + local spliced_source = {} + local bind = "local %s = ___replLocals___['%s']" + for line in lua_source:gmatch("([^\n]+)\n?") do + table.insert(spliced_source, line) + end + for name in pairs(env.___replLocals___) do + table.insert(spliced_source, 1, bind:format(name, name)) + end + if ((1 < #spliced_source) and (spliced_source[#spliced_source]):match("^ *return .*$")) then + table.insert(spliced_source, #spliced_source, save_source) + end + return table.concat(spliced_source, "\n") + end + local commands = {} + local function command_3f(input) + return input:match("^%s*,") + end + local function command_docs() + local _0_ + do + local tbl_0_ = {} + for name, f in pairs(commands) do + tbl_0_[(#tbl_0_ + 1)] = (" ,%s - %s"):format(name, ((compiler.metadata):get(f, "fnl/docstring") or "undocumented")) + end + _0_ = tbl_0_ + end + return table.concat(_0_, "\n") + end + commands.help = function(_, _0, on_values) + return on_values({("Welcome to Fennel.\nThis is the REPL where you can enter code to be evaluated.\nYou can also run these repl commands:\n\n" .. command_docs() .. "\n ,exit - Leave the repl.\n\nUse (doc something) to see descriptions for individual macros and special forms.\n\nFor more information about the language, see https://fennel-lang.org/reference")}) + end + do end (compiler.metadata):set(commands.help, "fnl/docstring", "Show this message.") + local function reload(module_name, env, on_values, on_error) + local _0_0, _1_0 = pcall(specials["load-code"]("return require(...)", env), module_name) + if ((_0_0 == true) and (nil ~= _1_0)) then + local old = _1_0 + local _ = nil + package.loaded[module_name] = nil + _ = nil + local ok, new = pcall(require, module_name) + local new0 = nil + if not ok then + on_values({new}) + new0 = old + else + new0 = new + end + if ((type(old) == "table") and (type(new0) == "table")) then + for k, v in pairs(new0) do + old[k] = v + end + for k in pairs(old) do + if (nil == new0[k]) then + old[k] = nil + end + end + package.loaded[module_name] = old + end + return on_values({"ok"}) + elseif ((_0_0 == false) and (nil ~= _1_0)) then + local msg = _1_0 + local function _3_() + local _2_0 = msg:gsub("\n.*", "") + return _2_0 + end + return on_error("Runtime", _3_()) + end + end + commands.reload = function(env, read, on_values, on_error) + local _0_0, _1_0, _2_0 = pcall(read) + if ((_0_0 == true) and (_1_0 == true) and (nil ~= _2_0)) then + local module_sym = _2_0 + return reload(tostring(module_sym), env, on_values, on_error) + elseif ((_0_0 == false) and true and true) then + local _3fparse_ok = _1_0 + local _3fmsg = _2_0 + return on_error("Parse", (_3fmsg or _3fparse_ok)) + end + end + do end (compiler.metadata):set(commands.reload, "fnl/docstring", "Reload the specified module.") + commands.reset = function(env, _, on_values) + env.___replLocals___ = {} + return on_values({"ok"}) + end + do end (compiler.metadata):set(commands.reset, "fnl/docstring", "Erase all repl-local scope.") + local function load_plugin_commands() + if (utils.root and utils.root.options and utils.root.options.plugins) then + for _, plugin in ipairs(utils.root.options.plugins) do + for name, f in pairs(plugin) do + local _0_0 = name:match("^repl%-command%-(.*)") + if (nil ~= _0_0) then + local cmd_name = _0_0 + commands[cmd_name] = (commands[cmd_name] or f) + end + end + end + return nil + end + end + local function run_command(input, read, loop, env, on_values, on_error) + load_plugin_commands() + local command_name = input:match(",([^%s/]+)") + do + local _0_0 = commands[command_name] + if (nil ~= _0_0) then + local command = _0_0 + command(env, read, on_values, on_error) + else + local _ = _0_0 + if ("exit" ~= command_name) then + on_values({"Unknown command", command_name}) + end + end + end + if ("exit" ~= command_name) then + return loop() + end + end + local function completer(env, scope, text) + local matches = {} + local input_fragment = text:gsub(".*[%s)(]+", "") + local function add_partials(input, tbl, prefix) + for k in utils.allpairs(tbl) do + local k0 = nil + if ((tbl == env) or (tbl == env.___replLocals___)) then + k0 = scope.unmanglings[k] + else + k0 = k + end + if ((#matches < 2000) and (type(k0) == "string") and (input == k0:sub(0, #input))) then + table.insert(matches, (prefix .. k0)) + end + end + return nil + end + local function add_matches(input, tbl, prefix) + local prefix0 = nil + if prefix then + prefix0 = (prefix .. ".") + else + prefix0 = "" + end + if not input:find("%.") then + return add_partials(input, tbl, prefix0) + else + local head, tail = input:match("^([^.]+)%.(.*)") + local raw_head = nil + if ((tbl == env) or (tbl == env.___replLocals___)) then + raw_head = scope.manglings[head] + else + raw_head = head + end + if (type(tbl[raw_head]) == "table") then + return add_matches(tail, tbl[raw_head], (prefix0 .. head)) + end + end + end + add_matches(input_fragment, (scope.specials or {})) + add_matches(input_fragment, (scope.macros or {})) + add_matches(input_fragment, (env.___replLocals___ or {})) + add_matches(input_fragment, env) + add_matches(input_fragment, (env._ENV or env._G or {})) + return matches + end + local function repl(options) + local old_root_options = utils.root.options + local env = nil + if options.env then + env = specials["wrap-env"](options.env) + else + env = setmetatable({}, {__index = (rawget(_G, "_ENV") or _G)}) + end + local save_locals_3f = ((options.saveLocals ~= false) and env.debug and env.debug.getlocal) + local opts = {} + local _ = nil + for k, v in pairs(options) do + opts[k] = v + end + _ = nil + local read_chunk = (opts.readChunk or default_read_chunk) + local on_values = (opts.onValues or default_on_values) + local on_error = (opts.onError or default_on_error) + local pp = (opts.pp or tostring) + local byte_stream, clear_stream = parser.granulate(read_chunk) + local chars = {} + local read, reset = nil, nil + local function _1_(parser_state) + local c = byte_stream(parser_state) + table.insert(chars, c) + return c + end + read, reset = parser.parser(_1_) + local scope = compiler["make-scope"]() + opts.useMetadata = (options.useMetadata ~= false) + if (opts.allowedGlobals == nil) then + opts.allowedGlobals = specials["current-global-names"](opts.env) + end + if opts.registerCompleter then + local function _3_(...) + return completer(env, scope, ...) + end + opts.registerCompleter(_3_) + end + local function print_values(...) + local vals = {...} + local out = {} + env._, env.__ = vals[1], vals + for i = 1, select("#", ...) do + table.insert(out, pp(vals[i])) + end + return on_values(out) + end + local function loop() + for k in pairs(chars) do + chars[k] = nil + end + local ok, parse_ok_3f, x = pcall(read) + local src_string = string.char((table.unpack or _G.unpack)(chars)) + utils.root.options = opts + if not ok then + on_error("Parse", parse_ok_3f) + clear_stream() + reset() + return loop() + elseif command_3f(src_string) then + return run_command(src_string, read, loop, env, on_values, on_error) + else + if parse_ok_3f then + do + local _4_0, _5_0 = pcall(compiler.compile, x, {["assert-compile"] = opts["assert-compile"], ["parse-error"] = opts["parse-error"], correlate = opts.correlate, moduleName = opts.moduleName, scope = scope, source = src_string, useMetadata = opts.useMetadata}) + if ((_4_0 == false) and (nil ~= _5_0)) then + local msg = _5_0 + clear_stream() + on_error("Compile", msg) + elseif ((_4_0 == true) and (nil ~= _5_0)) then + local src = _5_0 + local src0 = nil + if save_locals_3f then + src0 = splice_save_locals(env, src) + else + src0 = src + end + local _7_0, _8_0 = pcall(specials["load-code"], src0, env) + if ((_7_0 == false) and (nil ~= _8_0)) then + local msg = _8_0 + clear_stream() + on_error("Lua Compile", msg, src0) + elseif (true and (nil ~= _8_0)) then + local _0 = _7_0 + local chunk = _8_0 + local function _9_() + return print_values(chunk()) + end + local function _10_(...) + return on_error("Runtime", ...) + end + xpcall(_9_, _10_) + end + end + end + utils.root.options = old_root_options + return loop() + end + end + end + return loop() + end + return repl +end +package.preload["fennel.view"] = package.preload["fennel.view"] or function(...) + local type_order = {["function"] = 5, boolean = 2, number = 1, string = 3, table = 4, thread = 7, userdata = 6} + local function sort_keys(_0_0, _1_0) + local _1_ = _0_0 + local a = _1_[1] + local _2_ = _1_0 + local b = _2_[1] + local ta = type(a) + local tb = type(b) + if ((ta == tb) and ((ta == "string") or (ta == "number"))) then + return (a < b) + else + local dta = type_order[ta] + local dtb = type_order[tb] + if (dta and dtb) then + return (dta < dtb) + elseif dta then + return true + elseif dtb then + return false + else + return (ta < tb) + end + end + end + local function table_kv_pairs(t) + local assoc_3f = false + local kv = {} + local insert = table.insert + for k, v in pairs(t) do + if (type(k) ~= "number") then + assoc_3f = true + end + insert(kv, {k, v}) + end + table.sort(kv, sort_keys) + if (#kv == 0) then + return kv, "empty" + else + local function _2_() + if assoc_3f then + return "table" + else + return "seq" + end + end + return kv, _2_() + end + end + local function count_table_appearances(t, appearances) + if (type(t) == "table") then + if not appearances[t] then + appearances[t] = 1 + for k, v in pairs(t) do + count_table_appearances(k, appearances) + count_table_appearances(v, appearances) + end + else + appearances[t] = ((appearances[t] or 0) + 1) + end + end + return appearances + end + local function save_table(t, seen) + local seen0 = (seen or {len = 0}) + local id = (seen0.len + 1) + if not seen0[t] then + seen0[t] = id + seen0.len = id + end + return seen0 + end + local function detect_cycle(t, seen) + local seen0 = (seen or {}) + seen0[t] = true + for k, v in pairs(t) do + if ((type(k) == "table") and (seen0[k] or detect_cycle(k, seen0))) then + return true + end + if ((type(v) == "table") and (seen0[v] or detect_cycle(v, seen0))) then + return true + end + end + return nil + end + local function visible_cycle_3f(t, options) + return (options["detect-cycles?"] and detect_cycle(t) and save_table(t, options.seen) and (1 < (options.appearances[t] or 0))) + end + local function table_indent(t, indent, id) + local opener_length = nil + if id then + opener_length = (#tostring(id) + 2) + else + opener_length = 1 + end + return (indent + opener_length) + end + local pp = {} + local function concat_table_lines(elements, options, multiline_3f, indent, table_type, prefix) + local indent_str = ("\n" .. string.rep(" ", indent)) + local open = nil + local function _2_() + if ("seq" == table_type) then + return "[" + else + return "{" + end + end + open = ((prefix or "") .. _2_()) + local close = nil + if ("seq" == table_type) then + close = "]" + else + close = "}" + end + local oneline = (open .. table.concat(elements, " ") .. close) + local _4_ + if (table_type == "seq") then + _4_ = options["sequential-length"] + else + _4_ = options["associative-length"] + end + if (not options["one-line?"] and (multiline_3f or (#elements > _4_) or ((indent + #oneline) > options["line-length"]))) then + return (open .. table.concat(elements, indent_str) .. close) + else + return oneline + end + end + local function pp_associative(t, kv, options, indent, key_3f) + local multiline_3f = false + local id = options.seen[t] + if (options.level >= options.depth) then + return "{...}" + elseif (id and options["detect-cycles?"]) then + return ("@" .. id .. "{...}") + else + local visible_cycle_3f0 = visible_cycle_3f(t, options) + local id0 = (visible_cycle_3f0 and options.seen[t]) + local indent0 = table_indent(t, indent, id0) + local slength = nil + local function _3_() + local _2_0 = rawget(_G, "utf8") + if _2_0 then + return _2_0.len + else + return _2_0 + end + end + local function _4_(_241) + return #_241 + end + slength = ((options["utf8?"] and _3_()) or _4_) + local prefix = nil + if visible_cycle_3f0 then + prefix = ("@" .. id0) + else + prefix = "" + end + local elements = nil + do + local tbl_0_ = {} + for _, _6_0 in pairs(kv) do + local _7_ = _6_0 + local k = _7_[1] + local v = _7_[2] + local _8_ + do + local k0 = pp.pp(k, options, (indent0 + 1), true) + local v0 = pp.pp(v, options, (indent0 + slength(k0) + 1)) + multiline_3f = (multiline_3f or k0:find("\n") or v0:find("\n")) + _8_ = (k0 .. " " .. v0) + end + tbl_0_[(#tbl_0_ + 1)] = _8_ + end + elements = tbl_0_ + end + return concat_table_lines(elements, options, multiline_3f, indent0, "table", prefix) + end + end + local function pp_sequence(t, kv, options, indent) + local multiline_3f = false + local id = options.seen[t] + if (options.level >= options.depth) then + return "[...]" + elseif (id and options["detect-cycles?"]) then + return ("@" .. id .. "[...]") + else + local visible_cycle_3f0 = visible_cycle_3f(t, options) + local id0 = (visible_cycle_3f0 and options.seen[t]) + local indent0 = table_indent(t, indent, id0) + local prefix = nil + if visible_cycle_3f0 then + prefix = ("@" .. id0) + else + prefix = "" + end + local elements = nil + do + local tbl_0_ = {} + for _, _3_0 in pairs(kv) do + local _4_ = _3_0 + local _0 = _4_[1] + local v = _4_[2] + local _5_ + do + local v0 = pp.pp(v, options, indent0) + multiline_3f = (multiline_3f or v0:find("\n")) + _5_ = v0 + end + tbl_0_[(#tbl_0_ + 1)] = _5_ + end + elements = tbl_0_ + end + return concat_table_lines(elements, options, multiline_3f, indent0, "seq", prefix) + end + end + local function concat_lines(lines, options, indent, force_multi_line_3f) + if (#lines == 0) then + if options["empty-as-sequence?"] then + return "[]" + else + return "{}" + end + else + local oneline = nil + local _2_ + do + local tbl_0_ = {} + for _, line in ipairs(lines) do + tbl_0_[(#tbl_0_ + 1)] = line:gsub("^%s+", "") + end + _2_ = tbl_0_ + end + oneline = table.concat(_2_, " ") + if (not options["one-line?"] and (force_multi_line_3f or oneline:find("\n") or ((indent + #oneline) > options["line-length"]))) then + return table.concat(lines, ("\n" .. string.rep(" ", indent))) + else + return oneline + end + end + end + local function pp_metamethod(t, metamethod, options, indent) + if (options.level >= options.depth) then + if options["empty-as-sequence?"] then + return "[...]" + else + return "{...}" + end + else + local _ = nil + local function _2_(_241) + return visible_cycle_3f(_241, options) + end + options["visible-cycle?"] = _2_ + _ = nil + local lines, force_multi_line_3f = metamethod(t, pp.pp, options, indent) + options["visible-cycle?"] = nil + local _3_0 = type(lines) + if (_3_0 == "string") then + return lines + elseif (_3_0 == "table") then + return concat_lines(lines, options, indent, force_multi_line_3f) + else + local _0 = _3_0 + return error("Error: __fennelview metamethod must return a table of lines") + end + end + end + local function pp_table(x, options, indent) + options.level = (options.level + 1) + local x0 = nil + do + local _2_0 = nil + if options["metamethod?"] then + local _3_0 = x + if _3_0 then + local _4_0 = getmetatable(_3_0) + if _4_0 then + _2_0 = _4_0.__fennelview + else + _2_0 = _4_0 + end + else + _2_0 = _3_0 + end + else + _2_0 = nil + end + if (nil ~= _2_0) then + local metamethod = _2_0 + x0 = pp_metamethod(x, metamethod, options, indent) + else + local _ = _2_0 + local _4_0, _5_0 = table_kv_pairs(x) + if (true and (_5_0 == "empty")) then + local _0 = _4_0 + if options["empty-as-sequence?"] then + x0 = "[]" + else + x0 = "{}" + end + elseif ((nil ~= _4_0) and (_5_0 == "table")) then + local kv = _4_0 + x0 = pp_associative(x, kv, options, indent) + elseif ((nil ~= _4_0) and (_5_0 == "seq")) then + local kv = _4_0 + x0 = pp_sequence(x, kv, options, indent) + else + x0 = nil + end + end + end + options.level = (options.level - 1) + return x0 + end + local function number__3estring(n) + local _2_0, _3_0, _4_0 = math.modf(n) + if ((nil ~= _2_0) and (_3_0 == 0)) then + local int = _2_0 + return tostring(int) + else + local _5_ + do + local frac = _3_0 + _5_ = (((_2_0 == 0) and (nil ~= _3_0)) and (frac < 0)) + end + if _5_ then + local frac = _3_0 + return ("-0." .. tostring(frac):gsub("^-?0.", "")) + elseif ((nil ~= _2_0) and (nil ~= _3_0)) then + local int = _2_0 + local frac = _3_0 + return (int .. "." .. tostring(frac):gsub("^-?0.", "")) + end + end + end + local function colon_string_3f(s) + return s:find("^[-%w?\\^_!$%&*+./@:|<=>]+$") + end + local function make_options(t, options) + local defaults = {["associative-length"] = 4, ["detect-cycles?"] = true, ["empty-as-sequence?"] = false, ["line-length"] = 80, ["metamethod?"] = true, ["one-line?"] = false, ["sequential-length"] = 10, ["utf8?"] = true, depth = 128} + local overrides = {appearances = count_table_appearances(t, {}), level = 0, seen = {len = 0}} + for k, v in pairs((options or {})) do + defaults[k] = v + end + for k, v in pairs(overrides) do + defaults[k] = v + end + return defaults + end + pp.pp = function(x, options, indent, key_3f) + local indent0 = (indent or 0) + local options0 = (options or make_options(x)) + local tv = type(x) + local function _3_() + local _2_0 = getmetatable(x) + if _2_0 then + return _2_0.__fennelview + else + return _2_0 + end + end + if ((tv == "table") or ((tv == "userdata") and _3_())) then + return pp_table(x, options0, indent0) + elseif (tv == "number") then + return number__3estring(x) + elseif ((tv == "string") and key_3f and colon_string_3f(x)) then + return (":" .. x) + elseif (tv == "string") then + return string.format("%q", x) + elseif ((tv == "boolean") or (tv == "nil")) then + return tostring(x) + else + return ("#<" .. tostring(x) .. ">") + end + end + local function view(x, options) + return pp.pp(x, make_options(x, options), 0) + end + return view +end +package.preload["fennel.specials"] = package.preload["fennel.specials"] or function(...) + local utils = require("fennel.utils") + local view = require("fennel.view") + local parser = require("fennel.parser") + local compiler = require("fennel.compiler") + local unpack = (table.unpack or _G.unpack) + local SPECIALS = compiler.scopes.global.specials + local function wrap_env(env) + local function _0_(_, key) + if (type(key) == "string") then + return env[compiler["global-unmangling"](key)] + else + return env[key] + end + end + local function _1_(_, key, value) + if (type(key) == "string") then + env[compiler["global-unmangling"](key)] = value + return nil + else + env[key] = value + return nil + end + end + local function _2_() + local function putenv(k, v) + local _3_ + if (type(k) == "string") then + _3_ = compiler["global-unmangling"](k) + else + _3_ = k + end + return _3_, v + end + return next, utils.kvmap(env, putenv), nil + end + return setmetatable({}, {__index = _0_, __newindex = _1_, __pairs = _2_}) + end + local function current_global_names(env) + return utils.kvmap((env or _G), compiler["global-unmangling"]) + end + local function load_code(code, environment, filename) + local environment0 = (environment or rawget(_G, "_ENV") or _G) + if (rawget(_G, "setfenv") and rawget(_G, "loadstring")) then + local f = assert(_G.loadstring(code, filename)) + _G.setfenv(f, environment0) + return f + else + return assert(load(code, filename, "t", environment0)) + end + end + local function doc_2a(tgt, name) + if not tgt then + return (name .. " not found") + else + local docstring = (((compiler.metadata):get(tgt, "fnl/docstring") or "#")):gsub("\n$", ""):gsub("\n", "\n ") + local mt = getmetatable(tgt) + if ((type(tgt) == "function") or ((type(mt) == "table") and (type(mt.__call) == "function"))) then + local arglist = table.concat(((compiler.metadata):get(tgt, "fnl/arglist") or {"#"}), " ") + local _0_ + if (#arglist > 0) then + _0_ = " " + else + _0_ = "" + end + return string.format("(%s%s%s)\n %s", name, _0_, arglist, docstring) + else + return string.format("%s\n %s", name, docstring) + end + end + end + local function doc_special(name, arglist, docstring) + compiler.metadata[SPECIALS[name]] = {["fnl/arglist"] = arglist, ["fnl/docstring"] = docstring} + return nil + end + local function compile_do(ast, scope, parent, start) + local start0 = (start or 2) + local len = #ast + local sub_scope = compiler["make-scope"](scope) + for i = start0, len do + compiler.compile1(ast[i], sub_scope, parent, {nval = 0}) + end + return nil + end + SPECIALS["do"] = function(ast, scope, parent, opts, start, chunk, sub_scope, pre_syms) + local start0 = (start or 2) + local sub_scope0 = (sub_scope or compiler["make-scope"](scope)) + local chunk0 = (chunk or {}) + local len = #ast + local retexprs = {returned = true} + local function compile_body(outer_target, outer_tail, outer_retexprs) + if (len < start0) then + compiler.compile1(nil, sub_scope0, chunk0, {tail = outer_tail, target = outer_target}) + else + for i = start0, len do + local subopts = {nval = (((i ~= len) and 0) or opts.nval), tail = (((i == len) and outer_tail) or nil), target = (((i == len) and outer_target) or nil)} + local _ = utils["propagate-options"](opts, subopts) + local subexprs = compiler.compile1(ast[i], sub_scope0, chunk0, subopts) + if (i ~= len) then + compiler["keep-side-effects"](subexprs, parent, nil, ast[i]) + end + end + end + compiler.emit(parent, chunk0, ast) + compiler.emit(parent, "end", ast) + return (outer_retexprs or retexprs) + end + if (opts.target or (opts.nval == 0) or opts.tail) then + compiler.emit(parent, "do", ast) + return compile_body(opts.target, opts.tail) + elseif opts.nval then + local syms = {} + for i = 1, opts.nval do + local s = ((pre_syms and pre_syms[i]) or compiler.gensym(scope)) + syms[i] = s + retexprs[i] = utils.expr(s, "sym") + end + local outer_target = table.concat(syms, ", ") + compiler.emit(parent, string.format("local %s", outer_target), ast) + compiler.emit(parent, "do", ast) + return compile_body(outer_target, opts.tail) + else + local fname = compiler.gensym(scope) + local fargs = nil + if scope.vararg then + fargs = "..." + else + fargs = "" + end + compiler.emit(parent, string.format("local function %s(%s)", fname, fargs), ast) + utils.hook("do", ast, sub_scope0) + return compile_body(nil, true, utils.expr((fname .. "(" .. fargs .. ")"), "statement")) + end + end + doc_special("do", {"..."}, "Evaluate multiple forms; return last value.") + SPECIALS.values = function(ast, scope, parent) + local len = #ast + local exprs = {} + for i = 2, len do + local subexprs = compiler.compile1(ast[i], scope, parent, {nval = ((i ~= len) and 1)}) + table.insert(exprs, subexprs[1]) + if (i == len) then + for j = 2, #subexprs do + table.insert(exprs, subexprs[j]) + end + end + end + return exprs + end + doc_special("values", {"..."}, "Return multiple values from a function. Must be in tail position.") + local function deep_tostring(x, key_3f) + local elems = {} + if utils["sequence?"](x) then + local _0_ + do + local tbl_0_ = {} + for _, v in ipairs(x) do + tbl_0_[(#tbl_0_ + 1)] = deep_tostring(v) + end + _0_ = tbl_0_ + end + return ("[" .. table.concat(_0_, " ") .. "]") + elseif utils["table?"](x) then + local _0_ + do + local tbl_0_ = {} + for k, v in pairs(x) do + tbl_0_[(#tbl_0_ + 1)] = (deep_tostring(k, true) .. " " .. deep_tostring(v)) + end + _0_ = tbl_0_ + end + return ("{" .. table.concat(_0_, " ") .. "}") + elseif (key_3f and (type(x) == "string") and x:find("^[-%w?\\^_!$%&*+./@:|<=>]+$")) then + return (":" .. x) + elseif (type(x) == "string") then + return string.format("%q", x):gsub("\\\"", "\\\\\""):gsub("\"", "\\\"") + else + return tostring(x) + end + end + local function set_fn_metadata(arg_list, docstring, parent, fn_name) + if utils.root.options.useMetadata then + local args = nil + local function _0_(v) + return ("\"%s\""):format(deep_tostring(v)) + end + args = utils.map(arg_list, _0_) + local meta_fields = {"\"fnl/arglist\"", ("{" .. table.concat(args, ", ") .. "}")} + if docstring then + table.insert(meta_fields, "\"fnl/docstring\"") + table.insert(meta_fields, ("\"" .. docstring:gsub("%s+$", ""):gsub("\\", "\\\\"):gsub("\n", "\\n"):gsub("\"", "\\\"") .. "\"")) + end + local meta_str = ("require(\"%s\").metadata"):format((utils.root.options.moduleName or "fennel")) + return compiler.emit(parent, ("pcall(function() %s:setall(%s, %s) end)"):format(meta_str, fn_name, table.concat(meta_fields, ", "))) + end + end + local function get_fn_name(ast, scope, fn_name, multi) + if (fn_name and (fn_name[1] ~= "nil")) then + local _0_ + if not multi then + _0_ = compiler["declare-local"](fn_name, {}, scope, ast) + else + _0_ = compiler["symbol-to-expression"](fn_name, scope)[1] + end + return _0_, not multi, 3 + else + return compiler.gensym(scope), true, 2 + end + end + SPECIALS.fn = function(ast, scope, parent) + local f_scope = nil + do + local _0_0 = compiler["make-scope"](scope) + _0_0["vararg"] = false + f_scope = _0_0 + end + local f_chunk = {} + local fn_sym = utils["sym?"](ast[2]) + local multi = (fn_sym and utils["multi-sym?"](fn_sym[1])) + local fn_name, local_fn_3f, index = get_fn_name(ast, scope, fn_sym, multi) + local arg_list = compiler.assert(utils["table?"](ast[index]), "expected parameters table", ast) + compiler.assert((not multi or not multi["multi-sym-method-call"]), ("unexpected multi symbol " .. tostring(fn_name)), fn_sym) + local function get_arg_name(arg) + if utils["varg?"](arg) then + compiler.assert((arg == arg_list[#arg_list]), "expected vararg as last parameter", ast) + f_scope.vararg = true + return "..." + elseif (utils["sym?"](arg) and (utils.deref(arg) ~= "nil") and not utils["multi-sym?"](utils.deref(arg))) then + return compiler["declare-local"](arg, {}, f_scope, ast) + elseif utils["table?"](arg) then + local raw = utils.sym(compiler.gensym(scope)) + local declared = compiler["declare-local"](raw, {}, f_scope, ast) + compiler.destructure(arg, raw, ast, f_scope, f_chunk, {declaration = true, nomulti = true, symtype = "arg"}) + return declared + else + return compiler.assert(false, ("expected symbol for function parameter: %s"):format(tostring(arg)), ast[2]) + end + end + do + local arg_name_list = utils.map(arg_list, get_arg_name) + local index0, docstring = nil, nil + if ((type(ast[(index + 1)]) == "string") and ((index + 1) < #ast)) then + index0, docstring = (index + 1), ast[(index + 1)] + else + index0, docstring = index, nil + end + for i = (index0 + 1), #ast do + compiler.compile1(ast[i], f_scope, f_chunk, {nval = (((i ~= #ast) and 0) or nil), tail = (i == #ast)}) + end + local _2_ + if local_fn_3f then + _2_ = "local function %s(%s)" + else + _2_ = "%s = function(%s)" + end + compiler.emit(parent, string.format(_2_, fn_name, table.concat(arg_name_list, ", ")), ast) + compiler.emit(parent, f_chunk, ast) + compiler.emit(parent, "end", ast) + set_fn_metadata(arg_list, docstring, parent, fn_name) + end + utils.hook("fn", ast, f_scope) + return utils.expr(fn_name, "sym") + end + doc_special("fn", {"name?", "args", "docstring?", "..."}, "Function syntax. May optionally include a name and docstring.\nIf a name is provided, the function will be bound in the current scope.\nWhen called with the wrong number of args, excess args will be discarded\nand lacking args will be nil, use lambda for arity-checked functions.") + SPECIALS.lua = function(ast, _, parent) + compiler.assert(((#ast == 2) or (#ast == 3)), "expected 1 or 2 arguments", ast) + if (ast[2] ~= nil) then + table.insert(parent, {ast = ast, leaf = tostring(ast[2])}) + end + if (ast[3] ~= nil) then + return tostring(ast[3]) + end + end + SPECIALS.doc = function(ast, scope, parent) + assert(utils.root.options.useMetadata, "can't look up doc with metadata disabled.") + compiler.assert((#ast == 2), "expected one argument", ast) + local target = utils.deref(ast[2]) + local special_or_macro = (scope.specials[target] or scope.macros[target]) + if special_or_macro then + return ("print(%q)"):format(doc_2a(special_or_macro, target)) + else + local value = tostring(compiler.compile1(ast[2], scope, parent, {nval = 1})[1]) + return ("print(require('%s').doc(%s, '%s'))"):format((utils.root.options.moduleName or "fennel"), value, tostring(ast[2])) + end + end + doc_special("doc", {"x"}, "Print the docstring and arglist for a function, macro, or special form.") + local function dot(ast, scope, parent) + compiler.assert((1 < #ast), "expected table argument", ast) + local len = #ast + local _0_ = compiler.compile1(ast[2], scope, parent, {nval = 1}) + local lhs = _0_[1] + if (len == 2) then + return tostring(lhs) + else + local indices = {} + for i = 3, len do + local index = ast[i] + if ((type(index) == "string") and utils["valid-lua-identifier?"](index)) then + table.insert(indices, ("." .. index)) + else + local _1_ = compiler.compile1(index, scope, parent, {nval = 1}) + local index0 = _1_[1] + table.insert(indices, ("[" .. tostring(index0) .. "]")) + end + end + if (tostring(lhs):find("[{\"0-9]") or ("nil" == tostring(lhs))) then + return ("(" .. tostring(lhs) .. ")" .. table.concat(indices)) + else + return (tostring(lhs) .. table.concat(indices)) + end + end + end + SPECIALS["."] = dot + doc_special(".", {"tbl", "key1", "..."}, "Look up key1 in tbl table. If more args are provided, do a nested lookup.") + SPECIALS.global = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {forceglobal = true, nomulti = true, symtype = "global"}) + return nil + end + doc_special("global", {"name", "val"}, "Set name as a global with val.") + SPECIALS.set = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {noundef = true, symtype = "set"}) + return nil + end + doc_special("set", {"name", "val"}, "Set a local variable to a new value. Only works on locals using var.") + local function set_forcibly_21_2a(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {forceset = true, symtype = "set"}) + return nil + end + SPECIALS["set-forcibly!"] = set_forcibly_21_2a + local function local_2a(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {declaration = true, nomulti = true, symtype = "local"}) + return nil + end + SPECIALS["local"] = local_2a + doc_special("local", {"name", "val"}, "Introduce new top-level immutable local.") + SPECIALS.var = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {declaration = true, isvar = true, nomulti = true, symtype = "var"}) + return nil + end + doc_special("var", {"name", "val"}, "Introduce new mutable local.") + SPECIALS.let = function(ast, scope, parent, opts) + local bindings = ast[2] + local pre_syms = {} + compiler.assert((utils["list?"](bindings) or utils["table?"](bindings)), "expected binding table", ast) + compiler.assert(((#bindings % 2) == 0), "expected even number of name/value bindings", ast[2]) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + for _ = 1, (opts.nval or 0) do + table.insert(pre_syms, compiler.gensym(scope)) + end + local sub_scope = compiler["make-scope"](scope) + local sub_chunk = {} + for i = 1, #bindings, 2 do + compiler.destructure(bindings[i], bindings[(i + 1)], ast, sub_scope, sub_chunk, {declaration = true, nomulti = true, symtype = "let"}) + end + return SPECIALS["do"](ast, scope, parent, opts, 3, sub_chunk, sub_scope, pre_syms) + end + doc_special("let", {"[name1 val1 ... nameN valN]", "..."}, "Introduces a new scope in which a given set of local bindings are used.") + SPECIALS.tset = function(ast, scope, parent) + compiler.assert((#ast > 3), "expected table, key, and value arguments", ast) + local root = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + local keys = {} + for i = 3, (#ast - 1) do + local _0_ = compiler.compile1(ast[i], scope, parent, {nval = 1}) + local key = _0_[1] + table.insert(keys, tostring(key)) + end + local value = compiler.compile1(ast[#ast], scope, parent, {nval = 1})[1] + local rootstr = tostring(root) + local fmtstr = nil + if rootstr:match("^{") then + fmtstr = "do end (%s)[%s] = %s" + else + fmtstr = "%s[%s] = %s" + end + return compiler.emit(parent, fmtstr:format(tostring(root), table.concat(keys, "]["), tostring(value)), ast) + end + doc_special("tset", {"tbl", "key1", "...", "keyN", "val"}, "Set the value of a table field. Can take additional keys to set\nnested values, but all parents must contain an existing table.") + local function calculate_target(scope, opts) + if not (opts.tail or opts.target or opts.nval) then + return "iife", true, nil + elseif (opts.nval and (opts.nval ~= 0) and not opts.target) then + local accum = {} + local target_exprs = {} + for i = 1, opts.nval do + local s = compiler.gensym(scope) + accum[i] = s + target_exprs[i] = utils.expr(s, "sym") + end + return "target", opts.tail, table.concat(accum, ", "), target_exprs + else + return "none", opts.tail, opts.target + end + end + local function if_2a(ast, scope, parent, opts) + local do_scope = compiler["make-scope"](scope) + local branches = {} + local wrapper, inner_tail, inner_target, target_exprs = calculate_target(scope, opts) + local body_opts = {nval = opts.nval, tail = inner_tail, target = inner_target} + local function compile_body(i) + local chunk = {} + local cscope = compiler["make-scope"](do_scope) + compiler["keep-side-effects"](compiler.compile1(ast[i], cscope, chunk, body_opts), chunk, nil, ast[i]) + return {chunk = chunk, scope = cscope} + end + for i = 2, (#ast - 1), 2 do + local condchunk = {} + local res = compiler.compile1(ast[i], do_scope, condchunk, {nval = 1}) + local cond = res[1] + local branch = compile_body((i + 1)) + branch.cond = cond + branch.condchunk = condchunk + branch.nested = ((i ~= 2) and (next(condchunk, nil) == nil)) + table.insert(branches, branch) + end + local has_else_3f = ((#ast > 3) and ((#ast % 2) == 0)) + local else_branch = (has_else_3f and compile_body(#ast)) + local s = compiler.gensym(scope) + local buffer = {} + local last_buffer = buffer + for i = 1, #branches do + local branch = branches[i] + local fstr = nil + if not branch.nested then + fstr = "if %s then" + else + fstr = "elseif %s then" + end + local cond = tostring(branch.cond) + local cond_line = nil + if ((cond == "true") and branch.nested and (i == #branches)) then + cond_line = "else" + else + cond_line = fstr:format(cond) + end + if branch.nested then + compiler.emit(last_buffer, branch.condchunk, ast) + else + for _, v in ipairs(branch.condchunk) do + compiler.emit(last_buffer, v, ast) + end + end + compiler.emit(last_buffer, cond_line, ast) + compiler.emit(last_buffer, branch.chunk, ast) + if (i == #branches) then + if has_else_3f then + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, else_branch.chunk, ast) + elseif (inner_target and (cond_line ~= "else")) then + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, ("%s = nil"):format(inner_target), ast) + end + compiler.emit(last_buffer, "end", ast) + elseif not branches[(i + 1)].nested then + local next_buffer = {} + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, next_buffer, ast) + compiler.emit(last_buffer, "end", ast) + last_buffer = next_buffer + end + end + if (wrapper == "iife") then + local iifeargs = ((scope.vararg and "...") or "") + compiler.emit(parent, ("local function %s(%s)"):format(tostring(s), iifeargs), ast) + compiler.emit(parent, buffer, ast) + compiler.emit(parent, "end", ast) + return utils.expr(("%s(%s)"):format(tostring(s), iifeargs), "statement") + elseif (wrapper == "none") then + for i = 1, #buffer do + compiler.emit(parent, buffer[i], ast) + end + return {returned = true} + else + compiler.emit(parent, ("local %s"):format(inner_target), ast) + for i = 1, #buffer do + compiler.emit(parent, buffer[i], ast) + end + return target_exprs + end + end + SPECIALS["if"] = if_2a + doc_special("if", {"cond1", "body1", "...", "condN", "bodyN"}, "Conditional form.\nTakes any number of condition/body pairs and evaluates the first body where\nthe condition evaluates to truthy. Similar to cond in other lisps.") + SPECIALS.each = function(ast, scope, parent) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + local binding = compiler.assert(utils["table?"](ast[2]), "expected binding table", ast) + local iter = table.remove(binding, #binding) + local destructures = {} + local new_manglings = {} + local sub_scope = compiler["make-scope"](scope) + local function destructure_binding(v) + if utils["sym?"](v) then + return compiler["declare-local"](v, {}, sub_scope, ast, new_manglings) + else + local raw = utils.sym(compiler.gensym(sub_scope)) + destructures[raw] = v + return compiler["declare-local"](raw, {}, sub_scope, ast) + end + end + local bind_vars = utils.map(binding, destructure_binding) + local vals = compiler.compile1(iter, sub_scope, parent) + local val_names = utils.map(vals, tostring) + local chunk = {} + compiler.emit(parent, ("for %s in %s do"):format(table.concat(bind_vars, ", "), table.concat(val_names, ", ")), ast) + for raw, args in utils.stablepairs(destructures) do + compiler.destructure(args, raw, ast, sub_scope, chunk, {declaration = true, nomulti = true, symtype = "each"}) + end + compiler["apply-manglings"](sub_scope, new_manglings, ast) + compile_do(ast, sub_scope, chunk, 3) + compiler.emit(parent, chunk, ast) + return compiler.emit(parent, "end", ast) + end + doc_special("each", {"[key value (iterator)]", "..."}, "Runs the body once for each set of values provided by the given iterator.\nMost commonly used with ipairs for sequential tables or pairs for undefined\norder, but can be used with any iterator.") + local function while_2a(ast, scope, parent) + local len1 = #parent + local condition = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + local len2 = #parent + local sub_chunk = {} + if (len1 ~= len2) then + for i = (len1 + 1), len2 do + table.insert(sub_chunk, parent[i]) + parent[i] = nil + end + compiler.emit(parent, "while true do", ast) + compiler.emit(sub_chunk, ("if not %s then break end"):format(condition[1]), ast) + else + compiler.emit(parent, ("while " .. tostring(condition) .. " do"), ast) + end + compile_do(ast, compiler["make-scope"](scope), sub_chunk, 3) + compiler.emit(parent, sub_chunk, ast) + return compiler.emit(parent, "end", ast) + end + SPECIALS["while"] = while_2a + doc_special("while", {"condition", "..."}, "The classic while loop. Evaluates body until a condition is non-truthy.") + local function for_2a(ast, scope, parent) + local ranges = compiler.assert(utils["table?"](ast[2]), "expected binding table", ast) + local binding_sym = table.remove(ast[2], 1) + local sub_scope = compiler["make-scope"](scope) + local range_args = {} + local chunk = {} + compiler.assert(utils["sym?"](binding_sym), ("unable to bind %s %s"):format(type(binding_sym), tostring(binding_sym)), ast[2]) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + for i = 1, math.min(#ranges, 3) do + range_args[i] = tostring(compiler.compile1(ranges[i], sub_scope, parent, {nval = 1})[1]) + end + compiler.emit(parent, ("for %s = %s do"):format(compiler["declare-local"](binding_sym, {}, sub_scope, ast), table.concat(range_args, ", ")), ast) + compile_do(ast, sub_scope, chunk, 3) + compiler.emit(parent, chunk, ast) + return compiler.emit(parent, "end", ast) + end + SPECIALS["for"] = for_2a + doc_special("for", {"[index start stop step?]", "..."}, "Numeric loop construct.\nEvaluates body once for each value between start and stop (inclusive).") + local function native_method_call(ast, _scope, _parent, target, args) + local _0_ = ast + local _ = _0_[1] + local _0 = _0_[2] + local method_string = _0_[3] + local call_string = nil + if ((target.type == "literal") or (target.type == "expression")) then + call_string = "(%s):%s(%s)" + else + call_string = "%s:%s(%s)" + end + return utils.expr(string.format(call_string, tostring(target), method_string, table.concat(args, ", ")), "statement") + end + local function nonnative_method_call(ast, scope, parent, target, args) + local method_string = tostring(compiler.compile1(ast[3], scope, parent, {nval = 1})[1]) + local args0 = {tostring(target), unpack(args)} + return utils.expr(string.format("%s[%s](%s)", tostring(target), method_string, table.concat(args0, ", ")), "statement") + end + local function double_eval_protected_method_call(ast, scope, parent, target, args) + local method_string = tostring(compiler.compile1(ast[3], scope, parent, {nval = 1})[1]) + local call = "(function(tgt, m, ...) return tgt[m](tgt, ...) end)(%s, %s)" + table.insert(args, 1, method_string) + return utils.expr(string.format(call, tostring(target), table.concat(args, ", ")), "statement") + end + local function method_call(ast, scope, parent) + compiler.assert((2 < #ast), "expected at least 2 arguments", ast) + local _0_ = compiler.compile1(ast[2], scope, parent, {nval = 1}) + local target = _0_[1] + local args = {} + for i = 4, #ast do + local subexprs = nil + local _1_ + if (i ~= #ast) then + _1_ = 1 + else + _1_ = nil + end + subexprs = compiler.compile1(ast[i], scope, parent, {nval = _1_}) + utils.map(subexprs, tostring, args) + end + if ((type(ast[3]) == "string") and utils["valid-lua-identifier?"](ast[3])) then + return native_method_call(ast, scope, parent, target, args) + elseif (target.type == "sym") then + return nonnative_method_call(ast, scope, parent, target, args) + else + return double_eval_protected_method_call(ast, scope, parent, target, args) + end + end + SPECIALS[":"] = method_call + doc_special(":", {"tbl", "method-name", "..."}, "Call the named method on tbl with the provided args.\nMethod name doesn't have to be known at compile-time; if it is, use\n(tbl:method-name ...) instead.") + SPECIALS.comment = function(ast, _, parent) + local els = {} + for i = 2, #ast do + local function _1_() + local _0_0 = tostring(ast[i]):gsub("\n", " ") + return _0_0 + end + table.insert(els, _1_()) + end + return compiler.emit(parent, ("-- " .. table.concat(els, " ")), ast) + end + doc_special("comment", {"..."}, "Comment which will be emitted in Lua output.") + local function hashfn_max_used(f_scope, i, max) + local max0 = nil + if f_scope.symmeta[("$" .. i)].used then + max0 = i + else + max0 = max + end + if (i < 9) then + return hashfn_max_used(f_scope, (i + 1), max0) + else + return max0 + end + end + SPECIALS.hashfn = function(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument", ast) + local f_scope = nil + do + local _0_0 = compiler["make-scope"](scope) + _0_0["vararg"] = false + _0_0["hashfn"] = true + f_scope = _0_0 + end + local f_chunk = {} + local name = compiler.gensym(scope) + local symbol = utils.sym(name) + local args = {} + compiler["declare-local"](symbol, {}, scope, ast) + for i = 1, 9 do + args[i] = compiler["declare-local"](utils.sym(("$" .. i)), {}, f_scope, ast) + end + local function walker(idx, node, parent_node) + if (utils["sym?"](node) and (utils.deref(node) == "$...")) then + parent_node[idx] = utils.varg() + f_scope.vararg = true + return nil + else + return (utils["list?"](node) or utils["table?"](node)) + end + end + utils["walk-tree"](ast[2], walker) + compiler.compile1(ast[2], f_scope, f_chunk, {tail = true}) + local max_used = hashfn_max_used(f_scope, 1, 0) + if f_scope.vararg then + compiler.assert((max_used == 0), "$ and $... in hashfn are mutually exclusive", ast) + end + local arg_str = nil + if f_scope.vararg then + arg_str = utils.deref(utils.varg()) + else + arg_str = table.concat(args, ", ", 1, max_used) + end + compiler.emit(parent, string.format("local function %s(%s)", name, arg_str), ast) + compiler.emit(parent, f_chunk, ast) + compiler.emit(parent, "end", ast) + return utils.expr(name, "sym") + end + doc_special("hashfn", {"..."}, "Function literal shorthand; args are either $... OR $1, $2, etc.") + local function define_arithmetic_special(name, zero_arity, unary_prefix, lua_name) + do + local padded_op = (" " .. (lua_name or name) .. " ") + local function _0_(ast, scope, parent) + local len = #ast + if (len == 1) then + compiler.assert((zero_arity ~= nil), "Expected more than 0 arguments", ast) + return utils.expr(zero_arity, "literal") + else + local operands = {} + for i = 2, len do + local subexprs = nil + local _1_ + if (i ~= len) then + _1_ = 1 + else + _1_ = nil + end + subexprs = compiler.compile1(ast[i], scope, parent, {nval = _1_}) + utils.map(subexprs, tostring, operands) + end + if (#operands == 1) then + if unary_prefix then + return ("(" .. unary_prefix .. padded_op .. operands[1] .. ")") + else + return operands[1] + end + else + return ("(" .. table.concat(operands, padded_op) .. ")") + end + end + end + SPECIALS[name] = _0_ + end + return doc_special(name, {"a", "b", "..."}, "Arithmetic operator; works the same as Lua but accepts more arguments.") + end + define_arithmetic_special("+", "0") + define_arithmetic_special("..", "''") + define_arithmetic_special("^") + define_arithmetic_special("-", nil, "") + define_arithmetic_special("*", "1") + define_arithmetic_special("%") + define_arithmetic_special("/", nil, "1") + define_arithmetic_special("//", nil, "1") + define_arithmetic_special("lshift", nil, "1", "<<") + define_arithmetic_special("rshift", nil, "1", ">>") + define_arithmetic_special("band", "0", "0", "&") + define_arithmetic_special("bor", "0", "0", "|") + define_arithmetic_special("bxor", "0", "0", "~") + doc_special("lshift", {"x", "n"}, "Bitwise logical left shift of x by n bits; only works in Lua 5.3+.") + doc_special("rshift", {"x", "n"}, "Bitwise logical right shift of x by n bits; only works in Lua 5.3+.") + doc_special("band", {"x1", "x2"}, "Bitwise AND of arguments; only works in Lua 5.3+.") + doc_special("bor", {"x1", "x2"}, "Bitwise OR of arguments; only works in Lua 5.3+.") + doc_special("bxor", {"x1", "x2"}, "Bitwise XOR of arguments; only works in Lua 5.3+.") + define_arithmetic_special("or", "false") + define_arithmetic_special("and", "true") + doc_special("and", {"a", "b", "..."}, "Boolean operator; works the same as Lua but accepts more arguments.") + doc_special("or", {"a", "b", "..."}, "Boolean operator; works the same as Lua but accepts more arguments.") + doc_special("..", {"a", "b", "..."}, "String concatenation operator; works the same as Lua but accepts more arguments.") + local function native_comparator(op, _0_0, scope, parent) + local _1_ = _0_0 + local _ = _1_[1] + local lhs_ast = _1_[2] + local rhs_ast = _1_[3] + local _2_ = compiler.compile1(lhs_ast, scope, parent, {nval = 1}) + local lhs = _2_[1] + local _3_ = compiler.compile1(rhs_ast, scope, parent, {nval = 1}) + local rhs = _3_[1] + return string.format("(%s %s %s)", tostring(lhs), op, tostring(rhs)) + end + local function double_eval_protected_comparator(op, chain_op, ast, scope, parent) + local arglist = {} + local comparisons = {} + local vals = {} + local chain = string.format(" %s ", (chain_op or "and")) + for i = 2, #ast do + table.insert(arglist, tostring(compiler.gensym(scope))) + table.insert(vals, tostring(compiler.compile1(ast[i], scope, parent, {nval = 1})[1])) + end + for i = 1, (#arglist - 1) do + table.insert(comparisons, string.format("(%s %s %s)", arglist[i], op, arglist[(i + 1)])) + end + return string.format("(function(%s) return %s end)(%s)", table.concat(arglist, ","), table.concat(comparisons, chain), table.concat(vals, ",")) + end + local function define_comparator_special(name, lua_op, chain_op) + do + local op = (lua_op or name) + local function opfn(ast, scope, parent) + compiler.assert((2 < #ast), "expected at least two arguments", ast) + if (3 == #ast) then + return native_comparator(op, ast, scope, parent) + else + return double_eval_protected_comparator(op, chain_op, ast, scope, parent) + end + end + SPECIALS[name] = opfn + end + return doc_special(name, {"a", "b", "..."}, "Comparison operator; works the same as Lua but accepts more arguments.") + end + define_comparator_special(">") + define_comparator_special("<") + define_comparator_special(">=") + define_comparator_special("<=") + define_comparator_special("=", "==") + define_comparator_special("not=", "~=", "or") + SPECIALS["~="] = SPECIALS["not="] + local function define_unary_special(op, realop) + local function opfn(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument", ast) + local tail = compiler.compile1(ast[2], scope, parent, {nval = 1}) + return ((realop or op) .. tostring(tail[1])) + end + SPECIALS[op] = opfn + return nil + end + define_unary_special("not", "not ") + doc_special("not", {"x"}, "Logical operator; works the same as Lua.") + define_unary_special("bnot", "~") + doc_special("bnot", {"x"}, "Bitwise negation; only works in Lua 5.3+.") + define_unary_special("length", "#") + doc_special("length", {"x"}, "Returns the length of a table or string.") + SPECIALS["#"] = SPECIALS.length + SPECIALS.quote = function(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument") + local runtime, this_scope = true, scope + while this_scope do + this_scope = this_scope.parent + if (this_scope == compiler.scopes.compiler) then + runtime = false + end + end + return compiler["do-quote"](ast[2], scope, parent, runtime) + end + doc_special("quote", {"x"}, "Quasiquote the following form. Only works in macro/compiler scope.") + local already_warned_3f = {} + local compile_env_warning = ("WARNING: Attempting to %s %s in compile" .. " scope.\nIn future versions of Fennel this will not" .. " be allowed without the\n--no-compiler-sandbox flag" .. " or passing a :compilerEnv globals table in options.\n") + local function compiler_env_warn(_, key) + local v = _G[key] + if (v and io and io.stderr and not already_warned_3f[key]) then + already_warned_3f[key] = true + do end (io.stderr):write(compile_env_warning:format("use global", key)) + end + return v + end + local safe_compiler_env = setmetatable({assert = assert, bit = rawget(_G, "bit"), error = error, getmetatable = getmetatable, ipairs = ipairs, math = math, next = next, pairs = pairs, pcall = pcall, print = print, rawequal = rawequal, rawget = rawget, rawlen = rawget(_G, "rawlen"), rawset = rawset, select = select, setmetatable = setmetatable, string = string, table = table, tonumber = tonumber, tostring = tostring, type = type, xpcall = xpcall}, {__index = compiler_env_warn}) + local function make_compiler_env(ast, scope, parent) + local function _1_() + return compiler.scopes.macro + end + local function _2_(symbol) + compiler.assert(compiler.scopes.macro, "must call from macro", ast) + return compiler.scopes.macro.manglings[tostring(symbol)] + end + local function _3_(base) + return utils.sym(compiler.gensym((compiler.scopes.macro or scope), base)) + end + local function _4_(form) + compiler.assert(compiler.scopes.macro, "must call from macro", ast) + return compiler.macroexpand(form, compiler.scopes.macro) + end + local _6_ + do + local _5_0 = utils.root.options + if ((type(_5_0) == "table") and (nil ~= _5_0.compilerEnv)) then + local compilerEnv = _5_0.compilerEnv + _6_ = compilerEnv + elseif ((type(_5_0) == "table") and (nil ~= _5_0["compiler-env"])) then + local compiler_env = _5_0["compiler-env"] + _6_ = compiler_env + else + local _ = _5_0 + _6_ = safe_compiler_env + end + end + return setmetatable({["assert-compile"] = compiler.assert, ["get-scope"] = _1_, ["in-scope?"] = _2_, ["list?"] = utils["list?"], ["multi-sym?"] = utils["multi-sym?"], ["sequence?"] = utils["sequence?"], ["sym?"] = utils["sym?"], ["table?"] = utils["table?"], ["varg?"] = utils["varg?"], _AST = ast, _CHUNK = parent, _IS_COMPILER = true, _SCOPE = scope, _SPECIALS = compiler.scopes.global.specials, _VARARG = utils.varg(), gensym = _3_, list = utils.list, macroexpand = _4_, sequence = utils.sequence, sym = utils.sym, unpack = unpack, view = view}, {__index = _6_}) + end + local cfg = string.gmatch(package.config, "([^\n]+)") + local dirsep, pathsep, pathmark = (cfg() or "/"), (cfg() or ";"), (cfg() or "?") + local pkg_config = {dirsep = dirsep, pathmark = pathmark, pathsep = pathsep} + local function escapepat(str) + return string.gsub(str, "[^%w]", "%%%1") + end + local function search_module(modulename, pathstring) + local pathsepesc = escapepat(pkg_config.pathsep) + local pattern = ("([^%s]*)%s"):format(pathsepesc, pathsepesc) + local no_dot_module = modulename:gsub("%.", pkg_config.dirsep) + local fullpath = ((pathstring or utils["fennel-module"].path) .. pkg_config.pathsep) + local function try_path(path) + local filename = path:gsub(escapepat(pkg_config.pathmark), no_dot_module) + local filename2 = path:gsub(escapepat(pkg_config.pathmark), modulename) + local _1_0 = (io.open(filename) or io.open(filename2)) + if (nil ~= _1_0) then + local file = _1_0 + file:close() + return filename + end + end + local function find_in_path(start) + local _1_0 = fullpath:match(pattern, start) + if (nil ~= _1_0) then + local path = _1_0 + return (try_path(path) or find_in_path((start + #path + 1))) + end + end + return find_in_path(1) + end + local function make_searcher(options) + local function _1_(module_name) + local opts = utils.copy(utils.root.options) + for k, v in pairs((options or {})) do + opts[k] = v + end + opts["module-name"] = module_name + local _2_0 = search_module(module_name) + if (nil ~= _2_0) then + local filename = _2_0 + local function _3_(...) + return utils["fennel-module"].dofile(filename, opts, ...) + end + return _3_, filename + end + end + return _1_ + end + local function macro_globals(env, globals) + local allowed = current_global_names(env) + for _, k in pairs((globals or {})) do + table.insert(allowed, k) + end + return allowed + end + local function compiler_env_domodule(modname, env, _3fast) + local filename = compiler.assert(search_module(modname), (modname .. " module not found."), _3fast) + local globals = macro_globals(env, current_global_names()) + return utils["fennel-module"].dofile(filename, {allowedGlobals = globals, env = env, scope = compiler.scopes.compiler, useMetadata = utils.root.options.useMetadata}, modname, filename) + end + local macro_loaded = {} + local function metadata_only_fennel(modname) + if ((modname == "fennel.macros") or (package and package.loaded and ("table" == type(package.loaded[modname])) and (package.loaded[modname].metadata == compiler.metadata))) then + return {metadata = compiler.metadata} + end + end + safe_compiler_env.require = function(modname) + local function _1_() + local mod = compiler_env_domodule(modname, safe_compiler_env) + macro_loaded[modname] = mod + return mod + end + return (macro_loaded[modname] or metadata_only_fennel(modname) or _1_()) + end + local function add_macros(macros_2a, ast, scope) + compiler.assert(utils["table?"](macros_2a), "expected macros to be table", ast) + for k, v in pairs(macros_2a) do + compiler.assert((type(v) == "function"), "expected each macro to be function", ast) + scope.macros[k] = v + end + return nil + end + SPECIALS["require-macros"] = function(ast, scope, parent, real_ast) + compiler.assert((#ast == 2), "Expected one module name argument", (real_ast or ast)) + local filename = (ast[2].filename or ast.filename) + local modname_code = compiler.compile(ast[2]) + local modname = load_code(modname_code, nil, filename)(utils.root.options["module-name"], filename) + compiler.assert((type(modname) == "string"), "module name must compile to string", (real_ast or ast)) + if not macro_loaded[modname] then + local env = make_compiler_env(ast, scope, parent) + macro_loaded[modname] = compiler_env_domodule(modname, env, ast) + end + return add_macros(macro_loaded[modname], ast, scope, parent) + end + doc_special("require-macros", {"macro-module-name"}, "Load given module and use its contents as macro definitions in current scope.\nMacro module should return a table of macro functions with string keys.\nConsider using import-macros instead as it is more flexible.") + local function emit_included_fennel(src, path, opts, sub_chunk) + local subscope = compiler["make-scope"](utils.root.scope.parent) + local forms = {} + if utils.root.options.requireAsInclude then + subscope.specials.require = compiler["require-include"] + end + for _, val in parser.parser(parser["string-stream"](src), path) do + table.insert(forms, val) + end + for i = 1, #forms do + local subopts = nil + if (i == #forms) then + subopts = {tail = true} + else + subopts = {nval = 0} + end + utils["propagate-options"](opts, subopts) + compiler.compile1(forms[i], subscope, sub_chunk, subopts) + end + return nil + end + local function include_path(ast, opts, path, mod, fennel_3f) + utils.root.scope.includes[mod] = "fnl/loading" + local src = nil + do + local f = assert(io.open(path)) + local function close_handlers_0_(ok_0_, ...) + f:close() + if ok_0_ then + return ... + else + return error(..., 0) + end + end + local function _1_() + return f:read("*all"):gsub("[\13\n]*$", "") + end + src = close_handlers_0_(xpcall(_1_, (package.loaded.fennel or debug).traceback)) + end + local ret = utils.expr(("require(\"" .. mod .. "\")"), "statement") + local target = ("package.preload[%q]"):format(mod) + local preload_str = (target .. " = " .. target .. " or function(...)") + local temp_chunk, sub_chunk = {}, {} + compiler.emit(temp_chunk, preload_str, ast) + compiler.emit(temp_chunk, sub_chunk) + compiler.emit(temp_chunk, "end", ast) + for i, v in ipairs(temp_chunk) do + table.insert(utils.root.chunk, i, v) + end + if fennel_3f then + emit_included_fennel(src, path, opts, sub_chunk) + else + compiler.emit(sub_chunk, src, ast) + end + utils.root.scope.includes[mod] = ret + return ret + end + local function include_circular_fallback(mod, modexpr, fallback, ast) + if (utils.root.scope.includes[mod] == "fnl/loading") then + compiler.assert(fallback, "circular include detected", ast) + return fallback(modexpr) + end + end + SPECIALS.include = function(ast, scope, parent, opts) + compiler.assert((#ast == 2), "expected one argument", ast) + local modexpr = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + if ((modexpr.type ~= "literal") or ((modexpr[1]):byte() ~= 34)) then + if opts.fallback then + return opts.fallback(modexpr) + else + return compiler.assert(false, "module name must be string literal", ast) + end + else + local mod = load_code(("return " .. modexpr[1]))() + local function _2_() + local _1_0 = search_module(mod) + if (nil ~= _1_0) then + local fennel_path = _1_0 + return include_path(ast, opts, fennel_path, mod, true) + else + local _ = _1_0 + local lua_path = search_module(mod, package.path) + if lua_path then + return include_path(ast, opts, lua_path, mod, false) + elseif opts.fallback then + return opts.fallback(modexpr) + else + return compiler.assert(false, ("module not found " .. mod), ast) + end + end + end + return (include_circular_fallback(mod, modexpr, opts.fallback, ast) or utils.root.scope.includes[mod] or _2_()) + end + end + doc_special("include", {"module-name-literal"}, "Like require but load the target module during compilation and embed it in the\nLua output. The module must be a string literal and resolvable at compile time.") + local function eval_compiler_2a(ast, scope, parent) + local env = make_compiler_env(ast, scope, parent) + local opts = utils.copy(utils.root.options) + opts.scope = compiler["make-scope"](compiler.scopes.compiler) + opts.allowedGlobals = macro_globals(env, current_global_names()) + return load_code(compiler.compile(ast, opts), wrap_env(env))(opts["module-name"], ast.filename) + end + SPECIALS.macros = function(ast, scope, parent) + compiler.assert((#ast == 2), "Expected one table argument", ast) + return add_macros(eval_compiler_2a(ast[2], scope, parent), ast, scope, parent) + end + doc_special("macros", {"{:macro-name-1 (fn [...] ...) ... :macro-name-N macro-body-N}"}, "Define all functions in the given table as macros local to the current scope.") + SPECIALS["eval-compiler"] = function(ast, scope, parent) + local old_first = ast[1] + ast[1] = utils.sym("do") + local val = eval_compiler_2a(ast, scope, parent) + ast[1] = old_first + return val + end + doc_special("eval-compiler", {"..."}, "Evaluate the body at compile-time. Use the macro system instead if possible.") + return {["current-global-names"] = current_global_names, ["load-code"] = load_code, ["macro-loaded"] = macro_loaded, ["make-compiler-env"] = make_compiler_env, ["make-searcher"] = make_searcher, ["search-module"] = search_module, ["wrap-env"] = wrap_env, doc = doc_2a} +end +package.preload["fennel.compiler"] = package.preload["fennel.compiler"] or function(...) + local utils = require("fennel.utils") + local parser = require("fennel.parser") + local friend = require("fennel.friend") + local unpack = (table.unpack or _G.unpack) + local scopes = {} + local function make_scope(parent) + local parent0 = (parent or scopes.global) + local _0_ + if parent0 then + _0_ = ((parent0.depth or 0) + 1) + else + _0_ = 0 + end + return {autogensyms = {}, depth = _0_, hashfn = (parent0 and parent0.hashfn), includes = setmetatable({}, {__index = (parent0 and parent0.includes)}), macros = setmetatable({}, {__index = (parent0 and parent0.macros)}), manglings = setmetatable({}, {__index = (parent0 and parent0.manglings)}), parent = parent0, refedglobals = setmetatable({}, {__index = (parent0 and parent0.refedglobals)}), specials = setmetatable({}, {__index = (parent0 and parent0.specials)}), symmeta = setmetatable({}, {__index = (parent0 and parent0.symmeta)}), unmanglings = setmetatable({}, {__index = (parent0 and parent0.unmanglings)}), vararg = (parent0 and parent0.vararg)} + end + local function assert_msg(ast, msg) + local ast_tbl = nil + if ("table" == type(ast)) then + ast_tbl = ast + else + ast_tbl = {} + end + local m = getmetatable(ast) + local filename = ((m and m.filename) or ast_tbl.filename or "unknown") + local line = ((m and m.line) or ast_tbl.line or "?") + local target = nil + local function _1_() + if utils["sym?"](ast_tbl[1]) then + return utils.deref(ast_tbl[1]) + else + return (ast_tbl[1] or "()") + end + end + target = tostring(_1_()) + return string.format("Compile error in '%s' %s:%s: %s", target, filename, line, msg) + end + local function assert_compile(condition, msg, ast) + if not condition then + local _0_ = (utils.root.options or {}) + local source = _0_["source"] + local unfriendly = _0_["unfriendly"] + utils.root.reset() + if unfriendly then + error(assert_msg(ast, msg), 0) + else + friend["assert-compile"](condition, msg, ast, source) + end + end + return condition + end + scopes.global = make_scope() + scopes.global.vararg = true + scopes.compiler = make_scope(scopes.global) + scopes.macro = scopes.global + local serialize_subst = {["\11"] = "\\v", ["\12"] = "\\f", ["\7"] = "\\a", ["\8"] = "\\b", ["\9"] = "\\t", ["\n"] = "n"} + local function serialize_string(str) + local function _0_(_241) + return ("\\" .. _241:byte()) + end + return string.gsub(string.gsub(string.format("%q", str), ".", serialize_subst), "[\128-\255]", _0_) + end + local function global_mangling(str) + if utils["valid-lua-identifier?"](str) then + return str + else + local function _0_(_241) + return string.format("_%02x", _241:byte()) + end + return ("__fnl_global__" .. str:gsub("[^%w]", _0_)) + end + end + local function global_unmangling(identifier) + local _0_0 = string.match(identifier, "^__fnl_global__(.*)$") + if (nil ~= _0_0) then + local rest = _0_0 + local _1_0 = nil + local function _2_(_241) + return string.char(tonumber(_241:sub(2), 16)) + end + _1_0 = string.gsub(rest, "_[%da-f][%da-f]", _2_) + return _1_0 + else + local _ = _0_0 + return identifier + end + end + local allowed_globals = nil + local function global_allowed(name) + return (not allowed_globals or utils["member?"](name, allowed_globals)) + end + local function unique_mangling(original, mangling, scope, append) + if scope.unmanglings[mangling] then + return unique_mangling(original, (original .. append), scope, (append + 1)) + else + return mangling + end + end + local function local_mangling(str, scope, ast, temp_manglings) + assert_compile(not utils["multi-sym?"](str), ("unexpected multi symbol " .. str), ast) + local raw = nil + if (utils["lua-keywords"][str] or str:match("^%d")) then + raw = ("_" .. str) + else + raw = str + end + local mangling = nil + local function _1_(_241) + return string.format("_%02x", _241:byte()) + end + mangling = string.gsub(string.gsub(raw, "-", "_"), "[^%w_]", _1_) + local unique = unique_mangling(mangling, mangling, scope, 0) + scope.unmanglings[unique] = str + do + local manglings = (temp_manglings or scope.manglings) + manglings[str] = unique + end + return unique + end + local function apply_manglings(scope, new_manglings, ast) + for raw, mangled in pairs(new_manglings) do + assert_compile(not scope.refedglobals[mangled], ("use of global " .. raw .. " is aliased by a local"), ast) + scope.manglings[raw] = mangled + end + return nil + end + local function combine_parts(parts, scope) + local ret = (scope.manglings[parts[1]] or global_mangling(parts[1])) + for i = 2, #parts do + if utils["valid-lua-identifier?"](parts[i]) then + if (parts["multi-sym-method-call"] and (i == #parts)) then + ret = (ret .. ":" .. parts[i]) + else + ret = (ret .. "." .. parts[i]) + end + else + ret = (ret .. "[" .. serialize_string(parts[i]) .. "]") + end + end + return ret + end + local function gensym(scope, base) + local append, mangling = 0, ((base or "") .. "_0_") + while scope.unmanglings[mangling] do + mangling = ((base or "") .. "_" .. append .. "_") + append = (append + 1) + end + scope.unmanglings[mangling] = (base or true) + return mangling + end + local function autogensym(base, scope) + local _0_0 = utils["multi-sym?"](base) + if (nil ~= _0_0) then + local parts = _0_0 + parts[1] = autogensym(parts[1], scope) + return table.concat(parts, ((parts["multi-sym-method-call"] and ":") or ".")) + else + local _ = _0_0 + local function _1_() + local mangling = gensym(scope, base:sub(1, ( - 2))) + scope.autogensyms[base] = mangling + return mangling + end + return (scope.autogensyms[base] or _1_()) + end + end + local already_warned = {} + local function check_binding_valid(symbol, scope, ast) + local name = utils.deref(symbol) + if (io and io.stderr and name:find("&") and not already_warned[symbol]) then + already_warned[symbol] = true + do end (io.stderr):write(("-- Warning: & will not be allowed in identifier names in " .. "future versions: " .. symbol.filename .. ":" .. symbol.line .. "\n")) + end + assert_compile(not (scope.specials[name] or scope.macros[name]), ("local %s was overshadowed by a special form or macro"):format(name), ast) + return assert_compile(not utils["quoted?"](symbol), string.format("macro tried to bind %s without gensym", name), symbol) + end + local function declare_local(symbol, meta, scope, ast, temp_manglings) + check_binding_valid(symbol, scope, ast) + local name = utils.deref(symbol) + assert_compile(not utils["multi-sym?"](name), ("unexpected multi symbol " .. name), ast) + scope.symmeta[name] = meta + return local_mangling(name, scope, ast, temp_manglings) + end + local function hashfn_arg_name(name, multi_sym_parts, scope) + if not scope.hashfn then + return nil + elseif (name == "$") then + return "$1" + elseif multi_sym_parts then + if (multi_sym_parts and (multi_sym_parts[1] == "$")) then + multi_sym_parts[1] = "$1" + end + return table.concat(multi_sym_parts, ".") + end + end + local function symbol_to_expression(symbol, scope, reference_3f) + utils.hook("symbol-to-expression", symbol, scope, reference_3f) + local name = symbol[1] + local multi_sym_parts = utils["multi-sym?"](name) + local name0 = (hashfn_arg_name(name, multi_sym_parts, scope) or name) + local parts = (multi_sym_parts or {name0}) + local etype = (((#parts > 1) and "expression") or "sym") + local local_3f = scope.manglings[parts[1]] + if (local_3f and scope.symmeta[parts[1]]) then + scope.symmeta[parts[1]]["used"] = true + end + assert_compile((not reference_3f or local_3f or global_allowed(parts[1])), ("unknown global in strict mode: " .. parts[1]), symbol) + if (allowed_globals and not local_3f) then + utils.root.scope.refedglobals[parts[1]] = true + end + return utils.expr(combine_parts(parts, scope), etype) + end + local function emit(chunk, out, ast) + if (type(out) == "table") then + return table.insert(chunk, out) + else + return table.insert(chunk, {ast = ast, leaf = out}) + end + end + local function peephole(chunk) + if chunk.leaf then + return chunk + elseif ((#chunk >= 3) and (chunk[(#chunk - 2)].leaf == "do") and not chunk[(#chunk - 1)].leaf and (chunk[#chunk].leaf == "end")) then + local kid = peephole(chunk[(#chunk - 1)]) + local new_chunk = {ast = chunk.ast} + for i = 1, (#chunk - 3) do + table.insert(new_chunk, peephole(chunk[i])) + end + for i = 1, #kid do + table.insert(new_chunk, kid[i]) + end + return new_chunk + else + return utils.map(chunk, peephole) + end + end + local function flatten_chunk_correlated(main_chunk) + local function flatten(chunk, out, last_line, file) + local last_line0 = last_line + if chunk.leaf then + out[last_line0] = ((out[last_line0] or "") .. " " .. chunk.leaf) + else + for _, subchunk in ipairs(chunk) do + if (subchunk.leaf or (#subchunk > 0)) then + if (subchunk.ast and (file == subchunk.ast.file)) then + last_line0 = math.max(last_line0, (subchunk.ast.line or 0)) + end + last_line0 = flatten(subchunk, out, last_line0, file) + end + end + end + return last_line0 + end + local out = {} + local last = flatten(main_chunk, out, 1, main_chunk.file) + for i = 1, last do + if (out[i] == nil) then + out[i] = "" + end + end + return table.concat(out, "\n") + end + local function flatten_chunk(sm, chunk, tab, depth) + if chunk.leaf then + local code = chunk.leaf + local info = chunk.ast + if sm then + table.insert(sm, ((info and info.line) or ( - 1))) + end + return code + else + local tab0 = nil + do + local _0_0 = tab + if (_0_0 == true) then + tab0 = " " + elseif (_0_0 == false) then + tab0 = "" + elseif (_0_0 == tab) then + tab0 = tab + elseif (_0_0 == nil) then + tab0 = "" + else + tab0 = nil + end + end + local function parter(c) + if (c.leaf or (#c > 0)) then + local sub = flatten_chunk(sm, c, tab0, (depth + 1)) + if (depth > 0) then + return (tab0 .. sub:gsub("\n", ("\n" .. tab0))) + else + return sub + end + end + end + return table.concat(utils.map(chunk, parter), "\n") + end + end + local fennel_sourcemap = {} + local function make_short_src(source) + local source0 = source:gsub("\n", " ") + if (#source0 <= 49) then + return ("[fennel \"" .. source0 .. "\"]") + else + return ("[fennel \"" .. source0:sub(1, 46) .. "...\"]") + end + end + local function flatten(chunk, options) + local chunk0 = peephole(chunk) + if options.correlate then + return flatten_chunk_correlated(chunk0), {} + else + local sm = {} + local ret = flatten_chunk(sm, chunk0, options.indent, 0) + if sm then + sm.short_src = make_short_src((options.filename or options.source or ret)) + if options.filename then + sm.key = ("@" .. options.filename) + else + sm.key = ret + end + fennel_sourcemap[sm.key] = sm + end + return ret, sm + end + end + local function make_metadata() + local function _0_(self, tgt, key) + if self[tgt] then + return self[tgt][key] + end + end + local function _1_(self, tgt, key, value) + self[tgt] = (self[tgt] or {}) + self[tgt][key] = value + return tgt + end + local function _2_(self, tgt, ...) + local kv_len = select("#", ...) + local kvs = {...} + if ((kv_len % 2) ~= 0) then + error("metadata:setall() expected even number of k/v pairs") + end + self[tgt] = (self[tgt] or {}) + for i = 1, kv_len, 2 do + self[tgt][kvs[i]] = kvs[(i + 1)] + end + return tgt + end + return setmetatable({}, {__index = {get = _0_, set = _1_, setall = _2_}, __mode = "k"}) + end + local function exprs1(exprs) + return table.concat(utils.map(exprs, 1), ", ") + end + local function keep_side_effects(exprs, chunk, start, ast) + local start0 = (start or 1) + for j = start0, #exprs do + local se = exprs[j] + if ((se.type == "expression") and (se[1] ~= "nil")) then + emit(chunk, string.format("do local _ = %s end", tostring(se)), ast) + elseif (se.type == "statement") then + local code = tostring(se) + emit(chunk, (((code:byte() == 40) and ("do end " .. code)) or code), ast) + end + end + return nil + end + local function handle_compile_opts(exprs, parent, opts, ast) + if opts.nval then + local n = opts.nval + local len = #exprs + if (n ~= len) then + if (len > n) then + keep_side_effects(exprs, parent, (n + 1), ast) + for i = (n + 1), len do + exprs[i] = nil + end + else + for i = (#exprs + 1), n do + exprs[i] = utils.expr("nil", "literal") + end + end + end + end + if opts.tail then + emit(parent, string.format("return %s", exprs1(exprs)), ast) + end + if opts.target then + local result = exprs1(exprs) + local function _2_() + if (result == "") then + return "nil" + else + return result + end + end + emit(parent, string.format("%s = %s", opts.target, _2_()), ast) + end + if (opts.tail or opts.target) then + return {returned = true} + else + local _3_0 = exprs + _3_0["returned"] = true + return _3_0 + end + end + local function find_macro(ast, scope, multi_sym_parts) + local function find_in_table(t, i) + if (i <= #multi_sym_parts) then + return find_in_table((utils["table?"](t) and t[multi_sym_parts[i]]), (i + 1)) + else + return t + end + end + local macro_2a = (utils["sym?"](ast[1]) and scope.macros[utils.deref(ast[1])]) + if (not macro_2a and multi_sym_parts) then + local nested_macro = find_in_table(scope.macros, 1) + assert_compile((not scope.macros[multi_sym_parts[1]] or (type(nested_macro) == "function")), "macro not found in imported macro module", ast) + return nested_macro + else + return macro_2a + end + end + local function macroexpand_2a(ast, scope, once) + if not utils["list?"](ast) then + return ast + else + local macro_2a = find_macro(ast, scope, utils["multi-sym?"](ast[1])) + if not macro_2a then + return ast + else + local old_scope = scopes.macro + local _ = nil + scopes.macro = scope + _ = nil + local ok, transformed = pcall(macro_2a, unpack(ast, 2)) + scopes.macro = old_scope + assert_compile(ok, transformed, ast) + if (once or not transformed) then + return transformed + else + return macroexpand_2a(transformed, scope) + end + end + end + end + local function compile_special(ast, scope, parent, opts, special) + local exprs = (special(ast, scope, parent, opts) or utils.expr("nil", "literal")) + local exprs0 = nil + if (type(exprs) == "string") then + exprs0 = utils.expr(exprs, "expression") + else + exprs0 = exprs + end + local exprs2 = nil + if utils["expr?"](exprs0) then + exprs2 = {exprs0} + else + exprs2 = exprs0 + end + if not exprs2.returned then + return handle_compile_opts(exprs2, parent, opts, ast) + elseif (opts.tail or opts.target) then + return {returned = true} + else + return exprs2 + end + end + local function compile_function_call(ast, scope, parent, opts, compile1, len) + local fargs = {} + local fcallee = compile1(ast[1], scope, parent, {nval = 1})[1] + assert_compile((fcallee.type ~= "literal"), ("cannot call literal value " .. tostring(ast[1])), ast) + for i = 2, len do + local subexprs = nil + local _0_ + if (i ~= len) then + _0_ = 1 + else + _0_ = nil + end + subexprs = compile1(ast[i], scope, parent, {nval = _0_}) + table.insert(fargs, (subexprs[1] or utils.expr("nil", "literal"))) + if (i == len) then + for j = 2, #subexprs do + table.insert(fargs, subexprs[j]) + end + else + keep_side_effects(subexprs, parent, 2, ast[i]) + end + end + local call = string.format("%s(%s)", tostring(fcallee), exprs1(fargs)) + return handle_compile_opts({utils.expr(call, "statement")}, parent, opts, ast) + end + local function compile_call(ast, scope, parent, opts, compile1) + utils.hook("call", ast, scope) + local len = #ast + local first = ast[1] + local multi_sym_parts = utils["multi-sym?"](first) + local special = (utils["sym?"](first) and scope.specials[utils.deref(first)]) + assert_compile((len > 0), "expected a function, macro, or special to call", ast) + if special then + return compile_special(ast, scope, parent, opts, special) + elseif (multi_sym_parts and multi_sym_parts["multi-sym-method-call"]) then + local table_with_method = table.concat({unpack(multi_sym_parts, 1, (#multi_sym_parts - 1))}, ".") + local method_to_call = multi_sym_parts[#multi_sym_parts] + local new_ast = utils.list(utils.sym(":", scope), utils.sym(table_with_method, scope), method_to_call, select(2, unpack(ast))) + return compile1(new_ast, scope, parent, opts) + else + return compile_function_call(ast, scope, parent, opts, compile1, len) + end + end + local function compile_varg(ast, scope, parent, opts) + assert_compile(scope.vararg, "unexpected vararg", ast) + return handle_compile_opts({utils.expr("...", "varg")}, parent, opts, ast) + end + local function compile_sym(ast, scope, parent, opts) + local multi_sym_parts = utils["multi-sym?"](ast) + assert_compile(not (multi_sym_parts and multi_sym_parts["multi-sym-method-call"]), "multisym method calls may only be in call position", ast) + local e = nil + if (ast[1] == "nil") then + e = utils.expr("nil", "literal") + else + e = symbol_to_expression(ast, scope, true) + end + return handle_compile_opts({e}, parent, opts, ast) + end + local function serialize_number(n) + local _0_0, _1_0, _2_0 = math.modf(n) + if ((nil ~= _0_0) and (_1_0 == 0)) then + local int = _0_0 + return tostring(int) + else + local _3_ + do + local frac = _1_0 + _3_ = (((_0_0 == 0) and (nil ~= _1_0)) and (frac < 0)) + end + if _3_ then + local frac = _1_0 + return ("-0." .. tostring(frac):gsub("^-?0.", "")) + elseif ((nil ~= _0_0) and (nil ~= _1_0)) then + local int = _0_0 + local frac = _1_0 + return (int .. "." .. tostring(frac):gsub("^-?0.", "")) + end + end + end + local function compile_scalar(ast, _scope, parent, opts) + local serialize = nil + do + local _0_0 = type(ast) + if (_0_0 == "nil") then + serialize = tostring + elseif (_0_0 == "boolean") then + serialize = tostring + elseif (_0_0 == "string") then + serialize = serialize_string + elseif (_0_0 == "number") then + serialize = serialize_number + else + serialize = nil + end + end + return handle_compile_opts({utils.expr(serialize(ast), "literal")}, parent, opts) + end + local function compile_table(ast, scope, parent, opts, compile1) + local buffer = {} + for i = 1, #ast do + local nval = ((i ~= #ast) and 1) + table.insert(buffer, exprs1(compile1(ast[i], scope, parent, {nval = nval}))) + end + local function write_other_values(k) + if ((type(k) ~= "number") or (math.floor(k) ~= k) or (k < 1) or (k > #ast)) then + if ((type(k) == "string") and utils["valid-lua-identifier?"](k)) then + return {k, k} + else + local _0_ = compile1(k, scope, parent, {nval = 1}) + local compiled = _0_[1] + local kstr = ("[" .. tostring(compiled) .. "]") + return {kstr, k} + end + end + end + do + local keys = nil + do + local _0_0 = utils.kvmap(ast, write_other_values) + local function _1_(a, b) + return (a[1] < b[1]) + end + table.sort(_0_0, _1_) + keys = _0_0 + end + local function _1_(k) + local v = tostring(compile1(ast[k[2]], scope, parent, {nval = 1})[1]) + return string.format("%s = %s", k[1], v) + end + utils.map(keys, _1_, buffer) + end + return handle_compile_opts({utils.expr(("{" .. table.concat(buffer, ", ") .. "}"), "expression")}, parent, opts, ast) + end + local function compile1(ast, scope, parent, opts) + local opts0 = (opts or {}) + local ast0 = macroexpand_2a(ast, scope) + if utils["list?"](ast0) then + return compile_call(ast0, scope, parent, opts0, compile1) + elseif utils["varg?"](ast0) then + return compile_varg(ast0, scope, parent, opts0) + elseif utils["sym?"](ast0) then + return compile_sym(ast0, scope, parent, opts0) + elseif (type(ast0) == "table") then + return compile_table(ast0, scope, parent, opts0, compile1) + elseif ((type(ast0) == "nil") or (type(ast0) == "boolean") or (type(ast0) == "number") or (type(ast0) == "string")) then + return compile_scalar(ast0, scope, parent, opts0) + else + return assert_compile(false, ("could not compile value of type " .. type(ast0)), ast0) + end + end + local function destructure(to, from, ast, scope, parent, opts) + local opts0 = (opts or {}) + local _0_ = opts0 + local declaration = _0_["declaration"] + local forceglobal = _0_["forceglobal"] + local forceset = _0_["forceset"] + local isvar = _0_["isvar"] + local nomulti = _0_["nomulti"] + local noundef = _0_["noundef"] + local symtype = _0_["symtype"] + local symtype0 = ("_" .. (symtype or "dst")) + local setter = nil + if declaration then + setter = "local %s = %s" + else + setter = "%s = %s" + end + local new_manglings = {} + local function getname(symbol, up1) + local raw = symbol[1] + assert_compile(not (nomulti and utils["multi-sym?"](raw)), ("unexpected multi symbol " .. raw), up1) + if declaration then + return declare_local(symbol, nil, scope, symbol, new_manglings) + else + local parts = (utils["multi-sym?"](raw) or {raw}) + local meta = scope.symmeta[parts[1]] + if ((#parts == 1) and not forceset) then + assert_compile(not (forceglobal and meta), string.format("global %s conflicts with local", tostring(symbol)), symbol) + assert_compile(not (meta and not meta.var), ("expected var " .. raw), symbol) + assert_compile((meta or not noundef), ("expected local " .. parts[1]), symbol) + end + if forceglobal then + assert_compile(not scope.symmeta[scope.unmanglings[raw]], ("global " .. raw .. " conflicts with local"), symbol) + scope.manglings[raw] = global_mangling(raw) + scope.unmanglings[global_mangling(raw)] = raw + if allowed_globals then + table.insert(allowed_globals, raw) + end + end + return symbol_to_expression(symbol, scope)[1] + end + end + local function compile_top_target(lvalues) + local inits = nil + local function _2_(_241) + if scope.manglings[_241] then + return _241 + else + return "nil" + end + end + inits = utils.map(lvalues, _2_) + local init = table.concat(inits, ", ") + local lvalue = table.concat(lvalues, ", ") + local plen, plast = #parent, parent[#parent] + local ret = compile1(from, scope, parent, {target = lvalue}) + if declaration then + for pi = plen, #parent do + if (parent[pi] == plast) then + plen = pi + end + end + if ((#parent == (plen + 1)) and parent[#parent].leaf) then + parent[#parent]["leaf"] = ("local " .. parent[#parent].leaf) + else + table.insert(parent, (plen + 1), {ast = ast, leaf = ("local " .. lvalue .. " = " .. init)}) + end + end + return ret + end + local function destructure_sym(left, rightexprs, up1, top_3f) + local lname = getname(left, up1) + check_binding_valid(left, scope, left) + if top_3f then + compile_top_target({lname}) + else + emit(parent, setter:format(lname, exprs1(rightexprs)), left) + end + if declaration then + scope.symmeta[utils.deref(left)] = {var = isvar} + return nil + end + end + local function destructure_table(left, rightexprs, top_3f, destructure1) + local s = gensym(scope, symtype0) + local right = nil + do + local _2_0 = nil + if top_3f then + _2_0 = exprs1(compile1(from, scope, parent)) + else + _2_0 = exprs1(rightexprs) + end + if (_2_0 == "") then + right = "nil" + elseif (nil ~= _2_0) then + local right0 = _2_0 + right = right0 + else + right = nil + end + end + emit(parent, string.format("local %s = %s", s, right), left) + for k, v in utils.stablepairs(left) do + if not (("number" == type(k)) and tostring(left[(k - 1)]):find("^&")) then + if (utils["sym?"](v) and (utils.deref(v) == "&")) then + local unpack_str = "{(table.unpack or unpack)(%s, %s)}" + local formatted = string.format(unpack_str, s, k) + local subexpr = utils.expr(formatted, "expression") + assert_compile((utils["sequence?"](left) and (nil == left[(k + 2)])), "expected rest argument before last parameter", left) + destructure1(left[(k + 1)], {subexpr}, left) + elseif (utils["sym?"](k) and (utils.deref(k) == "&as")) then + destructure_sym(v, {utils.expr(tostring(s))}, left) + elseif (utils["sequence?"](left) and (utils.deref(v) == "&as")) then + local _, next_sym, trailing = select(k, unpack(left)) + assert_compile((nil == trailing), "expected &as argument before last parameter", left) + destructure_sym(next_sym, {utils.expr(tostring(s))}, left) + else + local key = nil + if (type(k) == "string") then + key = serialize_string(k) + else + key = k + end + local subexpr = utils.expr(string.format("%s[%s]", s, key), "expression") + destructure1(v, {subexpr}, left) + end + end + end + return nil + end + local function destructure_values(left, up1, top_3f, destructure1) + local left_names, tables = {}, {} + for i, name in ipairs(left) do + if utils["sym?"](name) then + table.insert(left_names, getname(name, up1)) + else + local symname = gensym(scope, symtype0) + table.insert(left_names, symname) + tables[i] = {name, utils.expr(symname, "sym")} + end + end + assert_compile(top_3f, "can't nest multi-value destructuring", left) + compile_top_target(left_names) + if declaration then + for _, sym in ipairs(left) do + scope.symmeta[utils.deref(sym)] = {var = isvar} + end + end + for _, pair in utils.stablepairs(tables) do + destructure1(pair[1], {pair[2]}, left) + end + return nil + end + local function destructure1(left, rightexprs, up1, top_3f) + if (utils["sym?"](left) and (left[1] ~= "nil")) then + destructure_sym(left, rightexprs, up1, top_3f) + elseif utils["table?"](left) then + destructure_table(left, rightexprs, top_3f, destructure1) + elseif utils["list?"](left) then + destructure_values(left, up1, top_3f, destructure1) + else + assert_compile(false, string.format("unable to bind %s %s", type(left), tostring(left)), (((type(up1[2]) == "table") and up1[2]) or up1)) + end + if top_3f then + return {returned = true} + end + end + local ret = destructure1(to, nil, ast, true) + utils.hook("destructure", from, to, scope) + apply_manglings(scope, new_manglings, ast) + return ret + end + local function require_include(ast, scope, parent, opts) + opts.fallback = function(e) + return utils.expr(string.format("require(%s)", tostring(e)), "statement") + end + return scopes.global.specials.include(ast, scope, parent, opts) + end + local function compile_stream(strm, options) + local opts = utils.copy(options) + local old_globals = allowed_globals + local scope = (opts.scope or make_scope(scopes.global)) + local vals = {} + local chunk = {} + local _0_ = utils.root + _0_["set-reset"](_0_) + allowed_globals = opts.allowedGlobals + if (opts.indent == nil) then + opts.indent = " " + end + if opts.requireAsInclude then + scope.specials.require = require_include + end + utils.root.chunk, utils.root.scope, utils.root.options = chunk, scope, opts + for _, val in parser.parser(strm, opts.filename, opts) do + table.insert(vals, val) + end + for i = 1, #vals do + local exprs = compile1(vals[i], scope, chunk, {nval = (((i < #vals) and 0) or nil), tail = (i == #vals)}) + keep_side_effects(exprs, chunk, nil, vals[i]) + end + allowed_globals = old_globals + utils.root.reset() + return flatten(chunk, opts) + end + local function compile_string(str, opts) + return compile_stream(parser["string-stream"](str), (opts or {})) + end + local function compile(ast, opts) + local opts0 = utils.copy(opts) + local old_globals = allowed_globals + local chunk = {} + local scope = (opts0.scope or make_scope(scopes.global)) + local _0_ = utils.root + _0_["set-reset"](_0_) + allowed_globals = opts0.allowedGlobals + if (opts0.indent == nil) then + opts0.indent = " " + end + if opts0.requireAsInclude then + scope.specials.require = require_include + end + utils.root.chunk, utils.root.scope, utils.root.options = chunk, scope, opts0 + local exprs = compile1(ast, scope, chunk, {tail = true}) + keep_side_effects(exprs, chunk, nil, ast) + allowed_globals = old_globals + utils.root.reset() + return flatten(chunk, opts0) + end + local function traceback_frame(info) + if ((info.what == "C") and info.name) then + return string.format(" [C]: in function '%s'", info.name) + elseif (info.what == "C") then + return " [C]: in ?" + else + local remap = fennel_sourcemap[info.source] + if (remap and remap[info.currentline]) then + info["short-src"] = remap["short-src"] + info.currentline = remap[info.currentline] + end + if (info.what == "Lua") then + local function _1_() + if info.name then + return ("'" .. info.name .. "'") + else + return "?" + end + end + return string.format(" %s:%d: in function %s", info.short_src, info.currentline, _1_()) + elseif (info["short-src"] == "(tail call)") then + return " (tail call)" + else + return string.format(" %s:%d: in main chunk", info.short_src, info.currentline) + end + end + end + local function traceback(msg, start) + local msg0 = (msg or "") + if ((msg0:find("^Compile error") or msg0:find("^Parse error")) and not utils["debug-on?"]("trace")) then + return msg0 + else + local lines = {} + if (msg0:find("^Compile error") or msg0:find("^Parse error")) then + table.insert(lines, msg0) + else + local newmsg = msg0:gsub("^[^:]*:%d+:%s+", "runtime error: ") + table.insert(lines, newmsg) + end + table.insert(lines, "stack traceback:") + local done_3f, level = false, (start or 2) + while not done_3f do + do + local _1_0 = debug.getinfo(level, "Sln") + if (_1_0 == nil) then + done_3f = true + elseif (nil ~= _1_0) then + local info = _1_0 + table.insert(lines, traceback_frame(info)) + end + end + level = (level + 1) + end + return table.concat(lines, "\n") + end + end + local function entry_transform(fk, fv) + local function _0_(k, v) + if (type(k) == "number") then + return k, fv(v) + else + return fk(k), fv(v) + end + end + return _0_ + end + local function no() + return nil + end + local function mixed_concat(t, joiner) + local seen = {} + local ret, s = "", "" + for k, v in ipairs(t) do + table.insert(seen, k) + ret = (ret .. s .. v) + s = joiner + end + for k, v in utils.stablepairs(t) do + if not seen[k] then + ret = (ret .. s .. "[" .. k .. "]" .. "=" .. v) + s = joiner + end + end + return ret + end + local function do_quote(form, scope, parent, runtime_3f) + local function q(x) + return do_quote(x, scope, parent, runtime_3f) + end + if utils["varg?"](form) then + assert_compile(not runtime_3f, "quoted ... may only be used at compile time", form) + return "_VARARG" + elseif utils["sym?"](form) then + local filename = nil + if form.filename then + filename = string.format("%q", form.filename) + else + filename = "nil" + end + local symstr = utils.deref(form) + assert_compile(not runtime_3f, "symbols may only be used at compile time", form) + if (symstr:find("#$") or symstr:find("#[:.]")) then + return string.format("sym('%s', nil, {filename=%s, line=%s})", autogensym(symstr, scope), filename, (form.line or "nil")) + else + return string.format("sym('%s', nil, {quoted=true, filename=%s, line=%s})", symstr, filename, (form.line or "nil")) + end + elseif (utils["list?"](form) and utils["sym?"](form[1]) and (utils.deref(form[1]) == "unquote")) then + local payload = form[2] + local res = unpack(compile1(payload, scope, parent)) + return res[1] + elseif utils["list?"](form) then + local mapped = utils.kvmap(form, entry_transform(no, q)) + local filename = nil + if form.filename then + filename = string.format("%q", form.filename) + else + filename = "nil" + end + assert_compile(not runtime_3f, "lists may only be used at compile time", form) + return string.format(("setmetatable({filename=%s, line=%s, bytestart=%s, %s}" .. ", getmetatable(list()))"), filename, (form.line or "nil"), (form.bytestart or "nil"), mixed_concat(mapped, ", ")) + elseif (type(form) == "table") then + local mapped = utils.kvmap(form, entry_transform(q, q)) + local source = getmetatable(form) + local filename = nil + if source.filename then + filename = string.format("%q", source.filename) + else + filename = "nil" + end + local function _1_() + if source then + return source.line + else + return "nil" + end + end + return string.format("setmetatable({%s}, {filename=%s, line=%s})", mixed_concat(mapped, ", "), filename, _1_()) + elseif (type(form) == "string") then + return serialize_string(form) + else + return tostring(form) + end + end + return {["apply-manglings"] = apply_manglings, ["compile-stream"] = compile_stream, ["compile-string"] = compile_string, ["declare-local"] = declare_local, ["do-quote"] = do_quote, ["global-mangling"] = global_mangling, ["global-unmangling"] = global_unmangling, ["keep-side-effects"] = keep_side_effects, ["make-scope"] = make_scope, ["require-include"] = require_include, ["symbol-to-expression"] = symbol_to_expression, assert = assert_compile, autogensym = autogensym, compile = compile, compile1 = compile1, destructure = destructure, emit = emit, gensym = gensym, macroexpand = macroexpand_2a, metadata = make_metadata(), scopes = scopes, traceback = traceback} +end +package.preload["fennel.friend"] = package.preload["fennel.friend"] or function(...) + local function ast_source(ast) + local m = getmetatable(ast) + return ((m and m.line and m) or (("table" == type(ast)) and ast) or {}) + end + local suggestions = {["$ and $... in hashfn are mutually exclusive"] = {"modifying the hashfn so it only contains $... or $, $1, $2, $3, etc"}, ["can't start multisym segment with a digit"] = {"removing the digit", "adding a non-digit before the digit"}, ["cannot call literal value"] = {"checking for typos", "checking for a missing function name"}, ["could not compile value of type "] = {"debugging the macro you're calling not to return a coroutine or userdata"}, ["could not read number (.*)"] = {"removing the non-digit character", "beginning the identifier with a non-digit if it is not meant to be a number"}, ["expected a function.* to call"] = {"removing the empty parentheses", "using square brackets if you want an empty table"}, ["expected binding table"] = {"placing a table here in square brackets containing identifiers to bind"}, ["expected body expression"] = {"putting some code in the body of this form after the bindings"}, ["expected each macro to be function"] = {"ensuring that the value for each key in your macros table contains a function", "avoid defining nested macro tables"}, ["expected even number of name/value bindings"] = {"finding where the identifier or value is missing"}, ["expected even number of values in table literal"] = {"removing a key", "adding a value"}, ["expected local"] = {"looking for a typo", "looking for a local which is used out of its scope"}, ["expected macros to be table"] = {"ensuring your macro definitions return a table"}, ["expected parameters"] = {"adding function parameters as a list of identifiers in brackets"}, ["expected rest argument before last parameter"] = {"moving & to right before the final identifier when destructuring"}, ["expected symbol for function parameter: (.*)"] = {"changing %s to an identifier instead of a literal value"}, ["expected var (.*)"] = {"declaring %s using var instead of let/local", "introducing a new local instead of changing the value of %s"}, ["expected vararg as last parameter"] = {"moving the \"...\" to the end of the parameter list"}, ["expected whitespace before opening delimiter"] = {"adding whitespace"}, ["global (.*) conflicts with local"] = {"renaming local %s"}, ["illegal character: (.)"] = {"deleting or replacing %s", "avoiding reserved characters like \", \\, ', ~, ;, @, `, and comma"}, ["local (.*) was overshadowed by a special form or macro"] = {"renaming local %s"}, ["macro not found in macro module"] = {"checking the keys of the imported macro module's returned table"}, ["macro tried to bind (.*) without gensym"] = {"changing to %s# when introducing identifiers inside macros"}, ["malformed multisym"] = {"ensuring each period or colon is not followed by another period or colon"}, ["may only be used at compile time"] = {"moving this to inside a macro if you need to manipulate symbols/lists", "using square brackets instead of parens to construct a table"}, ["method must be last component"] = {"using a period instead of a colon for field access", "removing segments after the colon", "making the method call, then looking up the field on the result"}, ["mismatched closing delimiter (.), expected (.)"] = {"replacing %s with %s", "deleting %s", "adding matching opening delimiter earlier"}, ["multisym method calls may only be in call position"] = {"using a period instead of a colon to reference a table's fields", "putting parens around this"}, ["unable to bind (.*)"] = {"replacing the %s with an identifier"}, ["unexpected closing delimiter (.)"] = {"deleting %s", "adding matching opening delimiter earlier"}, ["unexpected multi symbol (.*)"] = {"removing periods or colons from %s"}, ["unexpected vararg"] = {"putting \"...\" at the end of the fn parameters if the vararg was intended"}, ["unknown global in strict mode: (.*)"] = {"looking to see if there's a typo", "using the _G table instead, eg. _G.%s if you really want a global", "moving this code to somewhere that %s is in scope", "binding %s as a local in the scope of this code"}, ["unused local (.*)"] = {"fixing a typo so %s is used", "renaming the local to _%s"}, ["use of global (.*) is aliased by a local"] = {"renaming local %s", "refer to the global using _G.%s instead of directly"}} + local unpack = (table.unpack or _G.unpack) + local function suggest(msg) + local suggestion = nil + for pat, sug in pairs(suggestions) do + local matches = {msg:match(pat)} + if (0 < #matches) then + if ("table" == type(sug)) then + local out = {} + for _, s in ipairs(sug) do + table.insert(out, s:format(unpack(matches))) + end + suggestion = out + else + suggestion = sug(matches) + end + end + end + return suggestion + end + local function read_line_from_file(filename, line) + local bytes = 0 + local f = assert(io.open(filename)) + local _ = nil + for _0 = 1, (line - 1) do + bytes = (bytes + 1 + #f:read()) + end + _ = nil + local codeline = f:read() + f:close() + return codeline, bytes + end + local function read_line_from_source(source, line) + local lines, bytes, codeline = 0, 0 + for this_line, newline in string.gmatch((source .. "\n"), "(.-)(\13?\n)") do + lines = (lines + 1) + if (lines == line) then + codeline = this_line + break + end + bytes = (bytes + #newline + #this_line) + end + return codeline, bytes + end + local function read_line(filename, line, source) + if source then + return read_line_from_source(source, line) + else + return read_line_from_file(filename, line) + end + end + local function friendly_msg(msg, _0_0, source) + local _1_ = _0_0 + local byteend = _1_["byteend"] + local bytestart = _1_["bytestart"] + local filename = _1_["filename"] + local line = _1_["line"] + local ok, codeline, bol = pcall(read_line, filename, line, source) + local suggestions0 = suggest(msg) + local out = {msg, ""} + if (ok and codeline) then + table.insert(out, codeline) + end + if (ok and codeline and bytestart and byteend) then + table.insert(out, (string.rep(" ", (bytestart - bol - 1)) .. "^" .. string.rep("^", math.min((byteend - bytestart), ((bol + #codeline) - bytestart))))) + end + if (ok and codeline and bytestart and not byteend) then + table.insert(out, (string.rep("-", (bytestart - bol - 1)) .. "^")) + table.insert(out, "") + end + if suggestions0 then + for _, suggestion in ipairs(suggestions0) do + table.insert(out, ("* Try %s."):format(suggestion)) + end + end + return table.concat(out, "\n") + end + local function assert_compile(condition, msg, ast, source) + if not condition then + local _1_ = ast_source(ast) + local filename = _1_["filename"] + local line = _1_["line"] + error(friendly_msg(("Compile error in %s:%s\n %s"):format((filename or "unknown"), (line or "?"), msg), ast_source(ast), source), 0) + end + return condition + end + local function parse_error(msg, filename, line, bytestart, source) + return error(friendly_msg(("Parse error in %s:%s\n %s"):format(filename, line, msg), {bytestart = bytestart, filename = filename, line = line}, source), 0) + end + return {["assert-compile"] = assert_compile, ["parse-error"] = parse_error} +end +package.preload["fennel.parser"] = package.preload["fennel.parser"] or function(...) + local utils = require("fennel.utils") + local friend = require("fennel.friend") + local unpack = (table.unpack or _G.unpack) + local function granulate(getchunk) + local c, index, done_3f = "", 1, false + local function _0_(parser_state) + if not done_3f then + if (index <= #c) then + local b = c:byte(index) + index = (index + 1) + return b + else + local _1_0, _2_0, _3_0 = getchunk(parser_state) + local _4_ + do + local char = _1_0 + _4_ = ((nil ~= _1_0) and (char ~= "")) + end + if _4_ then + local char = _1_0 + c = char + index = 2 + return c:byte() + else + local _ = _1_0 + done_3f = true + return nil + end + end + end + end + local function _1_() + c = "" + return nil + end + return _0_, _1_ + end + local function string_stream(str) + local str0 = str:gsub("^#!", ";;") + local index = 1 + local function _0_() + local r = str0:byte(index) + index = (index + 1) + return r + end + return _0_ + end + local delims = {[123] = 125, [125] = true, [40] = 41, [41] = true, [91] = 93, [93] = true} + local function whitespace_3f(b) + return ((b == 32) or ((b >= 9) and (b <= 13))) + end + local function sym_char_3f(b) + local b0 = nil + if ("number" == type(b)) then + b0 = b + else + b0 = string.byte(b) + end + return ((b0 > 32) and not delims[b0] and (b0 ~= 127) and (b0 ~= 34) and (b0 ~= 39) and (b0 ~= 126) and (b0 ~= 59) and (b0 ~= 44) and (b0 ~= 64) and (b0 ~= 96)) + end + local prefixes = {[35] = "hashfn", [39] = "quote", [44] = "unquote", [96] = "quote"} + local function parser(getbyte, filename, options) + local stack = {} + local line = 1 + local byteindex = 0 + local lastb = nil + local function ungetb(ub) + if (ub == 10) then + line = (line - 1) + end + byteindex = (byteindex - 1) + lastb = ub + return nil + end + local function getb() + local r = nil + if lastb then + r, lastb = lastb, nil + else + r = getbyte({["stack-size"] = #stack}) + end + byteindex = (byteindex + 1) + if (r == 10) then + line = (line + 1) + end + return r + end + local function parse_error(msg, byteindex_override) + local _0_ = (options or utils.root.options or {}) + local source = _0_["source"] + local unfriendly = _0_["unfriendly"] + utils.root.reset() + if unfriendly then + return error(string.format("Parse error in %s:%s: %s", (filename or "unknown"), (line or "?"), msg), 0) + else + return friend["parse-error"](msg, (filename or "unknown"), (line or "?"), (byteindex_override or byteindex), source) + end + end + local function parse_stream() + local whitespace_since_dispatch, done_3f, retval = true + local function dispatch(v) + local _0_0 = stack[#stack] + if (_0_0 == nil) then + retval, done_3f, whitespace_since_dispatch = v, true, false + return nil + elseif ((type(_0_0) == "table") and (nil ~= _0_0.prefix)) then + local prefix = _0_0.prefix + table.remove(stack) + return dispatch(utils.list(utils.sym(prefix), v)) + elseif (nil ~= _0_0) then + local top = _0_0 + whitespace_since_dispatch = false + return table.insert(top, v) + end + end + local function badend() + local accum = utils.map(stack, "closer") + local _0_ + if (#stack == 1) then + _0_ = "" + else + _0_ = "s" + end + return parse_error(string.format("expected closing delimiter%s %s", _0_, string.char(unpack(accum)))) + end + local function skip_whitespace(b) + if (b and whitespace_3f(b)) then + whitespace_since_dispatch = true + return skip_whitespace(getb()) + elseif (not b and (#stack > 0)) then + return badend() + else + return b + end + end + local function parse_comment(b, contents) + if (b and (10 ~= b)) then + local function _1_() + local _0_0 = contents + table.insert(_0_0, string.char(b)) + return _0_0 + end + return parse_comment(getb(), _1_()) + elseif (options and options.comments) then + return dispatch(utils.comment(table.concat(contents))) + else + return b + end + end + local function open_table(b) + if not whitespace_since_dispatch then + parse_error(("expected whitespace before opening delimiter " .. string.char(b))) + end + return table.insert(stack, {bytestart = byteindex, closer = delims[b], filename = filename, line = line}) + end + local function close_list(list) + return dispatch(setmetatable(list, getmetatable(utils.list()))) + end + local function close_sequence(tbl) + local val = utils.sequence(unpack(tbl)) + for k, v in pairs(tbl) do + getmetatable(val)[k] = v + end + return dispatch(val) + end + local function close_curly_table(tbl) + local val = {} + if ((#tbl % 2) ~= 0) then + byteindex = (byteindex - 1) + parse_error("expected even number of values in table literal") + end + setmetatable(val, tbl) + for i = 1, #tbl, 2 do + if ((tostring(tbl[i]) == ":") and utils["sym?"](tbl[(i + 1)]) and utils["sym?"](tbl[i])) then + tbl[i] = tostring(tbl[(i + 1)]) + end + val[tbl[i]] = tbl[(i + 1)] + end + return dispatch(val) + end + local function close_table(b) + local top = table.remove(stack) + if (top == nil) then + parse_error(("unexpected closing delimiter " .. string.char(b))) + end + if (top.closer ~= b) then + parse_error(("mismatched closing delimiter " .. string.char(b) .. ", expected " .. string.char(top.closer))) + end + top.byteend = byteindex + if (b == 41) then + return close_list(top) + elseif (b == 93) then + return close_sequence(top) + else + return close_curly_table(top) + end + end + local function parse_string_loop(chars, b, state) + table.insert(chars, b) + local state0 = nil + do + local _0_0 = {state, b} + if ((type(_0_0) == "table") and (_0_0[1] == "base") and (_0_0[2] == 92)) then + state0 = "backslash" + elseif ((type(_0_0) == "table") and (_0_0[1] == "base") and (_0_0[2] == 34)) then + state0 = "done" + else + local _ = _0_0 + state0 = "base" + end + end + if (b and (state0 ~= "done")) then + return parse_string_loop(chars, getb(), state0) + else + return b + end + end + local function escape_char(c) + return ({[10] = "\\n", [11] = "\\v", [12] = "\\f", [13] = "\\r", [7] = "\\a", [8] = "\\b", [9] = "\\t"})[c:byte()] + end + local function parse_string() + table.insert(stack, {closer = 34}) + local chars = {34} + if not parse_string_loop(chars, getb(), "base") then + badend() + end + table.remove(stack) + local raw = string.char(unpack(chars)) + local formatted = raw:gsub("[\7-\13]", escape_char) + local load_fn = (rawget(_G, "loadstring") or load)(("return " .. formatted)) + return dispatch(load_fn()) + end + local function parse_prefix(b) + table.insert(stack, {prefix = prefixes[b]}) + local nextb = getb() + if whitespace_3f(nextb) then + if (b ~= 35) then + parse_error("invalid whitespace after quoting prefix") + end + table.remove(stack) + dispatch(utils.sym("#")) + end + return ungetb(nextb) + end + local function parse_sym_loop(chars, b) + if (b and sym_char_3f(b)) then + table.insert(chars, b) + return parse_sym_loop(chars, getb()) + else + if b then + ungetb(b) + end + return chars + end + end + local function parse_number(rawstr) + local number_with_stripped_underscores = (not rawstr:find("^_") and rawstr:gsub("_", "")) + if rawstr:match("^%d") then + dispatch((tonumber(number_with_stripped_underscores) or parse_error(("could not read number \"" .. rawstr .. "\"")))) + return true + else + local _0_0 = tonumber(number_with_stripped_underscores) + if (nil ~= _0_0) then + local x = _0_0 + dispatch(x) + return true + else + local _ = _0_0 + return false + end + end + end + local function check_malformed_sym(rawstr) + if (rawstr:match("^~") and (rawstr ~= "~=")) then + return parse_error("illegal character: ~") + elseif rawstr:match("%.[0-9]") then + return parse_error(("can't start multisym segment " .. "with a digit: " .. rawstr), (((byteindex - #rawstr) + rawstr:find("%.[0-9]")) + 1)) + elseif (rawstr:match("[%.:][%.:]") and (rawstr ~= "..") and (rawstr ~= "$...")) then + return parse_error(("malformed multisym: " .. rawstr), ((byteindex - #rawstr) + 1 + rawstr:find("[%.:][%.:]"))) + elseif rawstr:match(":.+[%.:]") then + return parse_error(("method must be last component " .. "of multisym: " .. rawstr), ((byteindex - #rawstr) + rawstr:find(":.+[%.:]"))) + end + end + local function parse_sym(b) + local bytestart = byteindex + local rawstr = string.char(unpack(parse_sym_loop({b}, getb()))) + if (rawstr == "true") then + return dispatch(true) + elseif (rawstr == "false") then + return dispatch(false) + elseif (rawstr == "...") then + return dispatch(utils.varg()) + elseif rawstr:match("^:.+$") then + return dispatch(rawstr:sub(2)) + elseif parse_number(rawstr) then + return nil + elseif check_malformed_sym(rawstr) then + return nil + else + return dispatch(utils.sym(rawstr, nil, {byteend = byteindex, bytestart = bytestart, filename = filename, line = line})) + end + end + local function parse_loop(b) + if not b then + elseif (b == 59) then + parse_comment(getb(), {";"}) + elseif (type(delims[b]) == "number") then + open_table(b) + elseif delims[b] then + close_table(b) + elseif (b == 34) then + parse_string(b) + elseif prefixes[b] then + parse_prefix(b) + elseif (sym_char_3f(b) or (b == string.byte("~"))) then + parse_sym(b) + else + parse_error(("illegal character: " .. string.char(b))) + end + if not b then + return nil + elseif done_3f then + return true, retval + else + return parse_loop(skip_whitespace(getb())) + end + end + return parse_loop(skip_whitespace(getb())) + end + local function _0_() + stack = {} + return nil + end + return parse_stream, _0_ + end + return {["string-stream"] = string_stream, ["sym-char?"] = sym_char_3f, granulate = granulate, parser = parser} +end +local utils = nil +package.preload["fennel.utils"] = package.preload["fennel.utils"] or function(...) + local function stablepairs(t) + local keys = {} + local succ = {} + for k in pairs(t) do + table.insert(keys, k) + end + local function _0_(a, b) + return (tostring(a) < tostring(b)) + end + table.sort(keys, _0_) + for i, k in ipairs(keys) do + succ[k] = keys[(i + 1)] + end + local function stablenext(tbl, idx) + if (idx == nil) then + return keys[1], tbl[keys[1]] + else + return succ[idx], succ[idx] and tbl[succ[idx]] + end + end + return stablenext, t, nil + end + local function map(t, f, out) + local out0 = (out or {}) + local f0 = nil + if (type(f) == "function") then + f0 = f + else + local s = f + local function _0_(x) + return x[s] + end + f0 = _0_ + end + for _, x in ipairs(t) do + local _1_0 = f0(x) + if (nil ~= _1_0) then + local v = _1_0 + table.insert(out0, v) + end + end + return out0 + end + local function kvmap(t, f, out) + local out0 = (out or {}) + local f0 = nil + if (type(f) == "function") then + f0 = f + else + local s = f + local function _0_(x) + return x[s] + end + f0 = _0_ + end + for k, x in stablepairs(t) do + local _1_0, _2_0 = f0(k, x) + if ((nil ~= _1_0) and (nil ~= _2_0)) then + local key = _1_0 + local value = _2_0 + out0[key] = value + elseif (nil ~= _1_0) then + local value = _1_0 + table.insert(out0, value) + end + end + return out0 + end + local function copy(from, to) + local to0 = (to or {}) + for k, v in pairs((from or {})) do + to0[k] = v + end + return to0 + end + local function member_3f(x, tbl, n) + local _0_0 = tbl[(n or 1)] + if (_0_0 == x) then + return true + elseif (_0_0 == nil) then + return false + else + local _ = _0_0 + return member_3f(x, tbl, ((n or 1) + 1)) + end + end + local function allpairs(tbl) + assert((type(tbl) == "table"), "allpairs expects a table") + local t = tbl + local seen = {} + local function allpairs_next(_, state) + local next_state, value = next(t, state) + if seen[next_state] then + return allpairs_next(nil, next_state) + elseif next_state then + seen[next_state] = true + return next_state, value + else + local meta = getmetatable(t) + if (meta and meta.__index) then + t = meta.__index + return allpairs_next(t) + end + end + end + return allpairs_next + end + local function deref(self) + return self[1] + end + local nil_sym = nil + local function list__3estring(self, tostring2) + local safe, max = {}, 0 + for k in pairs(self) do + if ((type(k) == "number") and (k > max)) then + max = k + end + end + for i = 1, max do + safe[i] = (((self[i] == nil) and nil_sym) or self[i]) + end + return ("(" .. table.concat(map(safe, (tostring2 or tostring)), " ", 1, max) .. ")") + end + local symbol_mt = {"SYMBOL", __fennelview = deref, __tostring = deref} + local expr_mt = {"EXPR", __tostring = deref} + local list_mt = {"LIST", __fennelview = list__3estring, __tostring = list__3estring} + local comment_mt = {"COMMENT", __fennelview = deref, __tostring = deref} + local sequence_marker = {"SEQUENCE"} + local vararg = setmetatable({"..."}, {"VARARG", __fennelview = deref, __tostring = deref}) + local getenv = nil + local function _0_() + return nil + end + getenv = ((os and os.getenv) or _0_) + local function debug_on_3f(flag) + local level = (getenv("FENNEL_DEBUG") or "") + return ((level == "all") or level:find(flag)) + end + local function list(...) + return setmetatable({...}, list_mt) + end + local function sym(str, scope, source) + local s = {str, scope = scope} + for k, v in pairs((source or {})) do + if (type(k) == "string") then + s[k] = v + end + end + return setmetatable(s, symbol_mt) + end + nil_sym = sym("nil") + local function sequence(...) + return setmetatable({...}, {sequence = sequence_marker}) + end + local function expr(strcode, etype) + return setmetatable({strcode, type = etype}, expr_mt) + end + local function comment_2a(contents) + return setmetatable({contents}, comment_mt) + end + local function varg() + return vararg + end + local function expr_3f(x) + return ((type(x) == "table") and (getmetatable(x) == expr_mt) and x) + end + local function varg_3f(x) + return ((x == vararg) and x) + end + local function list_3f(x) + return ((type(x) == "table") and (getmetatable(x) == list_mt) and x) + end + local function sym_3f(x) + return ((type(x) == "table") and (getmetatable(x) == symbol_mt) and x) + end + local function table_3f(x) + return ((type(x) == "table") and (x ~= vararg) and (getmetatable(x) ~= list_mt) and (getmetatable(x) ~= symbol_mt) and x) + end + local function sequence_3f(x) + local mt = ((type(x) == "table") and getmetatable(x)) + return (mt and (mt.sequence == sequence_marker) and x) + end + local function comment_3f(x) + return ((type(x) == "table") and (getmetatable(x) == comment_mt) and x) + end + local function multi_sym_3f(str) + if sym_3f(str) then + return multi_sym_3f(tostring(str)) + elseif (type(str) ~= "string") then + return false + else + local parts = {} + for part in str:gmatch("[^%.%:]+[%.%:]?") do + local last_char = part:sub(( - 1)) + if (last_char == ":") then + parts["multi-sym-method-call"] = true + end + if ((last_char == ":") or (last_char == ".")) then + parts[(#parts + 1)] = part:sub(1, ( - 2)) + else + parts[(#parts + 1)] = part + end + end + return ((#parts > 0) and (str:match("%.") or str:match(":")) and not str:match("%.%.") and (str:byte() ~= string.byte(".")) and (str:byte(( - 1)) ~= string.byte(".")) and parts) + end + end + local function quoted_3f(symbol) + return symbol.quoted + end + local function walk_tree(root, f, custom_iterator) + local function walk(iterfn, parent, idx, node) + if f(idx, node, parent) then + for k, v in iterfn(node) do + walk(iterfn, node, k, v) + end + return nil + end + end + walk((custom_iterator or pairs), nil, nil, root) + return root + end + local lua_keywords = {"and", "break", "do", "else", "elseif", "end", "false", "for", "function", "if", "in", "local", "nil", "not", "or", "repeat", "return", "then", "true", "until", "while", "goto"} + for i, v in ipairs(lua_keywords) do + lua_keywords[v] = i + end + local function valid_lua_identifier_3f(str) + return (str:match("^[%a_][%w_]*$") and not lua_keywords[str]) + end + local propagated_options = {"allowedGlobals", "indent", "correlate", "useMetadata", "env", "compiler-env", "compilerEnv"} + local function propagate_options(options, subopts) + for _, name in ipairs(propagated_options) do + subopts[name] = options[name] + end + return subopts + end + local root = nil + local function _1_() + end + root = {chunk = nil, options = nil, reset = _1_, scope = nil} + root["set-reset"] = function(_2_0) + local _3_ = _2_0 + local chunk = _3_["chunk"] + local options = _3_["options"] + local reset = _3_["reset"] + local scope = _3_["scope"] + root.reset = function() + root.chunk, root.scope, root.options, root.reset = chunk, scope, options, reset + return nil + end + return root.reset + end + local function hook(event, ...) + if (root.options and root.options.plugins) then + for _, plugin in ipairs(root.options.plugins) do + local _3_0 = plugin[event] + if (nil ~= _3_0) then + local f = _3_0 + f(...) + end + end + return nil + end + end + return {["comment?"] = comment_3f, ["debug-on?"] = debug_on_3f, ["expr?"] = expr_3f, ["list?"] = list_3f, ["lua-keywords"] = lua_keywords, ["member?"] = member_3f, ["multi-sym?"] = multi_sym_3f, ["propagate-options"] = propagate_options, ["quoted?"] = quoted_3f, ["sequence?"] = sequence_3f, ["sym?"] = sym_3f, ["table?"] = table_3f, ["valid-lua-identifier?"] = valid_lua_identifier_3f, ["varg?"] = varg_3f, ["walk-tree"] = walk_tree, allpairs = allpairs, comment = comment_2a, copy = copy, deref = deref, expr = expr, hook = hook, kvmap = kvmap, list = list, map = map, path = table.concat({"./?.fnl", "./?/init.fnl", getenv("FENNEL_PATH")}, ";"), root = root, sequence = sequence, stablepairs = stablepairs, sym = sym, varg = varg} +end +utils = require("fennel.utils") +local parser = require("fennel.parser") +local compiler = require("fennel.compiler") +local specials = require("fennel.specials") +local repl = require("fennel.repl") +local view = require("fennel.view") +local function get_env(env) + if (env == "_COMPILER") then + local env0 = specials["make-compiler-env"](nil, compiler.scopes.compiler, {}) + local mt = getmetatable(env0) + mt.__index = _G + return specials["wrap-env"](env0) + else + return (env and specials["wrap-env"](env)) + end +end +local function eval(str, options, ...) + local opts = utils.copy(options) + local _ = nil + if ((opts.allowedGlobals == nil) and not getmetatable(opts.env)) then + opts.allowedGlobals = specials["current-global-names"](opts.env) + _ = nil + else + _ = nil + end + local env = get_env(opts.env) + local lua_source = compiler["compile-string"](str, opts) + local loader = nil + local function _1_(...) + if opts.filename then + return ("@" .. opts.filename) + else + return str + end + end + loader = specials["load-code"](lua_source, env, _1_(...)) + opts.filename = nil + return loader(...) +end +local function dofile_2a(filename, options, ...) + local opts = utils.copy(options) + local f = assert(io.open(filename, "rb")) + local source = assert(f:read("*all"), ("Could not read " .. filename)) + f:close() + opts.filename = filename + return eval(source, opts, ...) +end +local mod = {["compile-stream"] = compiler["compile-stream"], ["compile-string"] = compiler["compile-string"], ["list?"] = utils["list?"], ["load-code"] = specials["load-code"], ["macro-loaded"] = specials["macro-loaded"], ["make-searcher"] = specials["make-searcher"], ["search-module"] = specials["search-module"], ["sequence?"] = utils["sequence?"], ["string-stream"] = parser["string-stream"], ["sym-char?"] = parser["sym-char?"], ["sym?"] = utils["sym?"], compile = compiler.compile, compile1 = compiler.compile1, compileStream = compiler["compile-stream"], compileString = compiler["compile-string"], doc = specials.doc, dofile = dofile_2a, eval = eval, gensym = compiler.gensym, granulate = parser.granulate, list = utils.list, loadCode = specials["load-code"], macroLoaded = specials["macro-loaded"], makeSearcher = specials["make-searcher"], make_searcher = specials["make-searcher"], mangle = compiler["global-mangling"], metadata = compiler.metadata, parser = parser.parser, path = utils.path, repl = repl, scope = compiler["make-scope"], searchModule = specials["search-module"], searcher = specials["make-searcher"](), sequence = utils.sequence, stringStream = parser["string-stream"], sym = utils.sym, traceback = compiler.traceback, unmangle = compiler["global-unmangling"], varg = utils.varg, version = "0.8.0", view = view} +utils["fennel-module"] = mod +do + local builtin_macros = [===[;; This module contains all the built-in Fennel macros. Unlike all the other + ;; modules that are loaded by the old bootstrap compiler, this runs in the + ;; compiler scope of the version of the compiler being defined. + + ;; The code for these macros is somewhat idiosyncratic because it cannot use any + ;; macros which have not yet been defined. + + ;; TODO: some of these macros modify their arguments; we should stop doing that, + ;; but in a way that preserves file/line metadata. + + (fn -> [val ...] + "Thread-first macro. + Take the first value and splice it into the second form as its first argument. + The value of the second form is spliced into the first arg of the third, etc." + (var x val) + (each [_ e (ipairs [...])] + (let [elt (if (list? e) e (list e))] + (table.insert elt 2 x) + (set x elt))) + x) + + (fn ->> [val ...] + "Thread-last macro. + Same as ->, except splices the value into the last position of each form + rather than the first." + (var x val) + (each [_ e (pairs [...])] + (let [elt (if (list? e) e (list e))] + (table.insert elt x) + (set x elt))) + x) + + (fn -?> [val ...] + "Nil-safe thread-first macro. + Same as -> except will short-circuit with nil when it encounters a nil value." + (if (= 0 (select "#" ...)) + val + (let [els [...] + e (table.remove els 1) + el (if (list? e) e (list e)) + tmp (gensym)] + (table.insert el 2 tmp) + `(let [,tmp ,val] + (if ,tmp + (-?> ,el ,(unpack els)) + ,tmp))))) + + (fn -?>> [val ...] + "Nil-safe thread-last macro. + Same as ->> except will short-circuit with nil when it encounters a nil value." + (if (= 0 (select "#" ...)) + val + (let [els [...] + e (table.remove els 1) + el (if (list? e) e (list e)) + tmp (gensym)] + (table.insert el tmp) + `(let [,tmp ,val] + (if ,tmp + (-?>> ,el ,(unpack els)) + ,tmp))))) + + (fn doto [val ...] + "Evaluates val and splices it into the first argument of subsequent forms." + (let [name (gensym) + form `(let [,name ,val])] + (each [_ elt (pairs [...])] + (table.insert elt 2 name) + (table.insert form elt)) + (table.insert form name) + form)) + + (fn when [condition body1 ...] + "Evaluate body for side-effects only when condition is truthy." + (assert body1 "expected body") + `(if ,condition + (do ,body1 ,...))) + + (fn with-open [closable-bindings ...] + "Like `let`, but invokes (v:close) on each binding after evaluating the body. + The body is evaluated inside `xpcall` so that bound values will be closed upon + encountering an error before propagating it." + (let [bodyfn `(fn [] ,...) + closer `(fn close-handlers# [ok# ...] (if ok# ... + (error ... 0))) + traceback `(. (or package.loaded.fennel debug) :traceback)] + (for [i 1 (# closable-bindings) 2] + (assert (sym? (. closable-bindings i)) + "with-open only allows symbols in bindings") + (table.insert closer 4 `(: ,(. closable-bindings i) :close))) + `(let ,closable-bindings ,closer + (close-handlers# (xpcall ,bodyfn ,traceback))))) + + (fn collect [iter-tbl key-value-expr ...] + "Returns a table made by running an iterator and evaluating an expression + that returns key-value pairs to be inserted sequentially into the table. + This can be thought of as a \"table comprehension\". The provided key-value + expression must return either 2 values, or nil. + + For example, + (collect [k v (pairs {:apple \"red\" :orange \"orange\"})] + (values v k)) + returns + {:red \"apple\" :orange \"orange\"}" + (assert (and (sequence? iter-tbl) (>= (length iter-tbl) 2)) + "expected iterator binding table") + (assert (not= nil key-value-expr) + "expected key-value expression") + (assert (= nil ...) + "expected exactly one body expression. Wrap multiple expressions with do") + `(let [tbl# {}] + (each ,iter-tbl + (match ,key-value-expr + (k# v#) (tset tbl# k# v#))) + tbl#)) + + (fn icollect [iter-tbl value-expr ...] + "Returns a sequential table made by running an iterator and evaluating an + expression that returns values to be inserted sequentially into the table. + This can be thought of as a \"list comprehension\". + + For example, + (icollect [_ v (ipairs [1 2 3 4 5])] (when (> v 2) (* v v))) + returns + [9 16 25]" + (assert (and (sequence? iter-tbl) (>= (length iter-tbl) 2)) + "expected iterator binding table") + (assert (not= nil value-expr) + "expected table value expression") + (assert (= nil ...) + "expected exactly one body expression. Wrap multiple expressions with do") + `(let [tbl# []] + (each ,iter-tbl + (tset tbl# (+ (length tbl#) 1) ,value-expr)) + tbl#)) + + (fn partial [f ...] + "Returns a function with all arguments partially applied to f." + (let [body (list f ...)] + (table.insert body _VARARG) + `(fn [,_VARARG] ,body))) + + (fn pick-args [n f] + "Creates a function of arity n that applies its arguments to f. + + For example, + (pick-args 2 func) + expands to + (fn [_0_ _1_] (func _0_ _1_))" + (assert (and (= (type n) :number) (= n (math.floor n)) (>= n 0)) + "Expected n to be an integer literal >= 0.") + (let [bindings []] + (for [i 1 n] (tset bindings i (gensym))) + `(fn ,bindings (,f ,(unpack bindings))))) + + (fn pick-values [n ...] + "Like the `values` special, but emits exactly n values. + + For example, + (pick-values 2 ...) + expands to + (let [(_0_ _1_) ...] + (values _0_ _1_))" + (assert (and (= :number (type n)) (>= n 0) (= n (math.floor n))) + "Expected n to be an integer >= 0") + (let [let-syms (list) + let-values (if (= 1 (select :# ...)) ... `(values ,...))] + (for [i 1 n] (table.insert let-syms (gensym))) + (if (= n 0) `(values) + `(let [,let-syms ,let-values] (values ,(unpack let-syms)))))) + + (fn lambda [...] + "Function literal with arity checking. + Will throw an exception if a declared argument is passed in as nil, unless + that argument name begins with ?." + (let [args [...] + has-internal-name? (sym? (. args 1)) + arglist (if has-internal-name? (. args 2) (. args 1)) + docstring-position (if has-internal-name? 3 2) + has-docstring? (and (> (# args) docstring-position) + (= :string (type (. args docstring-position)))) + arity-check-position (- 4 (if has-internal-name? 0 1) + (if has-docstring? 0 1)) + empty-body? (< (# args) arity-check-position)] + (fn check! [a] + (if (table? a) + (each [_ a (pairs a)] + (check! a)) + (let [as (tostring a)] + (and (not (as:match "^?")) (not= as "&") (not= as "_") (not= as "..."))) + (table.insert args arity-check-position + `(assert (not= nil ,a) + (string.format "Missing argument %s on %s:%s" + ,(tostring a) + ,(or a.filename "unknown") + ,(or a.line "?")))))) + (assert (= :table (type arglist)) "expected arg list") + (each [_ a (ipairs arglist)] + (check! a)) + (if empty-body? + (table.insert args (sym :nil))) + `(fn ,(unpack args)))) + + (fn macro [name ...] + "Define a single macro." + (assert (sym? name) "expected symbol for macro name") + (local args [...]) + `(macros { ,(tostring name) (fn ,(unpack args))})) + + (fn macrodebug [form return?] + "Print the resulting form after performing macroexpansion. + With a second argument, returns expanded form as a string instead of printing." + (let [handle (if return? `do `print)] + `(,handle ,(view (macroexpand form _SCOPE))))) + + (fn import-macros [binding1 module-name1 ...] + "Binds a table of macros from each macro module according to a binding form. + Each binding form can be either a symbol or a k/v destructuring table. + Example: + (import-macros mymacros :my-macros ; bind to symbol + {:macro1 alias : macro2} :proj.macros) ; import by name" + (assert (and binding1 module-name1 (= 0 (% (select :# ...) 2))) + "expected even number of binding/modulename pairs") + (for [i 1 (select :# binding1 module-name1 ...) 2] + (let [(binding modname) (select i binding1 module-name1 ...) + ;; generate a subscope of current scope, use require-macros + ;; to bring in macro module. after that, we just copy the + ;; macros from subscope to scope. + scope (get-scope) + subscope (fennel.scope scope)] + (_SPECIALS.require-macros `(require-macros ,modname) subscope {} ast) + (if (sym? binding) + ;; bind whole table of macros to table bound to symbol + (do (tset scope.macros (. binding 1) {}) + (each [k v (pairs subscope.macros)] + (tset (. scope.macros (. binding 1)) k v))) + + ;; 1-level table destructuring for importing individual macros + (table? binding) + (each [macro-name [import-key] (pairs binding)] + (assert (= :function (type (. subscope.macros macro-name))) + (.. "macro " macro-name " not found in module " + (tostring modname))) + (tset scope.macros import-key (. subscope.macros macro-name)))))) + nil) + + ;;; Pattern matching + + (fn match-values [vals pattern unifications match-pattern] + (let [condition `(and) + bindings []] + (each [i pat (ipairs pattern)] + (let [(subcondition subbindings) (match-pattern [(. vals i)] pat + unifications)] + (table.insert condition subcondition) + (each [_ b (ipairs subbindings)] + (table.insert bindings b)))) + (values condition bindings))) + + (fn match-table [val pattern unifications match-pattern] + (let [condition `(and (= (type ,val) :table)) + bindings []] + (each [k pat (pairs pattern)] + (if (and (sym? pat) (= "&" (tostring pat))) + (do (assert (not (. pattern (+ k 2))) + "expected rest argument before last parameter") + (table.insert bindings (. pattern (+ k 1))) + (table.insert bindings [`(select ,k ((or table.unpack + _G.unpack) + ,val))])) + (and (= :number (type k)) + (= "&" (tostring (. pattern (- k 1))))) + nil ; don't process the pattern right after &; already got it + (let [subval `(. ,val ,k) + (subcondition subbindings) (match-pattern [subval] pat + unifications)] + (table.insert condition subcondition) + (each [_ b (ipairs subbindings)] + (table.insert bindings b))))) + (values condition bindings))) + + (fn match-pattern [vals pattern unifications] + "Takes the AST of values and a single pattern and returns a condition + to determine if it matches as well as a list of bindings to + introduce for the duration of the body if it does match." + ;; we have to assume we're matching against multiple values here until we + ;; know we're either in a multi-valued clause (in which case we know the # + ;; of vals) or we're not, in which case we only care about the first one. + (let [[val] vals] + (if (or (and (sym? pattern) ; unification with outer locals (or nil) + (not= :_ (tostring pattern)) ; never unify _ + (or (in-scope? pattern) + (= :nil (tostring pattern)))) + (and (multi-sym? pattern) + (in-scope? (. (multi-sym? pattern) 1)))) + (values `(= ,val ,pattern) []) + ;; unify a local we've seen already + (and (sym? pattern) (. unifications (tostring pattern))) + (values `(= ,(. unifications (tostring pattern)) ,val) []) + ;; bind a fresh local + (sym? pattern) + (let [wildcard? (: (tostring pattern) :find "^_")] + (if (not wildcard?) (tset unifications (tostring pattern) val)) + (values (if (or wildcard? (string.find (tostring pattern) "^?")) + true `(not= ,(sym :nil) ,val)) + [pattern val])) + ;; guard clause + (and (list? pattern) (sym? (. pattern 2)) (= :? (tostring (. pattern 2)))) + (let [(pcondition bindings) (match-pattern vals (. pattern 1) + unifications) + condition `(and ,pcondition)] + (for [i 3 (# pattern)] ; splice in guard clauses + (table.insert condition (. pattern i))) + (values `(let ,bindings ,condition) bindings)) + + ;; multi-valued patterns (represented as lists) + (list? pattern) + (match-values vals pattern unifications match-pattern) + ;; table patterns + (= (type pattern) :table) + (match-table val pattern unifications match-pattern) + ;; literal value + (values `(= ,val ,pattern) [])))) + + (fn match-condition [vals clauses] + "Construct the actual `if` AST for the given match values and clauses." + (if (not= 0 (% (length clauses) 2)) ; treat odd final clause as default + (table.insert clauses (length clauses) (sym :_))) + (let [out `(if)] + (for [i 1 (length clauses) 2] + (let [pattern (. clauses i) + body (. clauses (+ i 1)) + (condition bindings) (match-pattern vals pattern {})] + (table.insert out condition) + (table.insert out `(let ,bindings ,body)))) + out)) + + (fn match-val-syms [clauses] + "How many multi-valued clauses are there? return a list of that many gensyms." + (let [syms (list (gensym))] + (for [i 1 (length clauses) 2] + (if (list? (. clauses i)) + (each [valnum (ipairs (. clauses i))] + (if (not (. syms valnum)) + (tset syms valnum (gensym)))))) + syms)) + + (fn match [val ...] + "Perform pattern matching on val. See reference for details." + (let [clauses [...] + vals (match-val-syms clauses)] + ;; protect against multiple evaluation of the value, bind against as + ;; many values as we ever match against in the clauses. + (list `let [vals val] + (match-condition vals clauses)))) + + {: -> : ->> : -?> : -?>> + : doto : when : with-open + : collect : icollect + : partial : lambda + : pick-args : pick-values + : macro : macrodebug : import-macros + : match} + ]===] + local module_name = "fennel.macros" + local _ = nil + local function _0_() + return mod + end + package.preload[module_name] = _0_ + _ = nil + local env = nil + do + local _1_0 = specials["make-compiler-env"](nil, compiler.scopes.compiler, {}) + _1_0["utils"] = utils + _1_0["fennel"] = mod + env = _1_0 + end + local built_ins = eval(builtin_macros, {allowedGlobals = false, env = env, filename = "src/fennel/macros.fnl", moduleName = module_name, scope = compiler.scopes.compiler, useMetadata = true}) + for k, v in pairs(built_ins) do + compiler.scopes.global.macros[k] = v + end + compiler.scopes.global.macros["\206\187"] = compiler.scopes.global.macros.lambda + package.preload[module_name] = nil +end +return mod diff --git a/lib/lume.lua b/lib/lume.lua new file mode 100644 index 0000000..2157891 --- /dev/null +++ b/lib/lume.lua @@ -0,0 +1,780 @@ +-- +-- lume +-- +-- Copyright (c) 2020 rxi +-- +-- 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. +-- + +local lume = { _version = "2.3.0" } + +local pairs, ipairs = pairs, ipairs +local type, assert, unpack = type, assert, unpack or table.unpack +local tostring, tonumber = tostring, tonumber +local math_floor = math.floor +local math_ceil = math.ceil +local math_atan2 = math.atan2 or math.atan +local math_sqrt = math.sqrt +local math_abs = math.abs + +local noop = function() +end + +local identity = function(x) + return x +end + +local patternescape = function(str) + return str:gsub("[%(%)%.%%%+%-%*%?%[%]%^%$]", "%%%1") +end + +local absindex = function(len, i) + return i < 0 and (len + i + 1) or i +end + +local iscallable = function(x) + if type(x) == "function" then return true end + local mt = getmetatable(x) + return mt and mt.__call ~= nil +end + +local getiter = function(x) + if lume.isarray(x) then + return ipairs + elseif type(x) == "table" then + return pairs + end + error("expected table", 3) +end + +local iteratee = function(x) + if x == nil then return identity end + if iscallable(x) then return x end + if type(x) == "table" then + return function(z) + for k, v in pairs(x) do + if z[k] ~= v then return false end + end + return true + end + end + return function(z) return z[x] end +end + + + +function lume.clamp(x, min, max) + return x < min and min or (x > max and max or x) +end + + +function lume.round(x, increment) + if increment then return lume.round(x / increment) * increment end + return x >= 0 and math_floor(x + .5) or math_ceil(x - .5) +end + + +function lume.sign(x) + return x < 0 and -1 or 1 +end + + +function lume.lerp(a, b, amount) + return a + (b - a) * lume.clamp(amount, 0, 1) +end + + +function lume.smooth(a, b, amount) + local t = lume.clamp(amount, 0, 1) + local m = t * t * (3 - 2 * t) + return a + (b - a) * m +end + + +function lume.pingpong(x) + return 1 - math_abs(1 - x % 2) +end + + +function lume.distance(x1, y1, x2, y2, squared) + local dx = x1 - x2 + local dy = y1 - y2 + local s = dx * dx + dy * dy + return squared and s or math_sqrt(s) +end + + +function lume.angle(x1, y1, x2, y2) + return math_atan2(y2 - y1, x2 - x1) +end + + +function lume.vector(angle, magnitude) + return math.cos(angle) * magnitude, math.sin(angle) * magnitude +end + + +function lume.random(a, b) + if not a then a, b = 0, 1 end + if not b then b = 0 end + return a + math.random() * (b - a) +end + + +function lume.randomchoice(t) + return t[math.random(#t)] +end + + +function lume.weightedchoice(t) + local sum = 0 + for _, v in pairs(t) do + assert(v >= 0, "weight value less than zero") + sum = sum + v + end + assert(sum ~= 0, "all weights are zero") + local rnd = lume.random(sum) + for k, v in pairs(t) do + if rnd < v then return k end + rnd = rnd - v + end +end + + +function lume.isarray(x) + return type(x) == "table" and x[1] ~= nil +end + + +function lume.push(t, ...) + local n = select("#", ...) + for i = 1, n do + t[#t + 1] = select(i, ...) + end + return ... +end + + +function lume.remove(t, x) + local iter = getiter(t) + for i, v in iter(t) do + if v == x then + if lume.isarray(t) then + table.remove(t, i) + break + else + t[i] = nil + break + end + end + end + return x +end + + +function lume.clear(t) + local iter = getiter(t) + for k in iter(t) do + t[k] = nil + end + return t +end + + +function lume.extend(t, ...) + for i = 1, select("#", ...) do + local x = select(i, ...) + if x then + for k, v in pairs(x) do + t[k] = v + end + end + end + return t +end + + +function lume.shuffle(t) + local rtn = {} + for i = 1, #t do + local r = math.random(i) + if r ~= i then + rtn[i] = rtn[r] + end + rtn[r] = t[i] + end + return rtn +end + + +function lume.sort(t, comp) + local rtn = lume.clone(t) + if comp then + if type(comp) == "string" then + table.sort(rtn, function(a, b) return a[comp] < b[comp] end) + else + table.sort(rtn, comp) + end + else + table.sort(rtn) + end + return rtn +end + + +function lume.array(...) + local t = {} + for x in ... do t[#t + 1] = x end + return t +end + + +function lume.each(t, fn, ...) + local iter = getiter(t) + if type(fn) == "string" then + for _, v in iter(t) do v[fn](v, ...) end + else + for _, v in iter(t) do fn(v, ...) end + end + return t +end + + +function lume.map(t, fn) + fn = iteratee(fn) + local iter = getiter(t) + local rtn = {} + for k, v in iter(t) do rtn[k] = fn(v) end + return rtn +end + + +function lume.all(t, fn) + fn = iteratee(fn) + local iter = getiter(t) + for _, v in iter(t) do + if not fn(v) then return false end + end + return true +end + + +function lume.any(t, fn) + fn = iteratee(fn) + local iter = getiter(t) + for _, v in iter(t) do + if fn(v) then return true end + end + return false +end + + +function lume.reduce(t, fn, first) + local started = first ~= nil + local acc = first + local iter = getiter(t) + for _, v in iter(t) do + if started then + acc = fn(acc, v) + else + acc = v + started = true + end + end + assert(started, "reduce of an empty table with no first value") + return acc +end + + +function lume.unique(t) + local rtn = {} + for k in pairs(lume.invert(t)) do + rtn[#rtn + 1] = k + end + return rtn +end + + +function lume.filter(t, fn, retainkeys) + fn = iteratee(fn) + local iter = getiter(t) + local rtn = {} + if retainkeys then + for k, v in iter(t) do + if fn(v) then rtn[k] = v end + end + else + for _, v in iter(t) do + if fn(v) then rtn[#rtn + 1] = v end + end + end + return rtn +end + + +function lume.reject(t, fn, retainkeys) + fn = iteratee(fn) + local iter = getiter(t) + local rtn = {} + if retainkeys then + for k, v in iter(t) do + if not fn(v) then rtn[k] = v end + end + else + for _, v in iter(t) do + if not fn(v) then rtn[#rtn + 1] = v end + end + end + return rtn +end + + +function lume.merge(...) + local rtn = {} + for i = 1, select("#", ...) do + local t = select(i, ...) + local iter = getiter(t) + for k, v in iter(t) do + rtn[k] = v + end + end + return rtn +end + + +function lume.concat(...) + local rtn = {} + for i = 1, select("#", ...) do + local t = select(i, ...) + if t ~= nil then + local iter = getiter(t) + for _, v in iter(t) do + rtn[#rtn + 1] = v + end + end + end + return rtn +end + + +function lume.find(t, value) + local iter = getiter(t) + for k, v in iter(t) do + if v == value then return k end + end + return nil +end + + +function lume.match(t, fn) + fn = iteratee(fn) + local iter = getiter(t) + for k, v in iter(t) do + if fn(v) then return v, k end + end + return nil +end + + +function lume.count(t, fn) + local count = 0 + local iter = getiter(t) + if fn then + fn = iteratee(fn) + for _, v in iter(t) do + if fn(v) then count = count + 1 end + end + else + if lume.isarray(t) then + return #t + end + for _ in iter(t) do count = count + 1 end + end + return count +end + + +function lume.slice(t, i, j) + i = i and absindex(#t, i) or 1 + j = j and absindex(#t, j) or #t + local rtn = {} + for x = i < 1 and 1 or i, j > #t and #t or j do + rtn[#rtn + 1] = t[x] + end + return rtn +end + + +function lume.first(t, n) + if not n then return t[1] end + return lume.slice(t, 1, n) +end + + +function lume.last(t, n) + if not n then return t[#t] end + return lume.slice(t, -n, -1) +end + + +function lume.invert(t) + local rtn = {} + for k, v in pairs(t) do rtn[v] = k end + return rtn +end + + +function lume.pick(t, ...) + local rtn = {} + for i = 1, select("#", ...) do + local k = select(i, ...) + rtn[k] = t[k] + end + return rtn +end + + +function lume.keys(t) + local rtn = {} + local iter = getiter(t) + for k in iter(t) do rtn[#rtn + 1] = k end + return rtn +end + + +function lume.clone(t) + local rtn = {} + for k, v in pairs(t) do rtn[k] = v end + return rtn +end + + +function lume.fn(fn, ...) + assert(iscallable(fn), "expected a function as the first argument") + local args = { ... } + return function(...) + local a = lume.concat(args, { ... }) + return fn(unpack(a)) + end +end + + +function lume.once(fn, ...) + local f = lume.fn(fn, ...) + local done = false + return function(...) + if done then return end + done = true + return f(...) + end +end + + +local memoize_fnkey = {} +local memoize_nil = {} + +function lume.memoize(fn) + local cache = {} + return function(...) + local c = cache + for i = 1, select("#", ...) do + local a = select(i, ...) or memoize_nil + c[a] = c[a] or {} + c = c[a] + end + c[memoize_fnkey] = c[memoize_fnkey] or {fn(...)} + return unpack(c[memoize_fnkey]) + end +end + + +function lume.combine(...) + local n = select('#', ...) + if n == 0 then return noop end + if n == 1 then + local fn = select(1, ...) + if not fn then return noop end + assert(iscallable(fn), "expected a function or nil") + return fn + end + local funcs = {} + for i = 1, n do + local fn = select(i, ...) + if fn ~= nil then + assert(iscallable(fn), "expected a function or nil") + funcs[#funcs + 1] = fn + end + end + return function(...) + for _, f in ipairs(funcs) do f(...) end + end +end + + +function lume.call(fn, ...) + if fn then + return fn(...) + end +end + + +function lume.time(fn, ...) + local start = os.clock() + local rtn = {fn(...)} + return (os.clock() - start), unpack(rtn) +end + + +local lambda_cache = {} + +function lume.lambda(str) + if not lambda_cache[str] then + local args, body = str:match([[^([%w,_ ]-)%->(.-)$]]) + assert(args and body, "bad string lambda") + local s = "return function(" .. args .. ")\nreturn " .. body .. "\nend" + lambda_cache[str] = lume.dostring(s) + end + return lambda_cache[str] +end + + +local serialize + +local serialize_map = { + [ "boolean" ] = tostring, + [ "nil" ] = tostring, + [ "string" ] = function(v) return string.format("%q", v) end, + [ "number" ] = function(v) + if v ~= v then return "0/0" -- nan + elseif v == 1 / 0 then return "1/0" -- inf + elseif v == -1 / 0 then return "-1/0" end -- -inf + return tostring(v) + end, + [ "table" ] = function(t, stk) + stk = stk or {} + if stk[t] then error("circular reference") end + local rtn = {} + stk[t] = true + for k, v in pairs(t) do + rtn[#rtn + 1] = "[" .. serialize(k, stk) .. "]=" .. serialize(v, stk) + end + stk[t] = nil + return "{" .. table.concat(rtn, ",") .. "}" + end +} + +setmetatable(serialize_map, { + __index = function(_, k) error("unsupported serialize type: " .. k) end +}) + +serialize = function(x, stk) + return serialize_map[type(x)](x, stk) +end + +function lume.serialize(x) + return serialize(x) +end + + +function lume.deserialize(str) + return lume.dostring("return " .. str) +end + + +function lume.split(str, sep) + if not sep then + return lume.array(str:gmatch("([%S]+)")) + else + assert(sep ~= "", "empty separator") + local psep = patternescape(sep) + return lume.array((str..sep):gmatch("(.-)("..psep..")")) + end +end + + +function lume.trim(str, chars) + if not chars then return str:match("^[%s]*(.-)[%s]*$") end + chars = patternescape(chars) + return str:match("^[" .. chars .. "]*(.-)[" .. chars .. "]*$") +end + + +function lume.wordwrap(str, limit) + limit = limit or 72 + local check + if type(limit) == "number" then + check = function(s) return #s >= limit end + else + check = limit + end + local rtn = {} + local line = "" + for word, spaces in str:gmatch("(%S+)(%s*)") do + local s = line .. word + if check(s) then + table.insert(rtn, line .. "\n") + line = word + else + line = s + end + for c in spaces:gmatch(".") do + if c == "\n" then + table.insert(rtn, line .. "\n") + line = "" + else + line = line .. c + end + end + end + table.insert(rtn, line) + return table.concat(rtn) +end + + +function lume.format(str, vars) + if not vars then return str end + local f = function(x) + return tostring(vars[x] or vars[tonumber(x)] or "{" .. x .. "}") + end + return (str:gsub("{(.-)}", f)) +end + + +function lume.trace(...) + local info = debug.getinfo(2, "Sl") + local t = { info.short_src .. ":" .. info.currentline .. ":" } + for i = 1, select("#", ...) do + local x = select(i, ...) + if type(x) == "number" then + x = string.format("%g", lume.round(x, .01)) + end + t[#t + 1] = tostring(x) + end + print(table.concat(t, " ")) +end + + +function lume.dostring(str) + return assert((loadstring or load)(str))() +end + + +function lume.uuid() + local fn = function(x) + local r = math.random(16) - 1 + r = (x == "x") and (r + 1) or (r % 4) + 9 + return ("0123456789abcdef"):sub(r, r) + end + return (("xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx"):gsub("[xy]", fn)) +end + + +function lume.hotswap(modname) + local oldglobal = lume.clone(_G) + local updated = {} + local function update(old, new) + if updated[old] then return end + updated[old] = true + local oldmt, newmt = getmetatable(old), getmetatable(new) + if oldmt and newmt then update(oldmt, newmt) end + for k, v in pairs(new) do + if type(v) == "table" then update(old[k], v) else old[k] = v end + end + end + local err = nil + local function onerror(e) + for k in pairs(_G) do _G[k] = oldglobal[k] end + err = lume.trim(e) + end + local ok, oldmod = pcall(require, modname) + oldmod = ok and oldmod or nil + xpcall(function() + package.loaded[modname] = nil + local newmod = require(modname) + if type(oldmod) == "table" then update(oldmod, newmod) end + for k, v in pairs(oldglobal) do + if v ~= _G[k] and type(v) == "table" then + update(v, _G[k]) + _G[k] = v + end + end + end, onerror) + package.loaded[modname] = oldmod + if err then return nil, err end + return oldmod +end + + +local ripairs_iter = function(t, i) + i = i - 1 + local v = t[i] + if v ~= nil then + return i, v + end +end + +function lume.ripairs(t) + return ripairs_iter, t, (#t + 1) +end + + +function lume.color(str, mul) + mul = mul or 1 + local r, g, b, a + r, g, b = str:match("#(%x%x)(%x%x)(%x%x)") + if r then + r = tonumber(r, 16) / 0xff + g = tonumber(g, 16) / 0xff + b = tonumber(b, 16) / 0xff + a = 1 + elseif str:match("rgba?%s*%([%d%s%.,]+%)") then + local f = str:gmatch("[%d.]+") + r = (f() or 0) / 0xff + g = (f() or 0) / 0xff + b = (f() or 0) / 0xff + a = f() or 1 + else + error(("bad color string '%s'"):format(str)) + end + return r * mul, g * mul, b * mul, a * mul +end + + +local chain_mt = {} +chain_mt.__index = lume.map(lume.filter(lume, iscallable, true), + function(fn) + return function(self, ...) + self._value = fn(self._value, ...) + return self + end + end) +chain_mt.__index.result = function(x) return x._value end + +function lume.chain(value) + return setmetatable({ _value = value }, chain_mt) +end + +setmetatable(lume, { + __call = function(_, ...) + return lume.chain(...) + end +}) + + +return lume diff --git a/lib/spawn.lua b/lib/spawn.lua new file mode 100644 index 0000000..238f4f7 --- /dev/null +++ b/lib/spawn.lua @@ -0,0 +1,44 @@ +-- adapted from https://gist.github.com/iMega/f47f5a2ae1f02d7d5769a008538fd925 + +local ffi = require 'ffi' +local C = ffi.C + +ffi.cdef([[ +typedef int32_t pid_t; +pid_t fork(void); +int open(const char *pathname, int flags, int mode); +int close(int fd); +int dup2(int oldfd, int newfd); +int execvp(const char *file, char *const argv[]); +int kill(pid_t pid, int sig); +pid_t setsid(void); +]]) + +local bor = bit.bor + +local ffi_cast = ffi.cast +local k_char_p_arr_t = ffi.typeof('const char * [?]') +local char_p_k_p_t = ffi.typeof('char * const *') + +local function spawn(args) + if not args or #args == 0 then error("couldn't tokenize cmd_line") end + + local pid = C.fork() + if pid < 0 then + error("fork failed " .. ffi.errno()) + elseif pid == 0 then -- child process + C.setsid() + local argv = k_char_p_arr_t(#args + 1) -- automatically NULL terminated + for i = 1, #args do + argv[i-1] = args[i] -- args is 1-based Lua table, argv is 0-based C array + end + + local res = C.execvp(args[1], ffi_cast(char_p_k_p_t, argv)) + if res == -1 then error("execvp failed with " .. ffi.errno()) end + -- HERE SHOULD BE UNREACHABLE!! + else + return pid + end +end + +return {spawn=spawn, kill=C.kill} diff --git a/lib/stdio.fnl b/lib/stdio.fnl new file mode 100644 index 0000000..52d6ef6 --- /dev/null +++ b/lib/stdio.fnl @@ -0,0 +1,46 @@ +(require "love.event") +(local view (require "lib.fennelview")) + +;; This module exists in order to expose stdio over a channel so that it +;; can be used in a non-blocking way from another thread. + +(local (event channel) ...) + +(when channel + (let [prompt (fn [] (io.write "> ") (io.flush) (io.read "*l"))] + ((fn looper [input] + (when input + ;; This is consumed by love.handlers[event] + (love.event.push event input) + (let [output (: channel :demand)] + ;; There is probably a more efficient way of determining an error + (if (and (. output 2) (= "Error:" (. output 2))) + (print (view output)) + (each [_ ret (ipairs output)] + (print ret)))) + (io.flush) + (looper (prompt)))) (prompt)))) + +{:start (fn start-repl [] + + (let [code (love.filesystem.read "lib/stdio.fnl") + luac (if code + (love.filesystem.newFileData + (fennel.compileString code) "io") + (love.filesystem.read "lib/stdio.lua")) + thread (love.thread.newThread luac) + io-channel (love.thread.newChannel) + coro (coroutine.create fennel.repl) + out (fn [val] + (: io-channel :push val)) + options {:readChunk coroutine.yield + :onValues out + :onError (fn [kind ...] (out [kind "Error:" ...])) + :pp view + :moduleName "lib.fennel"}] + ;; this thread will send "eval" events for us to consume: + (coroutine.resume coro options) + (: thread :start "eval" io-channel) + (set love.handlers.eval + (fn [input] + (coroutine.resume coro (.. input "\n"))))))} diff --git a/lib/util.fnl b/lib/util.fnl new file mode 100644 index 0000000..dc071ad --- /dev/null +++ b/lib/util.fnl @@ -0,0 +1,83 @@ +(local lume (require :lib.lume)) +(local json (require :lib.dkjson)) +(local core (require :core)) + +(fn string.fromhex [str] + (str:gsub ".." (fn [cc] (string.char (tonumber cc 16))))) +(fn string.tohex [str] + (str:gsub "." (fn [c] (string.format "%02X" (string.byte c))))) + +(fn lo [v] (bit.band v 0xff)) +(fn hi [v] (bit.band (bit.rshift v 8) 0xff)) +(fn int8-to-bytes [i] + (string.char (lo i))) +(fn int16-to-bytes [i] + (string.char (lo i) (hi i))) +(fn int24-to-bytes [i] + (string.char (lo i) (hi i) (bit.band (bit.rshift i 16) 0xff))) +(fn bytes-to-uint8 [b ?offset] + (string.byte b (+ 1 (or ?offset 0)) (+ 1 (or ?offset 0)))) +(fn bytes-to-uint16 [b ?offset] + (local (lo hi) (string.byte b (+ 1 (or ?offset 0)) (+ 2 (or ?offset 0)))) + (bit.bor lo (bit.lshift hi 8))) +(fn bytes-to-uint24 [b ?offset] + (local (lo mid hi) (string.byte b (+ 1 (or ?offset 0)) (+ 3 (or ?offset 0)))) + (bit.bor lo (bit.lshift mid 8) (bit.lshift hi 16))) + +(fn splice [bytes offset str] + (.. (bytes:sub 1 offset) + str + (bytes:sub (+ (length str) offset 1)))) + +(fn reload [modname] + (tset package.loaded modname nil) + (require modname)) + +; lume.hotswap really assumes your module is a table +(fn hotswap [modname] + (if (= (type (. package.loaded modname)) :table) + (lume.hotswap modname) + (reload modname))) + +(fn mk-swappable-fn [table k] + (fn [...] ((. table k) ...))) + +(fn swappable [table] + (local s {}) + (each [k v (pairs table)] + (if (= (type v) :function) + (tset s k (mk-swappable-fn table k)) + (tset s k v))) + s) + +(fn swappable-require [modname] + (swappable (require modname))) + +(fn readjson [filename] + (local f (io.open filename :r)) + (local text (f:read "*a")) + (f:close) + (json.decode text)) + +(fn writejson [filename value] + (local f (io.open filename :w)) + (f:write (json.encode value)) + (f:close)) + +(fn waitfor [pred] + (local coro (coroutine.running)) + (core.add_thread + (fn [] + (while (not (pred)) + (coroutine.yield)) + (coroutine.resume coro)) + coro) + (coroutine.yield)) + +(fn in-coro [f ...] (-> (coroutine.create f) (coroutine.resume ...))) + +{: int8-to-bytes : int16-to-bytes : int24-to-bytes : bytes-to-uint8 : bytes-to-uint16 : bytes-to-uint24 + : splice : lo : hi + : reload : hotswap : swappable :require swappable-require + : readjson : writejson : waitfor : in-coro} + diff --git a/main.lua b/main.lua new file mode 100644 index 0000000..e6035df --- /dev/null +++ b/main.lua @@ -0,0 +1,19 @@ +-- bootstrap the compiler +fennel = require("lib.fennel") +debug.traceback = fennel.traceback +table.insert(package.loaders, fennel.make_searcher({correlate=true})) +fv = fennel.view +pp = function(x) print(fv(x)) end +lume = require("lib.lume") + +_coroutine_resume = coroutine.resume +function coroutine.resume(...) + local state,result = _coroutine_resume(...) + if not state then + error( tostring(result), 2 ) -- Output error message + end + return state,result +end + +require("vendor.lite.main") +require("wrap") diff --git a/support/lite/plugins/betterfind.lua b/support/lite/plugins/betterfind.lua new file mode 100644 index 0000000..8c8c7c4 --- /dev/null +++ b/support/lite/plugins/betterfind.lua @@ -0,0 +1,25 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" +local CommandView = require "core.commandview" + +local function is_finding() + return core.active_view:is(CommandView) and core.active_view.label == "Find Text: " +end + +command.add(is_finding, { + ["better-find:done"] = function() core.active_view:submit() end, + ["better-find:next"] = function() + local commandview = core.active_view + commandview.state.submit(commandview:get_text()) + core.set_active_view(core.last_active_view) + command.perform("find-replace:repeat-find") + core.set_active_view(commandview) + end +}) + +keymap.add { + ["escape"] = "better-find:done", + ["return"] = "better-find:next" +} + diff --git a/support/lite/plugins/rainbowparen.lua b/support/lite/plugins/rainbowparen.lua new file mode 100644 index 0000000..b2689f0 --- /dev/null +++ b/support/lite/plugins/rainbowparen.lua @@ -0,0 +1,58 @@ +local tokenizer = require "core.tokenizer" +local style = require "core.style" +local common = require "core.common" + +local tokenize = tokenizer.tokenize +local closers = { + ["("] = ")", + ["["] = "]", + ["{"] = "}" +} +local function parenstyle(parenstack) + return "paren" .. ((#parenstack % 5) + 1) +end +function tokenizer.tokenize(syntax, text, state) + state = state or {} + local res, istate = tokenize(syntax, text, state.istate) + local parenstack = state.parenstack or "" + local newres = {} + -- split parens out + -- the stock tokenizer can't do this because it merges identical adjacent tokens + for i, type, text in tokenizer.each_token(res) do + if type == "normal" or type == "symbol" then + for normtext1, paren, normtext2 in text:gmatch("([^%(%[{}%]%)]*)([%(%[{}%]%)]?)([^%(%[{}%]%)]*)") do + if #normtext1 > 0 then + table.insert(newres, type) + table.insert(newres, normtext1) + end + if #paren > 0 then + if paren == parenstack:sub(-1) then -- expected closer + parenstack = parenstack:sub(1, -2) + table.insert(newres, parenstyle(parenstack)) + elseif closers[paren] then -- opener + table.insert(newres, parenstyle(parenstack)) + parenstack = parenstack .. closers[paren] + else -- unexpected closer + table.insert(newres, "paren_unbalanced") + end + table.insert(newres, paren) + end + if #normtext2 > 0 then + table.insert(newres, type) + table.insert(newres, normtext2) + end + end + else + table.insert(newres, type) + table.insert(newres, text) + end + end + return newres, { parenstack = parenstack, istate = istate } +end + +style.syntax.paren_unbalanced = style.syntax.paren_unbalanced or { common.color "#DC0408" } +style.syntax.paren1 = style.syntax.paren1 or { common.color "#FC6F71"} +style.syntax.paren2 = style.syntax.paren2 or { common.color "#fcb053"} +style.syntax.paren3 = style.syntax.paren3 or { common.color "#fcd476"} +style.syntax.paren4 = style.syntax.paren4 or { common.color "#52dab2"} +style.syntax.paren5 = style.syntax.paren5 or { common.color "#5a98cf"} diff --git a/todo.txt b/todo.txt new file mode 100644 index 0000000..b9a1971 --- /dev/null +++ b/todo.txt @@ -0,0 +1,3 @@ +TODO: +* tile editor (geometric shapes for now?) + diff --git a/vendor/jeejah/.gitrepo b/vendor/jeejah/.gitrepo new file mode 100644 index 0000000..3ff1896 --- /dev/null +++ b/vendor/jeejah/.gitrepo @@ -0,0 +1,12 @@ +; DO NOT EDIT (unless you know what you are doing) +; +; This subdirectory is a git "subrepo", and this file is maintained by the +; git-subrepo command. See https://github.com/git-commands/git-subrepo#readme +; +[subrepo] + remote = https://gitlab.com/technomancy/jeejah.git + branch = master + commit = 3ed9eb1f368c825e33e73dec0bcc9c553c33cf82 + parent = 3d52b70bbcc475d8ef69accd990c367f1a72bbba + method = merge + cmdver = 0.4.2 diff --git a/vendor/jeejah/Changelog.md b/vendor/jeejah/Changelog.md new file mode 100644 index 0000000..2146057 --- /dev/null +++ b/vendor/jeejah/Changelog.md @@ -0,0 +1,31 @@ +# Jeejah changelog: history of user-visible changes + +## 0.3.1 / 2020-04-24 + +* Fix compatibility for Lua 5.1 and 5.2. +* Improve error reporting. +* Move Fennel support to special handler instead of middleware. + +## 0.3.0 / 2019-08-01 + +* Fix a bug with socket timeout. +* Add foreground mode. +* Avoid burning CPU when there's nothing to do. + +## 0.2.1 / 2019-05-21 + +* Add support for launching a Fennel server using middleware. +* Add support for middleware. +* Support Luas newer than 5.1. + +## 0.2.0 / 2016-06-20 + +* Support requesting a read from stdin. +* Support stopping the server. +* Change module API to return a table, not a function. +* Support multiple sessions. + +## 0.1.0 / 2016-06-09 + +* Initial release! + diff --git a/vendor/jeejah/LICENSE b/vendor/jeejah/LICENSE new file mode 100644 index 0000000..22c94ef --- /dev/null +++ b/vendor/jeejah/LICENSE @@ -0,0 +1,19 @@ +Copyright © 2016-2019 Phil Hagelberg and contributors + +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. diff --git a/vendor/jeejah/Makefile b/vendor/jeejah/Makefile new file mode 100644 index 0000000..32c7fbb --- /dev/null +++ b/vendor/jeejah/Makefile @@ -0,0 +1 @@ +check: ; luacheck --std max jeejah.lua bencode.lua diff --git a/vendor/jeejah/Readme.md b/vendor/jeejah/Readme.md new file mode 100644 index 0000000..90e3035 --- /dev/null +++ b/vendor/jeejah/Readme.md @@ -0,0 +1,94 @@ +# JeeJah + +An nREPL server for [Fennel](https://fennel-lang.org) and [Lua](https://lua.org). + +## A what now? + +The [nREPL protocol](https://nrepl.org/nrepl/index.html#_why_nrepl) +allows developers to embed a server in their programs to which +external programs can connect for development, debugging, etc. + +The original implementation of the protocol was written in Clojure, +and many clients assume they will connect to a Clojure server; however +the protocol is quite agnostic about what language is being +evaluated. It supports evaluating snippets of code or whole files with +`print` and `io.write` redirected back to the connected client. + +This library was originally written to add Emacs support to +[Bussard](https://gitlab.com/technomancy/bussard), a spaceflight +programming game. + +Currently mainly tested with +[monroe](https://github.com/sanel/monroe/) and +[shevek](https://git.sr.ht/~technomancy/shevek/) as +clients. [grenchman](https://leiningen.org/grench.html) version 0.3.0+ +works. Other clients exist for Vim, Eclipse, and Atom, as well as +several independent command-line clients; however these may require +some adaptation to work with Jeejah. If you try your favorite client +and find that it makes Clojure-specific assumptions, please report a +bug with it so that it can gracefully degrade when those assumptions +don't hold. + +## Installation + +The pure-Lua dependencies are included (`bencode`, `serpent`, and +`fennel`) but you will need to install `luasocket` yourself. If your +operating system does not provide it, you can install it using LuaRocks: + + $ luarocks install --local luasocket + +Note that [LÖVE](https://love2d.org) ships with its own copy of +luasocket, so there is no need to install it there. + +You can symlink `bin/jeejah` to your `$PATH` or something. + +## Usage + +You can launch a standalone nREPL server: + + $ bin/jeejah + +Pass in a `--fennel` flag to start a server for evaluating Fennel code +instead of Lua. Accepts a `--port` argument and a `--debug` flag. + +You can use it as a library too, of course: + +```lua +local jeejah = require("jeejah") +local coro = jeejah.start(port, {debug=true, sandbox={x=12}}) +``` + +The function returns a coroutine which you'll need to repeatedly +resume in order to handle requests. Each accepted connection is stored +in a coroutine internal to that function; these are each repeatedly +resumed by the main coroutine. If all you're doing is starting an +nrepl server, you can pass `foreground=true` in the options table to +leave the server running in the foreground and skip the step of +resuming the coroutine. + +Note that the sandbox feature is not well-tested or audited and should +not be trusted to provide robust security. It currently only works +with Lua 5.1 and LuaJIT. + +You can also pass in a `handlers` table where the keys are custom +[nREPL ops](https://nrepl.org/nrepl/ops.html) +you want to handle yourself. + +## Completion + +The included `monroe-lua-complete.el` file adds support for completion +to the Monroe client by querying the connected nREPL server for +possibilities. Simply invoke `completion-at-point` (bound to `C-M-i` +by default) when connected. + +## Caveats + +PUC Lua 5.1 does not allow yielding coroutines from inside protected +calls, which means you cannot use `io.read`, though LuaJIT and +Lua 5.2+ allow it. + +## License + +Copyright © 2016-2020 Phil Hagelberg and contributors + +Distributed under the MIT license; see file LICENSE diff --git a/vendor/jeejah/bencode.lua b/vendor/jeejah/bencode.lua new file mode 100644 index 0000000..dddc432 --- /dev/null +++ b/vendor/jeejah/bencode.lua @@ -0,0 +1,78 @@ +local encode, decode + +local function decode_list(str, t, total_len) + -- print("list", str, lume.serialize(t)) + if(str:sub(1,1) == "e") then return t, total_len + 1 end + local value, v_len = decode(str) + table.insert(t, value) + total_len = total_len + v_len + return decode_list(str:sub(v_len + 1), t, total_len) +end + +local function decode_table(str, t, total_len) + -- print("table", str, lume.serialize(t)) + if(str:sub(1,1) == "e") then return t, total_len + 1 end + local key, k_len = decode(str) + local value, v_len = decode(str:sub(k_len+1)) + local end_pos = 1 + k_len + v_len + t[key] = value + total_len = total_len + k_len + v_len + return decode_table(str:sub(end_pos), t, total_len) +end + +function decode(str) + -- print("decoding", str) + if(str:sub(1,1) == "l") then + return decode_list(str:sub(2), {}, 1) + elseif(str:sub(1,1) == "d") then + return decode_table(str:sub(2), {}, 1) + elseif(str:sub(1,1) == "i") then + return(tonumber(str:sub(2, str:find("e") - 1))), str:find("e") + elseif(str:match("[0-9]+")) then + local num_str = str:match("[0-9]+") + local beginning_of_string = #num_str + 2 + local str_len = tonumber(num_str) + local total_len = beginning_of_string + str_len - 1 + return str:sub(beginning_of_string, total_len), total_len + else + error("Could not parse "..str) + end +end + +local function encode_str(s) return #s .. ":" .. s end +local function encode_int(n) return "i" .. tostring(n) .. "e" end + +local function encode_table(t) + local s = "d" + for k,v in pairs(t) do s = s .. encode(k) .. encode(v) end + return s .. "e" +end + +local function encode_list(l) + local s = "l" + for _,x in ipairs(l) do s = s .. encode(x) end + return s .. "e" +end + +local function count(tbl) + local i = 0 + for _ in pairs(tbl) do i = i + 1 end + return i +end + +function encode(x) + local unpack = unpack or table.unpack + if(type(x) == "table" and select("#", unpack(x)) == count(x)) then + return encode_list(x) + elseif(type(x) == "table") then + return encode_table(x) + elseif(type(x) == "number" and math.floor(x) == x) then + return encode_int(x) + elseif(type(x) == "string") then + return encode_str(x) + else + error("Could not encode " .. type(x) .. ": " .. tostring(x)) + end +end + +return {decode=decode, encode=encode} diff --git a/vendor/jeejah/bin/jeejah b/vendor/jeejah/bin/jeejah new file mode 100755 index 0000000..9b49226 --- /dev/null +++ b/vendor/jeejah/bin/jeejah @@ -0,0 +1,35 @@ +#!/usr/bin/env lua + +require "luarocks.loader" + +local opts, port = {foreground = true} + +for n,v in ipairs(arg) do + if(v == "--port") then + port = arg[n+1] + elseif(v == "--fennel") then + opts.fennel = true + elseif(v == "--debug") then + opts.debug = true + elseif(v == "--empty-sandbox") then + opts.sandbox = {} + elseif(v == "--version" or v == "--help") then + print("jeejah 0.2.0\n") + print("Options:") + print(" --fennel Start a Fennel server instead of Lua") + print(" --port Port on which to listen") + print(" --debug Print verbose debugging information") + os.exit(0) + end +end + +local root_dir = debug.getinfo(1).source:sub(2, -(1+#"bin/jeejah")) +local search_parent = string.format("%s?.lua;%s", root_dir, package.path) +if(package.searchpath) then + local jeejah = dofile(package.searchpath("jeejah", search_parent)) + jeejah.start(port, opts) +else -- 5.1 + if root_dir == "" then root_dir = "." end + local jeejah = dofile(root_dir .. "/jeejah.lua") + jeejah.start(port, opts) +end diff --git a/vendor/jeejah/fennel.lua b/vendor/jeejah/fennel.lua new file mode 100644 index 0000000..394380a --- /dev/null +++ b/vendor/jeejah/fennel.lua @@ -0,0 +1,3319 @@ +package.preload["fennel.repl"] = package.preload["fennel.repl"] or function(...) + local utils = require("fennel.utils") + local parser = require("fennel.parser") + local compiler = require("fennel.compiler") + local specials = require("fennel.specials") + local function default_read_chunk(parser_state) + local function _0_() + if (0 < parser_state["stack-size"]) then + return ".." + else + return ">> " + end + end + io.write(_0_()) + io.flush() + local input = io.read() + return (input and (input .. "\n")) + end + local function default_on_values(xs) + io.write(table.concat(xs, "\9")) + return io.write("\n") + end + local function default_on_error(errtype, err, lua_source) + local function _1_() + local _0_0 = errtype + if (_0_0 == "Lua Compile") then + return ("Bad code generated - likely a bug with the compiler:\n" .. "--- Generated Lua Start ---\n" .. lua_source .. "--- Generated Lua End ---\n") + elseif (_0_0 == "Runtime") then + return (compiler.traceback(err, 4) .. "\n") + else + local _ = _0_0 + return ("%s error: %s\n"):format(errtype, tostring(err)) + end + end + return io.write(_1_()) + end + local save_source = table.concat({"local ___i___ = 1", "while true do", " local name, value = debug.getlocal(1, ___i___)", " if(name and name ~= \"___i___\") then", " ___replLocals___[name] = value", " ___i___ = ___i___ + 1", " else break end end"}, "\n") + local function splice_save_locals(env, lua_source) + env.___replLocals___ = (env.___replLocals___ or {}) + local spliced_source = {} + local bind = "local %s = ___replLocals___['%s']" + for line in lua_source:gmatch("([^\n]+)\n?") do + table.insert(spliced_source, line) + end + for name in pairs(env.___replLocals___) do + table.insert(spliced_source, 1, bind:format(name, name)) + end + if ((1 < #spliced_source) and (spliced_source[#spliced_source]):match("^ *return .*$")) then + table.insert(spliced_source, #spliced_source, save_source) + end + return table.concat(spliced_source, "\n") + end + local commands = {} + local function command_3f(input) + return input:match("^%s*,") + end + commands.help = function(_, _0, on_values) + return on_values({"Welcome to Fennel.\nThis is the REPL where you can enter code to be evaluated.\nYou can also run these repl commands:\n\n ,help - show this message\n ,reload module-name - reload the specified module\n ,reset - erase all repl-local scope\n ,exit - leave the repl\n\nUse (doc something) to see descriptions for individual macros and special forms.\n\nFor more information about the language, see https://fennel-lang.org/reference"}) + end + local function reload(module_name, env, on_values, on_error) + local _0_0, _1_0 = pcall(specials["load-code"]("return require(...)", env), module_name) + if ((_0_0 == true) and (nil ~= _1_0)) then + local old = _1_0 + local _ = nil + package.loaded[module_name] = nil + _ = nil + local ok, new = pcall(require, module_name) + local new0 = nil + if not ok then + on_values(new) + new0 = old + else + new0 = new + end + if ((type(old) == "table") and (type(new0) == "table")) then + for k, v in pairs(new0) do + old[k] = v + end + for k in pairs(old) do + if (nil == new0[k]) then + old[k] = nil + end + end + package.loaded[module_name] = old + end + return on_values({"ok"}) + elseif ((_0_0 == false) and (nil ~= _1_0)) then + local msg = _1_0 + local function _3_() + local _2_0 = msg:gsub("\n.*", "") + return _2_0 + end + return on_error("Runtime", _3_()) + end + end + commands.reload = function(read, env, on_values, on_error) + local _0_0, _1_0, _2_0 = pcall(read) + if ((_0_0 == true) and (_1_0 == true) and (nil ~= _2_0)) then + local module_sym = _2_0 + return reload(tostring(module_sym), env, on_values, on_error) + elseif ((_0_0 == false) and true and true) then + local _3fparse_ok = _1_0 + local _3fmsg = _2_0 + return on_error("Parse", (_3fmsg or _3fparse_ok)) + end + end + commands.reset = function(_, env, on_values) + env.___replLocals___ = {} + return on_values({"ok"}) + end + local function run_command(input, read, loop, env, on_values, on_error) + local command_name = input:match(",([^%s/]+)") + do + local _0_0 = commands[command_name] + if (nil ~= _0_0) then + local command = _0_0 + command(read, env, on_values, on_error) + else + local _ = _0_0 + if ("exit" ~= command_name) then + on_values({"Unknown command", command_name}) + end + end + end + if ("exit" ~= command_name) then + return loop() + end + end + local function completer(env, scope, text) + local matches = {} + local input_fragment = text:gsub(".*[%s)(]+", "") + local function add_partials(input, tbl, prefix) + for k in utils.allpairs(tbl) do + local k0 = nil + if ((tbl == env) or (tbl == env.___replLocals___)) then + k0 = scope.unmanglings[k] + else + k0 = k + end + if ((#matches < 2000) and (type(k0) == "string") and (input == k0:sub(0, #input))) then + table.insert(matches, (prefix .. k0)) + end + end + return nil + end + local function add_matches(input, tbl, prefix) + local prefix0 = nil + if prefix then + prefix0 = (prefix .. ".") + else + prefix0 = "" + end + if not input:find("%.") then + return add_partials(input, tbl, prefix0) + else + local head, tail = input:match("^([^.]+)%.(.*)") + local raw_head = nil + if ((tbl == env) or (tbl == env.___replLocals___)) then + raw_head = scope.manglings[head] + else + raw_head = head + end + if (type(tbl[raw_head]) == "table") then + return add_matches(tail, tbl[raw_head], (prefix0 .. head)) + end + end + end + add_matches(input_fragment, (scope.specials or {})) + add_matches(input_fragment, (scope.macros or {})) + add_matches(input_fragment, (env.___replLocals___ or {})) + add_matches(input_fragment, env) + add_matches(input_fragment, (env._ENV or env._G or {})) + return matches + end + local function repl(options) + local old_root_options = utils.root.options + local env = nil + if options.env then + env = specials["wrap-env"](options.env) + else + env = setmetatable({}, {__index = (_G._ENV or _G)}) + end + local save_locals_3f = ((options.saveLocals ~= false) and env.debug and env.debug.getlocal) + local opts = {} + local _ = nil + for k, v in pairs(options) do + opts[k] = v + end + _ = nil + local read_chunk = (opts.readChunk or default_read_chunk) + local on_values = (opts.onValues or default_on_values) + local on_error = (opts.onError or default_on_error) + local pp = (opts.pp or tostring) + local byte_stream, clear_stream = parser.granulate(read_chunk) + local chars = {} + local read, reset = nil, nil + local function _1_(parser_state) + local c = byte_stream(parser_state) + table.insert(chars, c) + return c + end + read, reset = parser.parser(_1_) + local scope = compiler["make-scope"]() + opts.useMetadata = (options.useMetadata ~= false) + if (opts.allowedGlobals == nil) then + opts.allowedGlobals = specials["current-global-names"](opts.env) + end + if opts.registerCompleter then + local function _3_(...) + return completer(env, scope, ...) + end + opts.registerCompleter(_3_) + end + local function print_values(...) + local vals = {...} + local out = {} + env._, env.__ = vals[1], vals + for i = 1, select("#", ...) do + table.insert(out, pp(vals[i])) + end + return on_values(out) + end + local function loop() + for k in pairs(chars) do + chars[k] = nil + end + local ok, parse_ok_3f, x = pcall(read) + local src_string = string.char((_G.unpack or table.unpack)(chars)) + utils.root.options = opts + if not ok then + on_error("Parse", parse_ok_3f) + clear_stream() + reset() + return loop() + elseif command_3f(src_string) then + return run_command(src_string, read, loop, env, on_values, on_error) + else + if parse_ok_3f then + do + local _4_0, _5_0 = pcall(compiler.compile, x, {["assert-compile"] = opts["assert-compile"], ["parse-error"] = opts["parse-error"], correlate = opts.correlate, moduleName = opts.moduleName, scope = scope, source = src_string, useMetadata = opts.useMetadata}) + if ((_4_0 == false) and (nil ~= _5_0)) then + local msg = _5_0 + clear_stream() + on_error("Compile", msg) + elseif ((_4_0 == true) and (nil ~= _5_0)) then + local src = _5_0 + local src0 = nil + if save_locals_3f then + src0 = splice_save_locals(env, src) + else + src0 = src + end + local _7_0, _8_0 = pcall(specials["load-code"], src0, env) + if ((_7_0 == false) and (nil ~= _8_0)) then + local msg = _8_0 + clear_stream() + on_error("Lua Compile", msg, src0) + elseif (true and (nil ~= _8_0)) then + local _0 = _7_0 + local chunk = _8_0 + local function _9_() + return print_values(chunk()) + end + local function _10_(...) + return on_error("Runtime", ...) + end + xpcall(_9_, _10_) + end + end + end + utils.root.options = old_root_options + return loop() + end + end + end + return loop() + end + return repl +end +package.preload["fennel.specials"] = package.preload["fennel.specials"] or function(...) + local utils = require("fennel.utils") + local parser = require("fennel.parser") + local compiler = require("fennel.compiler") + local unpack = (_G.unpack or table.unpack) + local SPECIALS = compiler.scopes.global.specials + local function wrap_env(env) + local function _0_(_, key) + if (type(key) == "string") then + return env[compiler["global-unmangling"](key)] + else + return env[key] + end + end + local function _1_(_, key, value) + if (type(key) == "string") then + env[compiler["global-unmangling"](key)] = value + return nil + else + env[key] = value + return nil + end + end + local function _2_() + local function putenv(k, v) + local _3_ + if (type(k) == "string") then + _3_ = compiler["global-unmangling"](k) + else + _3_ = k + end + return _3_, v + end + return next, utils.kvmap(env, putenv), nil + end + return setmetatable({}, {__index = _0_, __newindex = _1_, __pairs = _2_}) + end + local function current_global_names(env) + return utils.kvmap((env or _G), compiler["global-unmangling"]) + end + local function load_code(code, environment, filename) + local environment0 = ((environment or _ENV) or _G) + if (_G.setfenv and _G.loadstring) then + local f = assert(_G.loadstring(code, filename)) + _G.setfenv(f, environment0) + return f + else + return assert(load(code, filename, "t", environment0)) + end + end + local function doc_2a(tgt, name) + if not tgt then + return (name .. " not found") + else + local docstring = (((compiler.metadata):get(tgt, "fnl/docstring") or "#")):gsub("\n$", ""):gsub("\n", "\n ") + if (type(tgt) == "function") then + local arglist = table.concat(((compiler.metadata):get(tgt, "fnl/arglist") or {"#"}), " ") + local _0_ + if (#arglist > 0) then + _0_ = " " + else + _0_ = "" + end + return string.format("(%s%s%s)\n %s", name, _0_, arglist, docstring) + else + return string.format("%s\n %s", name, docstring) + end + end + end + local function doc_special(name, arglist, docstring) + compiler.metadata[SPECIALS[name]] = {["fnl/arglist"] = arglist, ["fnl/docstring"] = docstring} + return nil + end + local function compile_do(ast, scope, parent, start) + local start0 = (start or 2) + local len = #ast + local sub_scope = compiler["make-scope"](scope) + for i = start0, len do + compiler.compile1(ast[i], sub_scope, parent, {nval = 0}) + end + return nil + end + SPECIALS["do"] = function(ast, scope, parent, opts, start, chunk, sub_scope, pre_syms) + local start0 = (start or 2) + local sub_scope0 = (sub_scope or compiler["make-scope"](scope)) + local chunk0 = (chunk or {}) + local len = #ast + local retexprs = {returned = true} + local function compile_body(outer_target, outer_tail, outer_retexprs) + if (len < start0) then + compiler.compile1(nil, sub_scope0, chunk0, {tail = outer_tail, target = outer_target}) + else + for i = start0, len do + local subopts = {nval = (((i ~= len) and 0) or opts.nval), tail = (((i == len) and outer_tail) or nil), target = (((i == len) and outer_target) or nil)} + local _ = utils["propagate-options"](opts, subopts) + local subexprs = compiler.compile1(ast[i], sub_scope0, chunk0, subopts) + if (i ~= len) then + compiler["keep-side-effects"](subexprs, parent, nil, ast[i]) + end + end + end + compiler.emit(parent, chunk0, ast) + compiler.emit(parent, "end", ast) + return (outer_retexprs or retexprs) + end + if (opts.target or (opts.nval == 0) or opts.tail) then + compiler.emit(parent, "do", ast) + return compile_body(opts.target, opts.tail) + elseif opts.nval then + local syms = {} + for i = 1, opts.nval do + local s = ((pre_syms and pre_syms[i]) or compiler.gensym(scope)) + syms[i] = s + retexprs[i] = utils.expr(s, "sym") + end + local outer_target = table.concat(syms, ", ") + compiler.emit(parent, string.format("local %s", outer_target), ast) + compiler.emit(parent, "do", ast) + return compile_body(outer_target, opts.tail) + else + local fname = compiler.gensym(scope) + local fargs = nil + if scope.vararg then + fargs = "..." + else + fargs = "" + end + compiler.emit(parent, string.format("local function %s(%s)", fname, fargs), ast) + utils.hook("do", ast, sub_scope0) + return compile_body(nil, true, utils.expr((fname .. "(" .. fargs .. ")"), "statement")) + end + end + doc_special("do", {"..."}, "Evaluate multiple forms; return last value.") + SPECIALS.values = function(ast, scope, parent) + local len = #ast + local exprs = {} + for i = 2, len do + local subexprs = compiler.compile1(ast[i], scope, parent, {nval = ((i ~= len) and 1)}) + table.insert(exprs, subexprs[1]) + if (i == len) then + for j = 2, #subexprs do + table.insert(exprs, subexprs[j]) + end + end + end + return exprs + end + doc_special("values", {"..."}, "Return multiple values from a function. Must be in tail position.") + local function set_fn_metadata(arg_list, docstring, parent, fn_name) + if utils.root.options.useMetadata then + local args = nil + local function _0_(v) + if utils["table?"](v) then + return "\"#\"" + else + return ("\"%s\""):format(tostring(v)) + end + end + args = utils.map(arg_list, _0_) + local meta_fields = {"\"fnl/arglist\"", ("{" .. table.concat(args, ", ") .. "}")} + if docstring then + table.insert(meta_fields, "\"fnl/docstring\"") + table.insert(meta_fields, ("\"" .. docstring:gsub("%s+$", ""):gsub("\\", "\\\\"):gsub("\n", "\\n"):gsub("\"", "\\\"") .. "\"")) + end + local meta_str = ("require(\"%s\").metadata"):format((utils.root.options.moduleName or "fennel")) + return compiler.emit(parent, ("pcall(function() %s:setall(%s, %s) end)"):format(meta_str, fn_name, table.concat(meta_fields, ", "))) + end + end + local function get_fn_name(ast, scope, fn_name, multi) + if (fn_name and (fn_name[1] ~= "nil")) then + local _0_ + if not multi then + _0_ = compiler["declare-local"](fn_name, {}, scope, ast) + else + _0_ = compiler["symbol-to-expression"](fn_name, scope)[1] + end + return _0_, not multi, 3 + else + return compiler.gensym(scope), true, 2 + end + end + SPECIALS.fn = function(ast, scope, parent) + local f_scope = nil + do + local _0_0 = compiler["make-scope"](scope) + _0_0["vararg"] = false + f_scope = _0_0 + end + local f_chunk = {} + local fn_sym = utils["sym?"](ast[2]) + local multi = (fn_sym and utils["multi-sym?"](fn_sym[1])) + local fn_name, local_fn_3f, index = get_fn_name(ast, scope, fn_sym, multi) + local arg_list = compiler.assert(utils["table?"](ast[index]), "expected parameters table", ast) + compiler.assert((not multi or not multi["multi-sym-method-call"]), ("unexpected multi symbol " .. tostring(fn_name)), fn_sym) + local function get_arg_name(arg) + if utils["varg?"](arg) then + compiler.assert((arg == arg_list[#arg_list]), "expected vararg as last parameter", ast) + f_scope.vararg = true + return "..." + elseif (utils["sym?"](arg) and (utils.deref(arg) ~= "nil") and not utils["multi-sym?"](utils.deref(arg))) then + return compiler["declare-local"](arg, {}, f_scope, ast) + elseif utils["table?"](arg) then + local raw = utils.sym(compiler.gensym(scope)) + local declared = compiler["declare-local"](raw, {}, f_scope, ast) + compiler.destructure(arg, raw, ast, f_scope, f_chunk, {declaration = true, nomulti = true}) + return declared + else + return compiler.assert(false, ("expected symbol for function parameter: %s"):format(tostring(arg)), ast[2]) + end + end + do + local arg_name_list = utils.map(arg_list, get_arg_name) + local index0, docstring = nil, nil + if ((type(ast[(index + 1)]) == "string") and ((index + 1) < #ast)) then + index0, docstring = (index + 1), ast[(index + 1)] + else + index0, docstring = index, nil + end + for i = (index0 + 1), #ast do + compiler.compile1(ast[i], f_scope, f_chunk, {nval = (((i ~= #ast) and 0) or nil), tail = (i == #ast)}) + end + local _2_ + if local_fn_3f then + _2_ = "local function %s(%s)" + else + _2_ = "%s = function(%s)" + end + compiler.emit(parent, string.format(_2_, fn_name, table.concat(arg_name_list, ", ")), ast) + compiler.emit(parent, f_chunk, ast) + compiler.emit(parent, "end", ast) + set_fn_metadata(arg_list, docstring, parent, fn_name) + end + utils.hook("fn", ast, f_scope) + return utils.expr(fn_name, "sym") + end + doc_special("fn", {"name?", "args", "docstring?", "..."}, "Function syntax. May optionally include a name and docstring.\nIf a name is provided, the function will be bound in the current scope.\nWhen called with the wrong number of args, excess args will be discarded\nand lacking args will be nil, use lambda for arity-checked functions.") + SPECIALS.lua = function(ast, _, parent) + compiler.assert(((#ast == 2) or (#ast == 3)), "expected 1 or 2 arguments", ast) + if (ast[2] ~= nil) then + table.insert(parent, {ast = ast, leaf = tostring(ast[2])}) + end + if (#ast == 3) then + return tostring(ast[3]) + end + end + SPECIALS.doc = function(ast, scope, parent) + assert(utils.root.options.useMetadata, "can't look up doc with metadata disabled.") + compiler.assert((#ast == 2), "expected one argument", ast) + local target = utils.deref(ast[2]) + local special_or_macro = (scope.specials[target] or scope.macros[target]) + if special_or_macro then + return ("print([[%s]])"):format(doc_2a(special_or_macro, target)) + else + local value = tostring(compiler.compile1(ast[2], scope, parent, {nval = 1})[1]) + return ("print(require('%s').doc(%s, '%s'))"):format((utils.root.options.moduleName or "fennel"), value, tostring(ast[2])) + end + end + doc_special("doc", {"x"}, "Print the docstring and arglist for a function, macro, or special form.") + local function dot(ast, scope, parent) + compiler.assert((1 < #ast), "expected table argument", ast) + local len = #ast + local lhs = compiler.compile1(ast[2], scope, parent, {nval = 1}) + if (len == 2) then + return tostring(lhs[1]) + else + local indices = {} + for i = 3, len do + local index = ast[i] + if ((type(index) == "string") and utils["valid-lua-identifier?"](index)) then + table.insert(indices, ("." .. index)) + else + local _0_ = compiler.compile1(index, scope, parent, {nval = 1}) + local index0 = _0_[1] + table.insert(indices, ("[" .. tostring(index0) .. "]")) + end + end + if utils["table?"](ast[2]) then + return ("(" .. tostring(lhs[1]) .. ")" .. table.concat(indices)) + else + return (tostring(lhs[1]) .. table.concat(indices)) + end + end + end + SPECIALS["."] = dot + doc_special(".", {"tbl", "key1", "..."}, "Look up key1 in tbl table. If more args are provided, do a nested lookup.") + SPECIALS.global = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {forceglobal = true, nomulti = true}) + return nil + end + doc_special("global", {"name", "val"}, "Set name as a global with val.") + SPECIALS.set = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {noundef = true}) + return nil + end + doc_special("set", {"name", "val"}, "Set a local variable to a new value. Only works on locals using var.") + local function set_forcibly_21_2a(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {forceset = true}) + return nil + end + SPECIALS["set-forcibly!"] = set_forcibly_21_2a + local function local_2a(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {declaration = true, nomulti = true}) + return nil + end + SPECIALS["local"] = local_2a + doc_special("local", {"name", "val"}, "Introduce new top-level immutable local.") + SPECIALS.var = function(ast, scope, parent) + compiler.assert((#ast == 3), "expected name and value", ast) + compiler.destructure(ast[2], ast[3], ast, scope, parent, {declaration = true, isvar = true, nomulti = true}) + return nil + end + doc_special("var", {"name", "val"}, "Introduce new mutable local.") + SPECIALS.let = function(ast, scope, parent, opts) + local bindings = ast[2] + local pre_syms = {} + compiler.assert((utils["list?"](bindings) or utils["table?"](bindings)), "expected binding table", ast) + compiler.assert(((#bindings % 2) == 0), "expected even number of name/value bindings", ast[2]) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + for _ = 1, (opts.nval or 0) do + table.insert(pre_syms, compiler.gensym(scope)) + end + local sub_scope = compiler["make-scope"](scope) + local sub_chunk = {} + for i = 1, #bindings, 2 do + compiler.destructure(bindings[i], bindings[(i + 1)], ast, sub_scope, sub_chunk, {declaration = true, nomulti = true}) + end + return SPECIALS["do"](ast, scope, parent, opts, 3, sub_chunk, sub_scope, pre_syms) + end + doc_special("let", {"[name1 val1 ... nameN valN]", "..."}, "Introduces a new scope in which a given set of local bindings are used.") + SPECIALS.tset = function(ast, scope, parent) + compiler.assert((#ast > 3), "expected table, key, and value arguments", ast) + local root = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + local keys = {} + for i = 3, (#ast - 1) do + local _0_ = compiler.compile1(ast[i], scope, parent, {nval = 1}) + local key = _0_[1] + table.insert(keys, tostring(key)) + end + local value = compiler.compile1(ast[#ast], scope, parent, {nval = 1})[1] + local rootstr = tostring(root) + local fmtstr = nil + if rootstr:match("^{") then + fmtstr = "do end (%s)[%s] = %s" + else + fmtstr = "%s[%s] = %s" + end + return compiler.emit(parent, fmtstr:format(tostring(root), table.concat(keys, "]["), tostring(value)), ast) + end + doc_special("tset", {"tbl", "key1", "...", "keyN", "val"}, "Set the value of a table field. Can take additional keys to set\nnested values, but all parents must contain an existing table.") + local function calculate_target(scope, opts) + if not (opts.tail or opts.target or opts.nval) then + return "iife", true, nil + elseif (opts.nval and (opts.nval ~= 0) and not opts.target) then + local accum = {} + local target_exprs = {} + for i = 1, opts.nval do + local s = compiler.gensym(scope) + accum[i] = s + target_exprs[i] = utils.expr(s, "sym") + end + return "target", opts.tail, table.concat(accum, ", "), target_exprs + else + return "none", opts.tail, opts.target + end + end + local function if_2a(ast, scope, parent, opts) + local do_scope = compiler["make-scope"](scope) + local branches = {} + local wrapper, inner_tail, inner_target, target_exprs = calculate_target(scope, opts) + local body_opts = {nval = opts.nval, tail = inner_tail, target = inner_target} + local function compile_body(i) + local chunk = {} + local cscope = compiler["make-scope"](do_scope) + compiler["keep-side-effects"](compiler.compile1(ast[i], cscope, chunk, body_opts), chunk, nil, ast[i]) + return {chunk = chunk, scope = cscope} + end + for i = 2, (#ast - 1), 2 do + local condchunk = {} + local res = compiler.compile1(ast[i], do_scope, condchunk, {nval = 1}) + local cond = res[1] + local branch = compile_body((i + 1)) + branch.cond = cond + branch.condchunk = condchunk + branch.nested = ((i ~= 2) and (next(condchunk, nil) == nil)) + table.insert(branches, branch) + end + local has_else_3f = ((#ast > 3) and ((#ast % 2) == 0)) + local else_branch = (has_else_3f and compile_body(#ast)) + local s = compiler.gensym(scope) + local buffer = {} + local last_buffer = buffer + for i = 1, #branches do + local branch = branches[i] + local fstr = nil + if not branch.nested then + fstr = "if %s then" + else + fstr = "elseif %s then" + end + local cond = tostring(branch.cond) + local cond_line = nil + if ((cond == "true") and branch.nested and (i == #branches)) then + cond_line = "else" + else + cond_line = fstr:format(cond) + end + if branch.nested then + compiler.emit(last_buffer, branch.condchunk, ast) + else + for _, v in ipairs(branch.condchunk) do + compiler.emit(last_buffer, v, ast) + end + end + compiler.emit(last_buffer, cond_line, ast) + compiler.emit(last_buffer, branch.chunk, ast) + if (i == #branches) then + if has_else_3f then + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, else_branch.chunk, ast) + elseif (inner_target and (cond_line ~= "else")) then + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, ("%s = nil"):format(inner_target), ast) + end + compiler.emit(last_buffer, "end", ast) + elseif not branches[(i + 1)].nested then + local next_buffer = {} + compiler.emit(last_buffer, "else", ast) + compiler.emit(last_buffer, next_buffer, ast) + compiler.emit(last_buffer, "end", ast) + last_buffer = next_buffer + end + end + if (wrapper == "iife") then + local iifeargs = ((scope.vararg and "...") or "") + compiler.emit(parent, ("local function %s(%s)"):format(tostring(s), iifeargs), ast) + compiler.emit(parent, buffer, ast) + compiler.emit(parent, "end", ast) + return utils.expr(("%s(%s)"):format(tostring(s), iifeargs), "statement") + elseif (wrapper == "none") then + for i = 1, #buffer do + compiler.emit(parent, buffer[i], ast) + end + return {returned = true} + else + compiler.emit(parent, ("local %s"):format(inner_target), ast) + for i = 1, #buffer do + compiler.emit(parent, buffer[i], ast) + end + return target_exprs + end + end + SPECIALS["if"] = if_2a + doc_special("if", {"cond1", "body1", "...", "condN", "bodyN"}, "Conditional form.\nTakes any number of condition/body pairs and evaluates the first body where\nthe condition evaluates to truthy. Similar to cond in other lisps.") + SPECIALS.each = function(ast, scope, parent) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + local binding = compiler.assert(utils["table?"](ast[2]), "expected binding table", ast) + local iter = table.remove(binding, #binding) + local destructures = {} + local new_manglings = {} + local sub_scope = compiler["make-scope"](scope) + local function destructure_binding(v) + if utils["sym?"](v) then + return compiler["declare-local"](v, {}, sub_scope, ast, new_manglings) + else + local raw = utils.sym(compiler.gensym(sub_scope)) + destructures[raw] = v + return compiler["declare-local"](raw, {}, sub_scope, ast) + end + end + local bind_vars = utils.map(binding, destructure_binding) + local vals = compiler.compile1(iter, sub_scope, parent) + local val_names = utils.map(vals, tostring) + local chunk = {} + compiler.emit(parent, ("for %s in %s do"):format(table.concat(bind_vars, ", "), table.concat(val_names, ", ")), ast) + for raw, args in utils.stablepairs(destructures) do + compiler.destructure(args, raw, ast, sub_scope, chunk, {declaration = true, nomulti = true}) + end + compiler["apply-manglings"](sub_scope, new_manglings, ast) + compile_do(ast, sub_scope, chunk, 3) + compiler.emit(parent, chunk, ast) + return compiler.emit(parent, "end", ast) + end + doc_special("each", {"[key value (iterator)]", "..."}, "Runs the body once for each set of values provided by the given iterator.\nMost commonly used with ipairs for sequential tables or pairs for undefined\norder, but can be used with any iterator.") + local function while_2a(ast, scope, parent) + local len1 = #parent + local condition = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + local len2 = #parent + local sub_chunk = {} + if (len1 ~= len2) then + for i = (len1 + 1), len2 do + table.insert(sub_chunk, parent[i]) + parent[i] = nil + end + compiler.emit(parent, "while true do", ast) + compiler.emit(sub_chunk, ("if not %s then break end"):format(condition[1]), ast) + else + compiler.emit(parent, ("while " .. tostring(condition) .. " do"), ast) + end + compile_do(ast, compiler["make-scope"](scope), sub_chunk, 3) + compiler.emit(parent, sub_chunk, ast) + return compiler.emit(parent, "end", ast) + end + SPECIALS["while"] = while_2a + doc_special("while", {"condition", "..."}, "The classic while loop. Evaluates body until a condition is non-truthy.") + local function for_2a(ast, scope, parent) + local ranges = compiler.assert(utils["table?"](ast[2]), "expected binding table", ast) + local binding_sym = table.remove(ast[2], 1) + local sub_scope = compiler["make-scope"](scope) + local range_args = {} + local chunk = {} + compiler.assert(utils["sym?"](binding_sym), ("unable to bind %s %s"):format(type(binding_sym), tostring(binding_sym)), ast[2]) + compiler.assert((#ast >= 3), "expected body expression", ast[1]) + for i = 1, math.min(#ranges, 3) do + range_args[i] = tostring(compiler.compile1(ranges[i], sub_scope, parent, {nval = 1})[1]) + end + compiler.emit(parent, ("for %s = %s do"):format(compiler["declare-local"](binding_sym, {}, sub_scope, ast), table.concat(range_args, ", ")), ast) + compile_do(ast, sub_scope, chunk, 3) + compiler.emit(parent, chunk, ast) + return compiler.emit(parent, "end", ast) + end + SPECIALS["for"] = for_2a + doc_special("for", {"[index start stop step?]", "..."}, "Numeric loop construct.\nEvaluates body once for each value between start and stop (inclusive).") + local function native_method_call(ast, _scope, _parent, target, args) + local _0_ = ast + local _ = _0_[1] + local _0 = _0_[2] + local method_string = _0_[3] + local call_string = nil + if ((target.type == "literal") or (target.type == "expression")) then + call_string = "(%s):%s(%s)" + else + call_string = "%s:%s(%s)" + end + return utils.expr(string.format(call_string, tostring(target), method_string, table.concat(args, ", ")), "statement") + end + local function nonnative_method_call(ast, scope, parent, target, args) + local method_string = tostring(compiler.compile1(ast[3], scope, parent, {nval = 1})[1]) + local args0 = {tostring(target), unpack(args)} + return utils.expr(string.format("%s[%s](%s)", tostring(target), method_string, table.concat(args0, ", ")), "statement") + end + local function double_eval_protected_method_call(ast, scope, parent, target, args) + local method_string = tostring(compiler.compile1(ast[3], scope, parent, {nval = 1})[1]) + local call = "(function(tgt, m, ...) return tgt[m](tgt, ...) end)(%s, %s)" + table.insert(args, 1, method_string) + return utils.expr(string.format(call, tostring(target), table.concat(args, ", ")), "statement") + end + local function method_call(ast, scope, parent) + compiler.assert((2 < #ast), "expected at least 2 arguments", ast) + local _0_ = compiler.compile1(ast[2], scope, parent, {nval = 1}) + local target = _0_[1] + local args = {} + for i = 4, #ast do + local subexprs = nil + local _1_ + if (i ~= #ast) then + _1_ = 1 + else + _1_ = nil + end + subexprs = compiler.compile1(ast[i], scope, parent, {nval = _1_}) + utils.map(subexprs, tostring, args) + end + if ((type(ast[3]) == "string") and utils["valid-lua-identifier?"](ast[3])) then + return native_method_call(ast, scope, parent, target, args) + elseif (target.type == "sym") then + return nonnative_method_call(ast, scope, parent, target, args) + else + return double_eval_protected_method_call(ast, scope, parent, target, args) + end + end + SPECIALS[":"] = method_call + doc_special(":", {"tbl", "method-name", "..."}, "Call the named method on tbl with the provided args.\nMethod name doesn't have to be known at compile-time; if it is, use\n(tbl:method-name ...) instead.") + SPECIALS.comment = function(ast, _, parent) + local els = {} + for i = 2, #ast do + local function _1_() + local _0_0 = tostring(ast[i]):gsub("\n", " ") + return _0_0 + end + table.insert(els, _1_()) + end + return compiler.emit(parent, ("-- " .. table.concat(els, " ")), ast) + end + doc_special("comment", {"..."}, "Comment which will be emitted in Lua output.") + local function hashfn_max_used(f_scope, i, max) + local max0 = nil + if f_scope.symmeta[("$" .. i)].used then + max0 = i + else + max0 = max + end + if (i < 9) then + return hashfn_max_used(f_scope, (i + 1), max0) + else + return max0 + end + end + SPECIALS.hashfn = function(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument", ast) + local f_scope = nil + do + local _0_0 = compiler["make-scope"](scope) + _0_0["vararg"] = false + _0_0["hashfn"] = true + f_scope = _0_0 + end + local f_chunk = {} + local name = compiler.gensym(scope) + local symbol = utils.sym(name) + local args = {} + compiler["declare-local"](symbol, {}, scope, ast) + for i = 1, 9 do + args[i] = compiler["declare-local"](utils.sym(("$" .. i)), {}, f_scope, ast) + end + local function walker(idx, node, parent_node) + if (utils["sym?"](node) and (utils.deref(node) == "$...")) then + parent_node[idx] = utils.varg() + f_scope.vararg = true + return nil + else + return (utils["list?"](node) or utils["table?"](node)) + end + end + utils["walk-tree"](ast[2], walker) + compiler.compile1(ast[2], f_scope, f_chunk, {tail = true}) + local max_used = hashfn_max_used(f_scope, 1, 0) + if f_scope.vararg then + compiler.assert((max_used == 0), "$ and $... in hashfn are mutually exclusive", ast) + end + local arg_str = nil + if f_scope.vararg then + arg_str = utils.deref(utils.varg()) + else + arg_str = table.concat(args, ", ", 1, max_used) + end + compiler.emit(parent, string.format("local function %s(%s)", name, arg_str), ast) + compiler.emit(parent, f_chunk, ast) + compiler.emit(parent, "end", ast) + return utils.expr(name, "sym") + end + doc_special("hashfn", {"..."}, "Function literal shorthand; args are either $... OR $1, $2, etc.") + local function define_arithmetic_special(name, zero_arity, unary_prefix, lua_name) + do + local padded_op = (" " .. (lua_name or name) .. " ") + local function _0_(ast, scope, parent) + local len = #ast + if (len == 1) then + compiler.assert((zero_arity ~= nil), "Expected more than 0 arguments", ast) + return utils.expr(zero_arity, "literal") + else + local operands = {} + for i = 2, len do + local subexprs = nil + local _1_ + if (i == 1) then + _1_ = 1 + else + _1_ = nil + end + subexprs = compiler.compile1(ast[i], scope, parent, {nval = _1_}) + utils.map(subexprs, tostring, operands) + end + if (#operands == 1) then + if unary_prefix then + return ("(" .. unary_prefix .. padded_op .. operands[1] .. ")") + else + return operands[1] + end + else + return ("(" .. table.concat(operands, padded_op) .. ")") + end + end + end + SPECIALS[name] = _0_ + end + return doc_special(name, {"a", "b", "..."}, "Arithmetic operator; works the same as Lua but accepts more arguments.") + end + define_arithmetic_special("+", "0") + define_arithmetic_special("..", "''") + define_arithmetic_special("^") + define_arithmetic_special("-", nil, "") + define_arithmetic_special("*", "1") + define_arithmetic_special("%") + define_arithmetic_special("/", nil, "1") + define_arithmetic_special("//", nil, "1") + define_arithmetic_special("lshift", nil, "1", "<<") + define_arithmetic_special("rshift", nil, "1", ">>") + define_arithmetic_special("band", "0", "0", "&") + define_arithmetic_special("bor", "0", "0", "|") + define_arithmetic_special("bxor", "0", "0", "~") + doc_special("lshift", {"x", "n"}, "Bitwise logical left shift of x by n bits; only works in Lua 5.3+.") + doc_special("rshift", {"x", "n"}, "Bitwise logical right shift of x by n bits; only works in Lua 5.3+.") + doc_special("band", {"x1", "x2"}, "Bitwise AND of arguments; only works in Lua 5.3+.") + doc_special("bor", {"x1", "x2"}, "Bitwise OR of arguments; only works in Lua 5.3+.") + doc_special("bxor", {"x1", "x2"}, "Bitwise XOR of arguments; only works in Lua 5.3+.") + define_arithmetic_special("or", "false") + define_arithmetic_special("and", "true") + doc_special("and", {"a", "b", "..."}, "Boolean operator; works the same as Lua but accepts more arguments.") + doc_special("or", {"a", "b", "..."}, "Boolean operator; works the same as Lua but accepts more arguments.") + doc_special("..", {"a", "b", "..."}, "String concatenation operator; works the same as Lua but accepts more arguments.") + local function native_comparator(op, _0_0, scope, parent) + local _1_ = _0_0 + local _ = _1_[1] + local lhs_ast = _1_[2] + local rhs_ast = _1_[3] + local _2_ = compiler.compile1(lhs_ast, scope, parent, {nval = 1}) + local lhs = _2_[1] + local _3_ = compiler.compile1(rhs_ast, scope, parent, {nval = 1}) + local rhs = _3_[1] + return string.format("(%s %s %s)", tostring(lhs), op, tostring(rhs)) + end + local function double_eval_protected_comparator(op, chain_op, ast, scope, parent) + local arglist = {} + local comparisons = {} + local vals = {} + local chain = string.format(" %s ", (chain_op or "and")) + for i = 2, #ast do + table.insert(arglist, tostring(compiler.gensym(scope))) + table.insert(vals, tostring(compiler.compile1(ast[i], scope, parent, {nval = 1})[1])) + end + for i = 1, (#arglist - 1) do + table.insert(comparisons, string.format("(%s %s %s)", arglist[i], op, arglist[(i + 1)])) + end + return string.format("(function(%s) return %s end)(%s)", table.concat(arglist, ","), table.concat(comparisons, chain), table.concat(vals, ",")) + end + local function define_comparator_special(name, lua_op, chain_op) + do + local op = (lua_op or name) + local function opfn(ast, scope, parent) + compiler.assert((2 < #ast), "expected at least two arguments", ast) + if (3 == #ast) then + return native_comparator(op, ast, scope, parent) + else + return double_eval_protected_comparator(op, chain_op, ast, scope, parent) + end + end + SPECIALS[name] = opfn + end + return doc_special(name, {"a", "b", "..."}, "Comparison operator; works the same as Lua but accepts more arguments.") + end + define_comparator_special(">") + define_comparator_special("<") + define_comparator_special(">=") + define_comparator_special("<=") + define_comparator_special("=", "==") + define_comparator_special("not=", "~=", "or") + SPECIALS["~="] = SPECIALS["not="] + local function define_unary_special(op, realop) + local function opfn(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument", ast) + local tail = compiler.compile1(ast[2], scope, parent, {nval = 1}) + return ((realop or op) .. tostring(tail[1])) + end + SPECIALS[op] = opfn + return nil + end + define_unary_special("not", "not ") + doc_special("not", {"x"}, "Logical operator; works the same as Lua.") + define_unary_special("bnot", "~") + doc_special("bnot", {"x"}, "Bitwise negation; only works in Lua 5.3+.") + define_unary_special("length", "#") + doc_special("length", {"x"}, "Returns the length of a table or string.") + SPECIALS["#"] = SPECIALS.length + SPECIALS.quote = function(ast, scope, parent) + compiler.assert((#ast == 2), "expected one argument") + local runtime, this_scope = true, scope + while this_scope do + this_scope = this_scope.parent + if (this_scope == compiler.scopes.compiler) then + runtime = false + end + end + return compiler["do-quote"](ast[2], scope, parent, runtime) + end + doc_special("quote", {"x"}, "Quasiquote the following form. Only works in macro/compiler scope.") + local already_warned_3f = {} + local compile_env_warning = ("WARNING: Attempting to %s %s in compile" .. " scope.\nIn future versions of Fennel this will not" .. " be allowed without the\n--no-compiler-sandbox flag" .. " or passing :compiler-env _G in options.\n") + local function compiler_env_warn(_, key) + local v = _G[key] + if (v and io and io.stderr and not already_warned_3f[key]) then + already_warned_3f[key] = true + do end (io.stderr):write(compile_env_warning:format("use global", key)) + end + return v + end + local safe_compiler_env = setmetatable({assert = assert, bit = _G.bit, error = error, getmetatable = getmetatable, ipairs = ipairs, math = math, next = next, pairs = pairs, pcall = pcall, print = print, rawequal = rawequal, rawget = rawget, rawlen = _G.rawlen, rawset = rawset, select = select, setmetatable = setmetatable, string = string, table = table, tonumber = tonumber, tostring = tostring, type = type, xpcall = xpcall}, {__index = compiler_env_warn}) + local function make_compiler_env(ast, scope, parent) + local function _1_() + return compiler.scopes.macro + end + local function _2_(symbol) + compiler.assert(compiler.scopes.macro, "must call from macro", ast) + return compiler.scopes.macro.manglings[tostring(symbol)] + end + local function _3_(base) + return utils.sym(compiler.gensym((compiler.scopes.macro or scope), base)) + end + local function _4_(form) + compiler.assert(compiler.scopes.macro, "must call from macro", ast) + return compiler.macroexpand(form, compiler.scopes.macro) + end + local _6_ + do + local _5_0 = utils.root.options + if ((type(_5_0) == "table") and (nil ~= _5_0["compiler-env"])) then + local compiler_env = _5_0["compiler-env"] + _6_ = compiler_env + else + local _ = _5_0 + _6_ = safe_compiler_env + end + end + return setmetatable({["assert-compile"] = compiler.assert, ["get-scope"] = _1_, ["in-scope?"] = _2_, ["list?"] = utils["list?"], ["multi-sym?"] = utils["multi-sym?"], ["sequence?"] = utils["sequence?"], ["sym?"] = utils["sym?"], ["table?"] = utils["table?"], ["varg?"] = utils["varg?"], _AST = ast, _CHUNK = parent, _IS_COMPILER = true, _SCOPE = scope, _SPECIALS = compiler.scopes.global.specials, _VARARG = utils.varg(), gensym = _3_, list = utils.list, macroexpand = _4_, sequence = utils.sequence, sym = utils.sym, unpack = unpack}, {__index = _6_}) + end + local cfg = string.gmatch(package.config, "([^\n]+)") + local dirsep, pathsep, pathmark = (cfg() or "/"), (cfg() or ";"), (cfg() or "?") + local pkg_config = {dirsep = dirsep, pathmark = pathmark, pathsep = pathsep} + local function escapepat(str) + return string.gsub(str, "[^%w]", "%%%1") + end + local function search_module(modulename, pathstring) + local pathsepesc = escapepat(pkg_config.pathsep) + local pattern = ("([^%s]*)%s"):format(pathsepesc, pathsepesc) + local no_dot_module = modulename:gsub("%.", pkg_config.dirsep) + local fullpath = ((pathstring or utils["fennel-module"].path) .. pkg_config.pathsep) + local function try_path(path) + local filename = path:gsub(escapepat(pkg_config.pathmark), no_dot_module) + local filename2 = path:gsub(escapepat(pkg_config.pathmark), modulename) + local _1_0 = (io.open(filename) or io.open(filename2)) + if (nil ~= _1_0) then + local file = _1_0 + file:close() + return filename + end + end + local function find_in_path(start) + local _1_0 = fullpath:match(pattern, start) + if (nil ~= _1_0) then + local path = _1_0 + return (try_path(path) or find_in_path((start + #path + 1))) + end + end + return find_in_path(1) + end + local function make_searcher(options) + local opts = utils.copy(utils.root.options) + for k, v in pairs((options or {})) do + opts[k] = v + end + local function _1_(module_name) + local filename = search_module(module_name) + if filename then + local function _2_(mod_name) + return utils["fennel-module"].dofile(filename, opts, mod_name) + end + return _2_ + end + end + return _1_ + end + local function macro_globals(env, globals) + local allowed = current_global_names(env) + for _, k in pairs((globals or {})) do + table.insert(allowed, k) + end + return allowed + end + local function compiler_env_domodule(modname, env, _3fast) + local filename = compiler.assert(search_module(modname), (modname .. " module not found."), _3fast) + local globals = macro_globals(env, current_global_names()) + return utils["fennel-module"].dofile(filename, {allowedGlobals = globals, env = env, scope = compiler.scopes.compiler, useMetadata = utils.root.options.useMetadata}) + end + local macro_loaded = {} + local function metadata_only_fennel(modname) + if ((modname == "fennel.macros") or (package and package.loaded and ("table" == type(package.loaded[modname])) and (package.loaded[modname].metadata == compiler.metadata))) then + return {metadata = compiler.metadata} + end + end + safe_compiler_env.require = function(modname) + local function _1_() + local mod = compiler_env_domodule(modname, safe_compiler_env) + macro_loaded[modname] = mod + return mod + end + return (macro_loaded[modname] or metadata_only_fennel(modname) or _1_()) + end + local function add_macros(macros_2a, ast, scope) + compiler.assert(utils["table?"](macros_2a), "expected macros to be table", ast) + for k, v in pairs(macros_2a) do + compiler.assert((type(v) == "function"), "expected each macro to be function", ast) + scope.macros[k] = v + end + return nil + end + SPECIALS["require-macros"] = function(ast, scope, parent) + compiler.assert((#ast == 2), "Expected one module name argument", ast) + local modname = ast[2] + if not macro_loaded[modname] then + local env = make_compiler_env(ast, scope, parent) + macro_loaded[modname] = compiler_env_domodule(modname, env, ast) + end + return add_macros(macro_loaded[modname], ast, scope, parent) + end + doc_special("require-macros", {"macro-module-name"}, "Load given module and use its contents as macro definitions in current scope.\nMacro module should return a table of macro functions with string keys.\nConsider using import-macros instead as it is more flexible.") + local function emit_fennel(src, path, opts, sub_chunk) + local subscope = compiler["make-scope"](utils.root.scope.parent) + local forms = {} + if utils.root.options.requireAsInclude then + subscope.specials.require = compiler["require-include"] + end + for _, val in parser.parser(parser["string-stream"](src), path) do + table.insert(forms, val) + end + for i = 1, #forms do + local subopts = nil + if (i == #forms) then + subopts = {nval = 1, tail = true} + else + subopts = {nval = 0} + end + utils["propagate-options"](opts, subopts) + compiler.compile1(forms[i], subscope, sub_chunk, subopts) + end + return nil + end + local function include_path(ast, opts, path, mod, fennel_3f) + utils.root.scope.includes[mod] = "fnl/loading" + local src = nil + do + local f = assert(io.open(path)) + local function close_handlers_0_(ok_0_, ...) + f:close() + if ok_0_ then + return ... + else + return error(..., 0) + end + end + local function _1_() + return f:read("*all"):gsub("[\13\n]*$", "") + end + src = close_handlers_0_(xpcall(_1_, (package.loaded.fennel or debug).traceback)) + end + local ret = utils.expr(("require(\"" .. mod .. "\")"), "statement") + local target = ("package.preload[%q]"):format(mod) + local preload_str = (target .. " = " .. target .. " or function(...)") + local temp_chunk, sub_chunk = {}, {} + compiler.emit(temp_chunk, preload_str, ast) + compiler.emit(temp_chunk, sub_chunk) + compiler.emit(temp_chunk, "end", ast) + for i, v in ipairs(temp_chunk) do + table.insert(utils.root.chunk, i, v) + end + if fennel_3f then + emit_fennel(src, path, opts, sub_chunk) + else + compiler.emit(sub_chunk, src, ast) + end + utils.root.scope.includes[mod] = ret + return ret + end + local function include_circular_fallback(mod, modexpr, fallback, ast) + if (utils.root.scope.includes[mod] == "fnl/loading") then + compiler.assert(fallback, "circular include detected", ast) + return fallback(modexpr) + end + end + SPECIALS.include = function(ast, scope, parent, opts) + compiler.assert((#ast == 2), "expected one argument", ast) + local modexpr = compiler.compile1(ast[2], scope, parent, {nval = 1})[1] + if ((modexpr.type ~= "literal") or ((modexpr[1]):byte() ~= 34)) then + if opts.fallback then + return opts.fallback(modexpr) + else + return compiler.assert(false, "module name must be string literal", ast) + end + else + local mod = load_code(("return " .. modexpr[1]))() + local function _2_() + local _1_0 = search_module(mod) + if (nil ~= _1_0) then + local fennel_path = _1_0 + return include_path(ast, opts, fennel_path, mod, true) + else + local _ = _1_0 + local lua_path = search_module(mod, package.path) + if lua_path then + return include_path(ast, opts, lua_path, mod, false) + elseif opts.fallback then + return opts.fallback(modexpr) + else + return compiler.assert(false, ("module not found " .. mod), ast) + end + end + end + return (include_circular_fallback(mod, modexpr, opts.fallback, ast) or utils.root.scope.includes[mod] or _2_()) + end + end + doc_special("include", {"module-name-literal"}, "Like require but load the target module during compilation and embed it in the\nLua output. The module must be a string literal and resolvable at compile time.") + local function eval_compiler_2a(ast, scope, parent) + local env = make_compiler_env(ast, scope, parent) + local opts = utils.copy(utils.root.options) + opts.scope = compiler["make-scope"](compiler.scopes.compiler) + opts.allowedGlobals = macro_globals(env, current_global_names()) + return load_code(compiler.compile(ast, opts), wrap_env(env))() + end + SPECIALS.macros = function(ast, scope, parent) + compiler.assert((#ast == 2), "Expected one table argument", ast) + return add_macros(eval_compiler_2a(ast[2], scope, parent), ast, scope, parent) + end + doc_special("macros", {"{:macro-name-1 (fn [...] ...) ... :macro-name-N macro-body-N}"}, "Define all functions in the given table as macros local to the current scope.") + SPECIALS["eval-compiler"] = function(ast, scope, parent) + local old_first = ast[1] + ast[1] = utils.sym("do") + local val = eval_compiler_2a(ast, scope, parent) + ast[1] = old_first + return val + end + doc_special("eval-compiler", {"..."}, "Evaluate the body at compile-time. Use the macro system instead if possible.") + return {["current-global-names"] = current_global_names, ["load-code"] = load_code, ["macro-loaded"] = macro_loaded, ["make-compiler-env"] = make_compiler_env, ["make-searcher"] = make_searcher, ["search-module"] = search_module, ["wrap-env"] = wrap_env, doc = doc_2a} +end +package.preload["fennel.compiler"] = package.preload["fennel.compiler"] or function(...) + local utils = require("fennel.utils") + local parser = require("fennel.parser") + local friend = require("fennel.friend") + local unpack = (_G.unpack or table.unpack) + local scopes = {} + local function make_scope(parent) + local parent0 = (parent or scopes.global) + local _0_ + if parent0 then + _0_ = ((parent0.depth or 0) + 1) + else + _0_ = 0 + end + return {autogensyms = {}, depth = _0_, hashfn = (parent0 and parent0.hashfn), includes = setmetatable({}, {__index = (parent0 and parent0.includes)}), macros = setmetatable({}, {__index = (parent0 and parent0.macros)}), manglings = setmetatable({}, {__index = (parent0 and parent0.manglings)}), parent = parent0, refedglobals = setmetatable({}, {__index = (parent0 and parent0.refedglobals)}), specials = setmetatable({}, {__index = (parent0 and parent0.specials)}), symmeta = setmetatable({}, {__index = (parent0 and parent0.symmeta)}), unmanglings = setmetatable({}, {__index = (parent0 and parent0.unmanglings)}), vararg = (parent0 and parent0.vararg)} + end + local function assert_compile(condition, msg, ast) + if not condition then + local _0_ = (utils.root.options or {}) + local source = _0_["source"] + local unfriendly = _0_["unfriendly"] + utils.root.reset() + if unfriendly then + local m = getmetatable(ast) + local filename = ((m and m.filename) or ast.filename or "unknown") + local line = ((m and m.line) or ast.line or "?") + local target = nil + local function _1_() + if utils["sym?"](ast[1]) then + return utils.deref(ast[1]) + else + return (ast[1] or "()") + end + end + target = tostring(_1_()) + error(string.format("Compile error in '%s' %s:%s: %s", target, filename, line, msg), 0) + else + friend["assert-compile"](condition, msg, ast, source) + end + end + return condition + end + scopes.global = make_scope() + scopes.global.vararg = true + scopes.compiler = make_scope(scopes.global) + scopes.macro = scopes.global + local serialize_subst = {["\11"] = "\\v", ["\12"] = "\\f", ["\7"] = "\\a", ["\8"] = "\\b", ["\9"] = "\\t", ["\n"] = "n"} + local function serialize_string(str) + local function _0_(_241) + return ("\\" .. _241:byte()) + end + return string.gsub(string.gsub(string.format("%q", str), ".", serialize_subst), "[\128-\255]", _0_) + end + local function global_mangling(str) + if utils["valid-lua-identifier?"](str) then + return str + else + local function _0_(_241) + return string.format("_%02x", _241:byte()) + end + return ("__fnl_global__" .. str:gsub("[^%w]", _0_)) + end + end + local function global_unmangling(identifier) + local _0_0 = string.match(identifier, "^__fnl_global__(.*)$") + if (nil ~= _0_0) then + local rest = _0_0 + local _1_0 = nil + local function _2_(_241) + return string.char(tonumber(_241:sub(2), 16)) + end + _1_0 = string.gsub(rest, "_[%da-f][%da-f]", _2_) + return _1_0 + else + local _ = _0_0 + return identifier + end + end + local allowed_globals = nil + local function global_allowed(name) + return (not allowed_globals or utils["member?"](name, allowed_globals)) + end + local function unique_mangling(original, mangling, scope, append) + if scope.unmanglings[mangling] then + return unique_mangling(original, (original .. append), scope, (append + 1)) + else + return mangling + end + end + local function local_mangling(str, scope, ast, temp_manglings) + assert_compile(not utils["multi-sym?"](str), ("unexpected multi symbol " .. str), ast) + local raw = nil + if (utils["lua-keywords"][str] or str:match("^%d")) then + raw = ("_" .. str) + else + raw = str + end + local mangling = nil + local function _1_(_241) + return string.format("_%02x", _241:byte()) + end + mangling = string.gsub(string.gsub(raw, "-", "_"), "[^%w_]", _1_) + local unique = unique_mangling(mangling, mangling, scope, 0) + scope.unmanglings[unique] = str + do + local manglings = (temp_manglings or scope.manglings) + manglings[str] = unique + end + return unique + end + local function apply_manglings(scope, new_manglings, ast) + for raw, mangled in pairs(new_manglings) do + assert_compile(not scope.refedglobals[mangled], ("use of global " .. raw .. " is aliased by a local"), ast) + scope.manglings[raw] = mangled + end + return nil + end + local function combine_parts(parts, scope) + local ret = (scope.manglings[parts[1]] or global_mangling(parts[1])) + for i = 2, #parts do + if utils["valid-lua-identifier?"](parts[i]) then + if (parts["multi-sym-method-call"] and (i == #parts)) then + ret = (ret .. ":" .. parts[i]) + else + ret = (ret .. "." .. parts[i]) + end + else + ret = (ret .. "[" .. serialize_string(parts[i]) .. "]") + end + end + return ret + end + local function gensym(scope, base) + local append, mangling = 0, ((base or "") .. "_0_") + while scope.unmanglings[mangling] do + mangling = ((base or "") .. "_" .. append .. "_") + append = (append + 1) + end + scope.unmanglings[mangling] = (base or true) + return mangling + end + local function autogensym(base, scope) + local _0_0 = utils["multi-sym?"](base) + if (nil ~= _0_0) then + local parts = _0_0 + parts[1] = autogensym(parts[1], scope) + return table.concat(parts, ((parts["multi-sym-method-call"] and ":") or ".")) + else + local _ = _0_0 + local function _1_() + local mangling = gensym(scope, base:sub(1, ( - 2))) + scope.autogensyms[base] = mangling + return mangling + end + return (scope.autogensyms[base] or _1_()) + end + end + local function check_binding_valid(symbol, scope, ast) + local name = utils.deref(symbol) + assert_compile(not (scope.specials[name] or scope.macros[name]), ("local %s was overshadowed by a special form or macro"):format(name), ast) + return assert_compile(not utils["quoted?"](symbol), string.format("macro tried to bind %s without gensym", name), symbol) + end + local function declare_local(symbol, meta, scope, ast, temp_manglings) + check_binding_valid(symbol, scope, ast) + local name = utils.deref(symbol) + assert_compile(not utils["multi-sym?"](name), ("unexpected multi symbol " .. name), ast) + scope.symmeta[name] = meta + return local_mangling(name, scope, ast, temp_manglings) + end + local function hashfn_arg_name(name, multi_sym_parts, scope) + if not scope.hashfn then + return nil + elseif (name == "$") then + return "$1" + elseif multi_sym_parts then + if (multi_sym_parts and (multi_sym_parts[1] == "$")) then + multi_sym_parts[1] = "$1" + end + return table.concat(multi_sym_parts, ".") + end + end + local function symbol_to_expression(symbol, scope, reference_3f) + utils.hook("symbol-to-expression", symbol, scope, reference_3f) + local name = symbol[1] + local multi_sym_parts = utils["multi-sym?"](name) + local name0 = (hashfn_arg_name(name, multi_sym_parts, scope) or name) + local parts = (multi_sym_parts or {name0}) + local etype = (((#parts > 1) and "expression") or "sym") + local local_3f = scope.manglings[parts[1]] + if (local_3f and scope.symmeta[parts[1]]) then + scope.symmeta[parts[1]]["used"] = true + end + assert_compile((not reference_3f or local_3f or global_allowed(parts[1])), ("unknown global in strict mode: " .. parts[1]), symbol) + if (allowed_globals and not local_3f) then + utils.root.scope.refedglobals[parts[1]] = true + end + return utils.expr(combine_parts(parts, scope), etype) + end + local function emit(chunk, out, ast) + if (type(out) == "table") then + return table.insert(chunk, out) + else + return table.insert(chunk, {ast = ast, leaf = out}) + end + end + local function peephole(chunk) + if chunk.leaf then + return chunk + elseif ((#chunk >= 3) and (chunk[(#chunk - 2)].leaf == "do") and not chunk[(#chunk - 1)].leaf and (chunk[#chunk].leaf == "end")) then + local kid = peephole(chunk[(#chunk - 1)]) + local new_chunk = {ast = chunk.ast} + for i = 1, (#chunk - 3) do + table.insert(new_chunk, peephole(chunk[i])) + end + for i = 1, #kid do + table.insert(new_chunk, kid[i]) + end + return new_chunk + else + return utils.map(chunk, peephole) + end + end + local function flatten_chunk_correlated(main_chunk) + local function flatten(chunk, out, last_line, file) + local last_line0 = last_line + if chunk.leaf then + out[last_line0] = ((out[last_line0] or "") .. " " .. chunk.leaf) + else + for _, subchunk in ipairs(chunk) do + if (subchunk.leaf or (#subchunk > 0)) then + if (subchunk.ast and (file == subchunk.ast.file)) then + last_line0 = math.max(last_line0, (subchunk.ast.line or 0)) + end + last_line0 = flatten(subchunk, out, last_line0, file) + end + end + end + return last_line0 + end + local out = {} + local last = flatten(main_chunk, out, 1, main_chunk.file) + for i = 1, last do + if (out[i] == nil) then + out[i] = "" + end + end + return table.concat(out, "\n") + end + local function flatten_chunk(sm, chunk, tab, depth) + if chunk.leaf then + local code = chunk.leaf + local info = chunk.ast + if sm then + table.insert(sm, ((info and info.line) or ( - 1))) + end + return code + else + local tab0 = nil + do + local _0_0 = tab + if (_0_0 == true) then + tab0 = " " + elseif (_0_0 == false) then + tab0 = "" + elseif (_0_0 == tab) then + tab0 = tab + elseif (_0_0 == nil) then + tab0 = "" + else + tab0 = nil + end + end + local function parter(c) + if (c.leaf or (#c > 0)) then + local sub = flatten_chunk(sm, c, tab0, (depth + 1)) + if (depth > 0) then + return (tab0 .. sub:gsub("\n", ("\n" .. tab0))) + else + return sub + end + end + end + return table.concat(utils.map(chunk, parter), "\n") + end + end + local fennel_sourcemap = {} + local function make_short_src(source) + local source0 = source:gsub("\n", " ") + if (#source0 <= 49) then + return ("[fennel \"" .. source0 .. "\"]") + else + return ("[fennel \"" .. source0:sub(1, 46) .. "...\"]") + end + end + local function flatten(chunk, options) + local chunk0 = peephole(chunk) + if options.correlate then + return flatten_chunk_correlated(chunk0), {} + else + local sm = {} + local ret = flatten_chunk(sm, chunk0, options.indent, 0) + if sm then + sm.short_src = make_short_src((options.filename or options.source or ret)) + if options.filename then + sm.key = ("@" .. options.filename) + else + sm.key = ret + end + fennel_sourcemap[sm.key] = sm + end + return ret, sm + end + end + local function make_metadata() + local function _0_(self, tgt, key) + if self[tgt] then + return self[tgt][key] + end + end + local function _1_(self, tgt, key, value) + self[tgt] = (self[tgt] or {}) + self[tgt][key] = value + return tgt + end + local function _2_(self, tgt, ...) + local kv_len = select("#", ...) + local kvs = {...} + if ((kv_len % 2) ~= 0) then + error("metadata:setall() expected even number of k/v pairs") + end + self[tgt] = (self[tgt] or {}) + for i = 1, kv_len, 2 do + self[tgt][kvs[i]] = kvs[(i + 1)] + end + return tgt + end + return setmetatable({}, {__index = {get = _0_, set = _1_, setall = _2_}, __mode = "k"}) + end + local function exprs1(exprs) + return table.concat(utils.map(exprs, 1), ", ") + end + local function keep_side_effects(exprs, chunk, start, ast) + local start0 = (start or 1) + for j = start0, #exprs do + local se = exprs[j] + if ((se.type == "expression") and (se[1] ~= "nil")) then + emit(chunk, string.format("do local _ = %s end", tostring(se)), ast) + elseif (se.type == "statement") then + local code = tostring(se) + emit(chunk, (((code:byte() == 40) and ("do end " .. code)) or code), ast) + end + end + return nil + end + local function handle_compile_opts(exprs, parent, opts, ast) + if opts.nval then + local n = opts.nval + local len = #exprs + if (n ~= len) then + if (len > n) then + keep_side_effects(exprs, parent, (n + 1), ast) + for i = (n + 1), len do + exprs[i] = nil + end + else + for i = (#exprs + 1), n do + exprs[i] = utils.expr("nil", "literal") + end + end + end + end + if opts.tail then + emit(parent, string.format("return %s", exprs1(exprs)), ast) + end + if opts.target then + local result = exprs1(exprs) + local function _2_() + if (result == "") then + return "nil" + else + return result + end + end + emit(parent, string.format("%s = %s", opts.target, _2_()), ast) + end + if (opts.tail or opts.target) then + return {returned = true} + else + local _3_0 = exprs + _3_0["returned"] = true + return _3_0 + end + end + local function find_macro(ast, scope, multi_sym_parts) + local function find_in_table(t, i) + if (i <= #multi_sym_parts) then + return find_in_table((utils["table?"](t) and t[multi_sym_parts[i]]), (i + 1)) + else + return t + end + end + local macro_2a = (utils["sym?"](ast[1]) and scope.macros[utils.deref(ast[1])]) + if (not macro_2a and multi_sym_parts) then + local nested_macro = find_in_table(scope.macros, 1) + assert_compile((not scope.macros[multi_sym_parts[1]] or (type(nested_macro) == "function")), "macro not found in imported macro module", ast) + return nested_macro + else + return macro_2a + end + end + local function macroexpand_2a(ast, scope, once) + if not utils["list?"](ast) then + return ast + else + local macro_2a = find_macro(ast, scope, utils["multi-sym?"](ast[1])) + if not macro_2a then + return ast + else + local old_scope = scopes.macro + local _ = nil + scopes.macro = scope + _ = nil + local ok, transformed = pcall(macro_2a, unpack(ast, 2)) + scopes.macro = old_scope + assert_compile(ok, transformed, ast) + if (once or not transformed) then + return transformed + else + return macroexpand_2a(transformed, scope) + end + end + end + end + local function compile_special(ast, scope, parent, opts, special) + local exprs = (special(ast, scope, parent, opts) or utils.expr("nil", "literal")) + local exprs0 = nil + if (type(exprs) == "string") then + exprs0 = utils.expr(exprs, "expression") + else + exprs0 = exprs + end + local exprs2 = nil + if utils["expr?"](exprs0) then + exprs2 = {exprs0} + else + exprs2 = exprs0 + end + if not exprs2.returned then + return handle_compile_opts(exprs2, parent, opts, ast) + elseif (opts.tail or opts.target) then + return {returned = true} + else + return exprs2 + end + end + local function compile_call(ast, scope, parent, opts, compile1) + utils.hook("call", ast, scope) + local len = #ast + local first = ast[1] + local multi_sym_parts = utils["multi-sym?"](first) + local special = (utils["sym?"](first) and scope.specials[utils.deref(first)]) + assert_compile((len > 0), "expected a function, macro, or special to call", ast) + if special then + return compile_special(ast, scope, parent, opts, special) + elseif (multi_sym_parts and multi_sym_parts["multi-sym-method-call"]) then + local table_with_method = table.concat({unpack(multi_sym_parts, 1, (#multi_sym_parts - 1))}, ".") + local method_to_call = multi_sym_parts[#multi_sym_parts] + local new_ast = utils.list(utils.sym(":", scope), utils.sym(table_with_method, scope), method_to_call, select(2, unpack(ast))) + return compile1(new_ast, scope, parent, opts) + else + local fargs = {} + local fcallee = compile1(ast[1], scope, parent, {nval = 1})[1] + assert_compile((fcallee.type ~= "literal"), ("cannot call literal value " .. tostring(first)), ast) + for i = 2, len do + local subexprs = compile1(ast[i], scope, parent, {nval = (((i ~= len) and 1) or nil)}) + table.insert(fargs, (subexprs[1] or utils.expr("nil", "literal"))) + if (i == len) then + for j = 2, #subexprs do + table.insert(fargs, subexprs[j]) + end + else + keep_side_effects(subexprs, parent, 2, ast[i]) + end + end + local call = string.format("%s(%s)", tostring(fcallee), exprs1(fargs)) + return handle_compile_opts({utils.expr(call, "statement")}, parent, opts, ast) + end + end + local function compile_varg(ast, scope, parent, opts) + assert_compile(scope.vararg, "unexpected vararg", ast) + return handle_compile_opts({utils.expr("...", "varg")}, parent, opts, ast) + end + local function compile_sym(ast, scope, parent, opts) + local multi_sym_parts = utils["multi-sym?"](ast) + assert_compile(not (multi_sym_parts and multi_sym_parts["multi-sym-method-call"]), "multisym method calls may only be in call position", ast) + local e = nil + if (ast[1] == "nil") then + e = utils.expr("nil", "literal") + else + e = symbol_to_expression(ast, scope, true) + end + return handle_compile_opts({e}, parent, opts, ast) + end + local function compile_scalar(ast, _scope, parent, opts) + local serialize = nil + do + local _0_0 = type(ast) + if (_0_0 == "nil") then + serialize = tostring + elseif (_0_0 == "boolean") then + serialize = tostring + elseif (_0_0 == "string") then + serialize = serialize_string + elseif (_0_0 == "number") then + local function _1_(...) + return string.format("%.17g", ...) + end + serialize = _1_ + else + serialize = nil + end + end + return handle_compile_opts({utils.expr(serialize(ast), "literal")}, parent, opts) + end + local function compile_table(ast, scope, parent, opts, compile1) + local buffer = {} + for i = 1, #ast do + local nval = ((i ~= #ast) and 1) + table.insert(buffer, exprs1(compile1(ast[i], scope, parent, {nval = nval}))) + end + local function write_other_values(k) + if ((type(k) ~= "number") or (math.floor(k) ~= k) or (k < 1) or (k > #ast)) then + if ((type(k) == "string") and utils["valid-lua-identifier?"](k)) then + return {k, k} + else + local _0_ = compile1(k, scope, parent, {nval = 1}) + local compiled = _0_[1] + local kstr = ("[" .. tostring(compiled) .. "]") + return {kstr, k} + end + end + end + do + local keys = nil + do + local _0_0 = utils.kvmap(ast, write_other_values) + local function _1_(a, b) + return (a[1] < b[1]) + end + table.sort(_0_0, _1_) + keys = _0_0 + end + local function _1_(k) + local v = tostring(compile1(ast[k[2]], scope, parent, {nval = 1})[1]) + return string.format("%s = %s", k[1], v) + end + utils.map(keys, _1_, buffer) + end + return handle_compile_opts({utils.expr(("{" .. table.concat(buffer, ", ") .. "}"), "expression")}, parent, opts, ast) + end + local function compile1(ast, scope, parent, opts) + local opts0 = (opts or {}) + local ast0 = macroexpand_2a(ast, scope) + if utils["list?"](ast0) then + return compile_call(ast0, scope, parent, opts0, compile1) + elseif utils["varg?"](ast0) then + return compile_varg(ast0, scope, parent, opts0) + elseif utils["sym?"](ast0) then + return compile_sym(ast0, scope, parent, opts0) + elseif (type(ast0) == "table") then + return compile_table(ast0, scope, parent, opts0, compile1) + elseif ((type(ast0) == "nil") or (type(ast0) == "boolean") or (type(ast0) == "number") or (type(ast0) == "string")) then + return compile_scalar(ast0, scope, parent, opts0) + else + return assert_compile(false, ("could not compile value of type " .. type(ast0)), ast0) + end + end + local function destructure(to, from, ast, scope, parent, opts) + local opts0 = (opts or {}) + local _0_ = opts0 + local declaration = _0_["declaration"] + local forceglobal = _0_["forceglobal"] + local forceset = _0_["forceset"] + local isvar = _0_["isvar"] + local nomulti = _0_["nomulti"] + local noundef = _0_["noundef"] + local setter = nil + if declaration then + setter = "local %s = %s" + else + setter = "%s = %s" + end + local new_manglings = {} + local function getname(symbol, up1) + local raw = symbol[1] + assert_compile(not (nomulti and utils["multi-sym?"](raw)), ("unexpected multi symbol " .. raw), up1) + if declaration then + return declare_local(symbol, nil, scope, symbol, new_manglings) + else + local parts = (utils["multi-sym?"](raw) or {raw}) + local meta = scope.symmeta[parts[1]] + if ((#parts == 1) and not forceset) then + assert_compile(not (forceglobal and meta), string.format("global %s conflicts with local", tostring(symbol)), symbol) + assert_compile(not (meta and not meta.var), ("expected var " .. raw), symbol) + assert_compile((meta or not noundef), ("expected local " .. parts[1]), symbol) + end + if forceglobal then + assert_compile(not scope.symmeta[scope.unmanglings[raw]], ("global " .. raw .. " conflicts with local"), symbol) + scope.manglings[raw] = global_mangling(raw) + scope.unmanglings[global_mangling(raw)] = raw + if allowed_globals then + table.insert(allowed_globals, raw) + end + end + return symbol_to_expression(symbol, scope)[1] + end + end + local function compile_top_target(lvalues) + local inits = nil + local function _2_(_241) + if scope.manglings[_241] then + return _241 + else + return "nil" + end + end + inits = utils.map(lvalues, _2_) + local init = table.concat(inits, ", ") + local lvalue = table.concat(lvalues, ", ") + local plen, plast = #parent, parent[#parent] + local ret = compile1(from, scope, parent, {target = lvalue}) + if declaration then + for pi = plen, #parent do + if (parent[pi] == plast) then + plen = pi + end + end + if ((#parent == (plen + 1)) and parent[#parent].leaf) then + parent[#parent]["leaf"] = ("local " .. parent[#parent].leaf) + else + table.insert(parent, (plen + 1), {ast = ast, leaf = ("local " .. lvalue .. " = " .. init)}) + end + end + return ret + end + local function effective_key(key, val) + local key0 = nil + if (utils["sym?"](key) and (tostring(key) == ":") and utils["sym?"](val)) then + key0 = tostring(val) + else + key0 = key + end + if (type(key0) == "string") then + return serialize_string(key0) + else + return key0 + end + end + local function destructure1(left, rightexprs, up1, top) + if (utils["sym?"](left) and (left[1] ~= "nil")) then + local lname = getname(left, up1) + check_binding_valid(left, scope, left) + if top then + compile_top_target({lname}) + else + emit(parent, setter:format(lname, exprs1(rightexprs)), left) + end + if declaration then + scope.symmeta[utils.deref(left)] = {var = isvar} + end + elseif utils["table?"](left) then + local s = gensym(scope) + local right = nil + if top then + right = exprs1(compile1(from, scope, parent)) + else + right = exprs1(rightexprs) + end + if (right == "") then + right = "nil" + end + emit(parent, string.format("local %s = %s", s, right), left) + for k, v in utils.stablepairs(left) do + if (utils["sym?"](left[k]) and (left[k][1] == "&")) then + assert_compile(((type(k) == "number") and not left[(k + 2)]), "expected rest argument before last parameter", left) + local unpack_str = "{(table.unpack or unpack)(%s, %s)}" + local formatted = string.format(unpack_str, s, k) + local subexpr = utils.expr(formatted, "expression") + destructure1(left[(k + 1)], {subexpr}, left) + return + else + local subexpr = utils.expr(string.format("%s[%s]", s, effective_key(k, v)), "expression") + destructure1(v, {subexpr}, left) + end + end + elseif utils["list?"](left) then + local left_names, tables = {}, {} + for i, name in ipairs(left) do + if utils["sym?"](name) then + table.insert(left_names, getname(name, up1)) + else + local symname = gensym(scope) + table.insert(left_names, symname) + tables[i] = {name, utils.expr(symname, "sym")} + end + end + if top then + compile_top_target(left_names) + else + local lvalue = table.concat(left_names, ", ") + local setting = setter:format(lvalue, exprs1(rightexprs)) + emit(parent, setting, left) + end + if declaration then + for _, sym in ipairs(left) do + scope.symmeta[utils.deref(sym)] = {var = isvar} + end + end + for _, pair in utils.stablepairs(tables) do + destructure1(pair[1], {pair[2]}, left) + end + else + assert_compile(false, string.format("unable to bind %s %s", type(left), tostring(left)), (((type(up1[2]) == "table") and up1[2]) or up1)) + end + if top then + return {returned = true} + end + end + local ret = destructure1(to, nil, ast, true) + utils.hook("destructure", from, to, scope) + apply_manglings(scope, new_manglings, ast) + return ret + end + local function require_include(ast, scope, parent, opts) + opts.fallback = function(e) + return utils.expr(string.format("require(%s)", tostring(e)), "statement") + end + return scopes.global.specials.include(ast, scope, parent, opts) + end + local function compile_stream(strm, options) + local opts = utils.copy(options) + local old_globals = allowed_globals + local scope = (opts.scope or make_scope(scopes.global)) + local vals = {} + local chunk = {} + local _0_ = utils.root + _0_["set-reset"](_0_) + allowed_globals = opts.allowedGlobals + if (opts.indent == nil) then + opts.indent = " " + end + if opts.requireAsInclude then + scope.specials.require = require_include + end + utils.root.chunk, utils.root.scope, utils.root.options = chunk, scope, opts + for _, val in parser.parser(strm, opts.filename, opts) do + table.insert(vals, val) + end + for i = 1, #vals do + local exprs = compile1(vals[i], scope, chunk, {nval = (((i < #vals) and 0) or nil), tail = (i == #vals)}) + keep_side_effects(exprs, chunk, nil, vals[i]) + end + allowed_globals = old_globals + utils.root.reset() + return flatten(chunk, opts) + end + local function compile_string(str, opts) + return compile_stream(parser["string-stream"](str), (opts or {})) + end + local function compile(ast, opts) + local opts0 = utils.copy(opts) + local old_globals = allowed_globals + local chunk = {} + local scope = (opts0.scope or make_scope(scopes.global)) + local _0_ = utils.root + _0_["set-reset"](_0_) + allowed_globals = opts0.allowedGlobals + if (opts0.indent == nil) then + opts0.indent = " " + end + if opts0.requireAsInclude then + scope.specials.require = require_include + end + utils.root.chunk, utils.root.scope, utils.root.options = chunk, scope, opts0 + local exprs = compile1(ast, scope, chunk, {tail = true}) + keep_side_effects(exprs, chunk, nil, ast) + allowed_globals = old_globals + utils.root.reset() + return flatten(chunk, opts0) + end + local function traceback_frame(info) + if ((info.what == "C") and info.name) then + return string.format(" [C]: in function '%s'", info.name) + elseif (info.what == "C") then + return " [C]: in ?" + else + local remap = fennel_sourcemap[info.source] + if (remap and remap[info.currentline]) then + info["short-src"] = remap["short-src"] + info.currentline = remap[info.currentline] + end + if (info.what == "Lua") then + local function _1_() + if info.name then + return ("'" .. info.name .. "'") + else + return "?" + end + end + return string.format(" %s:%d: in function %s", info.short_src, info.currentline, _1_()) + elseif (info["short-src"] == "(tail call)") then + return " (tail call)" + else + return string.format(" %s:%d: in main chunk", info.short_src, info.currentline) + end + end + end + local function traceback(msg, start) + local msg0 = (msg or "") + if ((msg0:find("^Compile error") or msg0:find("^Parse error")) and not utils["debug-on?"]("trace")) then + return msg0 + else + local lines = {} + if (msg0:find("^Compile error") or msg0:find("^Parse error")) then + table.insert(lines, msg0) + else + local newmsg = msg0:gsub("^[^:]*:%d+:%s+", "runtime error: ") + table.insert(lines, newmsg) + end + table.insert(lines, "stack traceback:") + local done_3f, level = false, (start or 2) + while not done_3f do + do + local _1_0 = debug.getinfo(level, "Sln") + if (_1_0 == nil) then + done_3f = true + elseif (nil ~= _1_0) then + local info = _1_0 + table.insert(lines, traceback_frame(info)) + end + end + level = (level + 1) + end + return table.concat(lines, "\n") + end + end + local function entry_transform(fk, fv) + local function _0_(k, v) + if (type(k) == "number") then + return k, fv(v) + else + return fk(k), fv(v) + end + end + return _0_ + end + local function no() + return nil + end + local function mixed_concat(t, joiner) + local seen = {} + local ret, s = "", "" + for k, v in ipairs(t) do + table.insert(seen, k) + ret = (ret .. s .. v) + s = joiner + end + for k, v in utils.stablepairs(t) do + if not seen[k] then + ret = (ret .. s .. "[" .. k .. "]" .. "=" .. v) + s = joiner + end + end + return ret + end + local function do_quote(form, scope, parent, runtime_3f) + local function q(x) + return do_quote(x, scope, parent, runtime_3f) + end + if utils["varg?"](form) then + assert_compile(not runtime_3f, "quoted ... may only be used at compile time", form) + return "_VARARG" + elseif utils["sym?"](form) then + local filename = nil + if form.filename then + filename = string.format("%q", form.filename) + else + filename = "nil" + end + local symstr = utils.deref(form) + assert_compile(not runtime_3f, "symbols may only be used at compile time", form) + if (symstr:find("#$") or symstr:find("#[:.]")) then + return string.format("sym('%s', nil, {filename=%s, line=%s})", autogensym(symstr, scope), filename, (form.line or "nil")) + else + return string.format("sym('%s', nil, {quoted=true, filename=%s, line=%s})", symstr, filename, (form.line or "nil")) + end + elseif (utils["list?"](form) and utils["sym?"](form[1]) and (utils.deref(form[1]) == "unquote")) then + local payload = form[2] + local res = unpack(compile1(payload, scope, parent)) + return res[1] + elseif utils["list?"](form) then + local mapped = utils.kvmap(form, entry_transform(no, q)) + local filename = nil + if form.filename then + filename = string.format("%q", form.filename) + else + filename = "nil" + end + assert_compile(not runtime_3f, "lists may only be used at compile time", form) + return string.format(("setmetatable({filename=%s, line=%s, bytestart=%s, %s}" .. ", getmetatable(list()))"), filename, (form.line or "nil"), (form.bytestart or "nil"), mixed_concat(mapped, ", ")) + elseif (type(form) == "table") then + local mapped = utils.kvmap(form, entry_transform(q, q)) + local source = getmetatable(form) + local filename = nil + if source.filename then + filename = string.format("%q", source.filename) + else + filename = "nil" + end + local function _1_() + if source then + return source.line + else + return "nil" + end + end + return string.format("setmetatable({%s}, {filename=%s, line=%s})", mixed_concat(mapped, ", "), filename, _1_()) + elseif (type(form) == "string") then + return serialize_string(form) + else + return tostring(form) + end + end + return {["apply-manglings"] = apply_manglings, ["compile-stream"] = compile_stream, ["compile-string"] = compile_string, ["declare-local"] = declare_local, ["do-quote"] = do_quote, ["global-mangling"] = global_mangling, ["global-unmangling"] = global_unmangling, ["keep-side-effects"] = keep_side_effects, ["make-scope"] = make_scope, ["require-include"] = require_include, ["symbol-to-expression"] = symbol_to_expression, assert = assert_compile, autogensym = autogensym, compile = compile, compile1 = compile1, destructure = destructure, emit = emit, gensym = gensym, macroexpand = macroexpand_2a, metadata = make_metadata(), scopes = scopes, traceback = traceback} +end +package.preload["fennel.friend"] = package.preload["fennel.friend"] or function(...) + local function ast_source(ast) + local m = getmetatable(ast) + if (m and m.line and m) then + return m + else + return ast + end + end + local suggestions = {["$ and $... in hashfn are mutually exclusive"] = {"modifying the hashfn so it only contains $... or $, $1, $2, $3, etc"}, ["can't start multisym segment with a digit"] = {"removing the digit", "adding a non-digit before the digit"}, ["cannot call literal value"] = {"checking for typos", "checking for a missing function name"}, ["could not compile value of type "] = {"debugging the macro you're calling not to return a coroutine or userdata"}, ["could not read number (.*)"] = {"removing the non-digit character", "beginning the identifier with a non-digit if it is not meant to be a number"}, ["expected a function.* to call"] = {"removing the empty parentheses", "using square brackets if you want an empty table"}, ["expected binding table"] = {"placing a table here in square brackets containing identifiers to bind"}, ["expected body expression"] = {"putting some code in the body of this form after the bindings"}, ["expected each macro to be function"] = {"ensuring that the value for each key in your macros table contains a function", "avoid defining nested macro tables"}, ["expected even number of name/value bindings"] = {"finding where the identifier or value is missing"}, ["expected even number of values in table literal"] = {"removing a key", "adding a value"}, ["expected local"] = {"looking for a typo", "looking for a local which is used out of its scope"}, ["expected macros to be table"] = {"ensuring your macro definitions return a table"}, ["expected parameters"] = {"adding function parameters as a list of identifiers in brackets"}, ["expected rest argument before last parameter"] = {"moving & to right before the final identifier when destructuring"}, ["expected symbol for function parameter: (.*)"] = {"changing %s to an identifier instead of a literal value"}, ["expected var (.*)"] = {"declaring %s using var instead of let/local", "introducing a new local instead of changing the value of %s"}, ["expected vararg as last parameter"] = {"moving the \"...\" to the end of the parameter list"}, ["expected whitespace before opening delimiter"] = {"adding whitespace"}, ["global (.*) conflicts with local"] = {"renaming local %s"}, ["illegal character: (.)"] = {"deleting or replacing %s", "avoiding reserved characters like \", \\, ', ~, ;, @, `, and comma"}, ["local (.*) was overshadowed by a special form or macro"] = {"renaming local %s"}, ["macro not found in macro module"] = {"checking the keys of the imported macro module's returned table"}, ["macro tried to bind (.*) without gensym"] = {"changing to %s# when introducing identifiers inside macros"}, ["malformed multisym"] = {"ensuring each period or colon is not followed by another period or colon"}, ["may only be used at compile time"] = {"moving this to inside a macro if you need to manipulate symbols/lists", "using square brackets instead of parens to construct a table"}, ["method must be last component"] = {"using a period instead of a colon for field access", "removing segments after the colon", "making the method call, then looking up the field on the result"}, ["mismatched closing delimiter (.), expected (.)"] = {"replacing %s with %s", "deleting %s", "adding matching opening delimiter earlier"}, ["multisym method calls may only be in call position"] = {"using a period instead of a colon to reference a table's fields", "putting parens around this"}, ["unable to bind (.*)"] = {"replacing the %s with an identifier"}, ["unexpected closing delimiter (.)"] = {"deleting %s", "adding matching opening delimiter earlier"}, ["unexpected multi symbol (.*)"] = {"removing periods or colons from %s"}, ["unexpected vararg"] = {"putting \"...\" at the end of the fn parameters if the vararg was intended"}, ["unknown global in strict mode: (.*)"] = {"looking to see if there's a typo", "using the _G table instead, eg. _G.%s if you really want a global", "moving this code to somewhere that %s is in scope", "binding %s as a local in the scope of this code"}, ["unused local (.*)"] = {"fixing a typo so %s is used", "renaming the local to _%s"}, ["use of global (.*) is aliased by a local"] = {"renaming local %s", "refer to the global using _G.%s instead of directly"}} + local unpack = (_G.unpack or table.unpack) + local function suggest(msg) + local suggestion = nil + for pat, sug in pairs(suggestions) do + local matches = {msg:match(pat)} + if (0 < #matches) then + if ("table" == type(sug)) then + local out = {} + for _, s in ipairs(sug) do + table.insert(out, s:format(unpack(matches))) + end + suggestion = out + else + suggestion = sug(matches) + end + end + end + return suggestion + end + local function read_line_from_file(filename, line) + local bytes = 0 + local f = assert(io.open(filename)) + local _ = nil + for _0 = 1, (line - 1) do + bytes = (bytes + 1 + #f:read()) + end + _ = nil + local codeline = f:read() + f:close() + return codeline, bytes + end + local function read_line_from_source(source, line) + local lines, bytes, codeline = 0, 0 + for this_line, newline in string.gmatch((source .. "\n"), "(.-)(\13?\n)") do + lines = (lines + 1) + if (lines == line) then + codeline = this_line + break + end + bytes = (bytes + #newline + #this_line) + end + return codeline, bytes + end + local function read_line(filename, line, source) + if source then + return read_line_from_source(source, line) + else + return read_line_from_file(filename, line) + end + end + local function friendly_msg(msg, _0_0, source) + local _1_ = _0_0 + local byteend = _1_["byteend"] + local bytestart = _1_["bytestart"] + local filename = _1_["filename"] + local line = _1_["line"] + local ok, codeline, bol = pcall(read_line, filename, line, source) + local suggestions0 = suggest(msg) + local out = {msg, ""} + if (ok and codeline) then + table.insert(out, codeline) + end + if (ok and codeline and bytestart and byteend) then + table.insert(out, (string.rep(" ", (bytestart - bol - 1)) .. "^" .. string.rep("^", math.min((byteend - bytestart), ((bol + #codeline) - bytestart))))) + end + if (ok and codeline and bytestart and not byteend) then + table.insert(out, (string.rep("-", (bytestart - bol - 1)) .. "^")) + table.insert(out, "") + end + if suggestions0 then + for _, suggestion in ipairs(suggestions0) do + table.insert(out, ("* Try %s."):format(suggestion)) + end + end + return table.concat(out, "\n") + end + local function assert_compile(condition, msg, ast, source) + if not condition then + local _1_ = ast_source(ast) + local filename = _1_["filename"] + local line = _1_["line"] + error(friendly_msg(("Compile error in %s:%s\n %s"):format((filename or "unknown"), (line or "?"), msg), ast_source(ast), source), 0) + end + return condition + end + local function parse_error(msg, filename, line, bytestart, source) + return error(friendly_msg(("Parse error in %s:%s\n %s"):format(filename, line, msg), {bytestart = bytestart, filename = filename, line = line}, source), 0) + end + return {["assert-compile"] = assert_compile, ["parse-error"] = parse_error} +end +package.preload["fennel.parser"] = package.preload["fennel.parser"] or function(...) + local utils = require("fennel.utils") + local friend = require("fennel.friend") + local unpack = (_G.unpack or table.unpack) + local function granulate(getchunk) + local c, index, done_3f = "", 1, false + local function _0_(parser_state) + if not done_3f then + if (index <= #c) then + local b = c:byte(index) + index = (index + 1) + return b + else + local _1_0, _2_0, _3_0 = getchunk(parser_state) + local _4_ + do + local char = _1_0 + _4_ = ((nil ~= _1_0) and (char ~= "")) + end + if _4_ then + local char = _1_0 + c = char + index = 2 + return c:byte() + else + local _ = _1_0 + done_3f = true + return nil + end + end + end + end + local function _1_() + c = "" + return nil + end + return _0_, _1_ + end + local function string_stream(str) + local str0 = str:gsub("^#![^\n]*\n", "") + local index = 1 + local function _0_() + local r = str0:byte(index) + index = (index + 1) + return r + end + return _0_ + end + local delims = {[123] = 125, [125] = true, [40] = 41, [41] = true, [91] = 93, [93] = true} + local function whitespace_3f(b) + return ((b == 32) or ((b >= 9) and (b <= 13))) + end + local function symbolchar_3f(b) + return ((b > 32) and not delims[b] and (b ~= 127) and (b ~= 34) and (b ~= 39) and (b ~= 126) and (b ~= 59) and (b ~= 44) and (b ~= 64) and (b ~= 96)) + end + local prefixes = {[35] = "hashfn", [39] = "quote", [44] = "unquote", [96] = "quote"} + local function parser(getbyte, filename, options) + local stack = {} + local line = 1 + local byteindex = 0 + local lastb = nil + local function ungetb(ub) + if (ub == 10) then + line = (line - 1) + end + byteindex = (byteindex - 1) + lastb = ub + return nil + end + local function getb() + local r = nil + if lastb then + r, lastb = lastb, nil + else + r = getbyte({["stack-size"] = #stack}) + end + byteindex = (byteindex + 1) + if (r == 10) then + line = (line + 1) + end + return r + end + local function parse_error(msg, byteindex_override) + local _0_ = (options or utils.root.options or {}) + local source = _0_["source"] + local unfriendly = _0_["unfriendly"] + utils.root.reset() + if unfriendly then + return error(string.format("Parse error in %s:%s: %s", (filename or "unknown"), (line or "?"), msg), 0) + else + return friend["parse-error"](msg, (filename or "unknown"), (line or "?"), (byteindex_override or byteindex), source) + end + end + local function parse_stream() + local whitespace_since_dispatch, done_3f, retval = true + local function dispatch(v) + local _0_0 = stack[#stack] + if (_0_0 == nil) then + retval, done_3f, whitespace_since_dispatch = v, true, false + return nil + elseif ((type(_0_0) == "table") and (nil ~= _0_0.prefix)) then + local prefix = _0_0.prefix + table.remove(stack) + return dispatch(utils.list(utils.sym(prefix), v)) + elseif (nil ~= _0_0) then + local top = _0_0 + whitespace_since_dispatch = false + return table.insert(top, v) + end + end + local function badend() + local accum = utils.map(stack, "closer") + local _0_ + if (#stack == 1) then + _0_ = "" + else + _0_ = "s" + end + return parse_error(string.format("expected closing delimiter%s %s", _0_, string.char(unpack(accum)))) + end + local function skip_whitespace(b) + if (b and whitespace_3f(b)) then + whitespace_since_dispatch = true + return skip_whitespace(getb()) + elseif (not b and (#stack > 0)) then + return badend() + else + return b + end + end + local function skip_comment(b) + if (b and (10 ~= b)) then + return skip_comment(getb()) + else + return b + end + end + local function open_table(b) + if not whitespace_since_dispatch then + parse_error(("expected whitespace before opening delimiter " .. string.char(b))) + end + return table.insert(stack, {bytestart = byteindex, closer = delims[b], filename = filename, line = line}) + end + local function close_list(list) + return dispatch(setmetatable(list, getmetatable(utils.list()))) + end + local function close_sequence(tbl) + local val = utils.sequence(unpack(tbl)) + for k, v in pairs(tbl) do + getmetatable(val)[k] = v + end + return dispatch(val) + end + local function close_curly_table(tbl) + local val = {} + if ((#tbl % 2) ~= 0) then + byteindex = (byteindex - 1) + parse_error("expected even number of values in table literal") + end + setmetatable(val, tbl) + for i = 1, #tbl, 2 do + if ((tostring(tbl[i]) == ":") and utils["sym?"](tbl[(i + 1)]) and utils["sym?"](tbl[i])) then + tbl[i] = tostring(tbl[(i + 1)]) + end + val[tbl[i]] = tbl[(i + 1)] + end + return dispatch(val) + end + local function close_table(b) + local top = table.remove(stack) + if (top == nil) then + parse_error(("unexpected closing delimiter " .. string.char(b))) + end + if (top.closer ~= b) then + parse_error(("mismatched closing delimiter " .. string.char(b) .. ", expected " .. string.char(top.closer))) + end + top.byteend = byteindex + if (b == 41) then + return close_list(top) + elseif (b == 93) then + return close_sequence(top) + else + return close_curly_table(top) + end + end + local function parse_string_loop(chars, b, state) + table.insert(chars, b) + local state0 = nil + do + local _0_0 = {state, b} + if ((type(_0_0) == "table") and (_0_0[1] == "base") and (_0_0[2] == 92)) then + state0 = "backslash" + elseif ((type(_0_0) == "table") and (_0_0[1] == "base") and (_0_0[2] == 34)) then + state0 = "done" + else + local _ = _0_0 + state0 = "base" + end + end + if (b and (state0 ~= "done")) then + return parse_string_loop(chars, getb(), state0) + else + return b + end + end + local function parse_string() + table.insert(stack, {closer = 34}) + local chars = {34} + if not parse_string_loop(chars, getb(), "base") then + badend() + end + table.remove(stack) + local raw = string.char(unpack(chars)) + local formatted = nil + local function _1_(c) + return ("\\" .. c:byte()) + end + formatted = raw:gsub("[\1-\31]", _1_) + local load_fn = (_G.loadstring or load)(("return " .. formatted)) + return dispatch(load_fn()) + end + local function parse_prefix(b) + table.insert(stack, {prefix = prefixes[b]}) + local nextb = getb() + if whitespace_3f(nextb) then + if (b ~= 35) then + parse_error("invalid whitespace after quoting prefix") + end + table.remove(stack) + dispatch(utils.sym("#")) + end + return ungetb(nextb) + end + local function parse_sym_loop(chars, b) + if (b and symbolchar_3f(b)) then + table.insert(chars, b) + return parse_sym_loop(chars, getb()) + else + if b then + ungetb(b) + end + return chars + end + end + local function parse_number(rawstr) + local force_number = rawstr:match("^%d") + local number_with_stripped_underscores = rawstr:gsub("_", "") + if force_number then + dispatch((tonumber(number_with_stripped_underscores) or parse_error(("could not read number \"" .. rawstr .. "\"")))) + return true + else + local _0_0 = tonumber(number_with_stripped_underscores) + if (nil ~= _0_0) then + local x = _0_0 + dispatch(x) + return true + else + local _ = _0_0 + return false + end + end + end + local function check_malformed_sym(rawstr) + if (rawstr:match("^~") and (rawstr ~= "~=")) then + return parse_error("illegal character: ~") + elseif rawstr:match("%.[0-9]") then + return parse_error(("can't start multisym segment " .. "with a digit: " .. rawstr), (((byteindex - #rawstr) + rawstr:find("%.[0-9]")) + 1)) + elseif (rawstr:match("[%.:][%.:]") and (rawstr ~= "..") and (rawstr ~= "$...")) then + return parse_error(("malformed multisym: " .. rawstr), ((byteindex - #rawstr) + 1 + rawstr:find("[%.:][%.:]"))) + elseif rawstr:match(":.+[%.:]") then + return parse_error(("method must be last component " .. "of multisym: " .. rawstr), ((byteindex - #rawstr) + rawstr:find(":.+[%.:]"))) + end + end + local function parse_sym(b) + local bytestart = byteindex + local rawstr = string.char(unpack(parse_sym_loop({b}, getb()))) + if (rawstr == "true") then + return dispatch(true) + elseif (rawstr == "false") then + return dispatch(false) + elseif (rawstr == "...") then + return dispatch(utils.varg()) + elseif rawstr:match("^:.+$") then + return dispatch(rawstr:sub(2)) + elseif parse_number(rawstr) then + return nil + elseif check_malformed_sym(rawstr) then + return nil + else + return dispatch(utils.sym(rawstr, nil, {byteend = byteindex, bytestart = bytestart, filename = filename, line = line})) + end + end + local function parse_loop(b) + if not b then + elseif (b == 59) then + skip_comment(getb()) + elseif (type(delims[b]) == "number") then + open_table(b) + elseif delims[b] then + close_table(b) + elseif (b == 34) then + parse_string(b) + elseif prefixes[b] then + parse_prefix(b) + elseif (symbolchar_3f(b) or (b == string.byte("~"))) then + parse_sym(b) + else + parse_error(("illegal character: " .. string.char(b))) + end + if not b then + return nil + elseif done_3f then + return true, retval + else + return parse_loop(skip_whitespace(getb())) + end + end + return parse_loop(skip_whitespace(getb())) + end + local function _0_() + stack = {} + return nil + end + return parse_stream, _0_ + end + return {["string-stream"] = string_stream, granulate = granulate, parser = parser} +end +local utils = nil +package.preload["fennel.utils"] = package.preload["fennel.utils"] or function(...) + local function stablepairs(t) + local keys = {} + local succ = {} + for k in pairs(t) do + table.insert(keys, k) + end + local function _0_(a, b) + return (tostring(a) < tostring(b)) + end + table.sort(keys, _0_) + for i, k in ipairs(keys) do + succ[k] = keys[(i + 1)] + end + local function stablenext(tbl, idx) + if (idx == nil) then + return keys[1], tbl[keys[1]] + else + return succ[idx], tbl[succ[idx]] + end + end + return stablenext, t, nil + end + local function map(t, f, out) + local out0 = (out or {}) + local f0 = nil + if (type(f) == "function") then + f0 = f + else + local s = f + local function _0_(x) + return x[s] + end + f0 = _0_ + end + for _, x in ipairs(t) do + local _1_0 = f0(x) + if (nil ~= _1_0) then + local v = _1_0 + table.insert(out0, v) + end + end + return out0 + end + local function kvmap(t, f, out) + local out0 = (out or {}) + local f0 = nil + if (type(f) == "function") then + f0 = f + else + local s = f + local function _0_(x) + return x[s] + end + f0 = _0_ + end + for k, x in stablepairs(t) do + local korv, v = f0(k, x) + if (korv and not v) then + table.insert(out0, korv) + end + if (korv and v) then + out0[korv] = v + end + end + return out0 + end + local function copy(from, to) + local to0 = (to or {}) + for k, v in pairs((from or {})) do + to0[k] = v + end + return to0 + end + local function member_3f(x, tbl, n) + local _0_0 = tbl[(n or 1)] + if (_0_0 == x) then + return true + elseif (_0_0 == nil) then + return false + else + local _ = _0_0 + return member_3f(x, tbl, ((n or 1) + 1)) + end + end + local function allpairs(tbl) + assert((type(tbl) == "table"), "allpairs expects a table") + local t = tbl + local seen = {} + local function allpairs_next(_, state) + local next_state, value = next(t, state) + if seen[next_state] then + return allpairs_next(nil, next_state) + elseif next_state then + seen[next_state] = true + return next_state, value + else + local meta = getmetatable(t) + if (meta and meta.__index) then + t = meta.__index + return allpairs_next(t) + end + end + end + return allpairs_next + end + local function deref(self) + return self[1] + end + local nil_sym = nil + local function list__3estring(self, tostring2) + local safe, max = {}, 0 + for k in pairs(self) do + if ((type(k) == "number") and (k > max)) then + max = k + end + end + for i = 1, max do + safe[i] = (((self[i] == nil) and nil_sym) or self[i]) + end + return ("(" .. table.concat(map(safe, (tostring2 or tostring)), " ", 1, max) .. ")") + end + local symbol_mt = {"SYMBOL", __fennelview = deref, __tostring = deref} + local expr_mt = {"EXPR", __tostring = deref} + local list_mt = {"LIST", __fennelview = list__3estring, __tostring = list__3estring} + local sequence_marker = {"SEQUENCE"} + local vararg = setmetatable({"..."}, {"VARARG", __fennelview = deref, __tostring = deref}) + local getenv = nil + local function _0_() + return nil + end + getenv = ((os and os.getenv) or _0_) + local function debug_on_3f(flag) + local level = (getenv("FENNEL_DEBUG") or "") + return ((level == "all") or level:find(flag)) + end + local function list(...) + return setmetatable({...}, list_mt) + end + local function sym(str, scope, source) + local s = {str, scope = scope} + for k, v in pairs((source or {})) do + if (type(k) == "string") then + s[k] = v + end + end + return setmetatable(s, symbol_mt) + end + nil_sym = sym("nil") + local function sequence(...) + return setmetatable({...}, {sequence = sequence_marker}) + end + local function expr(strcode, etype) + return setmetatable({strcode, type = etype}, expr_mt) + end + local function varg() + return vararg + end + local function expr_3f(x) + return ((type(x) == "table") and (getmetatable(x) == expr_mt) and x) + end + local function varg_3f(x) + return ((x == vararg) and x) + end + local function list_3f(x) + return ((type(x) == "table") and (getmetatable(x) == list_mt) and x) + end + local function sym_3f(x) + return ((type(x) == "table") and (getmetatable(x) == symbol_mt) and x) + end + local function table_3f(x) + return ((type(x) == "table") and (x ~= vararg) and (getmetatable(x) ~= list_mt) and (getmetatable(x) ~= symbol_mt) and x) + end + local function sequence_3f(x) + local mt = ((type(x) == "table") and getmetatable(x)) + return (mt and (mt.sequence == sequence_marker) and x) + end + local function multi_sym_3f(str) + if sym_3f(str) then + return multi_sym_3f(tostring(str)) + elseif (type(str) ~= "string") then + return false + else + local parts = {} + for part in str:gmatch("[^%.%:]+[%.%:]?") do + local last_char = part:sub(( - 1)) + if (last_char == ":") then + parts["multi-sym-method-call"] = true + end + if ((last_char == ":") or (last_char == ".")) then + parts[(#parts + 1)] = part:sub(1, ( - 2)) + else + parts[(#parts + 1)] = part + end + end + return ((#parts > 0) and (str:match("%.") or str:match(":")) and not str:match("%.%.") and (str:byte() ~= string.byte(".")) and (str:byte(( - 1)) ~= string.byte(".")) and parts) + end + end + local function quoted_3f(symbol) + return symbol.quoted + end + local function walk_tree(root, f, custom_iterator) + local function walk(iterfn, parent, idx, node) + if f(idx, node, parent) then + for k, v in iterfn(node) do + walk(iterfn, node, k, v) + end + return nil + end + end + walk((custom_iterator or pairs), nil, nil, root) + return root + end + local lua_keywords = {"and", "break", "do", "else", "elseif", "end", "false", "for", "function", "if", "in", "local", "nil", "not", "or", "repeat", "return", "then", "true", "until", "while", "goto"} + for i, v in ipairs(lua_keywords) do + lua_keywords[v] = i + end + local function valid_lua_identifier_3f(str) + return (str:match("^[%a_][%w_]*$") and not lua_keywords[str]) + end + local propagated_options = {"allowedGlobals", "indent", "correlate", "useMetadata", "env", "compiler-env"} + local function propagate_options(options, subopts) + for _, name in ipairs(propagated_options) do + subopts[name] = options[name] + end + return subopts + end + local root = nil + local function _1_() + end + root = {chunk = nil, options = nil, reset = _1_, scope = nil} + root["set-reset"] = function(_2_0) + local _3_ = _2_0 + local chunk = _3_["chunk"] + local options = _3_["options"] + local reset = _3_["reset"] + local scope = _3_["scope"] + root.reset = function() + root.chunk, root.scope, root.options, root.reset = chunk, scope, options, reset + return nil + end + return root.reset + end + local function hook(event, ...) + if (root.options and root.options.plugins) then + for _, plugin in ipairs(root.options.plugins) do + local _3_0 = plugin[event] + if (nil ~= _3_0) then + local f = _3_0 + f(...) + end + end + return nil + end + end + return {["debug-on?"] = debug_on_3f, ["expr?"] = expr_3f, ["list?"] = list_3f, ["lua-keywords"] = lua_keywords, ["member?"] = member_3f, ["multi-sym?"] = multi_sym_3f, ["propagate-options"] = propagate_options, ["quoted?"] = quoted_3f, ["sequence?"] = sequence_3f, ["sym?"] = sym_3f, ["table?"] = table_3f, ["valid-lua-identifier?"] = valid_lua_identifier_3f, ["varg?"] = varg_3f, ["walk-tree"] = walk_tree, allpairs = allpairs, copy = copy, deref = deref, expr = expr, hook = hook, kvmap = kvmap, list = list, map = map, path = table.concat({"./?.fnl", "./?/init.fnl", getenv("FENNEL_PATH")}, ";"), root = root, sequence = sequence, stablepairs = stablepairs, sym = sym, varg = varg} +end +utils = require("fennel.utils") +local parser = require("fennel.parser") +local compiler = require("fennel.compiler") +local specials = require("fennel.specials") +local repl = require("fennel.repl") +local function get_env(env) + if (env == "_COMPILER") then + local env0 = specials["make-compiler-env"](nil, compiler.scopes.compiler, {}) + local mt = getmetatable(env0) + mt.__index = _G + return specials["wrap-env"](env0) + else + return (env and specials["wrap-env"](env)) + end +end +local function eval(str, options, ...) + local opts = utils.copy(options) + local _ = nil + if ((opts.allowedGlobals == nil) and not getmetatable(opts.env)) then + opts.allowedGlobals = specials["current-global-names"](opts.env) + _ = nil + else + _ = nil + end + local env = get_env(opts.env) + local lua_source = compiler["compile-string"](str, opts) + local loader = nil + local function _1_(...) + if opts.filename then + return ("@" .. opts.filename) + else + return str + end + end + loader = specials["load-code"](lua_source, env, _1_(...)) + opts.filename = nil + return loader(...) +end +local function dofile_2a(filename, options, ...) + local opts = utils.copy(options) + local f = assert(io.open(filename, "rb")) + local source = assert(f:read("*all"), ("Could not read " .. filename)) + f:close() + opts.filename = filename + return eval(source, opts, ...) +end +local mod = {["compile-stream"] = compiler["compile-stream"], ["compile-string"] = compiler["compile-string"], ["list?"] = utils["list?"], ["load-code"] = specials["load-code"], ["macro-loaded"] = specials["macro-loaded"], ["make-searcher"] = specials["make-searcher"], ["search-module"] = specials["search-module"], ["string-stream"] = parser["string-stream"], ["sym?"] = utils["sym?"], compile = compiler.compile, compile1 = compiler.compile1, compileStream = compiler["compile-stream"], compileString = compiler["compile-string"], doc = specials.doc, dofile = dofile_2a, eval = eval, gensym = compiler.gensym, granulate = parser.granulate, list = utils.list, loadCode = specials["load-code"], macroLoaded = specials["macro-loaded"], makeSearcher = specials["make-searcher"], make_searcher = specials["make-searcher"], mangle = compiler["global-mangling"], metadata = compiler.metadata, parser = parser.parser, path = utils.path, repl = repl, scope = compiler["make-scope"], searchModule = specials["search-module"], searcher = specials["make-searcher"](), stringStream = parser["string-stream"], sym = utils.sym, traceback = compiler.traceback, unmangle = compiler["global-unmangling"], varg = utils.varg, version = "0.7.0"} +utils["fennel-module"] = mod +do + local builtin_macros = [===[;; This module contains all the built-in Fennel macros. Unlike all the other + ;; modules that are loaded by the old bootstrap compiler, this runs in the + ;; compiler scope of the version of the compiler being defined. + + ;; The code for these macros is somewhat idiosyncratic because it cannot use any + ;; macros which have not yet been defined. + + ;; TODO: some of these macros modify their arguments; we should stop doing that, + ;; but in a way that preserves file/line metadata. + + (fn -> [val ...] + "Thread-first macro. + Take the first value and splice it into the second form as its first argument. + The value of the second form is spliced into the first arg of the third, etc." + (var x val) + (each [_ e (ipairs [...])] + (let [elt (if (list? e) e (list e))] + (table.insert elt 2 x) + (set x elt))) + x) + + (fn ->> [val ...] + "Thread-last macro. + Same as ->, except splices the value into the last position of each form + rather than the first." + (var x val) + (each [_ e (pairs [...])] + (let [elt (if (list? e) e (list e))] + (table.insert elt x) + (set x elt))) + x) + + (fn -?> [val ...] + "Nil-safe thread-first macro. + Same as -> except will short-circuit with nil when it encounters a nil value." + (if (= 0 (select "#" ...)) + val + (let [els [...] + e (table.remove els 1) + el (if (list? e) e (list e)) + tmp (gensym)] + (table.insert el 2 tmp) + `(let [,tmp ,val] + (if ,tmp + (-?> ,el ,(unpack els)) + ,tmp))))) + + (fn -?>> [val ...] + "Nil-safe thread-last macro. + Same as ->> except will short-circuit with nil when it encounters a nil value." + (if (= 0 (select "#" ...)) + val + (let [els [...] + e (table.remove els 1) + el (if (list? e) e (list e)) + tmp (gensym)] + (table.insert el tmp) + `(let [,tmp ,val] + (if ,tmp + (-?>> ,el ,(unpack els)) + ,tmp))))) + + (fn doto [val ...] + "Evaluates val and splices it into the first argument of subsequent forms." + (let [name (gensym) + form `(let [,name ,val])] + (each [_ elt (pairs [...])] + (table.insert elt 2 name) + (table.insert form elt)) + (table.insert form name) + form)) + + (fn when [condition body1 ...] + "Evaluate body for side-effects only when condition is truthy." + (assert body1 "expected body") + `(if ,condition + (do ,body1 ,...))) + + (fn with-open [closable-bindings ...] + "Like `let`, but invokes (v:close) on each binding after evaluating the body. + The body is evaluated inside `xpcall` so that bound values will be closed upon + encountering an error before propagating it." + (let [bodyfn `(fn [] ,...) + closer `(fn close-handlers# [ok# ...] (if ok# ... + (error ... 0))) + traceback `(. (or package.loaded.fennel debug) :traceback)] + (for [i 1 (# closable-bindings) 2] + (assert (sym? (. closable-bindings i)) + "with-open only allows symbols in bindings") + (table.insert closer 4 `(: ,(. closable-bindings i) :close))) + `(let ,closable-bindings ,closer + (close-handlers# (xpcall ,bodyfn ,traceback))))) + + (fn partial [f ...] + "Returns a function with all arguments partially applied to f." + (let [body (list f ...)] + (table.insert body _VARARG) + `(fn [,_VARARG] ,body))) + + (fn pick-args [n f] + "Creates a function of arity n that applies its arguments to f. + + For example, + (pick-args 2 func) + expands to + (fn [_0_ _1_] (func _0_ _1_))" + (assert (and (= (type n) :number) (= n (math.floor n)) (>= n 0)) + "Expected n to be an integer literal >= 0.") + (let [bindings []] + (for [i 1 n] (tset bindings i (gensym))) + `(fn ,bindings (,f ,(unpack bindings))))) + + (fn pick-values [n ...] + "Like the `values` special, but emits exactly n values. + + For example, + (pick-values 2 ...) + expands to + (let [(_0_ _1_) ...] + (values _0_ _1_))" + (assert (and (= :number (type n)) (>= n 0) (= n (math.floor n))) + "Expected n to be an integer >= 0") + (let [let-syms (list) + let-values (if (= 1 (select :# ...)) ... `(values ,...))] + (for [i 1 n] (table.insert let-syms (gensym))) + (if (= n 0) `(values) + `(let [,let-syms ,let-values] (values ,(unpack let-syms)))))) + + (fn lambda [...] + "Function literal with arity checking. + Will throw an exception if a declared argument is passed in as nil, unless + that argument name begins with ?." + (let [args [...] + has-internal-name? (sym? (. args 1)) + arglist (if has-internal-name? (. args 2) (. args 1)) + docstring-position (if has-internal-name? 3 2) + has-docstring? (and (> (# args) docstring-position) + (= :string (type (. args docstring-position)))) + arity-check-position (- 4 (if has-internal-name? 0 1) + (if has-docstring? 0 1)) + empty-body? (< (# args) arity-check-position)] + (fn check! [a] + (if (table? a) + (each [_ a (pairs a)] + (check! a)) + (let [as (tostring a)] + (and (not (as:match "^?")) (not= as "&") (not= as "_") (not= as "..."))) + (table.insert args arity-check-position + `(assert (not= nil ,a) + (string.format "Missing argument %s on %s:%s" + ,(tostring a) + ,(or a.filename "unknown") + ,(or a.line "?")))))) + (assert (= :table (type arglist)) "expected arg list") + (each [_ a (ipairs arglist)] + (check! a)) + (if empty-body? + (table.insert args (sym :nil))) + `(fn ,(unpack args)))) + + (fn macro [name ...] + "Define a single macro." + (assert (sym? name) "expected symbol for macro name") + (local args [...]) + `(macros { ,(tostring name) (fn ,name ,(unpack args))})) + + (fn macrodebug [form return?] + "Print the resulting form after performing macroexpansion. + With a second argument, returns expanded form as a string instead of printing." + (let [(ok view) (pcall require :fennelview) + handle (if return? `do `print)] + `(,handle ,((if ok view tostring) (macroexpand form _SCOPE))))) + + (fn import-macros [binding1 module-name1 ...] + "Binds a table of macros from each macro module according to a binding form. + Each binding form can be either a symbol or a k/v destructuring table. + Example: + (import-macros mymacros :my-macros ; bind to symbol + {:macro1 alias : macro2} :proj.macros) ; import by name" + (assert (and binding1 module-name1 (= 0 (% (select :# ...) 2))) + "expected even number of binding/modulename pairs") + (for [i 1 (select :# binding1 module-name1 ...) 2] + (local (binding modname) (select i binding1 module-name1 ...)) + ;; generate a subscope of current scope, use require-macros + ;; to bring in macro module. after that, we just copy the + ;; macros from subscope to scope. + (local scope (get-scope)) + (local subscope (fennel.scope scope)) + (fennel.compile-string (string.format "(require-macros %q)" + modname) + {:scope subscope + :compiler-env utils.root.options.compiler-env}) + (if (sym? binding) + ;; bind whole table of macros to table bound to symbol + (do (tset scope.macros (. binding 1) {}) + (each [k v (pairs subscope.macros)] + (tset (. scope.macros (. binding 1)) k v))) + + ;; 1-level table destructuring for importing individual macros + (table? binding) + (each [macro-name [import-key] (pairs binding)] + (assert (= :function (type (. subscope.macros macro-name))) + (.. "macro " macro-name " not found in module " modname)) + (tset scope.macros import-key (. subscope.macros macro-name))))) + nil) + + ;;; Pattern matching + + (fn match-values [vals pattern unifications match-pattern] + (let [condition `(and) + bindings []] + (each [i pat (ipairs pattern)] + (let [(subcondition subbindings) (match-pattern [(. vals i)] pat + unifications)] + (table.insert condition subcondition) + (each [_ b (ipairs subbindings)] + (table.insert bindings b)))) + (values condition bindings))) + + (fn match-table [val pattern unifications match-pattern] + (let [condition `(and (= (type ,val) :table)) + bindings []] + (each [k pat (pairs pattern)] + (if (and (sym? pat) (= "&" (tostring pat))) + (do (assert (not (. pattern (+ k 2))) + "expected rest argument before last parameter") + (table.insert bindings (. pattern (+ k 1))) + (table.insert bindings [`(select ,k ((or _G.unpack + table.unpack) + ,val))])) + (and (= :number (type k)) + (= "&" (tostring (. pattern (- k 1))))) + nil ; don't process the pattern right after &; already got it + (let [subval `(. ,val ,k) + (subcondition subbindings) (match-pattern [subval] pat + unifications)] + (table.insert condition subcondition) + (each [_ b (ipairs subbindings)] + (table.insert bindings b))))) + (values condition bindings))) + + (fn match-pattern [vals pattern unifications] + "Takes the AST of values and a single pattern and returns a condition + to determine if it matches as well as a list of bindings to + introduce for the duration of the body if it does match." + ;; we have to assume we're matching against multiple values here until we + ;; know we're either in a multi-valued clause (in which case we know the # + ;; of vals) or we're not, in which case we only care about the first one. + (let [[val] vals] + (if (or (and (sym? pattern) ; unification with outer locals (or nil) + (not= :_ (tostring pattern)) ; never unify _ + (or (in-scope? pattern) + (= :nil (tostring pattern)))) + (and (multi-sym? pattern) + (in-scope? (. (multi-sym? pattern) 1)))) + (values `(= ,val ,pattern) []) + ;; unify a local we've seen already + (and (sym? pattern) (. unifications (tostring pattern))) + (values `(= ,(. unifications (tostring pattern)) ,val) []) + ;; bind a fresh local + (sym? pattern) + (let [wildcard? (: (tostring pattern) :find "^_")] + (if (not wildcard?) (tset unifications (tostring pattern) val)) + (values (if (or wildcard? (string.find (tostring pattern) "^?")) + true `(not= ,(sym :nil) ,val)) + [pattern val])) + ;; guard clause + (and (list? pattern) (sym? (. pattern 2)) (= :? (tostring (. pattern 2)))) + (let [(pcondition bindings) (match-pattern vals (. pattern 1) + unifications) + condition `(and ,pcondition)] + (for [i 3 (# pattern)] ; splice in guard clauses + (table.insert condition (. pattern i))) + (values `(let ,bindings ,condition) bindings)) + + ;; multi-valued patterns (represented as lists) + (list? pattern) + (match-values vals pattern unifications match-pattern) + ;; table patterns + (= (type pattern) :table) + (match-table val pattern unifications match-pattern) + ;; literal value + (values `(= ,val ,pattern) [])))) + + (fn match-condition [vals clauses] + "Construct the actual `if` AST for the given match values and clauses." + (if (not= 0 (% (length clauses) 2)) ; treat odd final clause as default + (table.insert clauses (length clauses) (sym :_))) + (let [out `(if)] + (for [i 1 (length clauses) 2] + (let [pattern (. clauses i) + body (. clauses (+ i 1)) + (condition bindings) (match-pattern vals pattern {})] + (table.insert out condition) + (table.insert out `(let ,bindings ,body)))) + out)) + + (fn match-val-syms [clauses] + "How many multi-valued clauses are there? return a list of that many gensyms." + (let [syms (list (gensym))] + (for [i 1 (length clauses) 2] + (if (list? (. clauses i)) + (each [valnum (ipairs (. clauses i))] + (if (not (. syms valnum)) + (tset syms valnum (gensym)))))) + syms)) + + (fn match [val ...] + "Perform pattern matching on val. See reference for details." + (let [clauses [...] + vals (match-val-syms clauses)] + ;; protect against multiple evaluation of the value, bind against as + ;; many values as we ever match against in the clauses. + (list `let [vals val] + (match-condition vals clauses)))) + + {: -> : ->> : -?> : -?>> + : doto : when : with-open + : partial : lambda + : pick-args : pick-values + : macro : macrodebug : import-macros + : match} + ]===] + local module_name = "fennel.macros" + local _ = nil + local function _0_() + return mod + end + package.preload[module_name] = _0_ + _ = nil + local env = nil + do + local _1_0 = specials["make-compiler-env"](nil, compiler.scopes.compiler, {}) + _1_0["require"] = require + _1_0["utils"] = utils + _1_0["fennel"] = mod + env = _1_0 + end + local built_ins = eval(builtin_macros, {allowedGlobals = false, env = env, filename = "src/fennel/macros.fnl", moduleName = module_name, scope = compiler.scopes.compiler, useMetadata = true}) + for k, v in pairs(built_ins) do + compiler.scopes.global.macros[k] = v + end + compiler.scopes.global.macros["\206\187"] = compiler.scopes.global.macros.lambda + package.preload[module_name] = nil +end +return mod diff --git a/vendor/jeejah/fennelview.fnl b/vendor/jeejah/fennelview.fnl new file mode 100644 index 0000000..19d9c16 --- /dev/null +++ b/vendor/jeejah/fennelview.fnl @@ -0,0 +1,202 @@ +;; A pretty-printer that outputs tables in Fennel syntax. +;; Loosely based on inspect.lua: http://github.com/kikito/inspect.lua + +(fn view-quote [str] (.. "\"" (: str :gsub "\"" "\\\"") "\"")) + +(local short-control-char-escapes + {"\a" "\\a" "\b" "\\b" "\f" "\\f" "\n" "\\n" + "\r" "\\r" "\t" "\\t" "\v" "\\v"}) + +(local long-control-char-escapes + (let [long {}] + (for [i 0 31] + (let [ch (string.char i)] + (when (not (. short-control-char-escapes ch)) + (tset short-control-char-escapes ch (.. "\\" i)) + (tset long ch (: "\\%03d" :format i))))) + long)) + +(fn escape [str] + (-> str + (: :gsub "\\" "\\\\") + (: :gsub "(%c)%f[0-9]" long-control-char-escapes) + (: :gsub "%c" short-control-char-escapes))) + +(fn sequence-key? [k len] + (and (= (type k) "number") + (<= 1 k) + (<= k len) + (= (math.floor k) k))) + +(local type-order {:number 1 :boolean 2 :string 3 :table 4 + :function 5 :userdata 6 :thread 7}) + +(fn sort-keys [a b] + (let [ta (type a) tb (type b)] + (if (and (= ta tb) + (or (= ta "string") (= ta "number"))) + (< a b) + (let [dta (. type-order a) + dtb (. type-order b)] + (if (and dta dtb) + (< dta dtb) + dta true + dtb false + :else (< ta tb)))))) + +(fn get-sequence-length [t] + (var len 1) + (each [i (ipairs t)] (set len i)) + len) + +(fn get-nonsequential-keys [t] + (let [keys {} + sequence-length (get-sequence-length t)] + (each [k (pairs t)] + (when (not (sequence-key? k sequence-length)) + (table.insert keys k))) + (table.sort keys sort-keys) + (values keys sequence-length))) + +(fn count-table-appearances [t appearances] + (when (= (type t) "table") + (if (not (. appearances t)) + (do (tset appearances t 1) + (each [k v (pairs t)] + (count-table-appearances k appearances) + (count-table-appearances v appearances))) + (tset appearances t (+ (or (. appearances t) 0) 1)))) + appearances) + + + +(var put-value nil) ; mutual recursion going on; defined below + +(fn puts [self ...] + (each [_ v (ipairs [...])] + (table.insert self.buffer v))) + +(fn tabify [self] (puts self "\n" (: self.indent :rep self.level))) + +(fn already-visited? [self v] (not= (. self.ids v) nil)) + +(fn get-id [self v] + (var id (. self.ids v)) + (when (not id) + (let [tv (type v)] + (set id (+ (or (. self.max-ids tv) 0) 1)) + (tset self.max-ids tv id) + (tset self.ids v id))) + (tostring id)) + +(fn put-sequential-table [self t len] + (puts self "[") + (set self.level (+ self.level 1)) + (for [i 1 len] + (when (< 1 i (+ 1 len)) + (puts self " ")) + (put-value self (. t i))) + (set self.level (- self.level 1)) + (puts self "]")) + +(fn put-key [self k] + (if (and (= (type k) "string") + (: k :find "^[-%w?\\^_!$%&*+./@:|<=>]+$")) + (puts self ":" k) + (put-value self k))) + +(fn put-kv-table [self t ordered-keys] + (puts self "{") + (set self.level (+ self.level 1)) + ;; first, output sorted nonsequential keys + (each [i k (ipairs ordered-keys)] + (when (or self.table-edges (not= i 1)) + (tabify self)) + (put-key self k) + (puts self " ") + (put-value self (. t k))) + ;; next, output any sequential keys + (each [i v (ipairs t)] + (tabify self) + (put-key self i) + (puts self " ") + (put-value self v)) + (set self.level (- self.level 1)) + (when self.table-edges + (tabify self)) + (puts self "}")) + +(fn put-table [self t] + (let [metamethod (and self.metamethod? (-?> t getmetatable (. :__fennelview)))] + (if (and (already-visited? self t) self.detect-cycles?) + (puts self "#
") + (>= self.level self.depth) + (puts self "{...}") + metamethod + (puts self (metamethod t self.fennelview)) + :else + (let [(non-seq-keys len) (get-nonsequential-keys t) + id (get-id self t)] + ;; fancy metatable stuff can result in self.appearances not including + ;; a table, so if it's not found, assume we haven't seen it; we can't + ;; do cycle detection in that case. + (when (and (< 1 (or (. self.appearances t) 0)) self.detect-cycles?) + (puts self "@" id)) + (if (and (= (length non-seq-keys) 0) (= (length t) 0)) + (puts self (if self.empty-as-square "[]" "{}")) + (= (length non-seq-keys) 0) + (put-sequential-table self t len) + :else + (put-kv-table self t non-seq-keys)))))) + +(set put-value (fn [self v] + (let [tv (type v)] + (if (= tv "string") + (puts self (view-quote (escape v))) + (or (= tv "number") (= tv "boolean") (= tv "nil")) + (puts self (tostring v)) + (= tv "table") + (put-table self v) + :else + (puts self "#<" (tostring v) ">"))))) + + + +(fn one-line [str] + ;; save return value as local to ignore gsub's extra return value + (let [ret (-> str + (: :gsub "\n" " ") + (: :gsub "%[ " "[") (: :gsub " %]" "]") + (: :gsub "%{ " "{") (: :gsub " %}" "}") + (: :gsub "%( " "(") (: :gsub " %)" ")"))] + ret)) + +(fn fennelview [x options] + "Return a string representation of x. + +Can take an options table with these keys: +* :one-line (boolean: default: false) keep the output string as a one-liner +* :depth (number, default: 128) limit how many levels to go (default: 128) +* :indent (string, default: \" \") use this string to indent each level +* :detect-cycles? (boolean, default: true) don't try to traverse a looping table +* :metamethod? (boolean: default: true) use the __fennelview metamethod if found +* :table-edges (boolean: default: true) put {} table brackets on their own line +* :empty-as-square (boolean: default: false) render empty tables as [], not {} + +The __fennelview metamethod should take the table being serialized as its first +argument and a function as its second arg which can be used on table elements to +continue the fennelview process on them. +" + (let [options (or options {}) + inspector {:appearances (count-table-appearances x {}) + :depth (or options.depth 128) + :level 0 :buffer {} :ids {} :max-ids {} + :indent (or options.indent (if options.one-line "" " ")) + :detect-cycles? (not (= false options.detect-cycles?)) + :metamethod? (not (= false options.metamethod?)) + :fennelview #(fennelview $1 options) + :table-edges (not= options.table-edges false) + :empty-as-square options.empty-as-square}] + (put-value inspector x) + (let [str (table.concat inspector.buffer)] + (if options.one-line (one-line str) str)))) diff --git a/vendor/jeejah/jeejah.lua b/vendor/jeejah/jeejah.lua new file mode 100644 index 0000000..3dffd9f --- /dev/null +++ b/vendor/jeejah/jeejah.lua @@ -0,0 +1,357 @@ +local socket = require "socket" +local serpent = require "serpent" +local bencode = require "bencode" + +local load = loadstring or load + +local timeout = 0.001 + +local d = os.getenv("DEBUG") and print or function(_) end +local serpent_pp = function(p) return function(x) + local serpent_opts = {maxlevel=8,maxnum=64,nocode=true} + p(serpent.block(x, serpent_opts)) end +end +local sessions = {} + +local response_for = function(old_msg, msg) + -- certain implementations break when the ns field is empty; see + -- https://gitlab.com/technomancy/jeejah/issues/5 + msg.session, msg.id, msg.ns = old_msg.session, old_msg.id, ">" + return msg +end + +local send = function(conn, msg) + d("Sending", bencode.encode(msg)) + conn:send(bencode.encode(msg)) +end + +local write_for = function(conn, msg) + return function(...) + send(conn, response_for(msg, {out=table.concat({...}, "\t")})) + end +end + +local print_for = function(write) + return function(...) + local args = {...} + for i,x in ipairs(args) do args[i] = tostring(x) end + table.insert(args, "\n") + write(table.concat(args, " ")) + end +end + +local read_for = function(conn, msg) + return function() + send(conn, response_for(msg, {status={"need-input"}})) + while(not sessions[msg.session].input) do + coroutine.yield() + d("yielded") + end + local input = sessions[msg.session].input + sessions[msg.session].input = nil + return input + end +end + +local sandbox_for = function(write, provided_sandbox) + local sandbox = { io = { write = write }, + print = print_for(write), } + for k,v in pairs(provided_sandbox) do + sandbox[k] = v + end + return sandbox +end + +-- for stuff that's shared between eval and load_file +local execute_chunk = function(session, chunk, pp) + local old_write, old_print, old_read = io.write, print, io.read + if(session.sandbox) then + setfenv(chunk, session.sandbox) + pp = pp or serpent_pp(session.sandbox.print) + else + _G.print = print_for(session.write) + _G.io.write, _G.io.read = session.write, session.read + pp = pp or serpent_pp(_G.print) + end + + local trace, err + local result = {xpcall(chunk, function(e) + trace = debug.traceback() + err = e end)} + + _G.print, _G.io.write, _G.io.read = old_print, old_write, old_read + + if(result[1]) then + local res, i = pp(result[2]), 3 + while i <= #result do + res = res .. ', ' .. pp(result[i]) + i = i + 1 + end + return res + else + return nil, (err or "Unknown error") .. "\n" .. trace + end +end + +local eval = function(session, code, pp) + local chunk, err = load("return " .. code, "*socket*") + if(err and not chunk) then -- statement, not expression + chunk, err = load(code, "*socket*") + if(not chunk) then + return nil, "Compilation error: " .. (err or "unknown") + end + end + return execute_chunk(session, chunk, pp) +end + +local load_file = function(session, file, loader) + local chunk, err = (loader or loadfile)(file) + if(not chunk) then + return nil, "Compilation error in " .. file ": ".. (err or "unknown") + end + return execute_chunk(session, chunk) +end + +local register_session = function(conn, msg, provided_sandbox) + local id = tostring(math.random(999999999)) + local write = write_for(conn, msg) + local sandbox = provided_sandbox and sandbox_for(write, provided_sandbox) + sessions[id] = { conn = conn, write = write, print = print_for(write), + sandbox = sandbox, coros = {}, id = id} + return response_for(msg, {["new-session"]=id, status={"done"}}) +end + +local unregister_session = function(msg) + sessions[msg.session] = nil + return response_for(msg, {status={"done"}}) +end + +local describe = function(msg, handlers) + local ops = { "clone", "close", "describe", "eval", "load-file", + "ls-sessions", "complete", "stdin", "interrupt" } + for op in handlers do table.insert(ops, op) end + return response_for(msg, {ops=ops, status={"done"}}) +end + +local session_for = function(conn, msg, sandbox) + local s = sessions[msg.session] or register_session(conn, msg, sandbox) + s.write = write_for(conn, msg) + s.read = read_for(conn, msg) + return s +end + +local complete = function(msg, sandbox) + local clone = function(t) + local n = {} for k,v in pairs(t) do n[k] = v end return n + end + local top_ctx = clone(sandbox or _G) + for k,v in pairs(msg.libs or {}) do + top_ctx[k] = require(v:sub(2,-2)) + end + + local function cpl_for(input_parts, ctx) + if type(ctx) ~= "table" then return {} end + if #input_parts == 0 and ctx ~= top_ctx then + return ctx + elseif #input_parts == 1 then + local matches = {} + for k in pairs(ctx) do + if k:find('^' .. input_parts[1]) then + table.insert(matches, k) + end + end + return matches + else + local token1 = table.remove(input_parts, 1) + return cpl_for(input_parts, ctx[token1]) + end + end + local input_parts = {} + for i in string.gmatch(msg.input, "([^.%s]+)") do + table.insert(input_parts, i) + end + return response_for(msg, {completions = cpl_for(input_parts, top_ctx)}) +end + +-- see https://github.com/clojure/tools.nrepl/blob/master/doc/ops.md +local handle = function(conn, handlers, sandbox, msg) + if(handlers and handlers[msg.op]) then + d("Custom op:", msg.op) + handlers[msg.op](conn, msg, session_for(conn, msg, sandbox), + send, response_for) + elseif(msg.op == "clone") then + d("New session.") + send(conn, register_session(conn, msg, sandbox)) + elseif(msg.op == "describe") then + d("Describe.") + send(conn, describe(msg, handlers)) + elseif(msg.op == "eval") then + d("Evaluating", msg.code) + local value, err = eval(session_for(conn, msg, sandbox), msg.code, msg.pp) + d("Got", value, err) + -- monroe bug means you have to send done status separately + send(conn, response_for(msg, {value=value, ex=err})) + send(conn, response_for(msg, {status={"done"}})) + elseif(msg.op == "load-file") then + d("Loading file", msg.file) + local value, err = load_file(session_for(conn, msg, sandbox), + msg.file, msg.loader) + d("Got", value, err) + send(conn, response_for(msg, {value=value, ex=err, status={"done"}})) + elseif(msg.op == "ls-sessions") then + d("List sessions") + local session_ids = {} + for id in pairs(sessions) do table.insert(session_ids, id) end + send(conn, response_for(msg, {sessions=session_ids, status={"done"}})) + elseif(msg.op == "complete") then + d("Complete", msg.input) + local session_sandbox = session_for(conn, msg, sandbox).sandbox + send(conn, complete(msg, session_sandbox)) + elseif(msg.op == "stdin") then + d("Stdin", serpent.block(msg)) + sessions[msg.session].input = msg.stdin + send(conn, response_for(msg, {status={"done"}})) + return + elseif(msg.op ~= "interrupt") then -- silently ignore interrupt + send(conn, response_for(msg, {status={"unknown-op"}})) + print(" | Unknown op", serpent.block(msg)) + end +end + +local handler_coros = {} + +local function receive(conn, partial) + local s, err = conn:receive(1) -- wow this is primitive + -- iterate backwards so we can safely remove + for i=#handler_coros, 1, -1 do + local ok, err2 = coroutine.resume(handler_coros[i]) + if(coroutine.status(handler_coros[i]) ~= "suspended") then + if(not ok) then print(" | Handler error", err2) end + table.remove(handler_coros, i) + end + end + + if(s) then + return receive(conn, (partial or "") .. s) + elseif(err == "timeout" and partial == nil) then + coroutine.yield() + return receive(conn) + elseif(err == "timeout") then + return partial + else + return nil, err + end +end + +local function client_loop(conn, sandbox, handlers, middleware, partial) + local input, r_err = receive(conn, partial) + if(input) then + local decoded, d_err = bencode.decode(input) + if decoded and d_err < #input then + partial = input:sub(d_err + 1) + else + partial = nil + end + coroutine.yield() + if(decoded and decoded.op == "close") then + d("End session.") + return send(conn, unregister_session(decoded)) + elseif(decoded and decoded.op ~= "close") then + -- If we don't spin up a coroutine here, we can't io.read, because + -- that requires waiting for a response from the client. But most + -- messages don't need to stick around. + local coro = coroutine.create(handle) + if(middleware) then + middleware(function(msg) + local ok, err = coroutine.resume(coro, conn, handlers, + sandbox, msg) + if(not ok) then print(" | Handler error", err) end + end, decoded) + else + local ok, err = coroutine.resume(coro, conn, handlers, + sandbox, decoded) + if(not ok) then print(" | Handler error", err) end + end + if(coroutine.status(coro) == "suspended") then + table.insert(handler_coros, coro) + end + else + print(" | Decoding error:", d_err) + end + return client_loop(conn, sandbox, handlers, middleware, partial) + else + return r_err + end +end + +local connections = {} + +local function loop(server, sandbox, handlers, middleware, foreground) + socket.sleep(timeout) + local conn, err = server:accept() + local stop = (not foreground) and (coroutine.yield() == "stop") + if(conn) then + conn:settimeout(timeout) + d("Connected.") + local coro = coroutine.create(function() + local _, h_err = pcall(client_loop, conn, sandbox, handlers, middleware) + if(h_err ~= "closed") then print("Connection closed: " .. h_err) end + end) + table.insert(connections, coro) + return loop(server, sandbox, handlers, middleware, foreground) + else + if(err ~= "timeout") then print(" | Socket error: " .. err) end + for _,c in ipairs(connections) do coroutine.resume(c) end + if(stop or err == "closed") then + server:close() + print("Server stopped.") + else + return loop(server, sandbox, handlers, middleware, foreground) + end + end +end + +return { + -- Start an nrepl socket server on the given port. For opts you can pass a + -- table with foreground=true to run in the foreground, debug=true for + -- verbose logging, and sandbox={...} to evaluate all code in a sandbox. You + -- can also give an opts.handlers table keying ops to handler functions which + -- take the socket, the decoded message, and the optional sandbox table. + start = function(port, opts) + port = port or 7888 + opts = opts or {} + opts.handlers = opts.handlers or {} + -- host should always be localhost on a PC, but not always on a micro + local server = assert(socket.bind(opts.host or "localhost", port)) + if(opts.debug) then d = print end + if(opts.timeout) then timeout = tonumber(opts.timeout) end + if(opts.fennel) then + local fenneleval = require("jeejah.fenneleval") + opts.handlers.eval = fenneleval + opts.handlers.stdin = fenneleval + end + assert(not opts.sandbox or setfenv, "Can't use sandbox on 5.2+") + + server:settimeout(timeout) + print("Server started on port " .. port .. "...") + if opts.foreground then + return loop(server, opts.sandbox, opts.handlers, + opts.middleware, opts.foreground) + else + return coroutine.create(function() + loop(server, opts.sandbox, opts.handlers, opts.middleware) + end) + end + end, + + -- Pass in the coroutine from jeejah.start to this function to stop it. + stop = function(coro) + coroutine.resume(coro, "stop") + end, + + broadcast = function(msg) + for _,session in pairs(sessions) do + send(session.conn, msg) + end + end, +} diff --git a/vendor/jeejah/jeejah/fenneleval.lua b/vendor/jeejah/jeejah/fenneleval.lua new file mode 100644 index 0000000..ffac3ce --- /dev/null +++ b/vendor/jeejah/jeejah/fenneleval.lua @@ -0,0 +1,77 @@ +local fennel = require("fennel") +local fennelview_ok, fennelview = pcall(require, "fennelview") +if not fennelview_ok then fennelview = fennel.dofile("fennelview.fnl") end + +local d = os.getenv("DEBUG") and print or function(_) end + +local repls = {} + +local print_for = function(write) + return function(...) + local args = {...} + for i,x in ipairs(args) do args[i] = tostring(x) end + table.insert(args, "\n") + write(table.concat(args, " ")) + end +end + +local make_repl = function(session, repls) + local on_values = function(xs) + session.values(xs) + session.done({status={"done"}}) + end + local read = function() + -- If we skip empty input, it confuses the client. + local input = coroutine.yield() + if(input:find("^%s*$")) then return "nil\n" else return input end + end + local err = function(errtype, msg) + session.write(table.concat({errtype, msg}, ": ")) session.done() + end + + local env = session.sandbox + if not env then + env = {} + for k, v in pairs(_G) do env[k] = v end + env.io = {} + end + env.print = print_for(session.write) + env.io.write = session.write + env.io.read = function() + session.needinput() + local input, done = coroutine.yield() + done() + return input + end + + local f = function() + return fennel.repl({readChunk = read, + onValues = on_values, + onError = err, + env = env, + pp = fennelview}) + end + repls[session.id] = coroutine.wrap(f) + repls[session.id]() + return repls[session.id] +end + +return function(conn, msg, session, send, response_for) + d("Evaluating", msg.code) + local repl = repls[session.id] or make_repl(session, repls) + if msg.op == "eval" then + session.values = function(xs) + send(conn, response_for(msg, {value=table.concat(xs, "\n") .. "\n"})) + end + session.done = function() + send(conn, response_for(msg, {status={"done"}})) + end + session.needinput = function() + send(conn, response_for(msg, {status={"need-input"}})) + end + repl(msg.code .. "\n") + elseif msg.op == "stdin" then + repl(msg.stdin, + function() send(conn, response_for(msg, {status={"done"}})) end) + end +end diff --git a/vendor/jeejah/monroe-lua-complete.el b/vendor/jeejah/monroe-lua-complete.el new file mode 100644 index 0000000..26836ba --- /dev/null +++ b/vendor/jeejah/monroe-lua-complete.el @@ -0,0 +1,89 @@ +;;; monroe-lua-complete.el --- Completion for Lua over Monroe connection + +;; Copyright © 2016 Phil Hagelberg +;; +;; Author: Phil Hagelberg +;; URL: https://gitlab.com/technomancy/jeejah +;; Version: 0.1.0 +;; Keywords: languages, nrepl, lua + +;; This program is free software: you can redistribute it and/or modify +;; it under the terms of the GNU General Public License as published by +;; the Free Software Foundation, either version 3 of the License, or +;; (at your option) any later version. + +;; This program 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 General Public License for more details. + +;; You should have received a copy of the GNU General Public License +;; along with this program. If not, see . + +;; This file is not part of GNU Emacs. + +;;; Commentary: + +;; Provides live completion results for Lua by querying a Lua process +;; over an nREPL connection. Uses `completion-at-point' but can be +;; adapted for other completion methods. + +;;; Installation: + +;; Copy it to your load-path and (require 'monroe-lua-complete) + +;;; Usage: + +;; * Launch an nREPL server using jeejah. +;; * Connect to it with M-x monroe. +;; * Complete the expression at point with M-x completion-at-point +;; also bound to M-tab or C-M-i. + +;;; Code: + +(require 'lua-mode) ; requires a newer lua-mode that has lua-start-of-expr +(require 'monroe) + +(defvar monroe-completion-candidates nil) + +(defun monroe-completion-handler (response) + "Set `monroe-completion-candidates' based on response from Lua server. + +Since monroe doesn't have any synchronous communication available, we +have to `sit-for' and hope a response has been returned and handled." + (monroe-dbind-response response (id completions status output) + (let ((process (get-buffer-process monroe-repl-buffer))) + (comint-output-filter process output) + (when completions + (setq monroe-completion-candidates completions)) + (when status + (when (member "done" status) + (remhash id monroe-requests)))))) + +(defun monroe-lua-complete-function () + "Completion function for `completion-at-point-functions'. + +Queries over current lua connection for possible completions." + (let ((expr (buffer-substring-no-properties (lua-start-of-expr) (point)))) + (monroe-send-request `("op" "complete" + "input" ,expr + ;; TODO: at this time, monroe cannot bencode + ;; nested values, only string->string dicts + ;; "libs" ,(lua-local-libs) + "session" ,(monroe-current-session)) + 'monroe-completion-handler)) + (sit-for 0.1) + (list (save-excursion (when (symbol-at-point) (backward-sexp)) (point)) + (point) + monroe-completion-candidates)) + +;;;###autoload +(defun monroe-lua-hook () + (make-local-variable 'completion-at-point-functions) + (add-to-list 'completion-at-point-functions 'monroe-lua-complete-function)) + +;;;###autoload +(eval-after-load 'lua-mode + '(add-to-list 'lua-mode-hook 'monroe-lua-hook)) + +;;; monroe-lua-complete.el ends here diff --git a/vendor/jeejah/rockspecs/jeejah-0.1.0-1.rockspec b/vendor/jeejah/rockspecs/jeejah-0.1.0-1.rockspec new file mode 100644 index 0000000..5669dee --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.1.0-1.rockspec @@ -0,0 +1,28 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.1.0-1" +source = { + url = "https://gitlab.com/technomancy/jeejah.git", + tag = "0.1.0", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah.git", + license = "MIT/X11", +} +dependencies = { + "lua ~> 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.2.1-1.rockspec b/vendor/jeejah/rockspecs/jeejah-0.2.1-1.rockspec new file mode 100644 index 0000000..03fd6c2 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.2.1-1.rockspec @@ -0,0 +1,28 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.2.1-1" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.2.1", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.2.1-4.rockspec b/vendor/jeejah/rockspecs/jeejah-0.2.1-4.rockspec new file mode 100644 index 0000000..305c2d3 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.2.1-4.rockspec @@ -0,0 +1,28 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.2.1-4" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.2.4", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.3.0-1.rockspec b/vendor/jeejah/rockspecs/jeejah-0.3.0-1.rockspec new file mode 100644 index 0000000..a383996 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.3.0-1.rockspec @@ -0,0 +1,28 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.3.0-1" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.3.0", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.3.1-1.rockspec b/vendor/jeejah/rockspecs/jeejah-0.3.1-1.rockspec new file mode 100644 index 0000000..9ca7801 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.3.1-1.rockspec @@ -0,0 +1,28 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.3.1-1" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.3.1", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.3.1-2.rockspec b/vendor/jeejah/rockspecs/jeejah-0.3.1-2.rockspec new file mode 100644 index 0000000..3db60a9 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.3.1-2.rockspec @@ -0,0 +1,29 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.3.1-2" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.3.1", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", + "bencode = 2.2.0-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", + ["jeejah.fenneleval"] = "jeejah/fenneleval.lua" }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/rockspecs/jeejah-0.3.1-4.rockspec b/vendor/jeejah/rockspecs/jeejah-0.3.1-4.rockspec new file mode 100644 index 0000000..34504f0 --- /dev/null +++ b/vendor/jeejah/rockspecs/jeejah-0.3.1-4.rockspec @@ -0,0 +1,30 @@ +-- -*- lua -*- + +package = "jeejah" +version = "0.3.1-4" +source = { + url = "git+https://gitlab.com/technomancy/jeejah.git", + tag = "0.3.1", +} +description = { + summary = "An nREPL server", + detailed = [[ + Implements a server that speaks the nREPL protocol and allows + clients to connect and evaluate code over a network connection. + ]], + homepage = "https://gitlab.com/technomancy/jeejah", + license = "MIT/X11", +} +dependencies = { + "lua >= 5.1", + "luasocket = 3.0rc1-2", + "serpent = 0.28-1", +} +build = { + type = "builtin", + modules = { jeejah = "jeejah.lua", + ["jeejah.fenneleval"] = "jeejah/fenneleval.lua", + bencode = "bencode.lua", + }, + install = { bin = { "bin/jeejah" } }, +} diff --git a/vendor/jeejah/serpent.lua b/vendor/jeejah/serpent.lua new file mode 100644 index 0000000..c0a0d8f --- /dev/null +++ b/vendor/jeejah/serpent.lua @@ -0,0 +1,125 @@ +local n, v = "serpent", 0.28 -- (C) 2012-15 Paul Kulchenko; MIT License +local c, d = "Paul Kulchenko", "Lua serializer and pretty printer" +local snum = {[tostring(1/0)]='1/0 --[[math.huge]]',[tostring(-1/0)]='-1/0 --[[-math.huge]]',[tostring(0/0)]='0/0'} +local badtype = {thread = true, userdata = true, cdata = true} +local keyword, globals, G = {}, {}, (_G or _ENV) +for _,k in ipairs({'and', 'break', 'do', 'else', 'elseif', 'end', 'false', + 'for', 'function', 'goto', 'if', 'in', 'local', 'nil', 'not', 'or', 'repeat', + 'return', 'then', 'true', 'until', 'while'}) do keyword[k] = true end +for k,v in pairs(G) do globals[v] = k end -- build func to name mapping +for _,g in ipairs({'coroutine', 'debug', 'io', 'math', 'string', 'table', 'os'}) do + for k,v in pairs(G[g] or {}) do globals[v] = g..'.'..k end end + +local function s(t, opts) + local name, indent, fatal, maxnum = opts.name, opts.indent, opts.fatal, opts.maxnum + local sparse, custom, huge = opts.sparse, opts.custom, not opts.nohuge + local space, maxl = (opts.compact and '' or ' '), (opts.maxlevel or math.huge) + local iname, comm = '_'..(name or ''), opts.comment and (tonumber(opts.comment) or math.huge) + local seen, sref, syms, symn = {}, {'local '..iname..'={}'}, {}, 0 + local function gensym(val) return '_'..(tostring(tostring(val)):gsub("[^%w]",""):gsub("(%d%w+)", + -- tostring(val) is needed because __tostring may return a non-string value + function(s) if not syms[s] then symn = symn+1; syms[s] = symn end return tostring(syms[s]) end)) end + local function safestr(s) return type(s) == "number" and tostring(huge and snum[tostring(s)] or s) + or type(s) ~= "string" and tostring(s) -- escape NEWLINE/010 and EOF/026 + or ("%q"):format(s):gsub("\010","n"):gsub("\026","\\026") end + local function comment(s,l) return comm and (l or 0) < comm and ' --[['..tostring(s)..']]' or '' end + local function globerr(s,l) return globals[s] and globals[s]..comment(s,l) or not fatal + and safestr(select(2, pcall(tostring, s))) or error("Can't serialize "..tostring(s)) end + local function safename(path, name) -- generates foo.bar, foo[3], or foo['b a r'] + local n = name == nil and '' or name + local plain = type(n) == "string" and n:match("^[%l%u_][%w_]*$") and not keyword[n] + local safe = plain and n or '['..safestr(n)..']' + return (path or '')..(plain and path and '.' or '')..safe, safe end + local alphanumsort = type(opts.sortkeys) == 'function' and opts.sortkeys or function(k, o, n) -- k=keys, o=originaltable, n=padding + local maxn, to = tonumber(n) or 12, {number = 'a', string = 'b'} + local function padnum(d) return ("%0"..tostring(maxn).."d"):format(tonumber(d)) end + table.sort(k, function(a,b) + -- sort numeric keys first: k[key] is not nil for numerical keys + return (k[a] ~= nil and 0 or to[type(a)] or 'z')..(tostring(a):gsub("%d+",padnum)) + < (k[b] ~= nil and 0 or to[type(b)] or 'z')..(tostring(b):gsub("%d+",padnum)) end) end + local function val2str(t, name, indent, insref, path, plainindex, level) + local ttype, level, mt = type(t), (level or 0), getmetatable(t) + local spath, sname = safename(path, name) + local tag = plainindex and + ((type(name) == "number") and '' or name..space..'='..space) or + (name ~= nil and sname..space..'='..space or '') + if seen[t] then -- already seen this element + sref[#sref+1] = spath..space..'='..space..seen[t] + return tag..'nil'..comment('ref', level) end + if type(mt) == 'table' and (mt.__serialize or mt.__tostring) then -- knows how to serialize itself + seen[t] = insref or spath + if mt.__serialize then t = mt.__serialize(t) else t = tostring(t) end + ttype = type(t) end -- new value falls through to be serialized + if ttype == "table" then + if level >= maxl then return tag..'{}'..comment('max', level) end + seen[t] = insref or spath + -- PNH: this breaks with our metatable monkeypatch to support iterators + -- if next(t) == nil then return tag..'{}'..comment(t, level) end -- table empty + local maxn, o, out = math.min(#t, maxnum or #t), {}, {} + for key = 1, maxn do o[key] = key end + if not maxnum or #o < maxnum then + local n = #o -- n = n + 1; o[n] is much faster than o[#o+1] on large tables + for key in pairs(t) do if o[key] ~= key then n = n + 1; o[n] = key end end end + if maxnum and #o > maxnum then o[maxnum+1] = nil end + if opts.sortkeys and #o > maxn then alphanumsort(o, t, opts.sortkeys) end + local sparse = sparse and #o > maxn -- disable sparsness if only numeric keys (shorter output) + for n, key in ipairs(o) do + local value, ktype, plainindex = t[key], type(key), n <= maxn and not sparse + if opts.valignore and opts.valignore[value] -- skip ignored values; do nothing + or opts.keyallow and not opts.keyallow[key] + or opts.valtypeignore and opts.valtypeignore[type(value)] -- skipping ignored value types + or sparse and value == nil then -- skipping nils; do nothing + elseif ktype == 'table' or ktype == 'function' or badtype[ktype] then + if not seen[key] and not globals[key] then + sref[#sref+1] = 'placeholder' + local sname = safename(iname, gensym(key)) -- iname is table for local variables + sref[#sref] = val2str(key,sname,indent,sname,iname,true) end + sref[#sref+1] = 'placeholder' + local path = seen[t]..'['..tostring(seen[key] or globals[key] or gensym(key))..']' + sref[#sref] = path..space..'='..space..tostring(seen[value] or val2str(value,nil,indent,path)) + else + out[#out+1] = val2str(value,key,indent,insref,seen[t],plainindex,level+1) + end + end + local prefix = string.rep(indent or '', level) + local head = indent and '{\n'..prefix..indent or '{' + local body = table.concat(out, ','..(indent and '\n'..prefix..indent or space)) + local tail = indent and "\n"..prefix..'}' or '}' + return (custom and custom(tag,head,body,tail) or tag..head..body..tail)..comment(t, level) + elseif badtype[ttype] then + seen[t] = insref or spath + return tag..globerr(t, level) + elseif ttype == 'function' then + seen[t] = insref or spath + local ok, res = pcall(string.dump, t) + local func = ok and ((opts.nocode and "function() --[[..skipped..]] end" or + "((loadstring or load)("..safestr(res)..",'@serialized'))")..comment(t, level)) + return tag..(func or globerr(t, level)) + else return tag..safestr(t) end -- handle all other types + end + local sepr = indent and "\n" or ";"..space + local body = val2str(t, name, indent) -- this call also populates sref + local tail = #sref>1 and table.concat(sref, sepr)..sepr or '' + local warn = opts.comment and #sref>1 and space.."--[[incomplete output with shared/self-references skipped]]" or '' + return not name and body..warn or "do local "..body..sepr..tail.."return "..name..sepr.."end" +end + +local function deserialize(data, opts) + local env = (opts and opts.safe == false) and G + or setmetatable({}, { + __index = function(t,k) return t end, + __call = function(t,...) error("cannot call functions") end + }) + local f, res = (loadstring or load)('return '..data, nil, nil, env) + if not f then f, res = (loadstring or load)(data, nil, nil, env) end + if not f then return f, res end + if setfenv then setfenv(f, env) end + return pcall(f) +end + +local function merge(a, b) if b then for k,v in pairs(b) do a[k] = v end end; return a; end +return { _NAME = n, _COPYRIGHT = c, _DESCRIPTION = d, _VERSION = v, serialize = s, + load = deserialize, + dump = function(a, opts) return s(a, merge({name = '_', compact = true, sparse = true}, opts)) end, + line = function(a, opts) return s(a, merge({sortkeys = true, comment = true}, opts)) end, + block = function(a, opts) return s(a, merge({indent = ' ', sortkeys = true, comment = true}, opts)) end } diff --git a/vendor/lite-plugins/.gitrepo b/vendor/lite-plugins/.gitrepo new file mode 100644 index 0000000..a68e0c5 --- /dev/null +++ b/vendor/lite-plugins/.gitrepo @@ -0,0 +1,12 @@ +; DO NOT EDIT (unless you know what you are doing) +; +; This subdirectory is a git "subrepo", and this file is maintained by the +; git-subrepo command. See https://github.com/git-commands/git-subrepo#readme +; +[subrepo] + remote = https://github.com/rxi/lite-plugins + branch = master + commit = de4227d55a5c821e3450554c952dfb3b1b192266 + parent = c843deea3de5d5d8782fe4dadbdbd40422ab88f8 + method = merge + cmdver = 0.4.2 diff --git a/vendor/lite-plugins/README.md b/vendor/lite-plugins/README.md new file mode 100644 index 0000000..502e1ed --- /dev/null +++ b/vendor/lite-plugins/README.md @@ -0,0 +1,86 @@ +Plugins for the [lite text editor](https://github.com/rxi/lite) + +*Note: if you make a pull request, the table should be updated and kept in +alphabetical order. If your plugin is large (or you'd otherwise prefer it to +have its own repo), the table can simply be updated to add a link to the repo; +otherwise the plugin file itself can be submitted. If a plugin's link resolves +to something other than a raw file it should be marked with an asterisk.* + +--- + +Plugin | Description +-------|----------------------------------------- +[`autoinsert`](plugins/autoinsert.lua?raw=1) | Automatically inserts closing brackets and quotes +[`autowrap`](plugins/autowrap.lua?raw=1) | Automatically hardwraps lines when typing +[`bigclock`](plugins/bigclock.lua?raw=1) | Shows the current time and date in a view with large text *([screenshot](https://user-images.githubusercontent.com/3920290/82752891-3318df00-9db9-11ea-803f-261d80d5cf53.png))* +[`black`](https://git.sr.ht/~tmpod/black-lite)* | Integrates the [black](https://github.com/psf/black) Python formatter with lite +[`bracketmatch`](plugins/bracketmatch.lua?raw=1) | Underlines matching pair for bracket under the caret *([screenshot](https://user-images.githubusercontent.com/3920290/80132745-0c863f00-8594-11ea-8875-c455c6fd7eae.png))* +[`centerdoc`](plugins/centerdoc.lua?raw=1) | Centers document's content on the screen *([screenshot](https://user-images.githubusercontent.com/3920290/82127896-bf6e4500-97ae-11ea-97fc-ba9a552bc9a4.png))* +[`colorpreview`](plugins/colorpreview.lua?raw=1) | Underlays color values (eg. `#ff00ff` or `rgb(255, 0, 255)`) with their resultant color. *([screenshot](https://user-images.githubusercontent.com/3920290/80743752-731bd780-8b15-11ea-97d3-847db927c5dc.png))* +[`console`](https://github.com/rxi/console)* | A console for running external commands and capturing their output *([gif](https://user-images.githubusercontent.com/3920290/81343656-49325a00-90ad-11ea-8647-ff39d8f1d730.gif))* +[`copyfilelocation`](plugins/copyfilelocation.lua?raw=1) | Copy file location to clipboard +[`datetimestamps`](plugins/datetimestamps.lua?raw=1) | Insert date-, time- and date-time-stamps +[`detectindent`](plugins/detectindent.lua?raw=1) | Automatically detects and uses the indentation size and tab type of a loaded file +[`dragdropselected`](plugins/dragdropselected.lua?raw=1) | Provides basic drag and drop of selected text (in same document) +[`drawwhitespace`](plugins/drawwhitespace.lua?raw=1) | Draws tabs and spaces *([screenshot](https://user-images.githubusercontent.com/3920290/80573013-22ae5800-89f7-11ea-9895-6362a1c0abc7.png))* +[`eofnewline`](https://github.com/bokunodev/lite_modules/blob/master/plugins/eofnewline.lua?raw=1) | Make sure the file ends with one blank line. +[`eval`](plugins/eval.lua?raw=1) | Replaces selected Lua code with its evaluated result +[`exec`](plugins/exec.lua?raw=1) | Runs selected text through shell command and replaces with result +[`ghmarkdown`](plugins/ghmarkdown.lua?raw=1) | Opens a preview of the current markdown file in a browser window *([screenshot](https://user-images.githubusercontent.com/3920290/82754898-f7394600-9dc7-11ea-8278-2305363ed372.png))* +[`gitstatus`](plugins/gitstatus.lua?raw=1) | Displays git branch and insert/delete count in status bar *([screenshot](https://user-images.githubusercontent.com/3920290/81107223-bcea3080-8f0e-11ea-8fc7-d03173f42e33.png))* +[`gofmt`](plugins/gofmt.lua?raw=1) | Auto-formats the current go file, adds the missing imports and the missing return cases +[`hidelinenumbers`](plugins/hidelinenumbers.lua?raw=1) | Hides the line numbers on the left of documents *([screenshot](https://user-images.githubusercontent.com/3920290/81692043-b8b19c00-9455-11ea-8d74-ad99be4b9c5f.png))* +[`hidestatus`](plugins/hidestatus.lua?raw=1) | Hides the status bar at the bottom of the window +[`inanimate`](plugins/inanimate.lua?raw=1) | Disables all transition animations +[`indentguide`](plugins/indentguide.lua?raw=1) | Adds indent guides *([screenshot](https://user-images.githubusercontent.com/3920290/79640716-f9860000-818a-11ea-9c3b-26d10dd0e0c0.png))* +[`language_angelscript`](plugins/language_angelscript.lua?raw=1) | Syntax for the [Angelscript](https://www.angelcode.com/angelscript/) programming language +[`language_batch`](plugins/language_batch.lua?raw=1) | Syntax for Windows [Batch Files](https://en.wikipedia.org/wiki/Batch_file) +[`language_cmake`](plugins/language_cmake.lua?raw=1) | Syntax for the CMake build system language +[`language_cpp`](plugins/language_cpp.lua?raw=1) | Syntax for the [C++](https://isocpp.org/) programming language +[`language_csharp`](plugins/language_csharp.lua?raw=1) | Syntax for the [C#](http://csharp.net) programming language +[`language_d`](plugins/language_d.lua?raw=1) | Syntax for the [D](https://dlang.org/) programming language +[`language_elixir`](plugins/language_elixir.lua?raw=1) | Syntax for the [Elixir](https://elixir-lang.org) programming language +[`language_elm`](plugins/language_elm.lua?raw=1) | Syntax for the [Elm](https://elm-lang.org) programming language +[`language_fe`](plugins/language_fe.lua?raw=1) | Syntax for the [fe](https://github.com/rxi/fe) programming language +[`language_fennel`](plugins/language_fennel.lua?raw=1) | Syntax for the [fennel](https://fennel-lang.org) programming language +[`language_gdscript`](plugins/language_gdscript.lua?raw=1) | Syntax for the [Godot Engine](https://godotengine.org/)'s GDScript scripting language +[`language_glsl`](plugins/language_glsl.lua?raw=1) | Syntax for the [GLSL](https://www.khronos.org/registry/OpenGL/specs/gl/) programming language +[`language_go`](plugins/language_go.lua?raw=1) | Syntax for the [Go](https://golang.org/) programming language +[`language_hlsl`](plugins/language_hlsl.lua?raw=1) | Syntax for the [HLSL](https://docs.microsoft.com/en-us/windows/win32/direct3dhlsl/dx-graphics-hlsl) programming language +[`language_hs`](plugins/language_hs.lua?raw=1) | Syntax for the [Haskell](https://www.haskell.org/) programming language +[`language_java`](plugins/language_java.lua?raw=1) | Syntax for the [Java](https://en.wikipedia.org/wiki/Java_(programming_language)) programming language +[`language_jiyu`](plugins/language_jiyu.lua?raw=1) | Syntax for the [jiyu](https://github.com/machinamentum/jiyu) programming language +[`language_ksy`](https://raw.githubusercontent.com/whiteh0le/lite-plugins/main/plugins/language_ksy.lua?raw=1) | Syntax for [Kaitai](http://kaitai.io/) struct files +[`language_make`](plugins/language_make.lua?raw=1) | Syntax for the Make build system language +[`language_meson`](plugins/language_meson.lua?raw=1) | Syntax for the [Meson](https://mesonbuild.com) build system language +[`language_odin`](plugins/language_odin.lua?raw=1) | Syntax for the [Odin](https://github.com/odin-lang/Odin) programming language +[`language_php`](plugins/language_php.lua?raw=1) | Syntax for the [PHP](https://php.net) programming language +[`language_pico8`](plugins/language_pico8.lua?raw=1) | Syntax for [Pico-8](https://www.lexaloffle.com/pico-8.php) cartridge files +[`language_powershell`](plugins/language_powershell.lua?raw=1) | Syntax for [PowerShell](https://docs.microsoft.com/en-us/powershell) scripting language +[`language_psql`](plugins/language_psql.lua?raw=1) | Syntax for the postgresql database access language +[`language_rust`](plugins/language_rust.lua?raw=1) | Syntax for the [Rust](https://rust-lang.org/) programming language +[`language_sh`](plugins/language_sh.lua?raw=1) | Syntax for shell scripting language +[`language_tex`](plugins/language_tex.lua?raw=1) | Syntax for the [LaTeX](https://www.latex-project.org/) typesetting language +[`language_wren`](plugins/language_wren.lua?raw=1) | Syntax for the [Wren](http://wren.io/) programming language +[`lastproject`](plugins/lastproject.lua?raw=1) | Loads the last loaded project if lite is launched without any arguments +[`lfautoinsert`](plugins/lfautoinsert.lua?raw=1) | Automatically inserts indentation and closing bracket/text after newline +[`linecopypaste`](plugins/linecopypaste.lua?raw=1) | Copy, cut and paste the current line when nothing is selected +[`lineguide`](plugins/lineguide.lua?raw=1) | Displays a line-guide at the line limit offset *([screenshot](https://user-images.githubusercontent.com/3920290/81476159-2cf70000-9208-11ea-928b-9dae3884c477.png))* +[`linter`](https://github.com/drmargarido/linters)* | Linters for multiple languages +[`macmodkeys`](plugins/macmodkeys.lua?raw=1) | Remaps mac modkeys `command/option` to `ctrl/alt` +[`markers`](plugins/markers.lua?raw=1) | Add markers to docs and jump between them quickly *([screenshot](https://user-images.githubusercontent.com/3920290/82252149-5faaa200-9946-11ea-9199-bea2efb7ee23.png))* +[`motiontrail`](plugins/motiontrail.lua?raw=1) | Adds a motion-trail to the caret *([screenshot](https://user-images.githubusercontent.com/3920290/83256814-085ccb00-a1ab-11ea-9e35-e6633cbed1a9.gif))* +[`openfilelocation`](plugins/openfilelocation.lua?raw=1) | Opens the parent directory of the current file in the file manager +[`openselected`](plugins/openselected.lua?raw=1) | Opens the selected filename or url +[`projectmanager`](plugins/projectmanager.lua?raw=1) | Save projects and load/reload them quickly +[`scale`](plugins/scale.lua?raw=1) | Provides support for dynamically adjusting the scale of the code font / UI (`ctrl+-`, `ctrl+=`) +[`scalestatus`](plugins/scalestatus.lua?raw=1) | Displays current scale (zoom) in status view (depends on scale plugin) +[`selectionhighlight`](plugins/selectionhighlight.lua?raw=1) | Highlights regions of code that match the current selection *([screenshot](https://user-images.githubusercontent.com/3920290/80710883-5f597c80-8ae7-11ea-97f0-76dfacc08439.png))* +[`sort`](plugins/sort.lua?raw=1) | Sorts selected lines alphabetically +[`spellcheck`](plugins/spellcheck.lua?raw=1) | Underlines misspelt words *([screenshot](https://user-images.githubusercontent.com/3920290/79923973-9caa7400-842e-11ea-85d4-7a196a91ca50.png))* *— note: on Windows a [`words.txt`](https://github.com/dwyl/english-words/blob/master/words.txt) dictionary file must be placed beside the exe* +[`theme16`](https://github.com/monolifed/theme16)* | Theme manager with base16 themes +[`titleize`](plugins/titleize.lua?raw=1) | Titleizes selected string (`hello world` => `Hello World`) +[`todotreeview`](https://github.com/drmargarido/TodoTreeView)* | Todo tree viewer for annotations in code like `TODO`, `BUG`, `FIX`, `IMPROVEMENT` +[`togglesnakecamel`](plugins/togglesnakecamel.lua?raw=1) | Toggles symbols between `snake_case` and `camelCase` +[`unboundedscroll`](plugins/unboundedscroll.lua?raw=1) | Allows scrolling outside the bounds of a document +[`workspace`](plugins/workspace.lua?raw=1) | Retains project's layout and open documents between sessions diff --git a/vendor/lite-plugins/plugins/autoinsert.lua b/vendor/lite-plugins/plugins/autoinsert.lua new file mode 100644 index 0000000..243e00b --- /dev/null +++ b/vendor/lite-plugins/plugins/autoinsert.lua @@ -0,0 +1,114 @@ +local core = require "core" +local translate = require "core.doc.translate" +local config = require "core.config" +local DocView = require "core.docview" +local command = require "core.command" +local keymap = require "core.keymap" + + +config.autoinsert_map = { + ["["] = "]", + ["{"] = "}", + ["("] = ")", + ['"'] = '"', + ["'"] = "'", + ["`"] = "`", +} + + +local function is_closer(chr) + for _, v in pairs(config.autoinsert_map) do + if v == chr then + return true + end + end +end + +local function count_char(text, chr) + local count = 0 + for _ in text:gmatch(chr) do + count = count + 1 + end + return count +end + + +local on_text_input = DocView.on_text_input + +function DocView:on_text_input(text) + local mapping = config.autoinsert_map[text] + + -- prevents plugin from operating on `CommandView` + if getmetatable(self) ~= DocView then + return on_text_input(self, text) + end + + -- wrap selection if we have a selection + if mapping and self.doc:has_selection() then + local l1, c1, l2, c2, swap = self.doc:get_selection(true) + self.doc:insert(l2, c2, mapping) + self.doc:insert(l1, c1, text) + self.doc:set_selection(l1, c1, l2, c2 + 2, swap) + return + end + + -- skip inserting closing text + local chr = self.doc:get_char(self.doc:get_selection()) + if text == chr and is_closer(chr) then + self.doc:move_to(1) + return + end + + -- don't insert closing quote if we have a non-even number on this line + local line = self.doc:get_selection() + if text == mapping and count_char(self.doc.lines[line], text) % 2 == 1 then + return on_text_input(self, text) + end + + -- auto insert closing bracket + if mapping and (chr:find("%s") or is_closer(chr) and chr ~= '"') then + on_text_input(self, text) + on_text_input(self, mapping) + self.doc:move_to(-1) + return + end + + on_text_input(self, text) +end + + + +local function predicate() + return getmetatable(core.active_view) == DocView + and not core.active_view.doc:has_selection() +end + +command.add(predicate, { + ["autoinsert:backspace"] = function() + local doc = core.active_view.doc + local l, c = doc:get_selection() + local chr = doc:get_char(l, c) + if config.autoinsert_map[doc:get_char(l, c - 1)] and is_closer(chr) then + doc:delete_to(1) + end + command.perform "doc:backspace" + end, + + ["autoinsert:delete-to-previous-word-start"] = function() + local doc = core.active_view.doc + local le, ce = translate.previous_word_start(doc, doc:get_selection()) + while true do + local l, c = doc:get_selection() + if l == le and c == ce then + break + end + command.perform "autoinsert:backspace" + end + end, +}) + +keymap.add { + ["backspace"] = "autoinsert:backspace", + ["ctrl+backspace"] = "autoinsert:delete-to-previous-word-start", + ["ctrl+shift+backspace"] = "autoinsert:delete-to-previous-word-start", +} diff --git a/vendor/lite-plugins/plugins/autowrap.lua b/vendor/lite-plugins/plugins/autowrap.lua new file mode 100644 index 0000000..85d4c24 --- /dev/null +++ b/vendor/lite-plugins/plugins/autowrap.lua @@ -0,0 +1,35 @@ +require "plugins.reflow" +local config = require "core.config" +local command = require "core.command" +local DocView = require "core.docview" + +config.autowrap_files = { "%.md$", "%.txt$" } + + +local on_text_input = DocView.on_text_input + +DocView.on_text_input = function(self, ...) + on_text_input(self, ...) + + -- early-exit if the filename does not match a file type pattern + local filename = self.doc.filename or "" + local matched = false + for _, ptn in ipairs(config.autowrap_files) do + if filename:match(ptn) then + matched = true + break + end + end + if not matched then return end + + -- do automatic reflow on line if we're typing at the end of the line and have + -- reached the line limit + local line, col = self.doc:get_selection() + local text = self.doc:get_text(line, 1, line, math.huge) + if #text >= config.line_limit and col > #text then + command.perform("doc:select-lines") + command.perform("reflow:reflow") + command.perform("doc:move-to-next-char") + command.perform("doc:move-to-previous-char") + end +end diff --git a/vendor/lite-plugins/plugins/bigclock.lua b/vendor/lite-plugins/plugins/bigclock.lua new file mode 100644 index 0000000..e35cdbe --- /dev/null +++ b/vendor/lite-plugins/plugins/bigclock.lua @@ -0,0 +1,72 @@ +local core = require "core" +local style = require "core.style" +local command = require "core.command" +local common = require "core.common" +local config = require "core.config" +local View = require "core.view" + + +config.bigclock_time_format = "%H:%M:%S" +config.bigclock_date_format = "%A, %d %B %Y" +config.bigclock_scale = 1 + + +local ClockView = View:extend() + + +function ClockView:new() + ClockView.super.new(self) + self.time_text = "" + self.date_text = "" +end + + +function ClockView:get_name() + return "Big Clock" +end + + +function ClockView:update_fonts() + local size = math.floor(self.size.x * 0.15 / 15) * 15 * config.bigclock_scale + if self.font_size ~= size then + self.time_font = renderer.font.load(EXEDIR .. "/data/fonts/font.ttf", size) + self.date_font = renderer.font.load(EXEDIR .. "/data/fonts/font.ttf", size * 0.3) + self.font_size = size + collectgarbage() + end + return self.font +end + + +function ClockView:update() + local time_text = os.date(config.bigclock_time_format) + local date_text = os.date(config.bigclock_date_format) + if self.time_text ~= time_text or self.date_text ~= date_text then + core.redraw = true + self.time_text = time_text + self.date_text = date_text + end + ClockView.super.update(self) +end + + +function ClockView:draw() + self:update_fonts() + self:draw_background(style.background) + local x, y = self.position.x, self.position.y + local w, h = self.size.x, self.size.y + local _, y = common.draw_text(self.time_font, style.text, self.time_text, "center", x, y, w, h) + local th = self.date_font:get_height() + common.draw_text(self.date_font, style.dim, self.date_text, "center", x, y, w, th) +end + + +command.add(nil, { + ["big-clock:open"] = function() + local node = core.root_view:get_active_node() + node:add_view(ClockView()) + end, +}) + + +return ClockView diff --git a/vendor/lite-plugins/plugins/bracketmatch.lua b/vendor/lite-plugins/plugins/bracketmatch.lua new file mode 100644 index 0000000..4253de7 --- /dev/null +++ b/vendor/lite-plugins/plugins/bracketmatch.lua @@ -0,0 +1,117 @@ +local core = require "core" +local style = require "core.style" +local command = require "core.command" +local keymap = require "core.keymap" +local DocView = require "core.docview" + +local bracket_maps = { + -- [ ] ( ) { } + { [91] = 93, [40] = 41, [123] = 125, step = 1 }, + -- ] [ ) ( } { + { [93] = 91, [41] = 40, [125] = 123, step = -1 }, +} + + +local function get_matching_bracket(doc, line, col, line_limit, open_byte, close_byte, step) + local end_line = line + line_limit * step + local depth = 0 + + while line ~= end_line do + local byte = doc.lines[line]:byte(col) + if byte == open_byte then + depth = depth + 1 + elseif byte == close_byte then + depth = depth - 1 + if depth == 0 then return line, col end + end + + local prev_line, prev_col = line, col + line, col = doc:position_offset(line, col, step) + if line == prev_line and col == prev_col then + break + end + end +end + + +local state = {} + +local function update_state(line_limit) + line_limit = line_limit or math.huge + + -- reset if we don't have a document (eg. DocView isn't focused) + local doc = core.active_view.doc + if not doc then + state = {} + return + end + + -- early exit if nothing has changed since the last call + local line, col = doc:get_selection() + local change_id = doc:get_change_id() + if state.doc == doc and state.line == line and state.col == col + and state.change_id == change_id and state.limit == line_limit then + return + end + + -- find matching bracket if we're on a bracket + local line2, col2 + for _, map in ipairs(bracket_maps) do + for i = 0, -1, -1 do + local line, col = doc:position_offset(line, col, i) + local open = doc.lines[line]:byte(col) + local close = map[open] + if close then + line2, col2 = get_matching_bracket(doc, line, col, line_limit, open, close, map.step) + goto found + end + end + end + ::found:: + + -- update + state = { + change_id = change_id, + doc = doc, + line = line, + col = col, + line2 = line2, + col2 = col2, + limit = line_limit, + } +end + + +local update = DocView.update + +function DocView:update(...) + update(self, ...) + update_state(100) +end + + +local draw_line_text = DocView.draw_line_text + +function DocView:draw_line_text(idx, x, y) + draw_line_text(self, idx, x, y) + + if self.doc == state.doc and idx == state.line2 then + local color = style.bracketmatch_color or style.syntax["function"] + local x1 = x + self:get_col_x_offset(idx, state.col2) + local x2 = x + self:get_col_x_offset(idx, state.col2 + 1) + local h = math.ceil(1 * SCALE) + renderer.draw_rect(x1, y + self:get_line_height() - h, x2 - x1, h, color) + end +end + + +command.add("core.docview", { + ["bracket-match:move-to-matching"] = function() + update_state() + if state.line2 then + core.active_view.doc:set_selection(state.line2, state.col2) + end + end, +}) + +keymap.add { ["ctrl+m"] = "bracket-match:move-to-matching" } diff --git a/vendor/lite-plugins/plugins/centerdoc.lua b/vendor/lite-plugins/plugins/centerdoc.lua new file mode 100644 index 0000000..1921467 --- /dev/null +++ b/vendor/lite-plugins/plugins/centerdoc.lua @@ -0,0 +1,19 @@ +local config = require "core.config" +local DocView = require "core.docview" + + +local draw_line_gutter = DocView.draw_line_gutter +local get_gutter_width = DocView.get_gutter_width + + +function DocView:draw_line_gutter(idx, x, y) + local offset = self:get_gutter_width() - get_gutter_width(self) + draw_line_gutter(self, idx, x + offset, y) +end + + +function DocView:get_gutter_width() + local real_gutter_width = get_gutter_width(self) + local width = real_gutter_width + self:get_font():get_width("n") * config.line_limit + return math.max((self.size.x - width) / 2, real_gutter_width) +end diff --git a/vendor/lite-plugins/plugins/colorpreview.lua b/vendor/lite-plugins/plugins/colorpreview.lua new file mode 100644 index 0000000..dca419c --- /dev/null +++ b/vendor/lite-plugins/plugins/colorpreview.lua @@ -0,0 +1,53 @@ +local common = require "core.common" +local DocView = require "core.docview" + + +local white = { common.color "#ffffff" } +local black = { common.color "#000000" } +local tmp = {} + + +local function draw_color_previews(self, idx, x, y, ptn, base, nibbles) + local text = self.doc.lines[idx] + local s, e = 0, 0 + + while true do + s, e = text:find(ptn, e + 1) + if not s then break end + + local str = text:sub(s, e) + local r, g, b = str:match(ptn) + r, g, b = tonumber(r, base), tonumber(g, base), tonumber(b, base) + + -- #123 becomes #112233 + if nibbles then + r = r * 16 + g = g * 16 + b = b * 16 + end + + local x1 = x + self:get_col_x_offset(idx, s) + local x2 = x + self:get_col_x_offset(idx, e + 1) + local oy = self:get_line_text_y_offset() + + local text_color = math.max(r, g, b) < 128 and white or black + tmp[1], tmp[2], tmp[3] = r, g, b + + local l1, _, l2, _ = self.doc:get_selection(true) + + if not (self.doc:has_selection() and idx >= l1 and idx <= l2) then + renderer.draw_rect(x1, y, x2 - x1, self:get_line_height(), tmp) + renderer.draw_text(self:get_font(), str, x1, y + oy, text_color) + end + end +end + + +local draw_line_text = DocView.draw_line_text + +function DocView:draw_line_text(idx, x, y) + draw_line_text(self, idx, x, y) + draw_color_previews(self, idx, x, y, "#(%x%x)(%x%x)(%x%x)%f[%W]", 16) + draw_color_previews(self, idx, x, y, "#(%x)(%x)(%x)%f[%W]", 16, true) -- support #fff css format + draw_color_previews(self, idx, x, y, "rgba?%((%d+)%D+(%d+)%D+(%d+).-%)", 10) +end diff --git a/vendor/lite-plugins/plugins/copyfilelocation.lua b/vendor/lite-plugins/plugins/copyfilelocation.lua new file mode 100644 index 0000000..d365240 --- /dev/null +++ b/vendor/lite-plugins/plugins/copyfilelocation.lua @@ -0,0 +1,17 @@ +local core = require "core" +local command = require "core.command" +local config = require "core.config" + + +command.add("core.docview", { + ["copy-file-location:copy-file-location"] = function() + local doc = core.active_view.doc + if not doc.filename then + core.error "Cannot copy location of unsaved doc" + return + end + local filename = system.absolute_path(doc.filename) + core.log("Copying to clipboard \"%s\"", filename) + system.set_clipboard(filename) + end +}) diff --git a/vendor/lite-plugins/plugins/datetimestamps.lua b/vendor/lite-plugins/plugins/datetimestamps.lua new file mode 100644 index 0000000..518f0a9 --- /dev/null +++ b/vendor/lite-plugins/plugins/datetimestamps.lua @@ -0,0 +1,60 @@ +local core = require "core" +local config = require "core.config" +local command = require "core.command" + +--[[ +Date and time format placeholders +from https://www.lua.org/pil/22.1.html +%a abbreviated weekday name (e.g., Wed) +%A full weekday name (e.g., Wednesday) +%b abbreviated month name (e.g., Sep) +%B full month name (e.g., September) +%c date and time (e.g., 09/16/98 23:48:10) +%d day of the month (16) [01-31] +%H hour, using a 24-hour clock (23) [00-23] +%I hour, using a 12-hour clock (11) [01-12] +%M minute (48) [00-59] +%m month (09) [01-12] +%p either "am" or "pm" (pm) +%S second (10) [00-61] +%w weekday (3) [0-6 = Sunday-Saturday] +%x date (e.g., 09/16/98) +%X time (e.g., 23:48:10) +%Y full year (1998) +%y two-digit year (98) [00-99] +%% the character `%´ +--]] +config.datetimestamps_format_datestamp = "%Y%m%d" +config.datetimestamps_format_datetimestamp = "%Y%m%d_%H%M%S" +config.datetimestamps_format_timestamp = "%H%M%S" + +local function datestamp() + + local sOut = os.date(config.datetimestamps_format_datestamp) + + core.active_view.doc:text_input(sOut) + +end + +local function datetimestamp() + + local sOut = os.date(config.datetimestamps_format_datetimestamp) + + core.active_view.doc:text_input(sOut) + +end + +local function timestamp() + + local sOut = os.date(config.datetimestamps_format_timestamp) + + core.active_view.doc:text_input(sOut) + +end + +command.add("core.docview", { + ["datetimestamps:insert-datestamp"] = datestamp, + ["datetimestamps:insert-timestamp"] = timestamp, + ["datetimestamps:insert-datetimestamp"] = datetimestamp +}) + diff --git a/vendor/lite-plugins/plugins/detectindent.lua b/vendor/lite-plugins/plugins/detectindent.lua new file mode 100644 index 0000000..9c473b5 --- /dev/null +++ b/vendor/lite-plugins/plugins/detectindent.lua @@ -0,0 +1,64 @@ +local core = require "core" +local command = require "core.command" +local config = require "core.config" +local DocView = require "core.docview" +local Doc = require "core.doc" + +local cache = setmetatable({}, { __mode = "k" }) + + +local function detect_indent(doc) + for _, text in ipairs(doc.lines) do + local str = text:match("^ +") + if str then return "soft", #str end + local str = text:match("^\t+") + if str then return "hard" end + end +end + + +local function update_cache(doc) + local type, size = detect_indent(doc) + if type then + cache[doc] = { type = type, size = size } + end +end + + +local new = Doc.new +function Doc:new(...) + new(self, ...) + update_cache(self) +end + +local clean = Doc.clean +function Doc:clean(...) + clean(self, ...) + update_cache(self) +end + + +local function with_indent_override(doc, fn, ...) + local c = cache[doc] + if not c then + return fn(...) + end + local type, size = config.tab_type, config.indent_size + config.tab_type, config.indent_size = c.type, c.size or config.indent_size + local r1, r2, r3 = fn(...) + config.tab_type, config.indent_size = type, size + return r1, r2, r3 +end + + +local perform = command.perform +function command.perform(...) + return with_indent_override(core.active_view.doc, perform, ...) +end + + +local draw = DocView.draw +function DocView:draw(...) + return with_indent_override(self.doc, draw, self, ...) +end + diff --git a/vendor/lite-plugins/plugins/dragdropselected.lua b/vendor/lite-plugins/plugins/dragdropselected.lua new file mode 100644 index 0000000..a2ce67f --- /dev/null +++ b/vendor/lite-plugins/plugins/dragdropselected.lua @@ -0,0 +1,112 @@ +--[[ + dragdropselected.lua + provides basic drag and drop of selected text (in same document) + version: 20200627_133351 + originally by SwissalpS + + TODO: use OS drag and drop events + TODO: change mouse cursor when duplicating + TODO: add dragging image +--]] +local DocView = require "core.docview" +local core = require "core" +local keymap = require "core.keymap" + +-- helper function for on_mouse_pressed to determine if mouse down is in selection +-- iLine is line number where mouse down happened +-- iCol is column where mouse down happened +-- iSelLine1 is line number where selection starts +-- iSelCol1 is column where selection starts +-- iSelLine2 is line number where selection ends +-- iSelCol2 is column where selection ends +local function isInSelection(iLine, iCol, iSelLine1, iSelCol1, iSelLine2, iSelCol2) + if iLine < iSelLine1 then return false end + if iLine > iSelLine2 then return false end + if (iLine == iSelLine1) and (iCol < iSelCol1) then return false end + if (iLine == iSelLine2) and (iCol > iSelCol2) then return false end + return true +end -- isInSelection + +-- override DocView:on_mouse_moved +local on_mouse_moved = DocView.on_mouse_moved +function DocView:on_mouse_moved(x, y, ...) + + local sCursor = nil + + -- make sure we only act if previously on_mouse_pressed was in selection + if self.bClickedIntoSelection then + + -- show that we are dragging something + sCursor = 'hand' + + -- check for modifier to duplicate + -- (may want to set a flag as this only needs to be done once) + -- TODO: make image to drag with and/or hand over to OS dnd event + if not keymap.modkeys['ctrl'] then + -- TODO: maybe check if moved at all and only delete then or + -- as some editors do, only when dropped. I do like it going + -- instantly as that reduces the travel-distance. + self.doc:delete_to(0) + --sCursor = 'arrowWithPlus' -- 'handWithPlus' + end + + -- calculate line and column for current mouse position + local iLine, iCol = self:resolve_screen_position(x, y) + -- move text cursor + self.doc:set_selection(iLine, iCol) + -- update scroll position + self:scroll_to_line(iLine, true) + + end -- if previously clicked into selection + + -- hand off to 'old' on_mouse_moved() + on_mouse_moved(self, x, y, ...) + -- override cursor as needed + if sCursor then self.cursor = sCursor end + +end -- DocView:on_mouse_moved + +-- override DocView:on_mouse_pressed +local on_mouse_pressed = DocView.on_mouse_pressed +function DocView:on_mouse_pressed(button, x, y, clicks) + + -- no need to proceed if not left button or has no selection + if ('left' ~= button) + or (not self.doc:has_selection()) + or (1 < clicks) then + return on_mouse_pressed(self, button, x, y, clicks) + end + -- convert pixel coordinates to line and column coordinates + local iLine, iCol = self:resolve_screen_position(x, y) + -- get selection coordinates + local iSelLine1, iSelCol1, iSelLine2, iSelCol2 = self.doc:get_selection(true) + -- set flag for on_mouse_released and on_mouse_moved() methods to detect dragging + self.bClickedIntoSelection = isInSelection(iLine, iCol, iSelLine1, iSelCol1, + iSelLine2, iSelCol2) + if self.bClickedIntoSelection then + -- stash selection for inserting later + self.sDraggedText = self.doc:get_text(self.doc:get_selection()) + else + -- let 'old' on_mouse_pressed() do whatever it needs to do + on_mouse_pressed(self, button, x, y, clicks) + end + +end -- DocView:on_mouse_pressed + +-- override DocView:on_mouse_released() +local on_mouse_released = DocView.on_mouse_released +function DocView:on_mouse_released(button) + + if self.bClickedIntoSelection then + -- insert stashed selected text at current position + self.doc:text_input(self.sDraggedText) + -- unset stash and flag(s) TODO: + self.sDraggedText = '' + self.bClickedIntoSelection = nil + end + + -- hand over to old handler + on_mouse_released(self, button) + +end -- DocView:on_mouse_released + diff --git a/vendor/lite-plugins/plugins/drawwhitespace.lua b/vendor/lite-plugins/plugins/drawwhitespace.lua new file mode 100644 index 0000000..c6ed07d --- /dev/null +++ b/vendor/lite-plugins/plugins/drawwhitespace.lua @@ -0,0 +1,37 @@ +local common = require "core.common" +local config = require "core.config" +local style = require "core.style" +local DocView = require "core.docview" +local command = require "core.command" + +-- originally written by luveti + +config.whitespace_map = { [" "] = "·", ["\t"] = "»" } +config.draw_whitespace = true + +local draw_line_text = DocView.draw_line_text + +function DocView:draw_line_text(idx, x, y) + draw_line_text(self, idx, x, y) + if not config.draw_whitespace then return end + + local text = self.doc.lines[idx] + local tx, ty = x, y + self:get_line_text_y_offset() + local font = self:get_font() + local color = style.whitespace or style.syntax.comment + local map = config.whitespace_map + + for chr in common.utf8_chars(text) do + local rep = map[chr] + if rep then + renderer.draw_text(font, rep, tx, ty, color) + end + tx = tx + font:get_width(chr) + end +end + +command.add("core.docview", { + ["draw-whitespace:toggle"] = function() config.draw_whitespace = not config.draw_whitespace end, + ["draw-whitespace:disable"] = function() config.draw_whitespace = false end, + ["draw-whitespace:enable"] = function() config.draw_whitespace = true end, +}) diff --git a/vendor/lite-plugins/plugins/eval.lua b/vendor/lite-plugins/plugins/eval.lua new file mode 100644 index 0000000..54e08ba --- /dev/null +++ b/vendor/lite-plugins/plugins/eval.lua @@ -0,0 +1,23 @@ +local core = require "core" +local command = require "core.command" + + +local function eval(str) + local fn, err = load("return " .. str) + if not fn then fn, err = load(str) end + assert(fn, err) + return tostring(fn()) +end + + +command.add("core.docview", { + ["eval:insert"] = function() + core.command_view:enter("Evaluate And Insert Result", function(cmd) + core.active_view.doc:text_input(eval(cmd)) + end) + end, + + ["eval:replace"] = function() + core.active_view.doc:replace(eval) + end, +}) diff --git a/vendor/lite-plugins/plugins/exec.lua b/vendor/lite-plugins/plugins/exec.lua new file mode 100644 index 0000000..fe87afc --- /dev/null +++ b/vendor/lite-plugins/plugins/exec.lua @@ -0,0 +1,45 @@ +local core = require "core" +local command = require "core.command" + + +local function exec(cmd, keep_newline) + local fp = io.popen(cmd, "r") + local res = fp:read("*a") + fp:close() + return keep_newline and res or res:gsub("%\n$", "") +end + + +local function shell_quote(str) + return "'" .. str:gsub("'", "'\\''") .. "'" +end + + +local printfb_sub = { + ["\\"] = "\\\\", + ["\0"] = "\\0000", + ["'"] = "'\\''", +} +local function printfb_quote(str) + return "'" .. str:gsub(".", printfb_sub) .. "'" +end + + +command.add("core.docview", { + ["exec:insert"] = function() + core.command_view:enter("Insert Result Of Command", function(cmd) + core.active_view.doc:text_input(exec(cmd)) + end) + end, + + ["exec:replace"] = function() + core.command_view:enter("Replace With Result Of Command", function(cmd) + core.active_view.doc:replace(function(str) + return exec( + "printf %b " .. printfb_quote(str:gsub("%\n$", "") .. "\n") .. " | eval '' " .. shell_quote(cmd), + str:find("%\n$") + ) + end) + end) + end, +}) diff --git a/vendor/lite-plugins/plugins/ghmarkdown.lua b/vendor/lite-plugins/plugins/ghmarkdown.lua new file mode 100644 index 0000000..0f49c02 --- /dev/null +++ b/vendor/lite-plugins/plugins/ghmarkdown.lua @@ -0,0 +1,73 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + + +local html = [[ + + + + ${title} + + + + + +]] + + +command.add("core.docview", { + ["ghmarkdown:show-preview"] = function() + local dv = core.active_view + + local content = dv.doc:get_text(1, 1, math.huge, math.huge) + local esc = { ['"'] = '\\"', ["\n"] = '\\n' } + local text = html:gsub("${(.-)}", { + title = dv:get_name(), + content = content:gsub(".", esc) + }) + + local htmlfile = core.temp_filename(".html") + local fp = io.open(htmlfile, "w") + fp:write(text) + fp:close() + + core.log("Opening markdown preview for \"%s\"", dv:get_name()) + if PLATFORM == "Windows" then + system.exec("start " .. htmlfile) + else + system.exec(string.format("xdg-open %q", htmlfile)) + end + + core.add_thread(function() + coroutine.yield(5) + os.remove(htmlfile) + end) + end +}) + + +keymap.add { ["ctrl+shift+m"] = "ghmarkdown:show-preview" } diff --git a/vendor/lite-plugins/plugins/gitstatus.lua b/vendor/lite-plugins/plugins/gitstatus.lua new file mode 100644 index 0000000..a58fd0f --- /dev/null +++ b/vendor/lite-plugins/plugins/gitstatus.lua @@ -0,0 +1,69 @@ +local core = require "core" +local config = require "core.config" +local style = require "core.style" +local StatusView = require "core.statusview" + + +local git = { + branch = nil, + inserts = 0, + deletes = 0, +} + + +local function exec(cmd, wait) + local tempfile = core.temp_filename() + system.exec(string.format("%s > %q", cmd, tempfile)) + coroutine.yield(wait) + local fp = io.open(tempfile) + local res = fp:read("*a") + fp:close() + os.remove(tempfile) + return res +end + + +core.add_thread(function() + while true do + if system.get_file_info(".git") then + -- get branch name + git.branch = exec("git rev-parse --abbrev-ref HEAD", 1):match("[^\n]*") + + -- get diff + local line = exec("git diff --stat", 1):match("[^\n]*%s*$") + git.inserts = tonumber(line:match("(%d+) ins")) or 0 + git.deletes = tonumber(line:match("(%d+) del")) or 0 + + else + git.branch = nil + end + + coroutine.yield(config.project_scan_rate) + end +end) + + +local get_items = StatusView.get_items + +function StatusView:get_items() + if not git.branch then + return get_items(self) + end + local left, right = get_items(self) + + local t = { + style.dim, self.separator, + (git.inserts ~= 0 or git.deletes ~= 0) and style.accent or style.text, + git.branch, + style.dim, " ", + git.inserts ~= 0 and style.accent or style.text, "+", git.inserts, + style.dim, " / ", + git.deletes ~= 0 and style.accent or style.text, "-", git.deletes, + } + for _, item in ipairs(t) do + table.insert(right, item) + end + + return left, right +end + diff --git a/vendor/lite-plugins/plugins/gofmt.lua b/vendor/lite-plugins/plugins/gofmt.lua new file mode 100644 index 0000000..11c90b9 --- /dev/null +++ b/vendor/lite-plugins/plugins/gofmt.lua @@ -0,0 +1,49 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + +local function exec(cmd) + local fp = io.popen(cmd, "r") + local res = fp:read("*a") + local success = fp:close() + return res:gsub("%\n$", ""), success +end + +local function get_cmd_text(cmd, doc) + local active_filename = doc and system.absolute_path(doc.filename or "") + return exec(string.format("%s %s", cmd, active_filename)) +end + +local function update_doc(cmd, doc) + local text, success = get_cmd_text(cmd, doc) + if success == nil then + local err_text = "Command '%s' not found in the system" + core.error(string.format(err_text, cmd)) + return + end + + local sel = { doc:get_selection() } + doc:remove(1, 1, math.huge, math.huge) + doc:insert(1, 1, text) + doc:set_selection(table.unpack(sel)) +end + +command.add("core.docview", { + ["gofmt:gofmt"] = function() + update_doc("gofmt", core.active_view.doc) + end, + + ["gofmt:goimports"] = function() + update_doc("goimports", core.active_view.doc) + end, + + ["gofmt:goreturns"] = function() + update_doc("goreturns", core.active_view.doc) + end, +}) + +keymap.add { + ["ctrl+i"] = "gofmt:gofmt", + ["ctrl+h"] = "gofmt:goimports", + ["ctrl+u"] = "gofmt:goreturns", +} diff --git a/vendor/lite-plugins/plugins/hidelinenumbers.lua b/vendor/lite-plugins/plugins/hidelinenumbers.lua new file mode 100644 index 0000000..206bd23 --- /dev/null +++ b/vendor/lite-plugins/plugins/hidelinenumbers.lua @@ -0,0 +1,5 @@ +local style = require "core.style" +local DocView = require "core.docview" + +DocView.draw_line_gutter = function() end +DocView.get_gutter_width = function() return style.padding.x end diff --git a/vendor/lite-plugins/plugins/hidestatus.lua b/vendor/lite-plugins/plugins/hidestatus.lua new file mode 100644 index 0000000..5c0bb15 --- /dev/null +++ b/vendor/lite-plugins/plugins/hidestatus.lua @@ -0,0 +1,18 @@ +local command = require "core.command" +local StatusView = require "core.statusview" + +local visible = false +local funcs = { + [true] = StatusView.update, + [false] = function(self) self.size.y = 0 end, +} + +function StatusView:update(...) + funcs[visible](self, ...) +end + +command.add(nil, { + ["hide-status:toggle"] = function() visible = not visible end, + ["hide-status:hide"] = function() visible = false end, + ["hide-status:show"] = function() visible = true end, +}) diff --git a/vendor/lite-plugins/plugins/inanimate.lua b/vendor/lite-plugins/plugins/inanimate.lua new file mode 100644 index 0000000..a01aa40 --- /dev/null +++ b/vendor/lite-plugins/plugins/inanimate.lua @@ -0,0 +1,12 @@ +local core = require "core" +local View = require "core.view" + +function View:move_towards(t, k, dest) + if type(t) ~= "table" then + return self:move_towards(self, t, k, dest) + end + if t[k] ~= dest then + core.redraw = true + end + t[k] = dest +end diff --git a/vendor/lite-plugins/plugins/indentguide.lua b/vendor/lite-plugins/plugins/indentguide.lua new file mode 100644 index 0000000..daf7d8b --- /dev/null +++ b/vendor/lite-plugins/plugins/indentguide.lua @@ -0,0 +1,45 @@ +local style = require "core.style" +local config = require "core.config" +local DocView = require "core.docview" + + +local function get_line_spaces(doc, idx, dir) + local text = doc.lines[idx] + if not text then + return 0 + end + local s, e = text:find("^%s*") + if e == #text then + return get_line_spaces(doc, idx + dir, dir) + end + local n = 0 + for i = s, e do + n = n + (text:byte(i) == 9 and config.indent_size or 1) + end + return n +end + + +local function get_line_indent_guide_spaces(doc, idx) + if doc.lines[idx]:find("^%s*\n") then + return math.max( + get_line_spaces(doc, idx - 1, -1), + get_line_spaces(doc, idx + 1, 1)) + end + return get_line_spaces(doc, idx) +end + + +local draw_line_text = DocView.draw_line_text + +function DocView:draw_line_text(idx, x, y) + local spaces = get_line_indent_guide_spaces(self.doc, idx) + local sw = self:get_font():get_width(" ") + local w = math.ceil(1 * SCALE) + local h = self:get_line_height() + for i = 0, spaces - 1, config.indent_size do + local color = style.guide or style.selection + renderer.draw_rect(x + sw * i, y, w, h, color) + end + draw_line_text(self, idx, x, y) +end diff --git a/vendor/lite-plugins/plugins/language_angelscript.lua b/vendor/lite-plugins/plugins/language_angelscript.lua new file mode 100644 index 0000000..8c39cff --- /dev/null +++ b/vendor/lite-plugins/plugins/language_angelscript.lua @@ -0,0 +1,86 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.as$", "%.asc$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0[xX]%x+", type = "number" }, + { pattern = "-?0[bB][0-1]+", type = "number" }, + { pattern = "-?0[oO][0-7]+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "&inout", type = "keyword" }, + { pattern = "&in", type = "keyword" }, + { pattern = "&out", type = "keyword" }, + { pattern = "[%a_][%w_]*@", type = "keyword2" }, + { pattern = "[%-%+!~@%?:&|%^<>%*/=%%]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + -- Common + ["shared"] = "keyword", + ["external"] = "keyword", + ["private"] = "keyword", + ["protected"] = "keyword", + ["const"] = "keyword", + ["final"] = "keyword", + ["abstract"] = "keyword", + ["class"] = "keyword", + ["typedef"] = "keyword", + ["namespace"] = "keyword", + ["interface"] = "keyword", + ["import"] = "keyword", + ["enum"] = "keyword", + ["funcdef"] = "keyword", + ["get"] = "keyword", + ["set"] = "keyword", + ["mixin"] = "keyword", + ["void"] = "keyword2", + ["int"] = "keyword2", + ["int8"] = "keyword2", + ["int16"] = "keyword2", + ["int32"] = "keyword2", + ["int64"] = "keyword2", + ["uint"] = "keyword2", + ["uint8"] = "keyword2", + ["uint16"] = "keyword2", + ["uint32"] = "keyword2", + ["uint64"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["bool"] = "keyword2", + ["auto"] = "keyword", + ["override"] = "keyword", + ["explicit"] = "keyword", + ["property"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["for"] = "keyword", + ["while"] = "keyword", + ["do"] = "keyword", + ["if"] = "keyword", + ["else"] = "keyword", + ["try"] = "keyword", + ["catch"] = "keyword", + ["cast"] = "keyword", + ["function"] = "keyword", + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + ["is"] = "operator", + ["and"] = "operator", + ["or"] = "operator", + ["xor"] = "operator", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_batch.lua b/vendor/lite-plugins/plugins/language_batch.lua new file mode 100644 index 0000000..8caad59 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_batch.lua @@ -0,0 +1,61 @@ +local syntax = require "core.syntax" + +-- batch syntax for lite + +-- windows batch files use caseless matching for symbols +local symtable = { + ["keyword"] = { + "if", "else", "elsif", "not", "for", "do", "in", + "equ", "neq", "lss", "leq", "gtr", "geq", -- == != < <= > >= + "nul", "con", "prn", "prn", "lpt1", "com1", "com2", "com3", "com4", + "exist", "defined", + "errorlevel", "cmdextversion", + "goto", "call", "verify", + }, + ["function"] = { + "set", "setlocal", "endlocal", "enabledelayedexpansion", + "echo", "type", + "cd", "chdir", + "md", "mkdir", + "pause", "choice", "exit", + "del", "rd", "rmdir", + "copy", "xcopy", + "move", "ren", + "find", "findstr", + "sort", "shift", "attrib", + "cmd", "command", + "forfiles", + }, +} +-- prepare a mixed symbol list +local function prepare_symbols(symtable) + local symbols = { } + for symtype, symlist in pairs(symtable) do + for _, symname in ipairs(symlist) do + symbols[symname:lower()] = symtype + symbols[symname:upper()] = symtype + end + end + return symbols +end + +syntax.add { + files = { "%.bat$", "%.cmd$" }, + comment = "rem", + patterns = { + { pattern = "@echo off\n", type = "keyword" }, + { pattern = "@echo on\n", type = "keyword" }, + { pattern = "rem.-\n", type = "comment" }, -- rem comment line, rem, rem. + { pattern = "REM.-\n", type = "comment" }, + { pattern = "%s*:[%w%-]+", type = "symbol" }, -- :labels + { pattern = "%:%:.-\n", type = "comment" }, -- :: comment line + { pattern = "%%%w+%%", type = "symbol" }, -- %variable% + { pattern = "%%%%?~?[%w:]+", type = "symbol" }, -- %1, %~dpn1, %~1:2, %%i, %%~i + { pattern = "[!=()%>&%^/\\@]", type = "operator" }, -- operators + { pattern = "-?%.?%d+f?", type = "number" }, -- integer numbers + { pattern = { '"', '"', '\\' }, type = "string" }, -- "strings" + { pattern = "[%a_][%w_]*", type = "normal" }, + { pattern = ":eof", type = "keyword" }, -- not quite as intended, but ok for now + }, + symbols = prepare_symbols(symtable), +} diff --git a/vendor/lite-plugins/plugins/language_cmake.lua b/vendor/lite-plugins/plugins/language_cmake.lua new file mode 100644 index 0000000..78354e1 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_cmake.lua @@ -0,0 +1,15 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.cmake$", "CMakeLists.txt$" }, + comment = "//", + patterns = { + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "normal" }, + { pattern = "%${[%a_][%w_]*%}", type = "operator" }, + }, + symbols = {}, +} diff --git a/vendor/lite-plugins/plugins/language_cpp.lua b/vendor/lite-plugins/plugins/language_cpp.lua new file mode 100644 index 0000000..2b2fce5 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_cpp.lua @@ -0,0 +1,121 @@ +pcall(require, "plugins.language_c") + +local syntax = require "core.syntax" + +syntax.add { + files = { + "%.h$", "%.inl$", "%.cpp$", "%.cc$", "%.C$", "%.cxx$", + "%.c++$", "%.hh$", "%.H$", "%.hxx$", "%.hpp$", "%.h++$" + }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["alignof"] = "keyword", + ["alignas"] = "keyword", + ["and"] = "keyword", + ["and_eq"] = "keyword", + ["not"] = "keyword", + ["not_eq"] = "keyword", + ["or"] = "keyword", + ["or_eq"] = "keyword", + ["xor"] = "keyword", + ["xor_eq"] = "keyword", + ["private"] = "keyword", + ["protected"] = "keyword", + ["public"] = "keyword", + ["register"] = "keyword", + ["nullptr"] = "keyword", + ["operator"] = "keyword", + ["asm"] = "keyword", + ["bitand"] = "keyword", + ["bitor"] = "keyword", + ["catch"] = "keyword", + ["throw"] = "keyword", + ["try"] = "keyword", + ["class"] = "keyword", + ["compl"] = "keyword", + ["explicit"] = "keyword", + ["export"] = "keyword", + ["concept"] = "keyword", + ["consteval"] = "keyword", + ["constexpr"] = "keyword", + ["constinit"] = "keyword", + ["const_cast"] = "keyword", + ["dynamic_cast"] = "keyword", + ["reinterpret_cast"] = "keyword", + ["static_cast"] = "keyword", + ["static_assert"] = "keyword", + ["template"] = "keyword", + ["this"] = "keyword", + ["thread_local"] = "keyword", + ["requires"] = "keyword", + ["co_wait"] = "keyword", + ["co_return"] = "keyword", + ["co_yield"] = "keyword", + ["decltype"] = "keyword", + ["delete"] = "keyword", + ["export"] = "keyword", + ["friend"] = "keyword", + ["typeid"] = "keyword", + ["typename"] = "keyword", + ["mutable"] = "keyword", + ["virtual"] = "keyword", + ["using"] = "keyword", + ["namespace"] = "keyword", + ["new"] = "keyword", + ["noexcept"] = "keyword", + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["do"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["goto"] = "keyword", + ["struct"] = "keyword", + ["union"] = "keyword", + ["typedef"] = "keyword", + ["enum"] = "keyword", + ["extern"] = "keyword", + ["static"] = "keyword", + ["volatile"] = "keyword", + ["const"] = "keyword", + ["inline"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["auto"] = "keyword", + ["const"] = "keyword", + ["void"] = "keyword", + ["int"] = "keyword2", + ["short"] = "keyword2", + ["long"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["char"] = "keyword2", + ["unsigned"] = "keyword2", + ["bool"] = "keyword2", + ["true"] = "keyword2", + ["false"] = "keyword2", + ["wchar_t"] = "keyword2", + ["char8_t"] = "keyword2", + ["char16_t"] = "keyword2", + ["char32_t"] = "keyword2", + ["NULL"] = "literal", + }, +} diff --git a/vendor/lite-plugins/plugins/language_csharp.lua b/vendor/lite-plugins/plugins/language_csharp.lua new file mode 100644 index 0000000..5e790e3 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_csharp.lua @@ -0,0 +1,112 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.cs$", + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "[%$%@]?\"", '"', '\\' }, type = "string" }, -- string interpolation and verbatim + { pattern = "'\\x%x?%x?%x?%x'", type = "string" }, -- character hexadecimal escape sequence + { pattern = "'\\u%x%x%x%x'", type = "string" }, -- character unicode escape sequence + { pattern = "'\\?.'", type = "string" }, -- character literal + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "%?%?", type = "operator" }, -- ?? null-coalescing + { pattern = "%?%.", type = "operator" }, -- ?. null-conditional + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + -- keywords + ["abstract"] = "keyword", + ["as"] = "keyword", + ["await"] = "keyword", + ["base"] = "keyword", + ["break"] = "keyword", + ["case"] = "keyword", + ["catch"] = "keyword", + ["checked"] = "keyword", + ["class"] = "keyword", + ["const"] = "keyword", + ["continue"] = "keyword", + ["default"] = "keyword", + ["delegate"] = "keyword", + ["do"] = "keyword", + ["else"] = "keyword", + ["enum"] = "keyword", + ["event"] = "keyword", + ["explicit"] = "keyword", + ["extern"] = "keyword", + ["finally"] = "keyword", + ["fixed"] = "keyword", + ["for"] = "keyword", + ["foreach"] = "keyword", + ["get"] = "keyword", + ["goto"] = "keyword", + ["if"] = "keyword", + ["implicit"] = "keyword", + ["in"] = "keyword", + ["interface"] = "keyword", + ["internal"] = "keyword", + ["is"] = "keyword", + ["lock"] = "keyword", + ["namespace"] = "keyword", + ["new"] = "keyword", + ["operator"] = "keyword", + ["out"] = "keyword", + ["override"] = "keyword", + ["params"] = "keyword", + ["private"] = "keyword", + ["protected"] = "keyword", + ["public"] = "keyword", + ["readonly"] = "keyword", + ["ref"] = "keyword", + ["return"] = "keyword", + ["sealed"] = "keyword", + ["set"] = "keyword", + ["sizeof"] = "keyword", + ["stackalloc"] = "keyword", + ["static"] = "keyword", + ["struct"] = "keyword", + ["switch"] = "keyword", + ["this"] = "keyword", + ["throw"] = "keyword", + ["try"] = "keyword", + ["typeof"] = "keyword", + ["unchecked"] = "keyword", + ["unsafe"] = "keyword", + ["using"] = "keyword", + ["var"] = "keyword", + ["virtual"] = "keyword", + ["void"] = "keyword", + ["volatile"] = "keyword", + ["where"] = "keyword", + ["while"] = "keyword", + ["yield"] = "keyword", + -- types + ["bool"] = "keyword2", + ["byte"] = "keyword2", + ["char"] = "keyword2", + ["decimal"] = "keyword2", + ["double"] = "keyword2", + ["float"] = "keyword2", + ["int"] = "keyword2", + ["long"] = "keyword2", + ["object"] = "keyword2", + ["sbyte"] = "keyword2", + ["short"] = "keyword2", + ["string"] = "keyword2", + ["uint"] = "keyword2", + ["ulong"] = "keyword2", + ["ushort"] = "keyword2", + -- literals + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_d.lua b/vendor/lite-plugins/plugins/language_d.lua new file mode 100644 index 0000000..4597943 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_d.lua @@ -0,0 +1,135 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.d$", "%.di$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "/%+", "%+/" }, type = "comment" }, + { pattern = { '`', '`', '\\' }, type = "string" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&%$]+", type = "operator" }, + { pattern = "[%a_][%w_]*!", type = "function" }, -- highlight templates + { pattern = "[%a_][%w_]*", type = "symbol" }, + { pattern = "@safe", type = "keyword" }, + { pattern = "@trusted", type = "keyword" }, + { pattern = "@nogc", type = "keyword" }, + }, + symbols = { + ["abstract"] = "keyword", + ["alias"] = "keyword", + ["align"] = "keyword", + ["asm"] = "keyword", + ["assert"] = "keyword", + ["auto"] = "keyword", + ["body"] = "keyword", + ["bool"] = "keyword2", + ["break"] = "keyword", + ["byte"] = "keyword2", + ["case"] = "keyword", + ["cast"] = "keyword", + ["catch"] = "keyword", + ["cdouble"] = "keyword2", + ["cent"] = "keyword2", + ["cfloat"] = "keyword2", + ["char"] = "keyword2", + ["class"] = "keyword", + ["const"] = "keyword", + ["continue"] = "keyword", + ["creal"] = "keyword2", + ["dchar"] = "keyword2", + ["debug"] = "keyword", + ["default"] = "keyword", + ["delegate"] = "keyword", + ["deprecated"] = "keyword", + ["do"] = "keyword", + ["double"] = "keyword2", + ["else"] = "keyword", + ["enum"] = "keyword", + ["export"] = "keyword", + ["extern"] = "keyword", + ["false"] = "literal", + ["final"] = "keyword", + ["finally"] = "keyword", + ["float"] = "keyword2", + ["for"] = "keyword", + ["foreach"] = "keyword", + ["foreach_reverse"] = "keyword", + ["function"] = "keyword", + ["goto"] = "keyword", + ["idouble"] = "keyword2", + ["if"] = "keyword", + ["ifloat"] = "keyword2", + ["immutable"] = "keyword", + ["import"] = "keyword", + ["in"] = "keyword", + ["inout"] = "keyword", + ["int"] = "keyword2", + ["interface"] = "keyword", + ["invariant"] = "keyword", + ["ireal"] = "keyword2", + ["is"] = "keyword", + ["lazy"] = "keyword", + ["long"] = "keyword2", + ["macro"] = "keyword", + ["mixin"] = "keyword", + ["module"] = "keyword", + ["new"] = "keyword", + ["nothrow"] = "keyword", + ["null"] = "literal", + ["out"] = "keyword", + ["override"] = "keyword", + ["package"] = "keyword", + ["pragma"] = "keyword", + ["private"] = "keyword", + ["protected"] = "keyword", + ["public"] = "keyword", + ["pure"] = "keyword", + ["real"] = "keyword2", + ["ref"] = "keyword", + ["return"] = "keyword", + ["scope"] = "keyword", + ["shared"] = "keyword", + ["short"] = "keyword2", + ["static"] = "keyword", + ["struct"] = "keyword", + ["super"] = "keyword", + ["switch"] = "keyword", + ["synchronized"] = "keyword", + ["template"] = "keyword", + ["this"] = "keyword", + ["throw"] = "keyword", + ["true"] = "literal", + ["try"] = "keyword", + ["typeid"] = "keyword", + ["typeof"] = "keyword", + ["ubyte"] = "keyword2", + ["ucent"] = "keyword2", + ["uint"] = "keyword2", + ["ulong"] = "keyword2", + ["union"] = "keyword", + ["unittest"] = "keyword", + ["ushort"] = "keyword2", + ["version"] = "keyword", + ["void"] = "keyword", + ["wchar"] = "keyword2", + ["while"] = "keyword", + ["with"] = "keyword", + ["__FILE__"] = "keyword", + ["__FILE_FULL_PATH__"] = "keyword", + ["__MODULE__"] = "keyword", + ["__LINE__"] = "keyword", + ["__FUNCTION__"] = "keyword", + ["__PRETTY_FUNCTION__"] = "keyword", + ["__gshared"] = "keyword", + ["__traits"] = "keyword", + ["__vector"] = "keyword", + ["__parameters"] = "keyword", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_elixir.lua b/vendor/lite-plugins/plugins/language_elixir.lua new file mode 100644 index 0000000..f87fad9 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_elixir.lua @@ -0,0 +1,92 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.ex$", "%.exs$"}, + comment = "#", + patterns = { + { pattern = "#.*\n", type = "comment" }, + { pattern = { ':"', '"', '\\' }, type = "number" }, + { pattern = { '"""', '"""', '\\' }, type = "string" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { '~%a[/"|\'%(%[%{<]', '[/"|\'%)%]%}>]', '\\' }, type = "string"}, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = ':"?[%a_][%w_]*"?', type = "number" }, + { pattern = "[%a][%w_!?]*%f[(]", type = "function" }, + { pattern = "%u%w+", type = "normal" }, + { pattern = "@[%a_][%w_]*", type = "keyword2" }, + { pattern = "_%a[%w_]*", type = "keyword2" }, + { pattern = "[%+%-=/%*<>!|&]", type = "operator" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["def"] = "keyword", + ["defp"] = "keyword", + ["defguard"] = "keyword", + ["defguardp"] = "keyword", + ["defmodule"] = "keyword", + ["defprotocol"] = "keyword", + ["defimpl"] = "keyword", + ["defrecord"] = "keyword", + ["defrecordp"] = "keyword", + ["defmacro"] = "keyword", + ["defmacrop"] = "keyword", + ["defdelegate"] = "keyword", + ["defoverridable"] = "keyword", + ["defexception"] = "keyword", + ["defcallback"] = "keyword", + ["defstruct"] = "keyword", + ["for"] = "keyword", + ["case"] = "keyword", + ["when"] = "keyword", + ["with"] = "keyword", + ["cond"] = "keyword", + ["if"] = "keyword", + ["unless"] = "keyword", + ["try"] = "keyword", + ["receive"] = "keyword", + ["after"] = "keyword", + ["raise"] = "keyword", + ["rescue"] = "keyword", + ["catch"] = "keyword", + ["else"] = "keyword", + ["quote"] = "keyword", + ["unquote"] = "keyword", + ["super"] = "keyword", + ["unquote_splicing"] = "keyword", + ["do"] = "keyword", + ["end"] = "keyword", + ["fn"] = "keyword", + ["import"] = "keyword2", + ["alias"] = "keyword2", + ["use"] = "keyword2", + ["require"] = "keyword2", + ["and"] = "operator", + ["or"] = "operator", + ["true"] = "literal", + ["false"] = "literal", + ["nil"] = "literal", + }, +} + +syntax.add { + files = { "%.l?eex$" }, + patterns = { + { pattern = { "" }, type = "comment" }, + { pattern = { '%f[^>][^<]', '%f[<]' }, type = "normal" }, + { pattern = { '<%%=?', '%%>' }, type = "normal" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "%f[^<]![%a_][%w_]*", type = "keyword2" }, + { pattern = "%f[^<][%a_][%w_]*", type = "function" }, + { pattern = "%f[^<]/[%a_][%w_]*", type = "function" }, + { pattern = "[%a_][%w_]*", type = "keyword" }, + { pattern = "[/<>=]", type = "operator" }, + }, + symbols = {}, +} diff --git a/vendor/lite-plugins/plugins/language_elm.lua b/vendor/lite-plugins/plugins/language_elm.lua new file mode 100644 index 0000000..4f449a0 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_elm.lua @@ -0,0 +1,47 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.elm$" }, + comment = "%-%-", + patterns = { + { pattern = {"%-%-", "\n"}, type = "comment" }, + { pattern = { "{%-", "%-}" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { '"""', '"""', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "%.%.", type = "operator" }, + { pattern = "[=:|&<>%+%-%*\\/%^%%]", type = "operator" }, + { pattern = "[%a_'][%w_']*", type = "symbol" }, + }, + symbols = { + ["as"] = "keyword", + ["case"] = "keyword", + ["of"] = "keyword", + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["import"] = "keyword", + ["module"] = "keyword", + ["exposing"] = "keyword", + ["let"] = "keyword", + ["in"] = "keyword", + ["type"] = "keyword", + ["alias"] = "keyword", + ["port"] = "keyword", + ["and"] = "keyword", + ["or"] = "keyword", + ["xor"] = "keyword", + ["not"] = "keyword", + ["number"] = "keyword2", + ["Bool"] = "keyword2", + ["Char"] = "keyword2", + ["Float"] = "keyword2", + ["Int"] = "keyword2", + ["String"] = "keyword2", + ["True"] = "literal", + ["False"] = "literal", + }, +} diff --git a/vendor/lite-plugins/plugins/language_fe.lua b/vendor/lite-plugins/plugins/language_fe.lua new file mode 100644 index 0000000..f97e73b --- /dev/null +++ b/vendor/lite-plugins/plugins/language_fe.lua @@ -0,0 +1,33 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.fe$", + comment = ";", + patterns = { + { pattern = ";.-\n", type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "'", type = "symbol" }, + { pattern = "%f[^(][^()'%s\"]+", type = "function" }, + { pattern = "[^()'%s\"]+", type = "symbol" }, + }, + symbols = { + ["if"] = "keyword2", + ["let"] = "keyword2", + ["do"] = "keyword2", + ["fn"] = "keyword2", + ["mac"] = "keyword2", + ["'"] = "keyword2", + ["print"] = "keyword", + ["while"] = "keyword", + ["car"] = "keyword", + ["cdr"] = "keyword", + ["not"] = "keyword", + ["setcdr"] = "keyword", + ["setcar"] = "keyword", + ["nil"] = "literal", + ["t"] = "literal", + } +} diff --git a/vendor/lite-plugins/plugins/language_fennel.lua b/vendor/lite-plugins/plugins/language_fennel.lua new file mode 100644 index 0000000..7320e91 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_fennel.lua @@ -0,0 +1,100 @@ +-- Support for the Fennel programming language: https://fennel-lang.org +-- Covers all the keywords up to Fennel version 0.4.0 + +-- Currently only covers highlighting, not indentation, delimiter +-- matching, or evaluation. + +local syntax = require "core.syntax" + +syntax.add { + files = "%.fnl$", + comment = ";", + patterns = { + { pattern = ";.-\n", type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "%f[^(][^()'%s\"]+", type = "function" }, + { pattern = "[^()'%s\"]+", type = "symbol" }, + }, + + symbols = { + ["eval-compiler"] = "keyword2", + ["doc"] = "keyword2", + ["lua"] = "keyword2", + ["hashfn"] = "keyword2", + ["macro"] = "keyword2", + ["macros"] = "keyword2", + ["import-macros"] = "keyword2", + ["do"] = "keyword2", + ["values"] = "keyword2", + ["if"] = "keyword2", + ["when"] = "keyword2", + ["each"] = "keyword2", + ["for"] = "keyword2", + ["fn"] = "keyword2", + ["lambda"] = "keyword2", + ["λ"] = "keyword2", + ["partial"] = "keyword2", + ["while"] = "keyword2", + ["set"] = "keyword2", + ["global"] = "keyword2", + ["var"] = "keyword2", + ["local"] = "keyword2", + ["let"] = "keyword2", + ["tset"] = "keyword2", + ["set-forcibly!"] = "keyword2", + ["doto"] = "keyword2", + ["match"] = "keyword2", + ["or"] = "keyword2", + ["and"] = "keyword2", + ["not"] = "keyword2", + ["not="] = "keyword2", + ["pick-args"] = "keyword2", + ["pick-values"] = "keyword2", + ["macrodebug"] = "keyword2", + + ["."] = "keyword", + ["+"] = "keyword", + [".."] = "keyword", + ["^"] = "keyword", + ["-"] = "keyword", + ["*"] = "keyword", + ["%"] = "keyword", + ["/"] = "keyword", + [">"] = "keyword", + ["<"] = "keyword", + [">="] = "keyword", + ["<="] = "keyword", + ["="] = "keyword", + ["#"] = "keyword", + ["..."] = "keyword", + [":"] = "keyword", + ["->"] = "keyword", + ["->>"] = "keyword", + ["-?>"] = "keyword", + ["-?>>"] = "keyword", + ["$"] = "keyword", + ["$1"] = "keyword", + ["$2"] = "keyword", + ["$3"] = "keyword", + ["$4"] = "keyword", + ["$5"] = "keyword", + ["$6"] = "keyword", + ["$7"] = "keyword", + ["$8"] = "keyword", + ["$9"] = "keyword", + + ["lshift"] = "keyword", + ["rshift"] = "keyword", + ["bor"] = "keyword", + ["band"] = "keyword", + ["bnot"] = "keyword", + ["bxor"] = "keyword", + + ["nil"] = "literal", + ["true"] = "literal", + ["false"] = "literal", + } +} diff --git a/vendor/lite-plugins/plugins/language_gdscript.lua b/vendor/lite-plugins/plugins/language_gdscript.lua new file mode 100644 index 0000000..e301354 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_gdscript.lua @@ -0,0 +1,99 @@ +-- Support for the GDScript programming language: https://godotengine.org/ +-- Covers the most used keywords up to Godot version 3.2.x + +local syntax = require "core.syntax" + +syntax.add { + files = { "%.gd$" }, + comment = "#", + patterns = { + { pattern = "#.-\n", type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x*", type = "number" }, + { pattern = "-?%d+[%d%.e]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "[%+%:%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + -- keywords + ["if"] = "keyword", + ["elif"] = "keyword", + ["else"] = "keyword", + ["for"] = "keyword", + ["while"] = "keyword", + ["match"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["pass"] = "keyword", + ["return"] = "keyword", + ["class"] = "keyword", + ["class_name"] = "keyword", + ["extends"] = "keyword", + ["is"] = "keyword", + ["in"] = "keyword", + ["as"] = "keyword", + ["and"] = "keyword", + ["or"] = "keyword", + ["not"] = "keyword", + ["self"] = "keyword", + ["tool"] = "keyword", + ["signal"] = "keyword", + ["func"] = "keyword", + ["static"] = "keyword", + ["const"] = "keyword", + ["enum"] = "keyword", + ["var"] = "keyword", + ["onready"] = "keyword", + ["export"] = "keyword", + ["setget"] = "keyword", + ["breakpoint"] = "keyword", + ["preload"] = "keyword", + ["yield"] = "keyword", + ["assert"] = "keyword", + ["remote"] = "keyword", + ["master"] = "keyword", + ["puppet"] = "keyword", + ["remotesync"] = "keyword", + ["mastersync"] = "keyword", + ["puppetsync"] = "keyword", + -- types + ["void"] = "keyword2", + ["int"] = "keyword2", + ["float"] = "keyword2", + ["bool"] = "keyword2", + ["String"] = "keyword2", + ["Vector2"] = "keyword2", + ["Rect2"] = "keyword2", + ["Vector3"] = "keyword2", + ["Transform2D"] = "keyword2", + ["Plane"] = "keyword2", + ["Quat"] = "keyword2", + ["AABB"] = "keyword2", + ["Basis"] = "keyword2", + ["Transform"] = "keyword2", + ["Color"] = "keyword2", + ["NodePath"] = "keyword2", + ["RID"] = "keyword2", + ["Object"] = "keyword2", + ["Array"] = "keyword2", + ["PoolByteArray"] = "keyword2", + ["PoolIntArray"] = "keyword2", + ["PoolRealArray"] = "keyword2", + ["PoolStringArray"] = "keyword2", + ["PoolVector2Array"] = "keyword2", + ["PoolVector3Array"] = "keyword2", + ["PoolColorArray"] = "keyword2", + ["Dictionary"] = "keyword2", + -- literals + ["null"] = "literal", + ["true"] = "literal", + ["false"] = "literal", + ["PI"] = "literal", + ["TAU"] = "literal", + ["INF"] = "literal", + ["NAN"] = "literal", + }, +} diff --git a/vendor/lite-plugins/plugins/language_glsl.lua b/vendor/lite-plugins/plugins/language_glsl.lua new file mode 100644 index 0000000..da69ebd --- /dev/null +++ b/vendor/lite-plugins/plugins/language_glsl.lua @@ -0,0 +1,387 @@ + +local style = require "core.style" +local common = require "core.common" + +local syntax = require "core.syntax" + +syntax.add { + files = { "%.glsl$", "%.frag$", "%.vert$", }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + + { pattern = "ivec[2-4]", type = "keyword2" }, + { pattern = "bvec[2-4]", type = "keyword2" }, + { pattern = "uvec[2-4]", type = "keyword2" }, + { pattern = "vec[2-4]", type = "keyword2" }, + { pattern = "dmat[2-4]x[2-4]", type = "keyword2" }, + { pattern = "dmat[2-4]", type = "keyword2" }, + { pattern = "mat[2-4]x[2-4]", type = "keyword2" }, + { pattern = "mat[2-4]", type = "keyword2" }, + + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + --https://www.khronos.org/registry/OpenGL/specs/gl/GLSLangSpec.4.60.pdf + --The symbols are added here in the order they appear in the spec + ["if"] = "keyword", + ["else"] = "keyword", + ["do"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["const"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["const"] = "keyword", + ["void"] = "keyword", + ["bool"] = "keyword2", + ["int"] = "keyword2", + ["uint"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["NULL"] = "literal", + + ["attribute"] = "keyword", + ["varying"] = "keyword", + ["uniform"] = "keyword", + ["buffer"] = "keyword", + ["shared"] = "keyword", + ["layout"] = "keyword", + ["centroid"] = "keyword", + ["flat"] = "keyword", + ["smooth"] = "keyword", + ["noperspective"]= "keyword", + ["patch"] = "keyword", + ["sample"] = "keyword", + ["in"] = "keyword", + ["out"] = "keyword", + ["inout"] = "keyword", + ["invariant"] = "keyword", + ["precise"] = "keyword", + ["lowp"] = "keyword", + ["mediump"] = "keyword", + ["highp"] = "keyword", + ["precision"] = "keyword", + ["struct"] = "keyword", + ["subroutine"] = "keyword", + + ["coherent"] = "keyword", + ["volatile"] = "keyword", + ["readonly"] = "keyword", + ["writeonly"] = "keyword", + + ["sampler1D"] = "keyword2", + ["sampler2D"] = "keyword2", + ["sampler3D"] = "keyword2", + ["samplerCube"] = "keyword2", + ["sampler1DShadow"] = "keyword2", + ["sampler2DShadow"] = "keyword2", + ["samplerCubeShadow"] = "keyword2", + ["sampler1DArray"] = "keyword2", + ["sampler2DArray"] = "keyword2", + ["samplerCubeArray"] = "keyword2", + ["sampler1DArrayShadow"] = "keyword2", + ["sampler2DArrayShadow"] = "keyword2", + ["samplerCubeArrayShadow"]= "keyword2", + ["isampler1D"] = "keyword2", + ["isampler2D"] = "keyword2", + ["isampler3D"] = "keyword2", + ["isamplerCube"] = "keyword2", + ["sampler2DMS"] = "keyword2", + ["isampler2DMS"] = "keyword2", + ["usampler2DMS"] = "keyword2", + ["sampler2DMSArray"] = "keyword2", + ["isampler2DMSArray"] = "keyword2", + ["usampler2DMSArray"] = "keyword2", + ["isampler1DArray"] = "keyword2", + ["isampler2DArray"] = "keyword2", + ["usampler1D"] = "keyword2", + ["usampler2D"] = "keyword2", + ["usampler3D"] = "keyword2", + ["usamplerCube"] = "keyword2", + ["usampler1DArray"] = "keyword2", + ["usampler2DArray"] = "keyword2", + ["sampler2DRect"] = "keyword2", + ["sampler2DRectShadow"] = "keyword2", + ["isampler2DRect"] = "keyword2", + ["usampler2DRect"] = "keyword2", + ["samplerBuffer"] = "keyword2", + ["isamplerBuffer"] = "keyword2", + ["usamplerBuffer"] = "keyword2", + + ["image1D"] = "keyword2", + ["iimage1D"] = "keyword2", + ["uimage1D"] = "keyword2", + ["image1DArray"] = "keyword2", + ["iimage1DArray"] = "keyword2", + ["uimage1DArray"] = "keyword2", + ["image2D"] = "keyword2", + ["iimage2D"] = "keyword2", + ["uimage2D"] = "keyword2", + ["image2DArray"] = "keyword2", + ["iimage2DArray"] = "keyword2", + ["uimage2DArray"] = "keyword2", + ["image2DRect"] = "keyword2", + ["iimage2DRect"] = "keyword2", + ["uimage2DRect"] = "keyword2", + ["image2DMS"] = "keyword2", + ["iimage2DMS"] = "keyword2", + ["uimage2DMS"] = "keyword2", + ["image2DMSArray"] = "keyword2", + ["iimage2DMSArray"]= "keyword2", + ["uimage2DMSArray"]= "keyword2", + ["image3D"] = "keyword2", + ["iimage3D"] = "keyword2", + ["uimage3D"] = "keyword2", + ["imageCube"] = "keyword2", + ["iimageCube"] = "keyword2", + ["uimageCube"] = "keyword2", + ["imageCubeArray"] = "keyword2", + ["iimageCubeArray"]= "keyword2", + ["uimageCubeArray"]= "keyword2", + ["imageBuffer"] = "keyword2", + ["iimageBuffer"] = "keyword2", + ["uimageBuffer"] = "keyword2", + + ["atomic_uint"] = "keyword2", + + ["radians"] = "keyword", + ["degrees"] = "keyword", + ["sin"] = "keyword", + ["cos"] = "keyword", + ["tan"] = "keyword", + ["asin"] = "keyword", + ["acos"] = "keyword", + ["atan"] = "keyword", + ["sinh"] = "keyword", + ["cosh"] = "keyword", + ["tanh"] = "keyword", + ["asinh"] = "keyword", + ["acosh"] = "keyword", + ["pow"] = "keyword", + ["exp"] = "keyword", + ["exp2"] = "keyword", + ["log2"] = "keyword", + ["sqrt"] = "keyword", + ["inversesqrt"] = "keyword", + ["abs"] = "keyword", + ["sign"] = "keyword", + ["floor"] = "keyword", + ["trunc"] = "keyword", + ["round"] = "keyword", + ["roundEven"] = "keyword", + ["ceil"] = "keyword", + ["fract"] = "keyword", + ["mod"] = "keyword", + ["modf"] = "keyword", + ["min"] = "keyword", + ["max"] = "keyword", + ["clamp"] = "keyword", + ["mix"] = "keyword", + ["step"] = "keyword", + ["smoothstep"] = "keyword", + ["isnan"] = "keyword", + ["isinf"] = "keyword", + ["floatBitsToInt"] = "keyword", + ["floatBitsToUint"] = "keyword", + ["intBitsToFloat"] = "keyword", + ["uintBitsToFloat"] = "keyword", + ["fma"] = "keyword", + ["frexp"] = "keyword", + ["ldexp"] = "keyword", + ["packUnorm2x16"] = "keyword", + ["packSnorm2x16"] = "keyword", + ["packUnorm4x8"] = "keyword", + ["packSnorm4x8"] = "keyword", + ["unpackUnorm2x16"] = "keyword", + ["unpackSnorm2x16"] = "keyword", + ["unpackUnorm4x8"] = "keyword", + ["unpackSnorm4x8"] = "keyword", + ["packHalf2x16"] = "keyword", + ["unpackHalf2x16"] = "keyword", + ["packDouble2x32"] = "keyword", + ["unpackDouble2x32"] = "keyword", + ["length"] = "keyword", + ["distance"] = "keyword", + ["dot"] = "keyword", + ["cross"] = "keyword", + ["normalize"] = "keyword", + ["ftransform"] = "keyword", + ["faceforward"] = "keyword", + ["reflect"] = "keyword", + ["refract"] = "keyword", + ["matrixCompMult"] = "keyword", + ["outerProduct"] = "keyword", + ["transpose"] = "keyword", + ["determinant"] = "keyword", + ["inverse"] = "keyword", + ["lessThan"] = "keyword", + ["lessThanEqual"] = "keyword", + ["greaterThan"] = "keyword", + ["greaterThanEqual"] = "keyword", + ["equal"] = "keyword", + ["notEqual"] = "keyword", + ["any"] = "keyword", + ["all"] = "keyword", + ["not"] = "keyword", + ["uaddCarry"] = "keyword", + ["usubBorrow"] = "keyword", + ["umulExtended"] = "keyword", + ["imulExtended"] = "keyword", + ["bitfieldExtract"] = "keyword", + ["bitfieldInsert"] = "keyword", + ["bitfieldReverse"] = "keyword", + ["bitCount"] = "keyword", + ["findLSB"] = "keyword", + ["findMSB"] = "keyword", + ["textureSize"] = "keyword", + ["textureQueryLod"] = "keyword", + ["textureQueryLevels"] = "keyword", + ["textureSamples"] = "keyword", + ["texture"] = "keyword", + ["textureProj"] = "keyword", + ["textureLod"] = "keyword", + ["textureOffset"] = "keyword", + ["texelFetch"] = "keyword", + ["texelFetchOffset"] = "keyword", + ["textureProjOffset"] = "keyword", + ["textureLodOffset"] = "keyword", + ["textureProjLod"] = "keyword", + ["textureProjLodOffset"] = "keyword", + ["textureGrad"] = "keyword", + ["textureGradOffset"] = "keyword", + ["textureProjGrad"] = "keyword", + ["textureProjGradOffset"]= "keyword", + ["textureGather"] = "keyword", + ["textureGatherOffset"] = "keyword", + ["textureGatherOffsets"] = "keyword", + + --Atomic Counter Functions + ["atomicCounterIncrement"]= "keyword", + ["atomicCounterDecrement"]= "keyword", + ["atomicCounter"] = "keyword", + ["atomicCounterAdd"] = "keyword", + ["atomicCounterSubtract"] = "keyword", + ["atomicCounterMin"] = "keyword", + ["atomicCounterMax"] = "keyword", + ["atomicCounterAnd"] = "keyword", + ["atomicCounterOr"] = "keyword", + ["atomicCounterXor"] = "keyword", + ["atomicCounterExchange"] = "keyword", + ["atomicCounterCompSwap"] = "keyword", + --Atomic Memory Functions + ["atomicAdd"] = "keyword", + ["atomicMin"] = "keyword", + ["atomicMax"] = "keyword", + ["atomicAnd"] = "keyword", + ["atomicOr"] = "keyword", + ["atomicXor"] = "keyword", + ["atomicExchange"]= "keyword", + ["atomicCompSwap"]= "keyword", + --Image Functions + ["imageSize"] = "keyword", + ["imageSamples"] = "keyword", + ["imageLoad"] = "keyword", + ["imageStore"] = "keyword", + ["imageAtomicAdd"] = "keyword", + ["imageAtomicMin"] = "keyword", + ["imageAtomicMax"] = "keyword", + ["imageAtomicAnd"] = "keyword", + ["imageAtomicOr"] = "keyword", + ["imageAtomicXor"] = "keyword", + ["imageAtomicExchange"]= "keyword", + ["imageAtomicCompSwap"]= "keyword", + --Geometry Shader Functions + ["EmitStreamVertex"] = "keyword", + ["EndStreamPrimitive"] = "keyword", + ["EmitVertex"] = "keyword", + ["EndPrimitive"] = "keyword", + --Fragment Processing Functions + ["dFdx"] = "keyword", + ["dFdy"] = "keyword", + ["dFdxFine"] = "keyword", + ["dFdyFine"] = "keyword", + ["dFdxCoarse"] = "keyword", + ["dFdyCoarse"] = "keyword", + ["fwidth"] = "keyword", + ["fwidthFine"] = "keyword", + ["fwidthCoarse"] = "keyword", + ["interpolateAtCentroid"]= "keyword", + ["interpolateAtSample"] = "keyword", + ["interpolateAtOffset"] = "keyword", + --Shader Invocation Control Functions + ["barrier"] = "keyword", + --Shader Memory Control Functions + ["memoryBarrier"] = "keyword", + ["memoryBarrierAtomicCounter"]= "keyword", + ["memoryBarrierBuffer"] = "keyword", + ["memoryBarrierShared"] = "keyword", + ["memoryBarrierImage"] = "keyword", + ["groupMemoryBarrier"] = "keyword", + --Subpass-Input Functions + ["subpassLoad"] = "keyword", + --Shader Invocation Group Functions + ["anyInvocation"] = "keyword", + ["allInvocations"] = "keyword", + ["allInvocationsEqual"]= "keyword", + + --"In addition, when targeting Vulkan, the following keywords also exist:" + ["texture1D"] = "keyword", + ["texture1DArray"] = "keyword", + ["itexture1D"] = "keyword", + ["itexture1DArray"] = "keyword", + ["utexture1D"] = "keyword", + ["utexture1DArray"] = "keyword", + ["texture2D"] = "keyword", + ["texture2DArray"] = "keyword", + ["itexture2D"] = "keyword", + ["itexture2DArray"] = "keyword", + ["utexture2D"] = "keyword", + ["utexture2DArray"] = "keyword", + ["texture2DRect"] = "keyword", + ["itexture2DRect"] = "keyword", + ["utexture2DRect"] = "keyword", + ["texture2DMS"] = "keyword", + ["itexture2DMS"] = "keyword", + ["utexture2DMS"] = "keyword", + ["texture2DMSArray"] = "keyword", + ["itexture2DMSArray"]= "keyword", + ["utexture2DMSArray"]= "keyword", + ["texture3D"] = "keyword", + ["itexture3D"] = "keyword", + ["utexture3D"] = "keyword", + ["textureCube"] = "keyword", + ["itextureCube"] = "keyword", + ["utextureCube"] = "keyword", + ["textureCubeArray"] = "keyword", + ["itextureCubeArray"]= "keyword", + ["utextureCubeArray"]= "keyword", + ["textureBuffer"] = "keyword", + ["itextureBuffer"] = "keyword", + ["utextureBuffer"] = "keyword", + ["sampler"] = "keyword2", + ["samplerShadow"] = "keyword2", + ["subpassInput"] = "keyword2", + ["isubpassInput"] = "keyword2", + ["usubpassInput"] = "keyword2", + ["subpassInputMS"] = "keyword2", + ["isubpassInputMS"] = "keyword2", + ["usubpassInputMS"] = "keyword2", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_go.lua b/vendor/lite-plugins/plugins/language_go.lua new file mode 100644 index 0000000..488725f --- /dev/null +++ b/vendor/lite-plugins/plugins/language_go.lua @@ -0,0 +1,71 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.go$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "`", "`", '\\' }, type = "string" }, + { pattern = "0[oO_][0-7]+", type = "number" }, + { pattern = "-?0x[%x_]+", type = "number" }, + { pattern = "-?%d+_%d", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = ":=", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["if"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["for"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["struct"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["const"] = "keyword", + ["package"] = "keyword", + ["import"] = "keyword", + ["func"] = "keyword", + ["var"] = "keyword", + ["type"] = "keyword", + ["interface"] = "keyword", + ["select"] = "keyword", + ["break"] = "keyword", + ["range"] = "keyword", + ["chan"] = "keyword", + ["defer"] = "keyword", + ["go"] = "keyword", + ["int"] = "keyword2", + ["int64"] = "keyword2", + ["int32"] = "keyword2", + ["int16"] = "keyword2", + ["int8"] = "keyword2", + ["uint"] = "keyword2", + ["uint64"] = "keyword2", + ["uint32"] = "keyword2", + ["uint16"] = "keyword2", + ["uint8"] = "keyword2", + ["uintptr"] = "keyword2", + ["float64"] = "keyword2", + ["float32"] = "keyword2", + ["map"] = "keyword2", + ["string"] = "keyword2", + ["rune"] = "keyword2", + ["bool"] = "keyword2", + ["byte"] = "keyword2", + ["error"] = "keyword2", + ["complex64"] = "keyword2", + ["complex128"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["nil"] = "literal", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_hlsl.lua b/vendor/lite-plugins/plugins/language_hlsl.lua new file mode 100644 index 0000000..1444ef4 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_hlsl.lua @@ -0,0 +1,275 @@ + +local style = require "core.style" +local common = require "core.common" + +local syntax = require "core.syntax" + +syntax.add { + files = { "%.hlsl$", }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + + { pattern = "int[1-9]x[1-9]", type = "keyword2" }, + { pattern = "int1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "int[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "int1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "int[1-4]", type = "keyword2" }, + + { pattern = "uint[1-9]x[1-9]", type = "keyword2" }, + { pattern = "uint1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "uint[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "uint1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "uint[1-4]", type = "keyword2" }, + + { pattern = "dword[1-9]x[1-9]", type = "keyword2" }, + { pattern = "dword1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "dword[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "dword1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "dword[1-4]", type = "keyword2" }, + + { pattern = "half[1-9]x[1-9]", type = "keyword2" }, + { pattern = "half1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "half[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "half1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "half[1-4]", type = "keyword2" }, + + { pattern = "float[1-9]x[1-9]", type = "keyword2" }, + { pattern = "float1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "float[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "float1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "float[1-4]", type = "keyword2" }, + + { pattern = "double[1-9]x[1-9]", type = "keyword2" }, + { pattern = "double1[0-6]x[1-9]", type = "keyword2" }, + { pattern = "double[1-9]x1[0-6]", type = "keyword2" }, + { pattern = "double1[0-6]x1[0-6]", type = "keyword2" }, + { pattern = "double[1-4]", type = "keyword2" }, + + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + --https://docs.microsoft.com/en-us/windows/win32/direct3dhlsl/dx-graphics-hlsl-appendix-keywords + --The symbols are added in the order they appear on this webpage, which is alphabetically + ["AppendStructuredBuffer"]= "keyword", + ["asm"] = "keyword", + ["asm_fragment"] = "keyword", + ["BlendState"] = "keyword2", + ["bool"] = "keyword2", + ["break"] = "keyword", + ["Buffer"] = "keyword2", + ["ByteAddressBuffer"]= "keyword2", + ["case"] = "keyword", + ["cbuffer"] = "keyword2", + ["centroid"] = "keyword2", + ["class"] = "keyword", + ["column_major"] = "keyword", + ["compile"] = "keyword", + ["compile_fragment"] = "keyword", + ["CompileShader"] = "keyword", + ["const"] = "keyword", + ["continue"] = "keyword", + ["ComputeShader"] = "keyword", + ["ConsumeStructuredBuffer"]= "keyword", + ["default"] = "keyword", + ["DepthStencilState"]= "keyword", + ["DepthStencilView"] = "keyword", + ["discard"] = "keyword", + ["do"] = "keyword", + ["double"] = "keyword2", + ["DomainShader"] = "keyword2", + ["dword"] = "keyword2", + ["else"] = "keyword", + ["export"] = "keyword", + ["extern"] = "keyword", + ["false"] = "literal", + ["float"] = "keyword2", + ["for"] = "keyword", + ["fxgroup"] = "keyword2", + ["GeometryShader"] = "keyword2", + ["groupshared"] = "keyword", + ["half"] = "keyword2", + ["HullShader"] = "keyword2", + ["if"] = "keyword", + ["in"] = "keyword", + ["inline"] = "keyword", + ["inout"] = "keyword", + ["InputPatch"] = "keyword2", + ["int"] = "keyword2", + ["interface"] = "keyword", + ["line"] = "keyword2", + ["lineadj"] = "keyword2", + ["linear"] = "keyword", + ["LineStream"] = "keyword2", + ["matrix"] = "keyword2", + ["min16float"] = "keyword2", + ["min10float"] = "keyword2", + ["min16int"] = "keyword2", + ["min12int"] = "keyword2", + ["min16uint"] = "keyword2", + ["namespace"] = "keyword", + ["nointerpolation"] = "keyword", + ["noperspective"] = "keyword", + ["NULL"] = "literal", + ["out"] = "keyword", + ["OutputPatch"] = "keyword2", + ["packoffset"] = "keyword", + ["pass"] = "keyword", + ["pixelfragment"] = "keyword", + ["PixelShader"] = "keyword2", + ["point"] = "keyword2", + ["PointStream"] = "keyword2", + ["precise"] = "keyword", + ["RasterizerState"] = "keyword2", + ["RenderTargetView"] = "keyword2", + ["return"] = "keyword", + ["register"] = "keyword", + ["row_major"] = "keyword", + ["RWBuffer"] = "keyword2", + ["RWByteAddressBuffer"]= "keyword2", + ["RWStructuredBuffer"]= "keyword2", + ["RWTexture1D"] = "keyword2", + ["RWTexture1DArray"] = "keyword2", + ["RWTexture2D"] = "keyword2", + ["RWTexture2DArray"] = "keyword2", + ["RWTexture3D"] = "keyword2", + ["sample"] = "keyword", + ["sampler"] = "keyword2", + ["SamplerState"] = "keyword2", + ["SamplerComparisonState"]= "keyword2", + ["shared"] = "keyword", + ["snorm"] = "keyword", + ["stateblock"] = "keyword", + ["stateblock_state"] = "keyword", + ["static"] = "keyword", + ["string"] = "keyword2", + ["struct"] = "keyword", + ["switch"] = "keyword", + ["StructuredBuffer"] = "keyword2", + ["tbuffer"] = "keyword2", + ["technique"] = "keyword2", + ["technique10"] = "keyword2", + ["technique11"] = "keyword2", + ["texture"] = "keyword2", + ["Texture1D"] = "keyword2", + ["Texture1DArray"] = "keyword2", + ["Texture2D"] = "keyword2", + ["Texture2DArray"] = "keyword2", + ["Texture2DMS"] = "keyword2", + ["Texture2DMSArray"] = "keyword2", + ["Texture3D"] = "keyword2", + ["TextureCube"] = "keyword2", + ["TextureCubeArray"] = "keyword2", + ["true"] = "literal", + ["typedef"] = "keyword", + ["triangle"] = "keyword2", + ["triangleadj"] = "keyword2", + ["TriangleStream"] = "keyword2", + ["uint"] = "keyword2", + ["uniform"] = "keyword", + ["unorm"] = "keyword", + ["unsigned"] = "keyword", + ["vector"] = "keyword2", + ["vertexfragment"] = "keyword2", + ["VertexShader"] = "keyword2", + ["void"] = "keyword", + ["volatile"] = "keyword", + ["while"] = "keyword", + + --https://docs.microsoft.com/en-us/windows/win32/direct3dhlsl/dx-graphics-hlsl-intrinsic-functions + --The symbols are added in the order they appear on this webpage, which is alphabetically + ["abort"] = "keyword", + ["abs"] = "keyword", + ["acos"] = "keyword", + ["all"] = "keyword", + ["any"] = "keyword", + ["asdouble"] = "keyword", + ["asfloat"] = "keyword", + ["asin"] = "keyword", + ["asint"] = "keyword", + ["asuint"] = "keyword", + ["atan"] = "keyword", + ["atan2"] = "keyword", + ["ceil"] = "keyword", + ["clamp"] = "keyword", + ["clip"] = "keyword", + ["cos"] = "keyword", + ["cosh"] = "keyword", + ["countbits"] = "keyword", + ["cross"] = "keyword", + ["ddx"] = "keyword", + ["ddx_coarse"] = "keyword", + ["ddx_fine"] = "keyword", + ["ddy"] = "keyword", + ["ddy_coarse"] = "keyword", + ["ddy_fine"] = "keyword", + ["degrees"] = "keyword", + ["determinant"] = "keyword", + ["distance"] = "keyword", + ["dot"] = "keyword", + ["dst"] = "keyword", + ["errorf"] = "keyword", + ["exp"] = "keyword", + ["exp2"] = "keyword", + ["f16tof32"] = "keyword", + ["f32tof16"] = "keyword", + ["faceforward"] = "keyword", + ["firstbithigh"]= "keyword", + ["firstbitlow"] = "keyword", + ["floor"] = "keyword", + ["fma"] = "keyword", + ["fmod"] = "keyword", + ["frac"] = "keyword", + ["frexp"] = "keyword", + ["fwidth"] = "keyword", + ["isfinite"] = "keyword", + ["isinf"] = "keyword", + ["isnan"] = "keyword", + ["ldexp"] = "keyword", + ["length"] = "keyword", + ["lerp"] = "keyword", + ["lit"] = "keyword", + ["log"] = "keyword", + ["log10"] = "keyword", + ["log2"] = "keyword", + ["mad"] = "keyword", + ["max"] = "keyword", + ["min"] = "keyword", + ["modf"] = "keyword", + ["msad4"] = "keyword", + ["mul"] = "keyword", + ["noise"] = "keyword", + ["normalize"] = "keyword", + ["pow"] = "keyword", + ["printf"] = "keyword", + ["radians"] = "keyword", + ["rcp"] = "keyword", + ["reflect"] = "keyword", + ["refract"] = "keyword", + ["reversebits"] = "keyword", + ["round"] = "keyword", + ["rsqrt"] = "keyword", + ["saturate"] = "keyword", + ["sign"] = "keyword", + ["sin"] = "keyword", + ["sincos"] = "keyword", + ["sinh"] = "keyword", + ["smoothstep"] = "keyword", + ["sqrt"] = "keyword", + ["step"] = "keyword", + ["tan"] = "keyword", + ["tanh"] = "keyword", + ["transpose"] = "keyword", + ["trunc"] = "keyword", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_hs.lua b/vendor/lite-plugins/plugins/language_hs.lua new file mode 100644 index 0000000..f0bf378 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_hs.lua @@ -0,0 +1,45 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.hs$" }, + comment = "%-%-", + patterns = { + { pattern = {"%-%-", "\n"}, type = "comment" }, + { pattern = { "{%-", "%-}" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[!%#%$%%&*+./%<=>%?@\\%^|%-~:]", type = "operator" }, + { pattern = "[%a_'][%w_']*", type = "symbol" }, + }, + symbols = { + ["as"] = "keyword", + ["case"] = "keyword", + ["of"] = "keyword", + ["class"] = "keyword", + ["data"] = "keyword", + ["default"] = "keyword", + ["deriving"] = "keyword", + ["do"] = "keyword", + ["forall"] = "keyword", + ["foreign"] = "keyword", + ["hiding"] = "keyword", + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["import"] = "keyword", + ["infix"] = "keyword", + ["infixl"] = "keyword", + ["infixr"] = "keyword", + ["let"] = "keyword", + ["in"] = "keyword", + ["mdo"] = "keyword", + ["module"] = "keyword", + ["newtype"] = "keyword", + ["qualified"] = "keyword", + ["type"] = "keyword", + ["where"] = "keyword", + }, +} diff --git a/vendor/lite-plugins/plugins/language_java.lua b/vendor/lite-plugins/plugins/language_java.lua new file mode 100644 index 0000000..1d9e12d --- /dev/null +++ b/vendor/lite-plugins/plugins/language_java.lua @@ -0,0 +1,75 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.java$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "'\\x%x?%x?%x?%x'", type = "string" }, -- character hexadecimal escape sequence + { pattern = "'\\u%x%x%x%x'", type = "string" }, -- character unicode escape sequence + { pattern = "'\\?.'", type = "string" }, -- character literal + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["else if"] = "keyword", + ["do"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["new"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["goto"] = "keyword", + ["class"] = "keyword", + ["implements"] = "keyword", + ["extends"] = "keyword", + ["private"] = "keyword", + ["protected"] = "keyword", + ["public"] = "keyword", + ["abstract"] = "keyword", + ["interface"] = "keyword", + ["assert"] = "keyword", + ["import"] = "keyword", + ["native"] = "keyword", + ["package"] = "keyword", + ["super"] = "keyword", + ["synchronized"] = "keyword", + ["instanceof"] = "keyword", + ["enum"] = "keyword", + ["catch"] = "keyword", + ["throw"] = "keyword", + ["throws"] = "keyword", + ["try"] = "keyword", + ["transient"] = "keyword", + ["finally"] = "keyword", + ["static"] = "keyword", + ["volatile"] = "keyword", + ["final"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["void"] = "keyword", + ["int"] = "keyword2", + ["short"] = "keyword2", + ["byte"] = "keyword2", + ["long"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["char"] = "keyword2", + ["boolean"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + }, +} diff --git a/vendor/lite-plugins/plugins/language_jiyu.lua b/vendor/lite-plugins/plugins/language_jiyu.lua new file mode 100644 index 0000000..1cf94dc --- /dev/null +++ b/vendor/lite-plugins/plugins/language_jiyu.lua @@ -0,0 +1,91 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.jiyu$", "%.jyu$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "\"\"\"", "\"\"\"" }, type = "string" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "0b[0-1]+", type = "number" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.]*", type = "number" }, + { pattern = "-?%.?%d+?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[<>~=+-*/]=", type = "operator" }, + { pattern = "[..]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[#@]?[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + -- Keywords + ["func"] = "keyword", + ["if"] = "keyword", + ["else"] = "keyword", + ["for"] = "keyword", + ["while"] = "keyword", + ["defer"] = "keyword", + ["return"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["fallthrough"] = "keyword", + ["struct"] = "keyword", + ["union"] = "keyword", + ["enum"] = "keyword", + ["using"] = "keyword", + ["var"] = "keyword", + ["let"] = "keyword", + ["typealias"] = "keyword", + ["library"] = "keyword", + ["framework"] = "keyword", + ["temporary_c_vararg"] = "keyword2"; + -- Builtin procedures and directives + ["cast"] = "keyword2", + ["sizeof"] = "keyword2", + ["alignof"] = "keyword2", + ["strideof"] = "keyword2", + ["offsetof"] = "keyword2", + ["type_of"] = "keyword2", + ["type_info"] = "keyword2", + ["#if"] = "keyword2", + ["#load"] = "keyword2", + ["#import"] = "keyword2", + ["#clang_import"] = "keyword2", + ["#file"] = "keyword2", + ["#filepath"] = "keyword2", + ["#line"] = "keyword2", + + ["@c_function"] = "keyword2", + ["@export"] = "keyword2", + ["@flags"] = "keyword2", + ["@metaprogram"] = "keyword2", + -- Types + ["string"] = "keyword2", + ["int"] = "keyword2", + ["uint"] = "keyword2", + ["uint8"] = "keyword2", + ["uint16"] = "keyword2", + ["uint32"] = "keyword2", + ["uint64"] = "keyword2", + ["uint128"] = "keyword2", + ["int8"] = "keyword2", + ["int16"] = "keyword2", + ["int32"] = "keyword2", + ["int64"] = "keyword2", + ["int128"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["void"] = "keyword2", + ["bool"] = "keyword2", + ["Type"] = "keyword2", + + -- Literals + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + } +} diff --git a/vendor/lite-plugins/plugins/language_make.lua b/vendor/lite-plugins/plugins/language_make.lua new file mode 100644 index 0000000..f586a05 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_make.lua @@ -0,0 +1,17 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "Makefile", "makefile", "%.mk$" }, + comment = "#", + patterns = { + { pattern = "#.*\n", type = "comment" }, + { pattern = [[\.]], type = "normal" }, + { pattern = "$[@^<%%?+|*]", type = "keyword2" }, + { pattern = "$%(.-%)", type = "variable" }, + { pattern = "%f[%w_][%d%.]+%f[^%w_]", type = "number" }, + { pattern = "%..*:", type = "keyword2" }, + { pattern = ".*:", type = "function" }, + }, + symbols = { + }, +} diff --git a/vendor/lite-plugins/plugins/language_meson.lua b/vendor/lite-plugins/plugins/language_meson.lua new file mode 100644 index 0000000..ab6be17 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_meson.lua @@ -0,0 +1,35 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "meson.build$", + comment = "#", + patterns = { + { pattern = { "#", "\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { "'''", "'''" }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+%d*", type = "number" }, + { pattern = "[%+%-=/%%%*!]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["elif"] = "keyword", + ["endif"] = "keyword", + ["foreach"] = "keyword", + ["endforeach"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["and"] = "keyword", + ["not"] = "keyword", + ["or"] = "keyword", + ["in"] = "keyword", + ["true"] = "literal", + ["false"] = "literal", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_odin.lua b/vendor/lite-plugins/plugins/language_odin.lua new file mode 100644 index 0000000..fb60a6c --- /dev/null +++ b/vendor/lite-plugins/plugins/language_odin.lua @@ -0,0 +1,157 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.odin$", + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { "`", "`" }, type = "string" }, + { pattern = "0b[01_]+", type = "number" }, + { pattern = "0o[0-7_]+", type = "number" }, + { pattern = "0[dz][%d_]+", type = "number" }, + { pattern = "0x[%da-fA-F_]+", type = "number" }, + { pattern = "-?%d+[%d%._e]*i?", type = "number" }, + { pattern = "-?%.?[%d_]+i?", type = "number" }, + { pattern = "[<>~=+-*/]=", type = "operator" }, + { pattern = "[::][:=]", type = "operator" }, + { pattern = "[%+%-=/%*%^%%<>!~|&:]", type = "operator" }, + { pattern = "%$[%a_][%w_]*", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[#@]?[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + -- Keywords + ["package"] = "keyword", + ["import"] = "keyword", + ["foreign"] = "keyword", + ["when"] = "keyword", + ["if"] = "keyword", + ["else"] = "keyword", + ["for"] = "keyword", + ["defer"] = "keyword", + ["return"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["in"] = "keyword", + ["notin"] = "keyword", + ["do"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["fallthrough"] = "keyword", + ["proc"] = "keyword", + ["struct"] = "keyword", + ["union"] = "keyword", + ["enum"] = "keyword", + ["bit_set"] = "keyword", + ["map"] = "keyword", + ["dynamic"] = "keyword", + ["using"] = "keyword", + ["inline"] = "keyword", + ["no_inline"] = "keyword", + ["context"] = "keyword", + ["distinct"] = "keyword", + ["opaque"] = "keyword", + ["macro"] = "keyword", -- Reserved, not yet used + ["const"] = "keyword", -- Reserved, not yet used + -- Builtin procedures and directives + ["cast"] = "keyword2", + ["auto_cast"] = "keyword2", + ["transmute"] = "keyword2", + ["len"] = "keyword2", + ["cap"] = "keyword2", + ["size_of"] = "keyword2", + ["align_of"] = "keyword2", + ["offset_of"] = "keyword2", + ["typeid_of"] = "keyword2", + ["type_of"] = "keyword2", + ["type_info_of"] = "keyword2", + ["type_info_base"] = "keyword2", + ["swizzle"] = "keyword2", + ["complex"] = "keyword2", + ["real"] = "keyword2", + ["imag"] = "keyword2", + ["conj"] = "keyword2", + ["min"] = "keyword2", + ["max"] = "keyword2", + ["abs"] = "keyword2", + ["clamp"] = "keyword2", + ["assert"] = "keyword2", + ["#assert"] = "keyword2", + ["#location"] = "keyword2", + ["#caller_location"] = "keyword2", + ["#packed"] = "keyword2", + ["#raw_union"] = "keyword2", + ["#align"] = "keyword2", + ["#no_nil"] = "keyword2", + ["#complete"] = "keyword2", + ["#no_alias"] = "keyword2", + ["#align"] = "keyword2", + ["#load"] = "keyword2", + ["#location"] = "keyword2", + ["#file"] = "keyword2", + ["#line"] = "keyword2", + ["#procedure"] = "keyword2", + ["#defined"] = "keyword2", + ["#no_bounds_check"] = "keyword2", + ["#bounds_check"] = "keyword2", + ["#type"] = "keyword2", + ["@private"] = "keyword2", + -- Types + ["rawptr"] = "keyword2", + ["typeid"] = "keyword2", + ["any"] = "keyword2", + ["string"] = "keyword2", + ["cstring"] = "keyword2", + ["int"] = "keyword2", + ["uint"] = "keyword2", + ["uintptr"] = "keyword2", + ["rune"] = "keyword2", + ["byte"] = "keyword2", + ["u8"] = "keyword2", + ["u16"] = "keyword2", + ["u32"] = "keyword2", + ["u64"] = "keyword2", + ["u128"] = "keyword2", + ["i8"] = "keyword2", + ["i16"] = "keyword2", + ["i32"] = "keyword2", + ["i64"] = "keyword2", + ["i128"] = "keyword2", + ["f16"] = "keyword2", + ["f32"] = "keyword2", + ["f64"] = "keyword2", + ["u16le"] = "keyword2", + ["u32le"] = "keyword2", + ["u64le"] = "keyword2", + ["u128le"] = "keyword2", + ["i16le"] = "keyword2", + ["i32le"] = "keyword2", + ["i64le"] = "keyword2", + ["i128le"] = "keyword2", + ["u16be"] = "keyword2", + ["u32be"] = "keyword2", + ["u64be"] = "keyword2", + ["u128be"] = "keyword2", + ["i16be"] = "keyword2", + ["i32be"] = "keyword2", + ["i64be"] = "keyword2", + ["i128be"] = "keyword2", + ["complex32"] = "keyword2", + ["complex64"] = "keyword2", + ["complex128"] = "keyword2", + ["quaternion128"] = "keyword2", + ["quaternion256"] = "keyword2", + ["bool"] = "keyword2", + ["b8"] = "keyword2", + ["b32"] = "keyword2", + ["b64"] = "keyword2", + ["b128"] = "keyword2", + -- Literals + ["true"] = "literal", + ["false"] = "literal", + ["nil"] = "literal", + } +} diff --git a/vendor/lite-plugins/plugins/language_php.lua b/vendor/lite-plugins/plugins/language_php.lua new file mode 100644 index 0000000..d6ed516 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_php.lua @@ -0,0 +1,99 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.php$", "%.phtml" }, + headers = "^<%?php", + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = "#.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + -- I dont know why the '//' are needed but I leave it here for now + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "%\\x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "[%.%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + -- To indicate variables. + { pattern = "%$", type = "operator" }, + }, + symbols = { + ["return"] = "keyword", + ["if"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["endif"] = "keyword", + ["declare"] = "keyword", + ["enddeclare"] = "keyword", + ["switch"] = "keyword", + ["endswitch"] = "keyword", + ["as"] = "keyword", + ["do"] = "keyword", + ["for"] = "keyword", + ["endfor"] = "keyword", + ["foreach"] = "keyword", + ["endforeach"] = "keyword", + ["while"] = "keyword", + ["endwhile"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["continue"] = "keyword", + ["default"] = "keyword", + ["break"] = "keyword", + ["exit"] = "keyword", + ["goto"] = "keyword", + + ["catch"] = "keyword", + ["throw"] = "keyword", + ["try"] = "keyword", + ["finally"] = "keyword", + + ["class"] = "keyword", + ["trait"] = "keyword", + ["interface"] = "keyword", + ["public"] = "keyword", + ["static"] = "keyword", + ["protected"] = "keyword", + ["private"] = "keyword", + ["abstract"] = "keyword", + ["final"] = "keyword", + + ["function"] = "keyword2", + ["global"] = "keyword2", + ["var"] = "keyword2", + ["const"] = "keyword2", + ["bool"] = "keyword2", + ["boolean"] = "keyword2", + ["int"] = "keyword2", + ["integer"] = "keyword2", + ["real"] = "keyword2", + ["double"] = "keyword2", + ["float"] = "keyword2", + ["string"] = "keyword2", + ["array"] = "keyword2", + ["object"] = "keyword2", + ["callable"] = "keyword2", + ["iterable"] = "keyword2", + + ["namespace"] = "keyword2", + ["extends"] = "keyword2", + ["implements"] = "keyword2", + ["instanceof"] = "keyword2", + ["require"] = "keyword2", + ["require_once"] = "keyword2", + ["include"] = "keyword2", + ["include_once"] = "keyword2", + ["use"] = "keyword2", + ["new"] = "keyword2", + ["clone"] = "keyword2", + + ["true"] = "literal", + ["false"] = "literal", + ["NULL"] = "literal", + ["parent"] = "literal", + ["self"] = "literal", + }, +} diff --git a/vendor/lite-plugins/plugins/language_pico8.lua b/vendor/lite-plugins/plugins/language_pico8.lua new file mode 100644 index 0000000..8edf92f --- /dev/null +++ b/vendor/lite-plugins/plugins/language_pico8.lua @@ -0,0 +1,51 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.p8$", + headers = "^pico-8 cartridge", + comment = "--", + patterns = { + { pattern = { 'pico%-8 cartridge', '__lua__' }, type = "comment" }, + { pattern = { '__gfx__\n', '%z' }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { "%[%[", "%]%]" }, type = "string" }, + { pattern = { "%-%-%[%[", "%]%]"}, type = "comment" }, + { pattern = "%-%-.-\n", type = "comment" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "%.%.%.?", type = "operator" }, + { pattern = "[<>~=&|]=", type = "operator" }, + { pattern = "[%+%-=/%*%^%%#<>]", type = "operator" }, + { pattern = "[%a_][%w_]*%s*%f[(\"{]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + { pattern = "::[%a_][%w_]*::", type = "function" }, + }, + symbols = { + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["end"] = "keyword", + ["do"] = "keyword", + ["function"] = "keyword", + ["repeat"] = "keyword", + ["until"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["break"] = "keyword", + ["return"] = "keyword", + ["local"] = "keyword", + ["in"] = "keyword", + ["not"] = "keyword", + ["and"] = "keyword", + ["or"] = "keyword", + ["goto"] = "keyword", + ["self"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["nil"] = "literal", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_powershell.lua b/vendor/lite-plugins/plugins/language_powershell.lua new file mode 100644 index 0000000..01c00f4 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_powershell.lua @@ -0,0 +1,72 @@ +local syntax = require "core.syntax" + +syntax.add { + files = {"%.ps1$", "%.psm1$", "%.psd1$", "%.ps1xml$", "%.pssc$", "%.psrc$", "%.cdxml$"}, + comment = "#", + patterns = { + {pattern = "#.*\n", type = "comment"}, + {pattern = [[\.]], type = "normal"}, + {pattern = {'"', '"'}, type = "string"}, + {pattern = {"'", "'"}, type = "string"}, + {pattern = "%f[%w_][%d%.]+%f[^%w_]", type = "number"}, + {pattern = "[%+=/%*%^%%<>!~|&,:]+", type = "operator"}, + {pattern = "%f[%S]%-[%w%-_]+", type = "function"}, + {pattern = "[%u][%a]+[%-][%u][%a]+", type = "function"}, + {pattern = "${.*}", type = "symbol"}, + {pattern = "$[%a_@*][%w_]*", type = "keyword2"}, + {pattern = "$[%$][%a]+", type = "keyword2"}, + {pattern = "[%a_][%w_]*", type = "symbol"} + }, + symbols = { + ["if"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["switch"] = "keyword", + ["default"] = "keyword", + ["function"] = "keyword", + ["filter"] = "keyword", + ["workflow"] = "keyword", + ["configuration"] = "keyword", + ["class"] = "keyword", + ["enum"] = "keyword", + ["Parameter"] = "keyword", + ["ValidateScript"] = "keyword", + ["CmdletBinding"] = "keyword", + ["try"] = "keyword", + ["catch"] = "keyword", + ["finally"] = "keyword", + ["throw"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["do"] = "keyword", + ["until"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["foreach"] = "keyword", + ["in"] = "keyword", + ["return"] = "keyword", + ["where"] = "function", + ["select"] = "function", + ["filter"] = "keyword", + ["in"] = "keyword", + ["trap"] = "keyword", + ["param"] = "keyword", + ["data"] = "keyword", + ["dynamicparam"] = "keyword", + ["begin"] = "function", + ["process"] = "function", + ["end"] = "function", + ["exit"] = "function", + ["inlinescript"] = "function", + ["parallel"] = "function", + ["sequence"] = "function", + ["true"] = "literal", + ["false"] = "literal", + ["TODO"] = "comment", + ["FIXME"] = "comment", + ["XXX"] = "comment", + ["TBD"] = "comment", + ["HACK"] = "comment", + ["NOTE"] = "comment" + } +} diff --git a/vendor/lite-plugins/plugins/language_psql.lua b/vendor/lite-plugins/plugins/language_psql.lua new file mode 100644 index 0000000..7c6c4b7 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_psql.lua @@ -0,0 +1,90 @@ +local syntax = require "core.syntax" + +-- In sql symbols can be lower case and upper case +local keywords = { + "CREATE", "SELECT", "INSERT", "INTO", "UPDATE", + "DELETE", "TABLE", "DROP", "VALUES", "NOT", + "NULL", "PRIMARY", "KEY", "REFERENCES", + "DEFAULT", "UNIQUE", "CONSTRAINT", "CHECK", + "ON", "EXCLUDE", "WITH", "USING", "WHERE", + "GROUP", "BY", "HAVING", "DISTINCT", "LIMIT", + "OFFSET", "ONLY", "CROSS", "JOIN", "INNER", + "LEFT", "RIGHT", "FULL", "OUTER", "NATURAL", + "AND", "OR", "AS", "ORDER", "ORDINALITY", + "UNNEST", "FROM", "VIEW", "RETURNS", "SETOF", + "LANGUAGE", "SQL", "LIKE", "LATERAL", + "INTERVAL", "PARTITION", "UNION", "INTERSECT", + "EXCEPT", "ALL", "ASC", "DESC", "NULLS", + "FIRST", "LAST", "IN", "RECURSIVE", "ARRAY", + "RETURNING", "SET", "ALSO", "INSTEAD", + "ALTER", "SEQUENCE", "OWNED", "AT", "ZONE", + "WITHOUT", "TO", "TIMEZONE", "TYPE", "ENUM", + "DOCUMENT", "XMLPARSE", "XMLSERIALIZE", + "CONTENT", "OPTION", "INDEX", "ANY", + "EXTENSION", "ISNULL", "NOTNULL", "UNKNOWN", + "CASE", "THEN", "WHEN", "ELSE", "END", + "ROWS", "BETWEEN", "UNBOUNDED", "PRECEDING", + "UNBOUNDED", "FOLLOWING", "EXISTS", "SOME", + "COLLATION", "FOR", "TRIGGER", "BEFORE", + "EACH", "ROW", "EXECUTE", "PROCEDURE", + "FUNCTION", "DECLARE", "BEGIN", "LOOP", + "RAISE", "NOTICE", "LOOP", "EVENT", + "OPERATOR", "DOMAIN", "VARIADIC", "FOREIGN" +} + +local types = { + "BIGINT", "INT8", "BIGSERIAL", "SERIAL8", + "BIT", "VARBIT", "BOOLEAN", "BOOL", "BOX", + "BYTEA", "CHARACTER", "CHAR", "VARCHAR", + "CIDR", "CIRCLE", "DATE", "DOUBLE", + "PRECISION", "FLOAT8", "INET", "INTEGER", + "INT", "INT4", "INTERVAL", "JSON", "JSONB", + "LINE", "LSEG", "MACADDR", "MONEY", "NUMERIC", + "DECIMAL", "PATH", "POINT", "POLYGON", "REAL", + "FLOAT4", "INT2", "SMALLINT", "SMALLSERIAL", + "SERIAL2", "SERIAL", "SERIAL4", "TEXT", + "TIME", "TIMEZ", "TIMESTAMP", "TIMESTAMPZ", + "TSQUERY", "TSVECTOR", "TXID_SNAPSHOT", + "UUID", "XML", "INT4RANGE", "INT8RANGE", + "NUMRANGE", "TSRANGE", "TSTZRANGE", + "DATERANGE", "PG_LSN" +} + +local literals = { + "FALSE", "TRUE", "CURRENT_TIMESTAMP", + "CURRENT_TIME", "CURRENT_DATE", "LOCALTIME", + "LOCALTIMESTAMP" +} + +local symbols = {} +for _, keyword in ipairs(keywords) do + symbols[keyword:lower()] = "keyword" + symbols[keyword] = "keyword" +end + +for _, type in ipairs(types) do + symbols[type:lower()] = "keyword2" + symbols[type] = "keyword2" +end + +for _, literal in ipairs(literals) do + symbols[literal:lower()] = "literal" + symbols[literal] = "literal" +end + +syntax.add { + files = { "%.sql$", "%.psql$" }, + comment = "--", + patterns = { + { pattern = "%-%-.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%%<>!~|&@%?$#]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = symbols, +} + diff --git a/vendor/lite-plugins/plugins/language_rust.lua b/vendor/lite-plugins/plugins/language_rust.lua new file mode 100644 index 0000000..321efc2 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_rust.lua @@ -0,0 +1,84 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.rs$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "`", "`", '\\' }, type = "string" }, + { pattern = "0[oO_][0-7]+", type = "number" }, + { pattern = "-?0x[%x_]+", type = "number" }, + { pattern = "-?%d+_%d", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["as"] = "keyword", + ["async"] = "keyword", + ["await"] = "keyword", + ["break"] = "keyword", + ["const"] = "keyword", + ["continue"] = "keyword", + ["crate"] = "keyword", + ["dyn"] = "keyword", + ["else"] = "keyword", + ["enum"] = "keyword", + ["extern"] = "keyword", + ["false"] = "keyword", + ["fn"] = "keyword", + ["for"] = "keyword", + ["if"] = "keyword", + ["impl"] = "keyword", + ["in"] = "keyword", + ["let"] = "keyword", + ["loop"] = "keyword", + ["match"] = "keyword", + ["mod"] = "keyword", + ["move"] = "keyword", + ["mut"] = "keyword", + ["pub"] = "keyword", + ["ref"] = "keyword", + ["return"] = "keyword", + ["Self"] = "keyword", + ["self"] = "keyword", + ["static"] = "keyword", + ["struct"] = "keyword", + ["super"] = "keyword", + ["trait"] = "keyword", + ["true"] = "keyword", + ["type"] = "keyword", + ["unsafe"] = "keyword", + ["use"] = "keyword", + ["where"] = "keyword", + ["while"] = "keyword", + ["i32"] = "keyword2", + ["i64"] = "keyword2", + ["i128"] = "keyword2", + ["i16"] = "keyword2", + ["i8"] = "keyword2", + ["u16"] = "keyword2", + ["u32"] = "keyword2", + ["u64"] = "keyword2", + ["usize"] = "keyword2", + ["isize"] = "keyword2", + ["f32"] = "keyword2", + ["f64"] = "keyword2", + ["f128"] = "keyword2", + ["String"] = "keyword2", + ["&str"] = "keyword2", + ["bool"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["None"] = "literal", + ["Some"] = "literal", + ["Option"] = "literal", + ["Result"] = "literal", + }, +} + + diff --git a/vendor/lite-plugins/plugins/language_sh.lua b/vendor/lite-plugins/plugins/language_sh.lua new file mode 100644 index 0000000..c4153c2 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_sh.lua @@ -0,0 +1,42 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.sh$" }, + headers = "^#!.*bin.*sh\n", + comment = "#", + patterns = { + { pattern = "#.*\n", type = "comment" }, + { pattern = [[\.]], type = "normal" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { '`', '`', '\\' }, type = "string" }, + { pattern = "%f[%w_][%d%.]+%f[^%w_]", type = "number" }, + { pattern = "[!<>|&%[%]=*]", type = "operator" }, + { pattern = "%f[%S]%-[%w%-_]+", type = "function" }, + { pattern = "${.*}", type = "keyword2" }, + { pattern = "$[%a_@*][%w_]*", type = "keyword2" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["case"] = "keyword", + ["do"] = "keyword", + ["done"] = "keyword", + ["elif"] = "keyword", + ["else"] = "keyword", + ["esac"] = "keyword", + ["fi"] = "keyword", + ["for"] = "keyword", + ["function"] = "keyword", + ["if"] = "keyword", + ["in"] = "keyword", + ["select"] = "keyword", + ["then"] = "keyword", + ["time"] = "keyword", + ["until"] = "keyword", + ["while"] = "keyword", + ["echo"] = "keyword", + ["true"] = "literal", + ["false"] = "literal", + }, +} + diff --git a/vendor/lite-plugins/plugins/language_tex.lua b/vendor/lite-plugins/plugins/language_tex.lua new file mode 100644 index 0000000..eced489 --- /dev/null +++ b/vendor/lite-plugins/plugins/language_tex.lua @@ -0,0 +1,16 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.tex$" }, + comment = "%%", + patterns = { + { pattern = {"%%", "\n"}, type = "comment" }, + { pattern = "&", type = "operator" }, + { pattern = "\\\\", type = "operator" }, + { pattern = {"%$", "%$"}, type = "operator" }, + { pattern = {"\\%[", "\\]"}, type = "operator" }, + { pattern = {"{", "}"}, type = "keyword" }, + { pattern = "\\%w*", type = "keyword2" }, + }, + symbols = {} +} diff --git a/vendor/lite-plugins/plugins/language_wren.lua b/vendor/lite-plugins/plugins/language_wren.lua new file mode 100644 index 0000000..ccd53db --- /dev/null +++ b/vendor/lite-plugins/plugins/language_wren.lua @@ -0,0 +1,43 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.wren$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "%.%.%.?", type = "operator" }, + { pattern = "[<>!=]=", type = "operator" }, + { pattern = "[%+%-=/%*%^%%<>!~|&?:]", type = "operator" }, + { pattern = "[%a_][%w_]*%s*%f[(\"{]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["break"] = "keyword", + ["class"] = "keyword", + ["construct"] = "keyword", + ["else"] = "keyword", + ["false"] = "keyword", + ["for"] = "keyword", + ["foreign"] = "keyword", + ["if"] = "keyword", + ["import"] = "keyword", + ["in"] = "keyword", + ["is"] = "keyword", + ["null"] = "keyword", + ["return"] = "keyword", + ["static"] = "keyword", + ["super"] = "keyword", + ["this"] = "keyword", + ["true"] = "keyword", + ["var"] = "keyword", + ["while"] = "keyword", + ["this"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + }, +} \ No newline at end of file diff --git a/vendor/lite-plugins/plugins/lastproject.lua b/vendor/lite-plugins/plugins/lastproject.lua new file mode 100644 index 0000000..09ca507 --- /dev/null +++ b/vendor/lite-plugins/plugins/lastproject.lua @@ -0,0 +1,26 @@ +local core = require "core" + +local last_project_filename = EXEDIR .. PATHSEP .. ".lite_last_project" + + +-- load last project path +local fp = io.open(last_project_filename) +local project_path +if fp then + project_path = fp:read("*a") + fp:close() +end + + +-- save current project path +local fp = io.open(last_project_filename, "w") +fp:write(system.absolute_path ".") +fp:close() + + +-- restart using last project path if we had no commandline arguments and could +-- find a last-project file +if #ARGS == 1 and project_path then + system.exec(string.format("%s %q", EXEFILE, project_path)) + core.quit(true) +end diff --git a/vendor/lite-plugins/plugins/lfautoinsert.lua b/vendor/lite-plugins/plugins/lfautoinsert.lua new file mode 100644 index 0000000..0ea7b9d --- /dev/null +++ b/vendor/lite-plugins/plugins/lfautoinsert.lua @@ -0,0 +1,64 @@ +local core = require "core" +local command = require "core.command" +local config = require "core.config" +local keymap = require "core.keymap" + +config.lfautoinsert_map = { + ["{%s*\n"] = "}", + ["%(%s*\n"] = ")", + ["%f[[]%[%s*\n"] = "]", + ["%[%[%s*\n"] = "]]", + ["=%s*\n"] = false, + [":%s*\n"] = false, + ["^#if.*\n"] = "#endif", + ["^#else.*\n"] = "#endif", + ["%f[%w]do%s*\n"] = "end", + ["%f[%w]then%s*\n"] = "end", + ["%f[%w]else%s*\n"] = "end", + ["%f[%w]repeat%s*\n"] = "until", + ["%f[%w]function.*%)%s*\n"] = "end", + ["^%s*<([^/][^%s>]*)[^>]*>%s*\n"] = "", +} + + +local function indent_size(doc, line) + local text = doc.lines[line] or "" + local s, e = text:find("^[\t ]*") + return e - s +end + +command.add("core.docview", { + ["autoinsert:newline"] = function() + command.perform("doc:newline") + + local doc = core.active_view.doc + local line, col = doc:get_selection() + local text = doc.lines[line - 1] + + for ptn, close in pairs(config.lfautoinsert_map) do + local s, _, str = text:find(ptn) + if s then + if close + and col == #doc.lines[line] + and indent_size(doc, line + 1) <= indent_size(doc, line - 1) + then + close = str and close:gsub("$TEXT", str) or close + command.perform("doc:newline") + core.active_view:on_text_input(close) + command.perform("doc:move-to-previous-line") + if doc.lines[line+1] == doc.lines[line+2] then + doc:remove(line+1, 1, line+2, 1) + end + elseif col < #doc.lines[line] then + command.perform("doc:newline") + command.perform("doc:move-to-previous-line") + end + command.perform("doc:indent") + end + end + end +}) + +keymap.add { + ["return"] = { "command:submit", "autoinsert:newline" } +} diff --git a/vendor/lite-plugins/plugins/linecopypaste.lua b/vendor/lite-plugins/plugins/linecopypaste.lua new file mode 100755 index 0000000..eb6f375 --- /dev/null +++ b/vendor/lite-plugins/plugins/linecopypaste.lua @@ -0,0 +1,45 @@ +local core = require "core" +local command = require "core.command" + +local function doc() + return core.active_view.doc +end + +local line_in_clipboard = false + +local doc_copy = command.map["doc:copy"].perform +command.map["doc:copy"].perform = function() + if doc():has_selection() then + doc_copy() + line_in_clipboard = false + else + local line = doc():get_selection() + system.set_clipboard(doc().lines[line]) + line_in_clipboard = true + end +end + +local doc_cut = command.map["doc:cut"].perform +command.map["doc:cut"].perform = function() + if doc():has_selection() then + doc_cut() + line_in_clipboard = false + else + local line = doc():get_selection() + system.set_clipboard(doc().lines[line]) + doc():remove(line, 1, line+1, 1) + doc():set_selection(line, 1) + line_in_clipboard = true + end +end + +local doc_paste = command.map["doc:paste"].perform +command.map["doc:paste"].perform = function() + if line_in_clipboard == false then + doc_paste() + else + local line, col = doc():get_selection() + doc():insert(line, 1, system.get_clipboard():gsub("\r", "")) + doc():set_selection(line+1, col) + end +end diff --git a/vendor/lite-plugins/plugins/lineguide.lua b/vendor/lite-plugins/plugins/lineguide.lua new file mode 100644 index 0000000..fc24567 --- /dev/null +++ b/vendor/lite-plugins/plugins/lineguide.lua @@ -0,0 +1,18 @@ +local config = require "core.config" +local style = require "core.style" +local DocView = require "core.docview" + +local draw = DocView.draw + +function DocView:draw(...) + draw(self, ...) + + local offset = self:get_font():get_width("n") * config.line_limit + local x = self:get_line_screen_position(1) + offset + local y = self.position.y + local w = math.ceil(SCALE * 1) + local h = self.size.y + + local color = style.guide or style.selection + renderer.draw_rect(x, y, w, h, color) +end diff --git a/vendor/lite-plugins/plugins/macmodkeys.lua b/vendor/lite-plugins/plugins/macmodkeys.lua new file mode 100644 index 0000000..69028ab --- /dev/null +++ b/vendor/lite-plugins/plugins/macmodkeys.lua @@ -0,0 +1,18 @@ +local keymap = require "core.keymap" + +local on_key_pressed = keymap.on_key_pressed +local on_key_released = keymap.on_key_released + +local function remap_key(k) + return k:gsub("command", "ctrl") + :gsub("option", "alt") +end + +function keymap.on_key_pressed(k) + return on_key_pressed(remap_key(k)) +end + +function keymap.on_key_released(k) + return on_key_released(remap_key(k)) +end + diff --git a/vendor/lite-plugins/plugins/markers.lua b/vendor/lite-plugins/plugins/markers.lua new file mode 100644 index 0000000..6e397d7 --- /dev/null +++ b/vendor/lite-plugins/plugins/markers.lua @@ -0,0 +1,103 @@ +-- Markers plugin for lite text editor +-- original implementation by Petri Häkkinen + +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" +local style = require "core.style" +local DocView = require "core.docview" +local Doc = require "core.doc" + +local cache = {} -- this table contains subtables for each document, each subtable is a set of line numbers +setmetatable(cache, { + __mode = "k", + __index = function(t, k) + t[k] = {} + return t[k] + end, +}) + + +local function shift_lines(doc, at, diff) + if diff == 0 then return end + local t = {} + for line in pairs(cache[doc]) do + line = line >= at and line + diff or line + t[line] = true + end + cache[doc] = t +end + + +local raw_insert = Doc.raw_insert + +function Doc:raw_insert(line, col, text, ...) + raw_insert(self, line, col, text, ...) + local line_count = 0 + for _ in text:gmatch("\n") do + line_count = line_count + 1 + end + shift_lines(self, line, line_count) +end + + +local raw_remove = Doc.raw_remove + +function Doc:raw_remove(line1, col1, line2, col2, ...) + raw_remove(self, line1, col1, line2, col2, ...) + shift_lines(self, line2, line1 - line2) +end + + +local draw_line_gutter = DocView.draw_line_gutter + +function DocView:draw_line_gutter(idx, x, y) + if cache[self.doc] and cache[self.doc][idx] then + local h = self:get_line_height() + renderer.draw_rect(x, y, style.padding.x * 0.4, h, style.selection) + end + draw_line_gutter(self, idx, x, y) +end + + +command.add("core.docview", { + ["markers:toggle-marker"] = function() + local doc = core.active_view.doc + local line = doc:get_selection() + local markers = cache[doc] + + if markers[line] then + markers[line] = nil + else + markers[line] = true + end + end, + + ["markers:go-to-next-marker"] = function() + local doc = core.active_view.doc + local line = doc:get_selection() + local markers = cache[doc] + + local first_marker = math.huge + local next_marker = math.huge + for l, _ in pairs(markers) do + if l > line and l < next_marker then + next_marker = l + end + first_marker = math.min(first_marker, l) + end + if next_marker == math.huge then + next_marker = first_marker + end + if next_marker ~= math.huge then + doc:set_selection(next_marker, 1) + core.active_view:scroll_to_line(next_marker, true) + end + end, +}) + + +keymap.add { + ["ctrl+f2"] = "markers:toggle-marker", + ["f2"] = "markers:go-to-next-marker", +} diff --git a/vendor/lite-plugins/plugins/motiontrail.lua b/vendor/lite-plugins/plugins/motiontrail.lua new file mode 100644 index 0000000..e688e1b --- /dev/null +++ b/vendor/lite-plugins/plugins/motiontrail.lua @@ -0,0 +1,46 @@ +local core = require "core" +local config = require "core.config" +local style = require "core.style" +local DocView = require "core.docview" + +config.motiontrail_steps = 50 + + +local function lerp(a, b, t) + return a + (b - a) * t +end + + +local function get_caret_rect(dv) + local line, col = dv.doc:get_selection() + local x, y = dv:get_line_screen_position(line) + x = x + dv:get_col_x_offset(line, col) + return x, y, style.caret_width, dv:get_line_height() +end + + +local last_x, last_y, last_view + +local draw = DocView.draw + +function DocView:draw(...) + draw(self, ...) + if self ~= core.active_view then return end + + local x, y, w, h = get_caret_rect(self) + + if last_view == self and (x ~= last_x or y ~= last_y) then + local lx = x + for i = 0, 1, 1 / config.motiontrail_steps do + local ix = lerp(x, last_x, i) + local iy = lerp(y, last_y, i) + local iw = math.max(w, math.ceil(math.abs(ix - lx))) + renderer.draw_rect(ix, iy, iw, h, style.caret) + lx = ix + end + core.redraw = true + end + + last_view, last_x, last_y = self, x, y +end + diff --git a/vendor/lite-plugins/plugins/openfilelocation.lua b/vendor/lite-plugins/plugins/openfilelocation.lua new file mode 100644 index 0000000..58c3d6f --- /dev/null +++ b/vendor/lite-plugins/plugins/openfilelocation.lua @@ -0,0 +1,30 @@ +local core = require "core" +local command = require "core.command" +local config = require "core.config" + + +if PLATFORM == "Windows" then + config.filemanager = "explorer" +elseif PLATFORM == "Mac OS X" then + config.filemanager = "open" +else + config.filemanager = "xdg-open" +end + + +command.add("core.docview", { + ["open-file-location:open-file-location"] = function() + local doc = core.active_view.doc + if not doc.filename then + core.error "Cannot open location of unsaved doc" + return + end + local folder = doc.filename:match("^(.*)[/\\].*$") or "." + core.log("Opening \"%s\"", folder) + if PLATFORM == "Windows" then + system.exec(string.format("%s %s", config.filemanager, folder)) + else + system.exec(string.format("%s %q", config.filemanager, folder)) + end + end +}) diff --git a/vendor/lite-plugins/plugins/openselected.lua b/vendor/lite-plugins/plugins/openselected.lua new file mode 100644 index 0000000..65fdeb8 --- /dev/null +++ b/vendor/lite-plugins/plugins/openselected.lua @@ -0,0 +1,26 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + + +command.add("core.docview", { + ["open-selected:open-selected"] = function() + local doc = core.active_view.doc + if not doc:has_selection() then + core.error("No text selected") + return + end + + local text = doc:get_text(doc:get_selection()) + core.log("Opening \"%s\"...", text) + + if PLATFORM == "Windows" then + system.exec("start " .. text) + else + system.exec(string.format("xdg-open %q", text)) + end + end, +}) + + +keymap.add { ["ctrl+shift+o"] = "open-selected:open-selected" } diff --git a/vendor/lite-plugins/plugins/projectmanager.lua b/vendor/lite-plugins/plugins/projectmanager.lua new file mode 100644 index 0000000..b5a66e3 --- /dev/null +++ b/vendor/lite-plugins/plugins/projectmanager.lua @@ -0,0 +1,128 @@ +local project_manager = {} + +local core = require "core" +local command = require "core.command" +local common = require "core.common" +local keymap = require "core.keymap" + +local projects_file = ".lite_projects.lua" + +project_manager.projects = {} + +local function load_projects() + local ok, t = pcall(dofile, EXEDIR .. "/" .. projects_file) + if ok then project_manager.projects = t end +end + +load_projects() + +local function serialize(val) + if type(val) == "string" then + return string.format("%q", val) + elseif type(val) == "table" then + local t = {} + for k, v in pairs(val) do + table.insert(t, "[" .. serialize(k) .. "]=" .. serialize(v)) + end + return "{" .. table.concat(t, ",") .. "}" + end + return tostring(val) +end + +local function save_projects() + local fp = io.open(EXEDIR .. "/" .. projects_file, "w") + if fp then + fp:write("return ", serialize(project_manager.projects), "\n") + fp:close() + end +end + +local function path_base_name(str) + local pattern = "[\\/]?([^\\/]+)[\\/]?$" + return str:match(pattern) +end + +function project_manager.add_project() + local proj_dir = system.absolute_path(".") + local proj_name = path_base_name(proj_dir) + core.command_view:set_text(proj_name) + core.command_view:enter("Project Name", + function(text) + if text then + project_manager.projects[text] = proj_dir + save_projects() + end + end) +end + +local function get_project_names() + local t = {} + for k, v in pairs(project_manager.projects) do table.insert(t, k) end + return t +end + +local function project_lister(func) + local projects = get_project_names(); + core.command_view:enter("Open Project", func, function(text) + local res = common.fuzzy_match(projects, text) + for i, name in ipairs(res) do + res[i] = { + text = name, + info = project_manager.projects[name], + } + end + return res + end) +end + +function project_manager.rename_project(func) + project_lister(function(text, item) + if item then + core.command_view:set_text(item.text) + core.command_view:enter("Rename ".. item.text, + function(_text) + if _text then + project_manager.projects[_text] = project_manager.projects[item.text] + project_manager.projects[item.text] = nil + save_projects() + end + end) + end + end) +end + +function project_manager.open_project() + project_lister(function(text, item) + if item then + system.exec(string.format("%q %q", EXEFILE, item.info)) + end + end) +end + +function project_manager.switch_project() + project_lister(function(text, item) + if item then + system.exec(string.format("%q %q", EXEFILE, item.info)) + os.exit() + end + end) +end + +function project_manager.remove_project() + project_lister(function(text, item) + if item then + project_manager.projects[item.text] = nil + save_projects() + end + end) +end + +command.add(nil, { + ["project-manager:open-project"] = project_manager.open_project, + ["project-manager:switch-project"] = project_manager.switch_project, + ["project-manager:add-project"] = project_manager.add_project, + ["project-manager:remove-project"] = project_manager.remove_project, + ["project-manager:rename-project"] = project_manager.rename_project, + }) + +return project_manager diff --git a/vendor/lite-plugins/plugins/scale.lua b/vendor/lite-plugins/plugins/scale.lua new file mode 100644 index 0000000..5dfa699 --- /dev/null +++ b/vendor/lite-plugins/plugins/scale.lua @@ -0,0 +1,110 @@ +local core = require "core" +local common = require "core.common" +local command = require "core.command" +local config = require "core.config" +local keymap = require "core.keymap" +local style = require "core.style" +local RootView = require "core.rootview" +local CommandView = require "core.commandview" + +config.scale_mode = "code" +config.scale_use_mousewheel = true + +local font_cache = setmetatable({}, { __mode = "k" }) + +-- the following should be kept in sync with core.style's default font settings +font_cache[style.font] = { EXEDIR .. "/data/fonts/font.ttf", 14 * SCALE } +font_cache[style.big_font] = { EXEDIR .. "/data/fonts/font.ttf", 34 * SCALE } +font_cache[style.icon_font] = { EXEDIR .. "/data/fonts/icons.ttf", 14 * SCALE } +font_cache[style.code_font] = { EXEDIR .. "/data/fonts/monospace.ttf", 13.5 * SCALE } + + +local load_font = renderer.font.load +function renderer.font.load(...) + local res = load_font(...) + font_cache[res] = { ... } + return res +end + + +local function scale_font(font, s) + local fc = font_cache[font] + return renderer.font.load(fc[1], fc[2] * s) +end + + +local current_scale = SCALE +local default = current_scale + + +local function get_scale() return current_scale end + + +local function set_scale(scale) + scale = common.clamp(scale, 0.2, 6) + + -- save scroll positions + local scrolls = {} + for _, view in ipairs(core.root_view.root_node:get_children()) do + local n = view:get_scrollable_size() + if n ~= math.huge and not view:is(CommandView) then + scrolls[view] = view.scroll.y / (n - view.size.y) + end + end + + local s = scale / current_scale + current_scale = scale + + if config.scale_mode == "ui" then + SCALE = current_scale + + style.padding.x = style.padding.x * s + style.padding.y = style.padding.y * s + style.divider_size = style.divider_size * s + style.scrollbar_size = style.scrollbar_size * s + style.caret_width = style.caret_width * s + style.tab_width = style.tab_width * s + + style.big_font = scale_font(style.big_font, s) + style.icon_font = scale_font(style.icon_font, s) + style.font = scale_font(style.font, s) + end + + style.code_font = scale_font(style.code_font, s) + + -- restore scroll positions + for view, n in pairs(scrolls) do + view.scroll.y = n * (view:get_scrollable_size() - view.size.y) + view.scroll.to.y = view.scroll.y + end + + core.redraw = true +end + + +local on_mouse_wheel = RootView.on_mouse_wheel + +function RootView:on_mouse_wheel(d, ...) + if keymap.modkeys["ctrl"] and config.scale_use_mousewheel then + if d < 0 then command.perform "scale:decrease" end + if d > 0 then command.perform "scale:increase" end + else + return on_mouse_wheel(self, d, ...) + end +end + + +command.add(nil, { + ["scale:reset" ] = function() set_scale(default) end, + ["scale:decrease"] = function() set_scale(current_scale * 0.9) end, + ["scale:increase"] = function() set_scale(current_scale * 1.1) end, +}) + +keymap.add { + ["ctrl+0"] = "scale:reset", + ["ctrl+-"] = "scale:decrease", + ["ctrl+="] = "scale:increase", +} + +return { get_scale = get_scale, set_scale = set_scale } + diff --git a/vendor/lite-plugins/plugins/scalestatus.lua b/vendor/lite-plugins/plugins/scalestatus.lua new file mode 100644 index 0000000..03216b5 --- /dev/null +++ b/vendor/lite-plugins/plugins/scalestatus.lua @@ -0,0 +1,41 @@ +--[[ + scalestatus.lua + displays current scale (zoom) in status view + version: 20200628_155804 + originally by SwissalpS + + Depends on plugin scale.lua version >= 20200628_154010 +--]] +local scale = require "plugins.scale" +-- make sure plugin is installed and has get_scale field +if not scale.get_scale then + local core = require "core" + core.error("Plugin 'scale' needs to be updated, scalestatus inactive.") + return false +end + +local config = require "core.config" +local StatusView = require "core.statusview" + +config.scalestatus_format = '%.0f%%' + +local get_items = StatusView.get_items +function StatusView:get_items() + + local left, right = get_items(self) + + local t = { + self.separator, + string.format(config.scalestatus_format, scale.get_scale() * 100), + } + + for _, item in ipairs(t) do + table.insert(right, item) + end + + return left, right + +end + +return true + diff --git a/vendor/lite-plugins/plugins/selectionhighlight.lua b/vendor/lite-plugins/plugins/selectionhighlight.lua new file mode 100644 index 0000000..93dfe17 --- /dev/null +++ b/vendor/lite-plugins/plugins/selectionhighlight.lua @@ -0,0 +1,37 @@ +local style = require "core.style" +local DocView = require "core.docview" + +-- originally written by luveti + +local function draw_box(x, y, w, h, color) + local r = renderer.draw_rect + local s = math.ceil(SCALE) + r(x, y, w, s, color) + r(x, y + h - s, w, s, color) + r(x, y + s, s, h - s * 2, color) + r(x + w - s, y + s, s, h - s * 2, color) +end + + +local draw_line_body = DocView.draw_line_body + +function DocView:draw_line_body(idx, x, y) + local line1, col1, line2, col2 = self.doc:get_selection(true) + if line1 == line2 and col1 ~= col2 then + local lh = self:get_line_height() + local selected_text = self.doc.lines[line1]:sub(col1, col2 - 1) + local current_line_text = self.doc.lines[idx] + local last_col = 1 + while true do + local start_col, end_col = current_line_text:find(selected_text, last_col, true) + if start_col == nil then break end + local x1 = x + self:get_col_x_offset(idx, start_col) + local x2 = x + self:get_col_x_offset(idx, end_col + 1) + local color = style.selectionhighlight or style.syntax.comment + draw_box(x1, y, x2 - x1, lh, color) + last_col = end_col + 1 + end + end + draw_line_body(self, idx, x, y) +end + diff --git a/vendor/lite-plugins/plugins/sort.lua b/vendor/lite-plugins/plugins/sort.lua new file mode 100644 index 0000000..2e865ab --- /dev/null +++ b/vendor/lite-plugins/plugins/sort.lua @@ -0,0 +1,30 @@ +local core = require "core" +local command = require "core.command" +local translate = require "core.doc.translate" + +local function split_lines(text) + local res = {} + for line in (text .. "\n"):gmatch("(.-)\n") do + table.insert(res, line) + end + return res +end + +command.add("core.docview", { + ["sort:sort"] = function() + local doc = core.active_view.doc + + local l1, c1, l2, c2, swap = doc:get_selection(true) + l1, c1 = translate.start_of_line(doc, l1, c1) + l2, c2 = translate.end_of_line(doc, l2, c2) + doc:set_selection(l1, c1, l2, c2, swap) + + doc:replace(function(text) + local head, body, foot = text:match("(\n*)(.-)(\n*)$") + local lines = split_lines(body) + table.sort(lines, function(a, b) return a:lower() < b:lower() end) + return head .. table.concat(lines, "\n") .. foot + end) + end, +}) + diff --git a/vendor/lite-plugins/plugins/spellcheck.lua b/vendor/lite-plugins/plugins/spellcheck.lua new file mode 100644 index 0000000..1f29792 --- /dev/null +++ b/vendor/lite-plugins/plugins/spellcheck.lua @@ -0,0 +1,179 @@ +local core = require "core" +local style = require "core.style" +local config = require "core.config" +local command = require "core.command" +local common = require "core.common" +local DocView = require "core.docview" +local Doc = require "core.doc" + +config.spellcheck_files = { "%.txt$", "%.md$", "%.markdown$" } +if PLATFORM == "Windows" then + config.dictionary_file = EXEDIR .. "/words.txt" +else + config.dictionary_file = "/usr/share/dict/words" +end + + +local last_input_time = 0 +local word_pattern = "%a+" +local words + +core.add_thread(function() + local t = {} + local i = 0 + for line in io.lines(config.dictionary_file) do + for word in line:gmatch(word_pattern) do + t[word:lower()] = true + end + i = i + 1 + if i % 1000 == 0 then coroutine.yield() end + end + words = t + core.redraw = true + core.log_quiet("Finished loading dictionary file: \"%s\"", config.dictionary_file) +end) + + +local function matches_any(filename, ptns) + for _, ptn in ipairs(ptns) do + if filename:find(ptn) then return true end + end +end + + +local function active_word(doc, line, tail) + local l, c = doc:get_selection() + return l == line and c == tail + and doc == core.active_view.doc + and system.get_time() - last_input_time < 0.5 +end + + +local text_input = Doc.text_input + +function Doc:text_input(...) + text_input(self, ...) + last_input_time = system.get_time() +end + + +local draw_line_text = DocView.draw_line_text + +function DocView:draw_line_text(idx, x, y) + draw_line_text(self, idx, x, y) + + if not words + or not matches_any(self.doc.filename or "", config.spellcheck_files) then + return + end + + local s, e = 0, 0 + local text = self.doc.lines[idx] + + while true do + s, e = text:find(word_pattern, e + 1) + if not s then break end + local word = text:sub(s, e):lower() + if not words[word] and not active_word(self.doc, idx, e + 1) then + local color = style.spellcheck_error or style.syntax.keyword2 + local x1 = x + self:get_col_x_offset(idx, s) + local x2 = x + self:get_col_x_offset(idx, e + 1) + local h = math.ceil(1 * SCALE) + renderer.draw_rect(x1, y + self:get_line_height() - h, x2 - x1, h, color) + end + end +end + + +local function get_word_at_caret() + local doc = core.active_view.doc + local l, c = doc:get_selection() + local s, e = 0, 0 + local text = doc.lines[l] + while true do + s, e = text:find(word_pattern, e + 1) + if c >= s and c <= e + 1 then + return text:sub(s, e):lower(), s, e + end + end +end + + +local function compare_words(word1, word2) + local res = 0 + for i = 1, math.max(#word1, #word2) do + if word1:byte(i) ~= word2:byte(i) then + res = res + 1 + end + end + return res +end + + +command.add("core.docview", { + + ["spell-check:add-to-dictionary"] = function() + local word = get_word_at_caret() + if words[word] then + core.error("\"%s\" already exists in the dictionary", word) + return + end + if word then + local fp = assert(io.open(config.dictionary_file, "a")) + fp:write("\n" .. word .. "\n") + fp:close() + words[word] = true + core.log("Added \"%s\" to dictionary", word) + end + end, + + + ["spell-check:replace"] = function() + local word, s, e = get_word_at_caret() + + -- find suggestions + local suggestions = {} + local word_len = #word + for w in pairs(words) do + if math.abs(#w - word_len) <= 2 then + local diff = compare_words(word, w) + if diff < word_len * 0.5 then + table.insert(suggestions, { diff = diff, text = w }) + end + end + end + if #suggestions == 0 then + core.error("Could not find any suggestions for \"%s\"", word) + return + end + + -- sort suggestions table and convert to properly-capitalized text + table.sort(suggestions, function(a, b) return a.diff < b.diff end) + local doc = core.active_view.doc + local line = doc:get_selection() + local has_upper = doc.lines[line]:sub(s, s):match("[A-Z]") + for k, v in pairs(suggestions) do + if has_upper then + v.text = v.text:gsub("^.", string.upper) + end + suggestions[k] = v.text + end + + -- select word and init replacement selector + local label = string.format("Replace \"%s\" With", word) + doc:set_selection(line, e + 1, line, s) + core.command_view:enter(label, function(text, item) + text = item and item.text or text + doc:replace(function() return text end) + end, function(text) + local t = {} + for _, w in ipairs(suggestions) do + if w:lower():find(text:lower(), 1, true) then + table.insert(t, w) + end + end + return t + end) + end, + +}) diff --git a/vendor/lite-plugins/plugins/titleize.lua b/vendor/lite-plugins/plugins/titleize.lua new file mode 100644 index 0000000..2e4b52a --- /dev/null +++ b/vendor/lite-plugins/plugins/titleize.lua @@ -0,0 +1,11 @@ +local core = require "core" +local command = require "core.command" + +command.add("core.docview", { + ["titleize:titleize"] = function() + core.active_view.doc:replace(function(text) + return text:gsub("%f[%w](%w)", string.upper) + end) + end, +}) + diff --git a/vendor/lite-plugins/plugins/togglesnakecamel.lua b/vendor/lite-plugins/plugins/togglesnakecamel.lua new file mode 100644 index 0000000..236c22e --- /dev/null +++ b/vendor/lite-plugins/plugins/togglesnakecamel.lua @@ -0,0 +1,32 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + + +local function f(x, y) + return x .. "_" .. string.lower(y) +end + + +local function toggle(symbol) + if not symbol:match("[a-z]") then + return + elseif symbol:match("_") then + return symbol:gsub("_(.)", string.upper) + elseif symbol:match("^[a-z]") then + return symbol:gsub("(.)([A-Z])", f):lower() + end +end + + +command.add("core.docview", { + ["toggle-snake-camel:toggle"] = function() + core.active_view.doc:replace(function(text) + return text:gsub("[%w][%w%d_]*", toggle) + end) + end, +}) + +keymap.add { + ["f6"] = "toggle-snake-camel:toggle", +} diff --git a/vendor/lite-plugins/plugins/unboundedscroll.lua b/vendor/lite-plugins/plugins/unboundedscroll.lua new file mode 100644 index 0000000..c4cc7bb --- /dev/null +++ b/vendor/lite-plugins/plugins/unboundedscroll.lua @@ -0,0 +1,5 @@ +local DocView = require "core.docview" + +function DocView.clamp_scroll_position() + -- do nothing +end diff --git a/vendor/lite-plugins/plugins/workspace.lua b/vendor/lite-plugins/plugins/workspace.lua new file mode 100644 index 0000000..028e0a2 --- /dev/null +++ b/vendor/lite-plugins/plugins/workspace.lua @@ -0,0 +1,164 @@ +local core = require "core" +local DocView = require "core.docview" + +local workspace_filename = ".lite_workspace.lua" + + +local function serialize(val) + if type(val) == "string" then + return string.format("%q", val) + elseif type(val) == "table" then + local t = {} + for k, v in pairs(val) do + table.insert(t, "[" .. serialize(k) .. "]=" .. serialize(v)) + end + return "{" .. table.concat(t, ",") .. "}" + end + return tostring(val) +end + + +local function has_no_locked_children(node) + if node.locked then return false end + if node.type == "leaf" then return true end + return has_no_locked_children(node.a) and has_no_locked_children(node.b) +end + + +local function get_unlocked_root(node) + if node.type == "leaf" then + return not node.locked and node + end + if has_no_locked_children(node) then + return node + end + return get_unlocked_root(node.a) or get_unlocked_root(node.b) +end + + +local function save_view(view) + local mt = getmetatable(view) + if mt == DocView then + return { + type = "doc", + active = (core.active_view == view), + filename = view.doc.filename, + selection = { view.doc:get_selection() }, + scroll = { x = view.scroll.to.x, y = view.scroll.to.y }, + text = not view.doc.filename and view.doc:get_text(1, 1, math.huge, math.huge) + } + end + for name, mod in pairs(package.loaded) do + if mod == mt then + return { + type = "view", + active = (core.active_view == view), + module = name + } + end + end +end + + +local function load_view(t) + if t.type == "doc" then + local ok, doc = pcall(core.open_doc, t.filename) + if not ok then + return DocView(core.open_doc()) + end + local dv = DocView(doc) + if t.text then doc:insert(1, 1, t.text) end + doc:set_selection(table.unpack(t.selection)) + dv.last_line, dv.last_col = doc:get_selection() + dv.scroll.x, dv.scroll.to.x = t.scroll.x, t.scroll.x + dv.scroll.y, dv.scroll.to.y = t.scroll.y, t.scroll.y + return dv + end + return require(t.module)() +end + + +local function save_node(node) + local res = {} + res.type = node.type + if node.type == "leaf" then + res.views = {} + for _, view in ipairs(node.views) do + local t = save_view(view) + if t then + table.insert(res.views, t) + if node.active_view == view then + res.active_view = #res.views + end + end + end + else + res.divider = node.divider + res.a = save_node(node.a) + res.b = save_node(node.b) + end + return res +end + + +local function load_node(node, t) + if t.type == "leaf" then + local res + for _, v in ipairs(t.views) do + local view = load_view(v) + if v.active then res = view end + node:add_view(view) + end + if t.active_view then + node:set_active_view(node.views[t.active_view]) + end + return res + else + node:split(t.type == "hsplit" and "right" or "down") + node.divider = t.divider + local res1 = load_node(node.a, t.a) + local res2 = load_node(node.b, t.b) + return res1 or res2 + end +end + + +local function save_workspace() + local root = get_unlocked_root(core.root_view.root_node) + local fp = io.open(workspace_filename, "w") + if fp then + fp:write("return ", serialize(save_node(root)), "\n") + fp:close() + end +end + + +local function load_workspace() + local ok, t = pcall(dofile, workspace_filename) + os.remove(workspace_filename) + if ok then + local root = get_unlocked_root(core.root_view.root_node) + local active_view = load_node(root, t) + if active_view then + core.set_active_view(active_view) + end + end +end + + +local run = core.run + +function core.run(...) + if #core.docs == 0 then + core.try(load_workspace) + + local exit = os.exit + function os.exit(...) + save_workspace() + exit(...) + end + end + + core.run = run + return core.run(...) +end diff --git a/vendor/lite/.gitattributes b/vendor/lite/.gitattributes new file mode 100644 index 0000000..bd2cfac --- /dev/null +++ b/vendor/lite/.gitattributes @@ -0,0 +1,3 @@ +winlib/* linguist-vendored +src/lib/* linguist-vendored +icon.inl linguist-vendored diff --git a/vendor/lite/.github/FUNDING.yml b/vendor/lite/.github/FUNDING.yml new file mode 100644 index 0000000..375655a --- /dev/null +++ b/vendor/lite/.github/FUNDING.yml @@ -0,0 +1,3 @@ +# These are supported funding model platforms + +github: rxi diff --git a/vendor/lite/.gitrepo b/vendor/lite/.gitrepo new file mode 100644 index 0000000..4b3b63a --- /dev/null +++ b/vendor/lite/.gitrepo @@ -0,0 +1,12 @@ +; DO NOT EDIT (unless you know what you are doing) +; +; This subdirectory is a git "subrepo", and this file is maintained by the +; git-subrepo command. See https://github.com/git-commands/git-subrepo#readme +; +[subrepo] + remote = https://github.com/jeremypenner/lite.git + branch = master + commit = 2783adc10c2f42beefdbc7f19cec8971e4e9bb80 + parent = dab1881d90ab1514301a081a9dbc265325672b20 + method = merge + cmdver = 0.4.2 diff --git a/vendor/lite/LICENSE b/vendor/lite/LICENSE new file mode 100644 index 0000000..39ddd05 --- /dev/null +++ b/vendor/lite/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2020 rxi + +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. diff --git a/vendor/lite/README.md b/vendor/lite/README.md new file mode 100644 index 0000000..8b9e290 --- /dev/null +++ b/vendor/lite/README.md @@ -0,0 +1,53 @@ +# lite-hearted + +lite-hearted is a small compatibility shim for the lite text editor that allows +it to run in love2d. It is a quick-and-dirty experiment in embedding editing tools +into a game engine, to allow for building smooth game development workflows. It's +also literally a two-evening hack, so you will probably run into some rough edges! + +You can run it simply by cloning this repo and running `love .`. Due to the +limitations of love2d's sandboxed filesystem, you can only edit files that are in +the project itself. Given the goals of this project, this should be fine. + +Original README follows: + +# lite +![screenshot](https://user-images.githubusercontent.com/3920290/81471642-6c165880-91ea-11ea-8cd1-fae7ae8f0bc4.png) + +A lightweight text editor written in Lua + +* **[Get lite](https://github.com/rxi/lite/releases/latest)** — Download + for Windows and Linux +* **[Get started](doc/usage.md)** — A quick overview on how to get started +* **[Get plugins](https://github.com/rxi/lite-plugins)** — Add additional + functionality +* **[Get color themes](https://github.com/rxi/lite-colors)** — Add additional colors + themes + +## Overview +lite is a lightweight text editor written mostly in Lua — it aims to provide +something practical, pretty, *small* and fast, implemented as simply as +possible; easy to modify and extend, or to use without doing either. + +## Customization +Additional functionality can be added through plugins which are available from +the [plugins repository](https://github.com/rxi/lite-plugins); additional color +themes can be found in the [colors repository](https://github.com/rxi/lite-colors). +The editor can be customized by making changes to the +[user module](data/user/init.lua). + +## Building +You can build the project yourself on Linux using the provided `build.sh` +script. Note that the project does not need to be rebuilt if you are only making +changes to the Lua portion of the code. + +## Contributing +Any additional functionality that can be added through a plugin should be done +so as a plugin, after which a pull request to the +[plugins repository](https://github.com/rxi/lite-plugins) can be made. In hopes +of remaining lightweight, pull requests adding additional functionality to the +core will likely not be merged. Bug reports and bug fixes are welcome. + +## License +This project is free software; you can redistribute it and/or modify it under +the terms of the MIT license. See [LICENSE](LICENSE) for details. diff --git a/vendor/lite/build.sh b/vendor/lite/build.sh new file mode 100755 index 0000000..308ebf9 --- /dev/null +++ b/vendor/lite/build.sh @@ -0,0 +1,43 @@ +#!/bin/bash + +cflags="-Wall -O3 -g -std=gnu11 -fno-strict-aliasing -Isrc" +lflags="-lSDL2 -lm" + +if [[ $* == *windows* ]]; then + platform="windows" + outfile="lite.exe" + compiler="x86_64-w64-mingw32-gcc" + cflags="$cflags -DLUA_USE_POPEN -Iwinlib/SDL2-2.0.10/x86_64-w64-mingw32/include" + lflags="$lflags -Lwinlib/SDL2-2.0.10/x86_64-w64-mingw32/lib" + lflags="-lmingw32 -lSDL2main $lflags -mwindows -o $outfile res.res" + x86_64-w64-mingw32-windres res.rc -O coff -o res.res +else + platform="unix" + outfile="lite" + compiler="gcc" + cflags="$cflags -DLUA_USE_POSIX" + lflags="$lflags -o $outfile" +fi + +if command -v ccache >/dev/null; then + compiler="ccache $compiler" +fi + + +echo "compiling ($platform)..." +for f in `find src -name "*.c"`; do + $compiler -c $cflags $f -o "${f//\//_}.o" + if [[ $? -ne 0 ]]; then + got_error=true + fi +done + +if [[ ! $got_error ]]; then + echo "linking..." + $compiler *.o $lflags +fi + +echo "cleaning up..." +rm *.o +rm res.res 2>/dev/null +echo "done" diff --git a/vendor/lite/build_release.sh b/vendor/lite/build_release.sh new file mode 100755 index 0000000..8e2084d --- /dev/null +++ b/vendor/lite/build_release.sh @@ -0,0 +1,10 @@ +#!/bin/bash +./build.sh release windows +./build.sh release +rm lite.zip 2>/dev/null +cp winlib/SDL2-2.0.10/x86_64-w64-mingw32/bin/SDL2.dll SDL2.dll +strip lite +strip lite.exe +strip SDL2.dll +zip lite.zip lite lite.exe SDL2.dll data -r + diff --git a/vendor/lite/conf.lua b/vendor/lite/conf.lua new file mode 100644 index 0000000..e148292 --- /dev/null +++ b/vendor/lite/conf.lua @@ -0,0 +1,6 @@ +function love.conf(t) + t.window.width = 1280 + t.window.height = 1000 + t.window.resizable = true + end + \ No newline at end of file diff --git a/vendor/lite/data/core/command.lua b/vendor/lite/data/core/command.lua new file mode 100644 index 0000000..8008d32 --- /dev/null +++ b/vendor/lite/data/core/command.lua @@ -0,0 +1,69 @@ +local core = require "core" +local command = {} + +command.map = {} + +local always_true = function() return true end + + +function command.add(predicate, map) + predicate = predicate or always_true + if type(predicate) == "string" then + predicate = require(predicate) + end + if type(predicate) == "table" then + local class = predicate + predicate = function() return core.active_view:is(class) end + end + for name, fn in pairs(map) do +-- assert(not command.map[name], "command already exists: " .. name) + command.map[name] = { predicate = predicate, perform = fn } + end +end + + +local function capitalize_first(str) + return str:sub(1, 1):upper() .. str:sub(2) +end + +function command.prettify_name(name) + return name:gsub(":", ": "):gsub("-", " "):gsub("%S+", capitalize_first) +end + + +function command.get_all_valid() + local res = {} + for name, cmd in pairs(command.map) do + if cmd.predicate() then + table.insert(res, name) + end + end + return res +end + + +local function perform(name) + local cmd = command.map[name] + if cmd and cmd.predicate() then + cmd.perform() + return true + end + return false +end + + +function command.perform(...) + local ok, res = core.try(perform, ...) + return not ok or res +end + + +function command.add_defaults() + local reg = { "core", "root", "command", "doc", "findreplace" } + for _, name in ipairs(reg) do + require("core.commands." .. name) + end +end + + +return command diff --git a/vendor/lite/data/core/commands/command.lua b/vendor/lite/data/core/commands/command.lua new file mode 100644 index 0000000..f0b8007 --- /dev/null +++ b/vendor/lite/data/core/commands/command.lua @@ -0,0 +1,30 @@ +local core = require "core" +local command = require "core.command" +local CommandView = require "core.commandview" + +local function has_commandview() + return core.active_view:is(CommandView) +end + + +command.add(has_commandview, { + ["command:submit"] = function() + core.active_view:submit() + end, + + ["command:complete"] = function() + core.active_view:complete() + end, + + ["command:escape"] = function() + core.active_view:exit() + end, + + ["command:select-previous"] = function() + core.active_view:move_suggestion_idx(1) + end, + + ["command:select-next"] = function() + core.active_view:move_suggestion_idx(-1) + end, +}) diff --git a/vendor/lite/data/core/commands/core.lua b/vendor/lite/data/core/commands/core.lua new file mode 100644 index 0000000..dbe08a4 --- /dev/null +++ b/vendor/lite/data/core/commands/core.lua @@ -0,0 +1,101 @@ +local core = require "core" +local common = require "core.common" +local command = require "core.command" +local keymap = require "core.keymap" +local LogView = require "core.logview" + + +local fullscreen = false + +command.add(nil, { + ["core:quit"] = function() + core.quit() + end, + + ["core:force-quit"] = function() + core.quit(true) + end, + + ["core:toggle-fullscreen"] = function() + fullscreen = not fullscreen + system.set_window_mode(fullscreen and "fullscreen" or "normal") + end, + + ["core:reload-module"] = function() + core.command_view:enter("Reload Module", function(text, item) + local text = item and item.text or text + core.reload_module(text) + core.log("Reloaded module %q", text) + end, function(text) + local items = {} + for name in pairs(package.loaded) do + table.insert(items, name) + end + return common.fuzzy_match(items, text) + end) + end, + + ["core:find-command"] = function() + local commands = command.get_all_valid() + core.command_view:enter("Do Command", function(text, item) + if item then + command.perform(item.command) + end + end, function(text) + local res = common.fuzzy_match(commands, text) + for i, name in ipairs(res) do + res[i] = { + text = command.prettify_name(name), + info = keymap.get_binding(name), + command = name, + } + end + return res + end) + end, + + ["core:find-file"] = function() + core.command_view:enter("Open File From Project", function(text, item) + text = item and item.text or text + core.root_view:open_doc(core.open_doc(text)) + end, function(text) + local files = {} + for _, item in pairs(core.project_files) do + if item.type == "file" then + table.insert(files, item.filename) + end + end + return common.fuzzy_match(files, text) + end) + end, + + ["core:new-doc"] = function() + core.root_view:open_doc(core.open_doc()) + end, + + ["core:open-file"] = function() + core.command_view:enter("Open File", function(text) + core.root_view:open_doc(core.open_doc(text)) + end, common.path_suggest) + end, + + ["core:open-log"] = function() + local node = core.root_view:get_active_node() + node:add_view(LogView()) + end, + + ["core:open-user-module"] = function() + core.root_view:open_doc(core.open_doc(EXEDIR .. "/data/user/init.lua")) + end, + + ["core:open-project-module"] = function() + local filename = ".lite_project.lua" + if system.get_file_info(filename) then + core.root_view:open_doc(core.open_doc(filename)) + else + local doc = core.open_doc() + core.root_view:open_doc(doc) + doc:save(filename) + end + end, +}) diff --git a/vendor/lite/data/core/commands/doc.lua b/vendor/lite/data/core/commands/doc.lua new file mode 100644 index 0000000..1afd546 --- /dev/null +++ b/vendor/lite/data/core/commands/doc.lua @@ -0,0 +1,363 @@ +local core = require "core" +local command = require "core.command" +local common = require "core.common" +local config = require "core.config" +local translate = require "core.doc.translate" +local DocView = require "core.docview" + + +local function dv() + return core.active_view +end + + +local function doc() + return core.active_view.doc +end + + +local function get_indent_string() + if config.tab_type == "hard" then + return "\t" + end + return string.rep(" ", config.indent_size) +end + + +local function insert_at_start_of_selected_lines(text, skip_empty) + local line1, col1, line2, col2, swap = doc():get_selection(true) + for line = line1, line2 do + local line_text = doc().lines[line] + if (not skip_empty or line_text:find("%S")) then + doc():insert(line, 1, text) + end + end + doc():set_selection(line1, col1 + #text, line2, col2 + #text, swap) +end + + +local function remove_from_start_of_selected_lines(text, skip_empty) + local line1, col1, line2, col2, swap = doc():get_selection(true) + for line = line1, line2 do + local line_text = doc().lines[line] + if line_text:sub(1, #text) == text + and (not skip_empty or line_text:find("%S")) + then + doc():remove(line, 1, line, #text + 1) + end + end + doc():set_selection(line1, col1 - #text, line2, col2 - #text, swap) +end + + +local function append_line_if_last_line(line) + if line >= #doc().lines then + doc():insert(line, math.huge, "\n") + end +end + + +local function save(filename) + doc():save(filename) + core.log("Saved \"%s\"", doc().filename) +end + + +local commands = { + ["doc:undo"] = function() + doc():undo() + end, + + ["doc:redo"] = function() + doc():redo() + end, + + ["doc:cut"] = function() + if doc():has_selection() then + local text = doc():get_text(doc():get_selection()) + system.set_clipboard(text) + doc():delete_to(0) + end + end, + + ["doc:copy"] = function() + if doc():has_selection() then + local text = doc():get_text(doc():get_selection()) + system.set_clipboard(text) + end + end, + + ["doc:paste"] = function() + doc():text_input(system.get_clipboard():gsub("\r", "")) + end, + + ["doc:newline"] = function() + local line, col = doc():get_selection() + local indent = doc().lines[line]:match("^[\t ]*") + if col <= #indent then + indent = indent:sub(#indent + 2 - col) + end + doc():text_input("\n" .. indent) + end, + + ["doc:newline-below"] = function() + local line = doc():get_selection() + local indent = doc().lines[line]:match("^[\t ]*") + doc():insert(line, math.huge, "\n" .. indent) + doc():set_selection(line + 1, math.huge) + end, + + ["doc:newline-above"] = function() + local line = doc():get_selection() + local indent = doc().lines[line]:match("^[\t ]*") + doc():insert(line, 1, indent .. "\n") + doc():set_selection(line, math.huge) + end, + + ["doc:delete"] = function() + local line, col = doc():get_selection() + if not doc():has_selection() and doc().lines[line]:find("^%s*$", col) then + doc():remove(line, col, line, math.huge) + end + doc():delete_to(translate.next_char) + end, + + ["doc:backspace"] = function() + local line, col = doc():get_selection() + if not doc():has_selection() then + local text = doc():get_text(line, 1, line, col) + if #text >= config.indent_size and text:find("^ *$") then + doc():delete_to(0, -config.indent_size) + return + end + end + doc():delete_to(translate.previous_char) + end, + + ["doc:select-all"] = function() + doc():set_selection(1, 1, math.huge, math.huge) + end, + + ["doc:select-none"] = function() + local line, col = doc():get_selection() + doc():set_selection(line, col) + end, + + ["doc:select-lines"] = function() + local line1, _, line2, _, swap = doc():get_selection(true) + append_line_if_last_line(line2) + doc():set_selection(line1, 1, line2 + 1, 1, swap) + end, + + ["doc:select-word"] = function() + local line1, col1 = doc():get_selection(true) + local line1, col1 = translate.start_of_word(doc(), line1, col1) + local line2, col2 = translate.end_of_word(doc(), line1, col1) + doc():set_selection(line2, col2, line1, col1) + end, + + ["doc:join-lines"] = function() + local line1, _, line2 = doc():get_selection(true) + if line1 == line2 then line2 = line2 + 1 end + local text = doc():get_text(line1, 1, line2, math.huge) + text = text:gsub("\n[\t ]*", " ") + doc():insert(line1, 1, text) + doc():remove(line1, #text + 1, line2, math.huge) + if doc():has_selection() then + doc():set_selection(line1, math.huge) + end + end, + + ["doc:indent"] = function() + local text = get_indent_string() + if doc():has_selection() then + insert_at_start_of_selected_lines(text) + else + doc():text_input(text) + end + end, + + ["doc:unindent"] = function() + local text = get_indent_string() + remove_from_start_of_selected_lines(text) + end, + + ["doc:duplicate-lines"] = function() + local line1, col1, line2, col2, swap = doc():get_selection(true) + append_line_if_last_line(line2) + local text = doc():get_text(line1, 1, line2 + 1, 1) + doc():insert(line2 + 1, 1, text) + local n = line2 - line1 + 1 + doc():set_selection(line1 + n, col1, line2 + n, col2, swap) + end, + + ["doc:delete-lines"] = function() + local line1, col1, line2 = doc():get_selection(true) + append_line_if_last_line(line2) + doc():remove(line1, 1, line2 + 1, 1) + doc():set_selection(line1, col1) + end, + + ["doc:move-lines-up"] = function() + local line1, col1, line2, col2, swap = doc():get_selection(true) + append_line_if_last_line(line2) + if line1 > 1 then + local text = doc().lines[line1 - 1] + doc():insert(line2 + 1, 1, text) + doc():remove(line1 - 1, 1, line1, 1) + doc():set_selection(line1 - 1, col1, line2 - 1, col2, swap) + end + end, + + ["doc:move-lines-down"] = function() + local line1, col1, line2, col2, swap = doc():get_selection(true) + append_line_if_last_line(line2 + 1) + if line2 < #doc().lines then + local text = doc().lines[line2 + 1] + doc():remove(line2 + 1, 1, line2 + 2, 1) + doc():insert(line1, 1, text) + doc():set_selection(line1 + 1, col1, line2 + 1, col2, swap) + end + end, + + ["doc:toggle-line-comments"] = function() + local comment = doc().syntax.comment + if not comment then return end + local comment_text = comment .. " " + local line1, _, line2 = doc():get_selection(true) + local uncomment = true + for line = line1, line2 do + local text = doc().lines[line] + if text:find("%S") and text:find(comment_text, 1, true) ~= 1 then + uncomment = false + end + end + if uncomment then + remove_from_start_of_selected_lines(comment_text, true) + else + insert_at_start_of_selected_lines(comment_text, true) + end + end, + + ["doc:upper-case"] = function() + doc():replace(string.upper) + end, + + ["doc:lower-case"] = function() + doc():replace(string.lower) + end, + + ["doc:go-to-line"] = function() + local dv = dv() + + local items + local function init_items() + if items then return end + items = {} + local mt = { __tostring = function(x) return x.text end } + for i, line in ipairs(dv.doc.lines) do + local item = { text = line:sub(1, -2), line = i, info = "line: " .. i } + table.insert(items, setmetatable(item, mt)) + end + end + + core.command_view:enter("Go To Line", function(text, item) + local line = item and item.line or tonumber(text) + if not line then + core.error("Invalid line number or unmatched string") + return + end + dv.doc:set_selection(line, 1 ) + dv:scroll_to_line(line, true) + + end, function(text) + if not text:find("^%d*$") then + init_items() + return common.fuzzy_match(items, text) + end + end) + end, + + ["doc:toggle-line-ending"] = function() + doc().crlf = not doc().crlf + end, + + ["doc:save-as"] = function() + if doc().filename then + core.command_view:set_text(doc().filename) + end + core.command_view:enter("Save As", function(filename) + save(filename) + end, common.path_suggest) + end, + + ["doc:save"] = function() + if doc().filename then + save() + else + command.perform("doc:save-as") + end + end, + + ["doc:rename"] = function() + local old_filename = doc().filename + if not old_filename then + core.error("Cannot rename unsaved doc") + return + end + core.command_view:set_text(old_filename) + core.command_view:enter("Rename", function(filename) + doc():save(filename) + core.log("Renamed \"%s\" to \"%s\"", old_filename, filename) + if filename ~= old_filename then + os.remove(old_filename) + end + end, common.path_suggest) + end, +} + + +local translations = { + ["previous-char"] = translate.previous_char, + ["next-char"] = translate.next_char, + ["previous-word-start"] = translate.previous_word_start, + ["next-word-end"] = translate.next_word_end, + ["previous-block-start"] = translate.previous_block_start, + ["next-block-end"] = translate.next_block_end, + ["start-of-doc"] = translate.start_of_doc, + ["end-of-doc"] = translate.end_of_doc, + ["start-of-line"] = translate.start_of_line, + ["end-of-line"] = translate.end_of_line, + ["start-of-word"] = translate.start_of_word, + ["end-of-word"] = translate.end_of_word, + ["previous-line"] = DocView.translate.previous_line, + ["next-line"] = DocView.translate.next_line, + ["previous-page"] = DocView.translate.previous_page, + ["next-page"] = DocView.translate.next_page, +} + +for name, fn in pairs(translations) do + commands["doc:move-to-" .. name] = function() doc():move_to(fn, dv()) end + commands["doc:select-to-" .. name] = function() doc():select_to(fn, dv()) end + commands["doc:delete-to-" .. name] = function() doc():delete_to(fn, dv()) end +end + +commands["doc:move-to-previous-char"] = function() + if doc():has_selection() then + local line, col = doc():get_selection(true) + doc():set_selection(line, col) + else + doc():move_to(translate.previous_char) + end +end + +commands["doc:move-to-next-char"] = function() + if doc():has_selection() then + local _, _, line, col = doc():get_selection(true) + doc():set_selection(line, col) + else + doc():move_to(translate.next_char) + end +end + +command.add("core.docview", commands) diff --git a/vendor/lite/data/core/commands/findreplace.lua b/vendor/lite/data/core/commands/findreplace.lua new file mode 100644 index 0000000..937c410 --- /dev/null +++ b/vendor/lite/data/core/commands/findreplace.lua @@ -0,0 +1,170 @@ +local core = require "core" +local command = require "core.command" +local config = require "core.config" +local search = require "core.doc.search" +local DocView = require "core.docview" + +local max_previous_finds = 50 + + +local function doc() + return core.active_view.doc +end + + +local previous_finds +local last_doc +local last_fn, last_text + + +local function push_previous_find(doc, sel) + if last_doc ~= doc then + last_doc = doc + previous_finds = {} + end + if #previous_finds >= max_previous_finds then + table.remove(previous_finds, 1) + end + table.insert(previous_finds, sel or { doc:get_selection() }) +end + + +local function find(label, search_fn) + local dv = core.active_view + local sel = { dv.doc:get_selection() } + local text = dv.doc:get_text(table.unpack(sel)) + local found = false + + core.command_view:set_text(text, true) + + core.command_view:enter(label, function(text) + if found then + last_fn, last_text = search_fn, text + previous_finds = {} + push_previous_find(dv.doc, sel) + else + core.error("Couldn't find %q", text) + dv.doc:set_selection(table.unpack(sel)) + dv:scroll_to_make_visible(sel[1], sel[2]) + end + + end, function(text) + local ok, line1, col1, line2, col2 = pcall(search_fn, dv.doc, sel[1], sel[2], text) + if ok and line1 and text ~= "" then + dv.doc:set_selection(line2, col2, line1, col1) + dv:scroll_to_line(line2, true) + found = true + else + dv.doc:set_selection(table.unpack(sel)) + found = false + end + + end, function(explicit) + if explicit then + dv.doc:set_selection(table.unpack(sel)) + dv:scroll_to_make_visible(sel[1], sel[2]) + end + end) +end + + +local function replace(kind, default, fn) + core.command_view:set_text(default, true) + + core.command_view:enter("Find To Replace " .. kind, function(old) + core.command_view:set_text(old, true) + + local s = string.format("Replace %s %q With", kind, old) + core.command_view:enter(s, function(new) + local n = doc():replace(function(text) + return fn(text, old, new) + end) + core.log("Replaced %d instance(s) of %s %q with %q", n, kind, old, new) + end) + end) +end + + +local function has_selection() + return core.active_view:is(DocView) + and core.active_view.doc:has_selection() +end + +command.add(has_selection, { + ["find-replace:select-next"] = function() + local l1, c1, l2, c2 = doc():get_selection(true) + local text = doc():get_text(l1, c1, l2, c2) + local l1, c1, l2, c2 = search.find(doc(), l2, c2, text, { wrap = true }) + if l2 then doc():set_selection(l2, c2, l1, c1) end + end +}) + +command.add("core.docview", { + ["find-replace:find"] = function() + find("Find Text", function(doc, line, col, text) + local opt = { wrap = true, no_case = true } + return search.find(doc, line, col, text, opt) + end) + end, + + ["find-replace:find-pattern"] = function() + find("Find Text Pattern", function(doc, line, col, text) + local opt = { wrap = true, no_case = true, pattern = true } + return search.find(doc, line, col, text, opt) + end) + end, + + ["find-replace:repeat-find"] = function() + if not last_fn then + core.error("No find to continue from") + else + local line, col = doc():get_selection() + local line1, col1, line2, col2 = last_fn(doc(), line, col, last_text) + if line1 then + push_previous_find(doc()) + doc():set_selection(line2, col2, line1, col1) + core.active_view:scroll_to_line(line2, true) + end + end + end, + + ["find-replace:previous-find"] = function() + local sel = table.remove(previous_finds) + if not sel or doc() ~= last_doc then + core.error("No previous finds") + return + end + doc():set_selection(table.unpack(sel)) + core.active_view:scroll_to_line(sel[3], true) + end, + + ["find-replace:replace"] = function() + replace("Text", "", function(text, old, new) + return text:gsub(old:gsub("%W", "%%%1"), new:gsub("%%", "%%%%"), nil) + end) + end, + + ["find-replace:replace-pattern"] = function() + replace("Pattern", "", function(text, old, new) + return text:gsub(old, new) + end) + end, + + ["find-replace:replace-symbol"] = function() + local first = "" + if doc():has_selection() then + local text = doc():get_text(doc():get_selection()) + first = text:match(config.symbol_pattern) or "" + end + replace("Symbol", first, function(text, old, new) + local n = 0 + local res = text:gsub(config.symbol_pattern, function(sym) + if old == sym then + n = n + 1 + return new + end + end) + return res, n + end) + end, +}) diff --git a/vendor/lite/data/core/commands/root.lua b/vendor/lite/data/core/commands/root.lua new file mode 100644 index 0000000..58c83e2 --- /dev/null +++ b/vendor/lite/data/core/commands/root.lua @@ -0,0 +1,105 @@ +local core = require "core" +local style = require "core.style" +local DocView = require "core.docview" +local command = require "core.command" +local common = require "core.common" + + +local t = { + ["root:close"] = function() + local node = core.root_view:get_active_node() + node:close_active_view(core.root_view.root_node) + end, + + ["root:switch-to-previous-tab"] = function() + local node = core.root_view:get_active_node() + local idx = node:get_view_idx(core.active_view) + idx = idx - 1 + if idx < 1 then idx = #node.views end + node:set_active_view(node.views[idx]) + end, + + ["root:switch-to-next-tab"] = function() + local node = core.root_view:get_active_node() + local idx = node:get_view_idx(core.active_view) + idx = idx + 1 + if idx > #node.views then idx = 1 end + node:set_active_view(node.views[idx]) + end, + + ["root:move-tab-left"] = function() + local node = core.root_view:get_active_node() + local idx = node:get_view_idx(core.active_view) + if idx > 1 then + table.remove(node.views, idx) + table.insert(node.views, idx - 1, core.active_view) + end + end, + + ["root:move-tab-right"] = function() + local node = core.root_view:get_active_node() + local idx = node:get_view_idx(core.active_view) + if idx < #node.views then + table.remove(node.views, idx) + table.insert(node.views, idx + 1, core.active_view) + end + end, + + ["root:shrink"] = function() + local node = core.root_view:get_active_node() + local parent = node:get_parent_node(core.root_view.root_node) + local n = (parent.a == node) and -0.1 or 0.1 + parent.divider = common.clamp(parent.divider + n, 0.1, 0.9) + end, + + ["root:grow"] = function() + local node = core.root_view:get_active_node() + local parent = node:get_parent_node(core.root_view.root_node) + local n = (parent.a == node) and 0.1 or -0.1 + parent.divider = common.clamp(parent.divider + n, 0.1, 0.9) + end, +} + + +for i = 1, 9 do + t["root:switch-to-tab-" .. i] = function() + local node = core.root_view:get_active_node() + local view = node.views[i] + if view then + node:set_active_view(view) + end + end +end + + +for _, dir in ipairs { "left", "right", "up", "down" } do + t["root:split-" .. dir] = function() + local node = core.root_view:get_active_node() + local av = node.active_view + node:split(dir) + if av:is(DocView) then + core.root_view:open_doc(av.doc) + end + end + + t["root:switch-to-" .. dir] = function() + local node = core.root_view:get_active_node() + local x, y + if dir == "left" or dir == "right" then + y = node.position.y + node.size.y / 2 + x = node.position.x + (dir == "left" and -1 or node.size.x + style.divider_size) + else + x = node.position.x + node.size.x / 2 + y = node.position.y + (dir == "up" and -1 or node.size.y + style.divider_size) + end + local node = core.root_view.root_node:get_child_overlapping_point(x, y) + if not node:get_locked_size() then + core.set_active_view(node.active_view) + end + end +end + +command.add(function() + local node = core.root_view:get_active_node() + return not node:get_locked_size() +end, t) diff --git a/vendor/lite/data/core/commandview.lua b/vendor/lite/data/core/commandview.lua new file mode 100644 index 0000000..3fbb1ff --- /dev/null +++ b/vendor/lite/data/core/commandview.lua @@ -0,0 +1,256 @@ +local core = require "core" +local common = require "core.common" +local style = require "core.style" +local Doc = require "core.doc" +local DocView = require "core.docview" +local View = require "core.view" + + +local SingleLineDoc = Doc:extend() + +function SingleLineDoc:insert(line, col, text) + SingleLineDoc.super.insert(self, line, col, text:gsub("\n", "")) +end + + +local CommandView = DocView:extend() + +local max_suggestions = 10 + +local noop = function() end + +local default_state = { + submit = noop, + suggest = noop, + cancel = noop, +} + + +function CommandView:new() + CommandView.super.new(self, SingleLineDoc()) + self.suggestion_idx = 1 + self.suggestions = {} + self.suggestions_height = 0 + self.last_change_id = 0 + self.gutter_width = 0 + self.gutter_text_brightness = 0 + self.selection_offset = 0 + self.state = default_state + self.font = "font" + self.size.y = 0 + self.label = "" +end + + +function CommandView:get_name() + return View.get_name(self) +end + + +function CommandView:get_line_screen_position() + local x = CommandView.super.get_line_screen_position(self, 1) + local _, y = self:get_content_offset() + local lh = self:get_line_height() + return x, y + (self.size.y - lh) / 2 +end + + +function CommandView:get_scrollable_size() + return 0 +end + + +function CommandView:scroll_to_make_visible() + -- no-op function to disable this functionality +end + + +function CommandView:get_text() + return self.doc:get_text(1, 1, 1, math.huge) +end + + +function CommandView:set_text(text, select) + self.doc:remove(1, 1, math.huge, math.huge) + self.doc:text_input(text) + if select then + self.doc:set_selection(math.huge, math.huge, 1, 1) + end +end + + +function CommandView:move_suggestion_idx(dir) + local n = self.suggestion_idx + dir + self.suggestion_idx = common.clamp(n, 1, #self.suggestions) + self:complete() + self.last_change_id = self.doc:get_change_id() +end + + +function CommandView:complete() + if #self.suggestions > 0 then + self:set_text(self.suggestions[self.suggestion_idx].text) + end +end + + +function CommandView:submit() + local suggestion = self.suggestions[self.suggestion_idx] + local text = self:get_text() + local submit = self.state.submit + self:exit(true) + submit(text, suggestion) +end + + +function CommandView:enter(text, submit, suggest, cancel) + if self.state ~= default_state then + return + end + self.state = { + submit = submit or noop, + suggest = suggest or noop, + cancel = cancel or noop, + } + core.set_active_view(self) + self:update_suggestions() + self.gutter_text_brightness = 100 + self.label = text .. ": " +end + + +function CommandView:exit(submitted, inexplicit) + if core.active_view == self then + core.set_active_view(core.last_active_view) + end + local cancel = self.state.cancel + self.state = default_state + self.doc:reset() + self.suggestions = {} + if not submitted then cancel(not inexplicit) end +end + + +function CommandView:get_gutter_width() + return self.gutter_width +end + + +function CommandView:get_suggestion_line_height() + return self:get_font():get_height() + style.padding.y +end + + +function CommandView:update_suggestions() + local t = self.state.suggest(self:get_text()) or {} + local res = {} + for i, item in ipairs(t) do + if i == max_suggestions then + break + end + if type(item) == "string" then + item = { text = item } + end + res[i] = item + end + self.suggestions = res + self.suggestion_idx = 1 +end + + +function CommandView:update() + CommandView.super.update(self) + + if core.active_view ~= self and self.state ~= default_state then + self:exit(false, true) + end + + -- update suggestions if text has changed + if self.last_change_id ~= self.doc:get_change_id() then + self:update_suggestions() + self.last_change_id = self.doc:get_change_id() + end + + -- update gutter text color brightness + self:move_towards("gutter_text_brightness", 0, 0.1) + + -- update gutter width + local dest = self:get_font():get_width(self.label) + style.padding.x + if self.size.y <= 0 then + self.gutter_width = dest + else + self:move_towards("gutter_width", dest) + end + + -- update suggestions box height + local lh = self:get_suggestion_line_height() + local dest = #self.suggestions * lh + self:move_towards("suggestions_height", dest) + + -- update suggestion cursor offset + local dest = self.suggestion_idx * self:get_suggestion_line_height() + self:move_towards("selection_offset", dest) + + -- update size based on whether this is the active_view + local dest = 0 + if self == core.active_view then + dest = style.font:get_height() + style.padding.y * 2 + end + self:move_towards(self.size, "y", dest) +end + + +function CommandView:draw_line_highlight() + -- no-op function to disable this functionality +end + + +function CommandView:draw_line_gutter(idx, x, y) + local yoffset = self:get_line_text_y_offset() + local pos = self.position + local color = common.lerp(style.text, style.accent, self.gutter_text_brightness / 100) + core.push_clip_rect(pos.x, pos.y, self:get_gutter_width(), self.size.y) + x = x + style.padding.x + renderer.draw_text(self:get_font(), self.label, x, y + yoffset, color) + core.pop_clip_rect() +end + + +local function draw_suggestions_box(self) + local lh = self:get_suggestion_line_height() + local dh = style.divider_size + local x, _ = self:get_line_screen_position() + local h = math.ceil(self.suggestions_height) + local rx, ry, rw, rh = self.position.x, self.position.y - h - dh, self.size.x, h + + -- draw suggestions background + if #self.suggestions > 0 then + renderer.draw_rect(rx, ry, rw, rh, style.background3) + renderer.draw_rect(rx, ry - dh, rw, dh, style.divider) + local y = self.position.y - self.selection_offset - dh + renderer.draw_rect(rx, y, rw, lh, style.line_highlight) + end + + -- draw suggestion text + core.push_clip_rect(rx, ry, rw, rh) + for i, item in ipairs(self.suggestions) do + local color = (i == self.suggestion_idx) and style.accent or style.text + local y = self.position.y - i * lh - dh + common.draw_text(self:get_font(), color, item.text, nil, x, y, 0, lh) + + if item.info then + local w = self.size.x - x - style.padding.x + common.draw_text(self:get_font(), style.dim, item.info, "right", x, y, w, lh) + end + end + core.pop_clip_rect() +end + + +function CommandView:draw() + CommandView.super.draw(self) + core.root_view:defer_draw(draw_suggestions_box, self) +end + + +return CommandView diff --git a/vendor/lite/data/core/common.lua b/vendor/lite/data/core/common.lua new file mode 100644 index 0000000..5bf4f3d --- /dev/null +++ b/vendor/lite/data/core/common.lua @@ -0,0 +1,140 @@ +local common = {} + + +function common.is_utf8_cont(char) + local byte = char:byte() + return byte >= 0x80 and byte < 0xc0 +end + + +function common.utf8_chars(text) + return text:gmatch("[%z\001-\127\194-\244][\128-\191]*") +end + + +function common.clamp(n, lo, hi) + return math.max(math.min(n, hi), lo) +end + + +function common.round(n) + return n >= 0 and math.floor(n + 0.5) or math.ceil(n - 0.5) +end + + +function common.lerp(a, b, t) + if type(a) ~= "table" then + return a + (b - a) * t + end + local res = {} + for k, v in pairs(b) do + res[k] = common.lerp(a[k], v, t) + end + return res +end + + +function common.color(str) + local r, g, b, a = str:match("#(%x%x)(%x%x)(%x%x)") + if r then + r = tonumber(r, 16) + g = tonumber(g, 16) + b = tonumber(b, 16) + a = 1 + elseif str:match("rgba?%s*%([%d%s%.,]+%)") then + local f = str:gmatch("[%d.]+") + r = (f() or 0) + g = (f() or 0) + b = (f() or 0) + a = f() or 1 + else + error(string.format("bad color string '%s'", str)) + end + return r, g, b, a * 0xff +end + + +local function compare_score(a, b) + return a.score > b.score +end + +local function fuzzy_match_items(items, needle) + local res = {} + for _, item in ipairs(items) do + local score = system.fuzzy_match(tostring(item), needle) + if score then + table.insert(res, { text = item, score = score }) + end + end + table.sort(res, compare_score) + for i, item in ipairs(res) do + res[i] = item.text + end + return res +end + + +function common.fuzzy_match(haystack, needle) + if type(haystack) == "table" then + return fuzzy_match_items(haystack, needle) + end + return system.fuzzy_match(haystack, needle) +end + + +function common.path_suggest(text) + local path, name = text:match("^(.-)([^/\\]*)$") + local files = system.list_dir(path == "" and "." or path) or {} + local res = {} + for _, file in ipairs(files) do + file = path .. file + local info = system.get_file_info(file) + if info then + if info.type == "dir" then + file = file .. PATHSEP + end + if file:lower():find(text:lower(), nil, true) == 1 then + table.insert(res, file) + end + end + end + return res +end + + +function common.match_pattern(text, pattern, ...) + if type(pattern) == "string" then + return text:find(pattern, ...) + end + for _, p in ipairs(pattern) do + local s, e = common.match_pattern(text, p, ...) + if s then return s, e end + end + return false +end + + +function common.draw_text(font, color, text, align, x,y,w,h) + local tw, th = font:get_width(text), font:get_height(text) + if align == "center" then + x = x + (w - tw) / 2 + elseif align == "right" then + x = x + (w - tw) + end + y = common.round(y + (h - th) / 2) + return renderer.draw_text(font, text, x, y, color), y + th +end + + +function common.bench(name, fn, ...) + local start = system.get_time() + local res = fn(...) + local t = system.get_time() - start + local ms = t * 1000 + local per = (t / (1 / 60)) * 100 + print(string.format("*** %-16s : %8.3fms %6.2f%%", name, ms, per)) + return res +end + + +return common diff --git a/vendor/lite/data/core/config.lua b/vendor/lite/data/core/config.lua new file mode 100644 index 0000000..a9f106f --- /dev/null +++ b/vendor/lite/data/core/config.lua @@ -0,0 +1,20 @@ +local config = {} + +config.project_scan_rate = 5 +config.fps = 60 +config.max_log_items = 80 +config.message_timeout = 3 +config.mouse_wheel_scroll = 50 * SCALE +config.file_size_limit = 10 +config.ignore_files = "^%." +config.symbol_pattern = "[%a_][%w_]*" +config.non_word_chars = " \t\n/\\()\"':,.;<>~!@#$%^&*|+=[]{}`?-" +config.undo_merge_timeout = 0.3 +config.max_undos = 10000 +config.highlight_current_line = true +config.line_height = 1.2 +config.indent_size = 2 +config.tab_type = "soft" +config.line_limit = 80 + +return config diff --git a/vendor/lite/data/core/doc/highlighter.lua b/vendor/lite/data/core/doc/highlighter.lua new file mode 100644 index 0000000..e7650d0 --- /dev/null +++ b/vendor/lite/data/core/doc/highlighter.lua @@ -0,0 +1,80 @@ +local core = require "core" +local config = require "core.config" +local tokenizer = require "core.tokenizer" +local Object = require "core.object" + + +local Highlighter = Object:extend() + + +function Highlighter:new(doc) + self.doc = doc + self:reset() + + -- init incremental syntax highlighting + core.add_thread(function() + while true do + if self.first_invalid_line > self.max_wanted_line then + self.max_wanted_line = 0 + coroutine.yield(1 / config.fps) + + else + local max = math.min(self.first_invalid_line + 40, self.max_wanted_line) + + for i = self.first_invalid_line, max do + local state = (i > 1) and self.lines[i - 1].state + local line = self.lines[i] + if not (line and line.init_state == state) then + self.lines[i] = self:tokenize_line(i, state) + end + end + + self.first_invalid_line = max + 1 + core.redraw = true + coroutine.yield() + end + end + end, self) +end + + +function Highlighter:reset() + self.lines = {} + self.first_invalid_line = 1 + self.max_wanted_line = 0 +end + + +function Highlighter:invalidate(idx) + self.first_invalid_line = math.min(self.first_invalid_line, idx) + self.max_wanted_line = math.min(self.max_wanted_line, #self.doc.lines) +end + + +function Highlighter:tokenize_line(idx, state) + local res = {} + res.init_state = state + res.text = self.doc.lines[idx] + res.tokens, res.state = tokenizer.tokenize(self.doc.syntax, res.text, state) + return res +end + + +function Highlighter:get_line(idx) + local line = self.lines[idx] + if not line or line.text ~= self.doc.lines[idx] then + local prev = self.lines[idx - 1] + line = self:tokenize_line(idx, prev and prev.state) + self.lines[idx] = line + end + self.max_wanted_line = math.max(self.max_wanted_line, idx) + return line +end + + +function Highlighter:each_token(idx) + return tokenizer.each_token(self:get_line(idx).tokens) +end + + +return Highlighter diff --git a/vendor/lite/data/core/doc/init.lua b/vendor/lite/data/core/doc/init.lua new file mode 100644 index 0000000..83b5fc0 --- /dev/null +++ b/vendor/lite/data/core/doc/init.lua @@ -0,0 +1,393 @@ +local Object = require "core.object" +local Highlighter = require "core.doc.highlighter" +local syntax = require "core.syntax" +local config = require "core.config" +local common = require "core.common" + + +local Doc = Object:extend() + + +local function split_lines(text) + local res = {} + for line in (text .. "\n"):gmatch("(.-)\n") do + table.insert(res, line) + end + return res +end + + +local function splice(t, at, remove, insert) + insert = insert or {} + local offset = #insert - remove + local old_len = #t + if offset < 0 then + for i = at - offset, old_len - offset do + t[i + offset] = t[i] + end + elseif offset > 0 then + for i = old_len, at, -1 do + t[i + offset] = t[i] + end + end + for i, item in ipairs(insert) do + t[at + i - 1] = item + end +end + + +function Doc:new(filename) + self:reset() + if filename then + self:load(filename) + end +end + + +function Doc:reset() + self.lines = { "\n" } + self.selection = { a = { line=1, col=1 }, b = { line=1, col=1 } } + self.undo_stack = { idx = 1 } + self.redo_stack = { idx = 1 } + self.clean_change_id = 1 + self.highlighter = Highlighter(self) + self:reset_syntax() +end + + +function Doc:reset_syntax() + local header = self:get_text(1, 1, self:position_offset(1, 1, 128)) + local syn = syntax.get(self.filename or "", header) + if self.syntax ~= syn then + self.syntax = syn + self.highlighter:reset() + end +end + + +function Doc:load(filename) + local fp = assert( io.open(filename, "rb") ) + self:reset() + self.filename = filename + self.lines = {} + for line in fp:lines() do + if line:byte(-1) == 13 then + line = line:sub(1, -2) + self.crlf = true + end + table.insert(self.lines, line .. "\n") + end + if #self.lines == 0 then + table.insert(self.lines, "\n") + end + fp:close() + self:reset_syntax() +end + + +function Doc:save(filename) + filename = filename or assert(self.filename, "no filename set to default to") + local fp = assert( io.open(filename, "wb") ) + for _, line in ipairs(self.lines) do + if self.crlf then line = line:gsub("\n", "\r\n") end + fp:write(line) + end + fp:close() + self.filename = filename or self.filename + self:reset_syntax() + self:clean() +end + + +function Doc:get_name() + return self.filename or "unsaved" +end + + +function Doc:is_dirty() + return self.clean_change_id ~= self:get_change_id() +end + + +function Doc:clean() + self.clean_change_id = self:get_change_id() +end + + +function Doc:get_change_id() + return self.undo_stack.idx +end + + +function Doc:set_selection(line1, col1, line2, col2, swap) + assert(not line2 == not col2, "expected 2 or 4 arguments") + if swap then line1, col1, line2, col2 = line2, col2, line1, col1 end + line1, col1 = self:sanitize_position(line1, col1) + line2, col2 = self:sanitize_position(line2 or line1, col2 or col1) + self.selection.a.line, self.selection.a.col = line1, col1 + self.selection.b.line, self.selection.b.col = line2, col2 +end + + +local function sort_positions(line1, col1, line2, col2) + if line1 > line2 + or line1 == line2 and col1 > col2 then + return line2, col2, line1, col1, true + end + return line1, col1, line2, col2, false +end + + +function Doc:get_selection(sort) + local a, b = self.selection.a, self.selection.b + if sort then + return sort_positions(a.line, a.col, b.line, b.col) + end + return a.line, a.col, b.line, b.col +end + + +function Doc:has_selection() + local a, b = self.selection.a, self.selection.b + return not (a.line == b.line and a.col == b.col) +end + + +function Doc:sanitize_selection() + self:set_selection(self:get_selection()) +end + + +function Doc:sanitize_position(line, col) + line = common.clamp(line, 1, #self.lines) + col = common.clamp(col, 1, #self.lines[line]) + return line, col +end + + +local function position_offset_func(self, line, col, fn, ...) + line, col = self:sanitize_position(line, col) + return fn(self, line, col, ...) +end + + +local function position_offset_byte(self, line, col, offset) + line, col = self:sanitize_position(line, col) + col = col + offset + while line > 1 and col < 1 do + line = line - 1 + col = col + #self.lines[line] + end + while line < #self.lines and col > #self.lines[line] do + col = col - #self.lines[line] + line = line + 1 + end + return self:sanitize_position(line, col) +end + + +local function position_offset_linecol(self, line, col, lineoffset, coloffset) + return self:sanitize_position(line + lineoffset, col + coloffset) +end + + +function Doc:position_offset(line, col, ...) + if type(...) ~= "number" then + return position_offset_func(self, line, col, ...) + elseif select("#", ...) == 1 then + return position_offset_byte(self, line, col, ...) + elseif select("#", ...) == 2 then + return position_offset_linecol(self, line, col, ...) + else + error("bad number of arguments") + end +end + + +function Doc:get_text(line1, col1, line2, col2) + line1, col1 = self:sanitize_position(line1, col1) + line2, col2 = self:sanitize_position(line2, col2) + line1, col1, line2, col2 = sort_positions(line1, col1, line2, col2) + if line1 == line2 then + return self.lines[line1]:sub(col1, col2 - 1) + end + local lines = { self.lines[line1]:sub(col1) } + for i = line1 + 1, line2 - 1 do + table.insert(lines, self.lines[i]) + end + table.insert(lines, self.lines[line2]:sub(1, col2 - 1)) + return table.concat(lines) +end + + +function Doc:get_char(line, col) + line, col = self:sanitize_position(line, col) + return self.lines[line]:sub(col, col) +end + + +local function push_undo(undo_stack, time, type, ...) + undo_stack[undo_stack.idx] = { type = type, time = time, ... } + undo_stack[undo_stack.idx - config.max_undos] = nil + undo_stack.idx = undo_stack.idx + 1 +end + + +local function pop_undo(self, undo_stack, redo_stack) + -- pop command + local cmd = undo_stack[undo_stack.idx - 1] + if not cmd then return end + undo_stack.idx = undo_stack.idx - 1 + + -- handle command + if cmd.type == "insert" then + local line, col, text = table.unpack(cmd) + self:raw_insert(line, col, text, redo_stack, cmd.time) + + elseif cmd.type == "remove" then + local line1, col1, line2, col2 = table.unpack(cmd) + self:raw_remove(line1, col1, line2, col2, redo_stack, cmd.time) + + elseif cmd.type == "selection" then + self.selection.a.line, self.selection.a.col = cmd[1], cmd[2] + self.selection.b.line, self.selection.b.col = cmd[3], cmd[4] + end + + -- if next undo command is within the merge timeout then treat as a single + -- command and continue to execute it + local next = undo_stack[undo_stack.idx - 1] + if next and math.abs(cmd.time - next.time) < config.undo_merge_timeout then + return pop_undo(self, undo_stack, redo_stack) + end +end + + +function Doc:raw_insert(line, col, text, undo_stack, time) + -- split text into lines and merge with line at insertion point + local lines = split_lines(text) + local before = self.lines[line]:sub(1, col - 1) + local after = self.lines[line]:sub(col) + for i = 1, #lines - 1 do + lines[i] = lines[i] .. "\n" + end + lines[1] = before .. lines[1] + lines[#lines] = lines[#lines] .. after + + -- splice lines into line array + splice(self.lines, line, 1, lines) + + -- push undo + local line2, col2 = self:position_offset(line, col, #text) + push_undo(undo_stack, time, "selection", self:get_selection()) + push_undo(undo_stack, time, "remove", line, col, line2, col2) + + -- update highlighter and assure selection is in bounds + self.highlighter:invalidate(line) + self:sanitize_selection() +end + + +function Doc:raw_remove(line1, col1, line2, col2, undo_stack, time) + -- push undo + local text = self:get_text(line1, col1, line2, col2) + push_undo(undo_stack, time, "selection", self:get_selection()) + push_undo(undo_stack, time, "insert", line1, col1, text) + + -- get line content before/after removed text + local before = self.lines[line1]:sub(1, col1 - 1) + local after = self.lines[line2]:sub(col2) + + -- splice line into line array + splice(self.lines, line1, line2 - line1 + 1, { before .. after }) + + -- update highlighter and assure selection is in bounds + self.highlighter:invalidate(line1) + self:sanitize_selection() +end + + +function Doc:insert(line, col, text) + self.redo_stack = { idx = 1 } + line, col = self:sanitize_position(line, col) + self:raw_insert(line, col, text, self.undo_stack, system.get_time()) +end + + +function Doc:remove(line1, col1, line2, col2) + self.redo_stack = { idx = 1 } + line1, col1 = self:sanitize_position(line1, col1) + line2, col2 = self:sanitize_position(line2, col2) + line1, col1, line2, col2 = sort_positions(line1, col1, line2, col2) + self:raw_remove(line1, col1, line2, col2, self.undo_stack, system.get_time()) +end + + +function Doc:undo() + pop_undo(self, self.undo_stack, self.redo_stack) +end + + +function Doc:redo() + pop_undo(self, self.redo_stack, self.undo_stack) +end + + +function Doc:text_input(text) + if self:has_selection() then + self:delete_to() + end + local line, col = self:get_selection() + self:insert(line, col, text) + self:move_to(#text) +end + + +function Doc:replace(fn) + local line1, col1, line2, col2, swap + local had_selection = self:has_selection() + if had_selection then + line1, col1, line2, col2, swap = self:get_selection(true) + else + line1, col1, line2, col2 = 1, 1, #self.lines, #self.lines[#self.lines] + end + local old_text = self:get_text(line1, col1, line2, col2) + local new_text, n = fn(old_text) + if old_text ~= new_text then + self:insert(line2, col2, new_text) + self:remove(line1, col1, line2, col2) + if had_selection then + line2, col2 = self:position_offset(line1, col1, #new_text) + self:set_selection(line1, col1, line2, col2, swap) + end + end + return n +end + + +function Doc:delete_to(...) + local line, col = self:get_selection(true) + if self:has_selection() then + self:remove(self:get_selection()) + else + local line2, col2 = self:position_offset(line, col, ...) + self:remove(line, col, line2, col2) + line, col = sort_positions(line, col, line2, col2) + end + self:set_selection(line, col) +end + + +function Doc:move_to(...) + local line, col = self:get_selection() + self:set_selection(self:position_offset(line, col, ...)) +end + + +function Doc:select_to(...) + local line, col, line2, col2 = self:get_selection() + line, col = self:position_offset(line, col, ...) + self:set_selection(line, col, line2, col2) +end + + +return Doc diff --git a/vendor/lite/data/core/doc/search.lua b/vendor/lite/data/core/doc/search.lua new file mode 100644 index 0000000..fe57523 --- /dev/null +++ b/vendor/lite/data/core/doc/search.lua @@ -0,0 +1,52 @@ +local search = {} + +local default_opt = {} + + +local function pattern_lower(str) + if str:sub(1, 1) == "%" then + return str + end + return str:lower() +end + + +local function init_args(doc, line, col, text, opt) + opt = opt or default_opt + line, col = doc:sanitize_position(line, col) + + if opt.no_case then + if opt.pattern then + text = text:gsub("%%?.", pattern_lower) + else + text = text:lower() + end + end + + return doc, line, col, text, opt +end + + +function search.find(doc, line, col, text, opt) + doc, line, col, text, opt = init_args(doc, line, col, text, opt) + + for line = line, #doc.lines do + local line_text = doc.lines[line] + if opt.no_case then + line_text = line_text:lower() + end + local s, e = line_text:find(text, col, not opt.pattern) + if s then + return line, s, line, e + 1 + end + col = 1 + end + + if opt.wrap then + opt = { no_case = opt.no_case, pattern = opt.pattern } + return search.find(doc, 1, 1, text, opt) + end +end + + +return search diff --git a/vendor/lite/data/core/doc/translate.lua b/vendor/lite/data/core/doc/translate.lua new file mode 100644 index 0000000..b084e89 --- /dev/null +++ b/vendor/lite/data/core/doc/translate.lua @@ -0,0 +1,136 @@ +local common = require "core.common" +local config = require "core.config" + +-- functions for translating a Doc position to another position these functions +-- can be passed to Doc:move_to|select_to|delete_to() + +local translate = {} + + +local function is_non_word(char) + return config.non_word_chars:find(char, nil, true) +end + + +function translate.previous_char(doc, line, col) + repeat + line, col = doc:position_offset(line, col, -1) + until not common.is_utf8_cont(doc:get_char(line, col)) + return line, col +end + + +function translate.next_char(doc, line, col) + repeat + line, col = doc:position_offset(line, col, 1) + until not common.is_utf8_cont(doc:get_char(line, col)) + return line, col +end + + +function translate.previous_word_start(doc, line, col) + local prev + while line > 1 or col > 1 do + local l, c = doc:position_offset(line, col, -1) + local char = doc:get_char(l, c) + if prev and prev ~= char or not is_non_word(char) then + break + end + prev, line, col = char, l, c + end + return translate.start_of_word(doc, line, col) +end + + +function translate.next_word_end(doc, line, col) + local prev + local end_line, end_col = translate.end_of_doc(doc, line, col) + while line < end_line or col < end_col do + local char = doc:get_char(line, col) + if prev and prev ~= char or not is_non_word(char) then + break + end + line, col = doc:position_offset(line, col, 1) + prev = char + end + return translate.end_of_word(doc, line, col) +end + + +function translate.start_of_word(doc, line, col) + while true do + local line2, col2 = doc:position_offset(line, col, -1) + local char = doc:get_char(line2, col2) + if is_non_word(char) + or line == line2 and col == col2 then + break + end + line, col = line2, col2 + end + return line, col +end + + +function translate.end_of_word(doc, line, col) + while true do + local line2, col2 = doc:position_offset(line, col, 1) + local char = doc:get_char(line, col) + if is_non_word(char) + or line == line2 and col == col2 then + break + end + line, col = line2, col2 + end + return line, col +end + + +function translate.previous_block_start(doc, line, col) + while true do + line = line - 1 + if line <= 1 then + return 1, 1 + end + if doc.lines[line-1]:find("^%s*$") + and not doc.lines[line]:find("^%s*$") then + return line, (doc.lines[line]:find("%S")) + end + end +end + + +function translate.next_block_end(doc, line, col) + while true do + if line >= #doc.lines then + return #doc.lines, 1 + end + if doc.lines[line+1]:find("^%s*$") + and not doc.lines[line]:find("^%s*$") then + return line+1, #doc.lines[line+1] + end + line = line + 1 + end +end + + +function translate.start_of_line(doc, line, col) + return line, 1 +end + + +function translate.end_of_line(doc, line, col) + return line, math.huge +end + + +function translate.start_of_doc(doc, line, col) + return 1, 1 +end + + +function translate.end_of_doc(doc, line, col) + return #doc.lines, #doc.lines[#doc.lines] +end + + +return translate diff --git a/vendor/lite/data/core/docview.lua b/vendor/lite/data/core/docview.lua new file mode 100644 index 0000000..73191c2 --- /dev/null +++ b/vendor/lite/data/core/docview.lua @@ -0,0 +1,383 @@ +local core = require "core" +local common = require "core.common" +local config = require "core.config" +local style = require "core.style" +local keymap = require "core.keymap" +local translate = require "core.doc.translate" +local View = require "core.view" + + +local DocView = View:extend() + + +local function move_to_line_offset(dv, line, col, offset) + local xo = dv.last_x_offset + if xo.line ~= line or xo.col ~= col then + xo.offset = dv:get_col_x_offset(line, col) + end + xo.line = line + offset + xo.col = dv:get_x_offset_col(line + offset, xo.offset) + return xo.line, xo.col +end + + +DocView.translate = { + ["previous_page"] = function(doc, line, col, dv) + local min, max = dv:get_visible_line_range() + return line - (max - min), 1 + end, + + ["next_page"] = function(doc, line, col, dv) + local min, max = dv:get_visible_line_range() + return line + (max - min), 1 + end, + + ["previous_line"] = function(doc, line, col, dv) + if line == 1 then + return 1, 1 + end + return move_to_line_offset(dv, line, col, -1) + end, + + ["next_line"] = function(doc, line, col, dv) + if line == #doc.lines then + return #doc.lines, math.huge + end + return move_to_line_offset(dv, line, col, 1) + end, +} + +local blink_period = 0.8 + + +function DocView:new(doc) + DocView.super.new(self) + self.cursor = "ibeam" + self.scrollable = true + self.doc = assert(doc) + self.font = "code_font" + self.last_x_offset = {} + self.blink_timer = 0 +end + + +function DocView:try_close(do_close) + if self.doc:is_dirty() + and #core.get_views_referencing_doc(self.doc) == 1 then + core.command_view:enter("Unsaved Changes; Confirm Close", function(_, item) + if item.text:match("^[cC]") then + do_close() + elseif item.text:match("^[sS]") then + self.doc:save() + do_close() + end + end, function(text) + local items = {} + if not text:find("^[^cC]") then table.insert(items, "Close Without Saving") end + if not text:find("^[^sS]") then table.insert(items, "Save And Close") end + return items + end) + else + do_close() + end +end + + +function DocView:get_name() + local post = self.doc:is_dirty() and "*" or "" + local name = self.doc:get_name() + return name:match("[^/%\\]*$") .. post +end + + +function DocView:get_scrollable_size() + return self:get_line_height() * (#self.doc.lines - 1) + self.size.y +end + + +function DocView:get_font() + return style[self.font] +end + + +function DocView:get_line_height() + return math.floor(self:get_font():get_height() * config.line_height) +end + + +function DocView:get_gutter_width() + return self:get_font():get_width(#self.doc.lines) + style.padding.x * 2 +end + + +function DocView:get_line_screen_position(idx) + local x, y = self:get_content_offset() + local lh = self:get_line_height() + local gw = self:get_gutter_width() + return x + gw, y + (idx-1) * lh + style.padding.y +end + + +function DocView:get_line_text_y_offset() + local lh = self:get_line_height() + local th = self:get_font():get_height() + return (lh - th) / 2 +end + + +function DocView:get_visible_line_range() + local x, y, x2, y2 = self:get_content_bounds() + local lh = self:get_line_height() + local minline = math.max(1, math.floor(y / lh)) + local maxline = math.min(#self.doc.lines, math.floor(y2 / lh) + 1) + return minline, maxline +end + + +function DocView:get_col_x_offset(line, col) + local text = self.doc.lines[line] + if not text then return 0 end + return self:get_font():get_width(text:sub(1, col - 1)) +end + + +function DocView:get_x_offset_col(line, x) + local text = self.doc.lines[line] + + local xoffset, last_i, i = 0, 1, 1 + for char in common.utf8_chars(text) do + local w = self:get_font():get_width(char) + if xoffset >= x then + return (xoffset - x > w / 2) and last_i or i + end + xoffset = xoffset + w + last_i = i + i = i + #char + end + + return #text +end + + +function DocView:resolve_screen_position(x, y) + local ox, oy = self:get_line_screen_position(1) + local line = math.floor((y - oy) / self:get_line_height()) + 1 + line = common.clamp(line, 1, #self.doc.lines) + local col = self:get_x_offset_col(line, x - ox) + return line, col +end + + +function DocView:scroll_to_line(line, ignore_if_visible, instant) + local min, max = self:get_visible_line_range() + if not (ignore_if_visible and line > min and line < max) then + local lh = self:get_line_height() + self.scroll.to.y = math.max(0, lh * (line - 1) - self.size.y / 2) + if instant then + self.scroll.y = self.scroll.to.y + end + end +end + + +function DocView:scroll_to_make_visible(line, col) + local min = self:get_line_height() * (line - 1) + local max = self:get_line_height() * (line + 2) - self.size.y + self.scroll.to.y = math.min(self.scroll.to.y, min) + self.scroll.to.y = math.max(self.scroll.to.y, max) + local gw = self:get_gutter_width() + local xoffset = self:get_col_x_offset(line, col) + local max = xoffset - self.size.x + gw + self.size.x / 5 + self.scroll.to.x = math.max(0, max) +end + + +local function mouse_selection(doc, clicks, line1, col1, line2, col2) + local swap = line2 < line1 or line2 == line1 and col2 <= col1 + if swap then + line1, col1, line2, col2 = line2, col2, line1, col1 + end + if clicks == 2 then + line1, col1 = translate.start_of_word(doc, line1, col1) + line2, col2 = translate.end_of_word(doc, line2, col2) + elseif clicks == 3 then + if line2 == #doc.lines and doc.lines[#doc.lines] ~= "\n" then + doc:insert(math.huge, math.huge, "\n") + end + line1, col1, line2, col2 = line1, 1, line2 + 1, 1 + end + if swap then + return line2, col2, line1, col1 + end + return line1, col1, line2, col2 +end + + +function DocView:on_mouse_pressed(button, x, y, clicks) + local caught = DocView.super.on_mouse_pressed(self, button, x, y, clicks) + if caught then + return + end + if keymap.modkeys["shift"] then + if clicks == 1 then + local line1, col1 = select(3, self.doc:get_selection()) + local line2, col2 = self:resolve_screen_position(x, y) + self.doc:set_selection(line2, col2, line1, col1) + end + else + local line, col = self:resolve_screen_position(x, y) + self.doc:set_selection(mouse_selection(self.doc, clicks, line, col, line, col)) + self.mouse_selecting = { line, col, clicks = clicks } + end + self.blink_timer = 0 +end + + +function DocView:on_mouse_moved(x, y, ...) + DocView.super.on_mouse_moved(self, x, y, ...) + + if self:scrollbar_overlaps_point(x, y) or self.dragging_scrollbar then + self.cursor = "arrow" + else + self.cursor = "ibeam" + end + + if self.mouse_selecting then + local l1, c1 = self:resolve_screen_position(x, y) + local l2, c2 = table.unpack(self.mouse_selecting) + local clicks = self.mouse_selecting.clicks + self.doc:set_selection(mouse_selection(self.doc, clicks, l1, c1, l2, c2)) + end +end + + +function DocView:on_mouse_released(button) + DocView.super.on_mouse_released(self, button) + self.mouse_selecting = nil +end + + +function DocView:on_text_input(text) + self.doc:text_input(text) +end + + +function DocView:update() + -- scroll to make caret visible and reset blink timer if it moved + local line, col = self.doc:get_selection() + if (line ~= self.last_line or col ~= self.last_col) and self.size.x > 0 then + if core.active_view == self then + self:scroll_to_make_visible(line, col) + end + self.blink_timer = 0 + self.last_line, self.last_col = line, col + end + + -- update blink timer + if self == core.active_view and not self.mouse_selecting then + local n = blink_period / 2 + local prev = self.blink_timer + self.blink_timer = (self.blink_timer + 1 / config.fps) % blink_period + if (self.blink_timer > n) ~= (prev > n) then + core.redraw = true + end + end + + DocView.super.update(self) +end + + +function DocView:draw_line_highlight(x, y) + local lh = self:get_line_height() + renderer.draw_rect(x, y, self.size.x, lh, style.line_highlight) +end + + +function DocView:draw_line_text(idx, x, y) + local tx, ty = x, y + self:get_line_text_y_offset() + local font = self:get_font() + for _, type, text in self.doc.highlighter:each_token(idx) do + local color = style.syntax[type] + tx = renderer.draw_text(font, text, tx, ty, color) + end +end + + +function DocView:draw_line_body(idx, x, y) + local line, col = self.doc:get_selection() + + -- draw selection if it overlaps this line + local line1, col1, line2, col2 = self.doc:get_selection(true) + if idx >= line1 and idx <= line2 then + local text = self.doc.lines[idx] + if line1 ~= idx then col1 = 1 end + if line2 ~= idx then col2 = #text + 1 end + local x1 = x + self:get_col_x_offset(idx, col1) + local x2 = x + self:get_col_x_offset(idx, col2) + local lh = self:get_line_height() + renderer.draw_rect(x1, y, x2 - x1, lh, style.selection) + end + + -- draw line highlight if caret is on this line + if config.highlight_current_line and not self.doc:has_selection() + and line == idx and core.active_view == self then + self:draw_line_highlight(x + self.scroll.x, y) + end + + -- draw line's text + self:draw_line_text(idx, x, y) + + -- draw caret if it overlaps this line + if line == idx and core.active_view == self + and self.blink_timer < blink_period / 2 + and system.window_has_focus() then + local lh = self:get_line_height() + local x1 = x + self:get_col_x_offset(line, col) + renderer.draw_rect(x1, y, style.caret_width, lh, style.caret) + end +end + + +function DocView:draw_line_gutter(idx, x, y) + local color = style.line_number + local line1, _, line2, _ = self.doc:get_selection(true) + if idx >= line1 and idx <= line2 then + color = style.line_number2 + end + local yoffset = self:get_line_text_y_offset() + x = x + style.padding.x + renderer.draw_text(self:get_font(), idx, x, y + yoffset, color) +end + + +function DocView:draw() + self:draw_background(style.background) + + local font = self:get_font() + font:set_tab_width(font:get_width(" ") * config.indent_size) + + local minline, maxline = self:get_visible_line_range() + local lh = self:get_line_height() + + local _, y = self:get_line_screen_position(minline) + local x = self.position.x + for i = minline, maxline do + self:draw_line_gutter(i, x, y) + y = y + lh + end + + local x, y = self:get_line_screen_position(minline) + local gw = self:get_gutter_width() + local pos = self.position + core.push_clip_rect(pos.x + gw, pos.y, self.size.x, self.size.y) + for i = minline, maxline do + self:draw_line_body(i, x, y) + y = y + lh + end + core.pop_clip_rect() + + self:draw_scrollbar() +end + + +return DocView diff --git a/vendor/lite/data/core/init.lua b/vendor/lite/data/core/init.lua new file mode 100644 index 0000000..3af4844 --- /dev/null +++ b/vendor/lite/data/core/init.lua @@ -0,0 +1,487 @@ +require "core.strict" +local common = require "core.common" +local config = require "core.config" +local style = require "core.style" +local command +local keymap +local RootView +local StatusView +local CommandView +local Doc + +local core = {} + + +local function project_scan_thread() + local function diff_files(a, b) + if #a ~= #b then return true end + for i, v in ipairs(a) do + if b[i].filename ~= v.filename + or b[i].modified ~= v.modified then + return true + end + end + end + + local function compare_file(a, b) + return a.filename < b.filename + end + + local function get_files(path, t) + coroutine.yield() + t = t or {} + local size_limit = config.file_size_limit * 10e5 + local all = system.list_dir(path) or {} + local dirs, files = {}, {} + + for _, file in ipairs(all) do + if not common.match_pattern(file, config.ignore_files) then + local file = (path ~= "." and path .. PATHSEP or "") .. file + local info = system.get_file_info(file) + if info and info.size < size_limit then + info.filename = file + table.insert(info.type == "dir" and dirs or files, info) + end + end + end + + table.sort(dirs, compare_file) + for _, f in ipairs(dirs) do + table.insert(t, f) + get_files(f.filename, t) + end + + table.sort(files, compare_file) + for _, f in ipairs(files) do + table.insert(t, f) + end + + return t + end + + while true do + -- get project files and replace previous table if the new table is + -- different + local t = get_files(".") + if diff_files(core.project_files, t) then + core.project_files = t + core.redraw = true + end + + -- wait for next scan + coroutine.yield(config.project_scan_rate) + end +end + + +function core.init() + command = require "core.command" + keymap = require "core.keymap" + RootView = require "core.rootview" + StatusView = require "core.statusview" + CommandView = require "core.commandview" + Doc = require "core.doc" + + local project_dir = EXEDIR + local files = {} + for i = 2, #ARGS do + local info = system.get_file_info(ARGS[i]) or {} + if info.type == "file" then + table.insert(files, system.absolute_path(ARGS[i])) + elseif info.type == "dir" then + project_dir = ARGS[i] + end + end + + system.chdir(project_dir) + + core.frame_start = 0 + core.clip_rect_stack = {{ 0,0,0,0 }} + core.log_items = {} + core.docs = {} + core.threads = setmetatable({}, { __mode = "k" }) + core.project_files = {} + core.redraw = true + + core.root_view = RootView() + core.command_view = CommandView() + core.status_view = StatusView() + + core.root_view.root_node:split("down", core.command_view, true) + core.root_view.root_node.b:split("down", core.status_view, true) + + core.add_thread(project_scan_thread) + command.add_defaults() + local got_plugin_error = not core.load_plugins() + local got_user_error = not core.try(require, "user") + local got_project_error = not core.load_project_module() + + for _, filename in ipairs(files) do + core.root_view:open_doc(core.open_doc(filename)) + end + + if got_plugin_error or got_user_error or got_project_error then + command.perform("core:open-log") + end +end + + +local temp_uid = (system.get_time() * 1000) % 0xffffffff +local temp_file_prefix = string.format(".lite_temp_%08x", temp_uid) +local temp_file_counter = 0 + +local function delete_temp_files() + for _, filename in ipairs(system.list_dir(EXEDIR)) do + if filename:find(temp_file_prefix, 1, true) == 1 then + os.remove(EXEDIR .. PATHSEP .. filename) + end + end +end + +function core.temp_filename(ext) + temp_file_counter = temp_file_counter + 1 + return EXEDIR .. PATHSEP .. temp_file_prefix + .. string.format("%06x", temp_file_counter) .. (ext or "") +end + + +function core.quit(force) + if force then + delete_temp_files() + os.exit() + end + local dirty_count = 0 + local dirty_name + for _, doc in ipairs(core.docs) do + if doc:is_dirty() then + dirty_count = dirty_count + 1 + dirty_name = doc:get_name() + end + end + if dirty_count > 0 then + local text + if dirty_count == 1 then + text = string.format("\"%s\" has unsaved changes. Quit anyway?", dirty_name) + else + text = string.format("%d docs have unsaved changes. Quit anyway?", dirty_count) + end + local confirm = system.show_confirm_dialog("Unsaved Changes", text) + if not confirm then return end + end + core.quit(true) +end + + +function core.load_plugins() + local no_errors = true + local files = system.list_dir(EXEDIR .. "/data/plugins") + for _, filename in ipairs(files) do + local modname = "plugins." .. filename:gsub(".lua$", "") + local ok = core.try(require, modname) + if ok then + core.log_quiet("Loaded plugin %q", modname) + else + no_errors = false + end + end + return no_errors +end + + +function core.load_project_module() + local filename = ".lite_project.lua" + if system.get_file_info(filename) then + return core.try(function() + local fn, err = loadfile(filename) + if not fn then error("Error when loading project module:\n\t" .. err) end + fn() + core.log_quiet("Loaded project module") + end) + end + return true +end + + +function core.reload_module(name) + local old = package.loaded[name] + package.loaded[name] = nil + local new = require(name) + if type(old) == "table" then + for k, v in pairs(new) do old[k] = v end + package.loaded[name] = old + end +end + + +function core.set_active_view(view) + assert(view, "Tried to set active view to nil") + if view ~= core.active_view then + core.last_active_view = core.active_view + core.active_view = view + end +end + + +function core.add_thread(f, weak_ref) + local key = weak_ref or #core.threads + 1 + local fn = function() return core.try(f) end + core.threads[key] = { cr = coroutine.create(fn), wake = 0 } +end + + +function core.push_clip_rect(x, y, w, h) + local x2, y2, w2, h2 = table.unpack(core.clip_rect_stack[#core.clip_rect_stack]) + local r, b, r2, b2 = x+w, y+h, x2+w2, y2+h2 + x, y = math.max(x, x2), math.max(y, y2) + b, r = math.min(b, b2), math.min(r, r2) + w, h = r-x, b-y + table.insert(core.clip_rect_stack, { x, y, w, h }) + renderer.set_clip_rect(x, y, w, h) + return (#core.clip_rect_stack) - 1 +end + +function core.pop_clip_rect_to(length) + while #core.clip_rect_stack > length do + core.pop_clip_rect() + end +end + +function core.pop_clip_rect() + table.remove(core.clip_rect_stack) + local x, y, w, h = table.unpack(core.clip_rect_stack[#core.clip_rect_stack]) + renderer.set_clip_rect(x, y, w, h) +end + + +function core.open_doc(filename) + if filename then + -- try to find existing doc for filename + local abs_filename = system.absolute_path(filename) + for _, doc in ipairs(core.docs) do + if doc.filename + and abs_filename == system.absolute_path(doc.filename) then + return doc + end + end + end + -- no existing doc for filename; create new + local doc = Doc(filename) + table.insert(core.docs, doc) + core.log_quiet(filename and "Opened doc \"%s\"" or "Opened new doc", filename) + return doc +end + + +function core.get_views_referencing_doc(doc) + local res = {} + local views = core.root_view.root_node:get_children() + for _, view in ipairs(views) do + if view.doc == doc then table.insert(res, view) end + end + return res +end + + +local function log(icon, icon_color, fmt, ...) + local text = string.format(fmt, ...) + if icon then + core.status_view:show_message(icon, icon_color, text) + end + + local info = debug.getinfo(2, "Sl") + local at = string.format("%s:%d", info.short_src, info.currentline) + local item = { text = text, time = os.time(), at = at } + table.insert(core.log_items, item) + if #core.log_items > config.max_log_items then + table.remove(core.log_items, 1) + end + return item +end + + +function core.log(...) + return log("i", style.text, ...) +end + + +function core.log_quiet(...) + return log(nil, nil, ...) +end + + +function core.error(...) + return log("!", style.accent, ...) +end + + +function core.try(fn, ...) + local err + local ok, res = xpcall(fn, function(msg) + print(debug.traceback()) + local item = core.error("%s", msg) + item.info = debug.traceback(nil, 2):gsub("\t", "") + err = msg + end, ...) + if ok then + return true, res + end + return false, err +end + + +function core.on_event(type, ...) + local did_keymap = false + if type == "textinput" then + core.root_view:on_text_input(...) + elseif type == "keypressed" then + did_keymap = keymap.on_key_pressed(...) + elseif type == "keyreleased" then + keymap.on_key_released(...) + elseif type == "mousemoved" then + core.root_view:on_mouse_moved(...) + elseif type == "mousepressed" then + core.root_view:on_mouse_pressed(...) + elseif type == "mousereleased" then + core.root_view:on_mouse_released(...) + elseif type == "mousewheel" then + core.root_view:on_mouse_wheel(...) + elseif type == "filedropped" then + local filename, mx, my = ... + local info = system.get_file_info(filename) + if info and info.type == "dir" then + system.exec(string.format("%q %q", EXEFILE, filename)) + else + local ok, doc = core.try(core.open_doc, filename) + if ok then + local node = core.root_view.root_node:get_child_overlapping_point(mx, my) + node:set_active_view(node.active_view) + core.root_view:open_doc(doc) + end + end + elseif type == "quit" then + core.quit() + end + return did_keymap +end + + +function core.step() + -- handle events + local did_keymap = false + local mouse_moved = false + local mouse = { x = 0, y = 0, dx = 0, dy = 0 } + + for type, a,b,c,d in system.poll_event do + if type == "mousemoved" then + mouse_moved = true + mouse.x, mouse.y = a, b + mouse.dx, mouse.dy = mouse.dx + c, mouse.dy + d + elseif type == "textinput" and did_keymap then + did_keymap = false + else + local _, res = core.try(core.on_event, type, a, b, c, d) + did_keymap = res or did_keymap + end + core.redraw = true + end + if mouse_moved then + core.try(core.on_event, "mousemoved", mouse.x, mouse.y, mouse.dx, mouse.dy) + end + + local width, height = renderer.get_size() + + -- update + core.root_view.size.x, core.root_view.size.y = width, height + core.root_view:update() + if not core.redraw then return false end + core.redraw = false + + -- close unreferenced docs + for i = #core.docs, 1, -1 do + local doc = core.docs[i] + if #core.get_views_referencing_doc(doc) == 0 then + table.remove(core.docs, i) + core.log_quiet("Closed doc \"%s\"", doc:get_name()) + end + end + + -- update window title + local name = core.active_view:get_name() + local title = (name ~= "---") and (name .. " - lite") or "lite" + if title ~= core.window_title then + system.set_window_title(title) + core.window_title = title + end + + -- draw + renderer.begin_frame() + core.clip_rect_stack[1] = { 0, 0, width, height } + renderer.set_clip_rect(table.unpack(core.clip_rect_stack[1])) + core.root_view:draw() + renderer.end_frame() + return true +end + + +core.run_threads = coroutine.wrap(function() + while true do + local max_time = 1 / config.fps - 0.004 + local ran_any_threads = false + + for k, thread in pairs(core.threads) do + -- run thread + if thread.wake < system.get_time() then + local _, wait = assert(coroutine.resume(thread.cr)) + if coroutine.status(thread.cr) == "dead" then + if type(k) == "number" then + table.remove(core.threads, k) + else + core.threads[k] = nil + end + elseif wait then + thread.wake = system.get_time() + wait + end + ran_any_threads = true + end + + -- stop running threads if we're about to hit the end of frame + if system.get_time() - core.frame_start > max_time then + coroutine.yield() + end + end + + if not ran_any_threads then coroutine.yield() end + end +end) + + +function core.run() + while true do + core.frame_start = system.get_time() + local did_redraw = core.step() + core.run_threads() + if not did_redraw and not system.window_has_focus() then + system.wait_event(0.25) + end + local elapsed = system.get_time() - core.frame_start + system.sleep(math.max(0, 1 / config.fps - elapsed)) + end +end + + +function core.on_error(err) + -- write error to file + local fp = io.open(EXEDIR .. "/error.txt", "wb") + fp:write("Error: " .. tostring(err) .. "\n") + fp:write(debug.traceback(nil, 4)) + fp:close() + -- save copy of all unsaved documents + for _, doc in ipairs(core.docs) do + if doc:is_dirty() and doc.filename then + doc:save(doc.filename .. "~") + end + end +end + + +return core diff --git a/vendor/lite/data/core/keymap.lua b/vendor/lite/data/core/keymap.lua new file mode 100644 index 0000000..4d48ed4 --- /dev/null +++ b/vendor/lite/data/core/keymap.lua @@ -0,0 +1,186 @@ +local command = require "core.command" +local keymap = {} + +keymap.modkeys = {} +keymap.map = {} +keymap.reverse_map = {} + +local modkey_map = { + ["left ctrl"] = "ctrl", + ["right ctrl"] = "ctrl", + ["left shift"] = "shift", + ["right shift"] = "shift", + ["left alt"] = "alt", + ["right alt"] = "altgr", +} + +local modkeys = { "ctrl", "alt", "altgr", "shift" } + +local function key_to_stroke(k) + local stroke = "" + for _, mk in ipairs(modkeys) do + if keymap.modkeys[mk] then + stroke = stroke .. mk .. "+" + end + end + return stroke .. k +end + + +function keymap.add(map, overwrite) + for stroke, commands in pairs(map) do + if type(commands) == "string" then + commands = { commands } + end + if overwrite then + keymap.map[stroke] = commands + else + keymap.map[stroke] = keymap.map[stroke] or {} + for i = #commands, 1, -1 do + table.insert(keymap.map[stroke], 1, commands[i]) + end + end + for _, cmd in ipairs(commands) do + keymap.reverse_map[cmd] = stroke + end + end +end + + +function keymap.get_binding(cmd) + return keymap.reverse_map[cmd] +end + + +function keymap.on_key_pressed(k) + local mk = modkey_map[k] + if mk then + keymap.modkeys[mk] = true + -- work-around for windows where `altgr` is treated as `ctrl+alt` + if mk == "altgr" then + keymap.modkeys["ctrl"] = false + end + else + local stroke = key_to_stroke(k) + local commands = keymap.map[stroke] + if commands then + for _, cmd in ipairs(commands) do + local performed = command.perform(cmd) + if performed then break end + end + return true + end + end + return false +end + + +function keymap.on_key_released(k) + local mk = modkey_map[k] + if mk then + keymap.modkeys[mk] = false + end +end + + +keymap.add { + ["ctrl+shift+p"] = "core:find-command", + ["ctrl+p"] = "core:find-file", + ["ctrl+o"] = "core:open-file", + ["ctrl+n"] = "core:new-doc", + ["alt+return"] = "core:toggle-fullscreen", + + ["alt+shift+j"] = "root:split-left", + ["alt+shift+l"] = "root:split-right", + ["alt+shift+i"] = "root:split-up", + ["alt+shift+k"] = "root:split-down", + ["alt+j"] = "root:switch-to-left", + ["alt+l"] = "root:switch-to-right", + ["alt+i"] = "root:switch-to-up", + ["alt+k"] = "root:switch-to-down", + + ["ctrl+w"] = "root:close", + ["ctrl+tab"] = "root:switch-to-next-tab", + ["ctrl+shift+tab"] = "root:switch-to-previous-tab", + ["ctrl+pageup"] = "root:move-tab-left", + ["ctrl+pagedown"] = "root:move-tab-right", + ["alt+1"] = "root:switch-to-tab-1", + ["alt+2"] = "root:switch-to-tab-2", + ["alt+3"] = "root:switch-to-tab-3", + ["alt+4"] = "root:switch-to-tab-4", + ["alt+5"] = "root:switch-to-tab-5", + ["alt+6"] = "root:switch-to-tab-6", + ["alt+7"] = "root:switch-to-tab-7", + ["alt+8"] = "root:switch-to-tab-8", + ["alt+9"] = "root:switch-to-tab-9", + + ["ctrl+f"] = "find-replace:find", + ["ctrl+r"] = "find-replace:replace", + ["f3"] = "find-replace:repeat-find", + ["shift+f3"] = "find-replace:previous-find", + ["ctrl+g"] = "doc:go-to-line", + ["ctrl+s"] = "doc:save", + ["ctrl+shift+s"] = "doc:save-as", + + ["ctrl+z"] = "doc:undo", + ["ctrl+y"] = "doc:redo", + ["ctrl+x"] = "doc:cut", + ["ctrl+c"] = "doc:copy", + ["ctrl+v"] = "doc:paste", + ["escape"] = { "command:escape", "doc:select-none" }, + ["tab"] = { "command:complete", "doc:indent" }, + ["shift+tab"] = "doc:unindent", + ["backspace"] = "doc:backspace", + ["shift+backspace"] = "doc:backspace", + ["ctrl+backspace"] = "doc:delete-to-previous-word-start", + ["ctrl+shift+backspace"] = "doc:delete-to-previous-word-start", + ["delete"] = "doc:delete", + ["shift+delete"] = "doc:delete", + ["ctrl+delete"] = "doc:delete-to-next-word-end", + ["ctrl+shift+delete"] = "doc:delete-to-next-word-end", + ["return"] = { "command:submit", "doc:newline" }, + ["keypad enter"] = { "command:submit", "doc:newline" }, + ["ctrl+return"] = "doc:newline-below", + ["ctrl+shift+return"] = "doc:newline-above", + ["ctrl+j"] = "doc:join-lines", + ["ctrl+a"] = "doc:select-all", + ["ctrl+d"] = { "find-replace:select-next", "doc:select-word" }, + ["ctrl+l"] = "doc:select-lines", + ["ctrl+/"] = "doc:toggle-line-comments", + ["ctrl+up"] = "doc:move-lines-up", + ["ctrl+down"] = "doc:move-lines-down", + ["ctrl+shift+d"] = "doc:duplicate-lines", + ["ctrl+shift+k"] = "doc:delete-lines", + + ["left"] = "doc:move-to-previous-char", + ["right"] = "doc:move-to-next-char", + ["up"] = { "command:select-previous", "doc:move-to-previous-line" }, + ["down"] = { "command:select-next", "doc:move-to-next-line" }, + ["ctrl+left"] = "doc:move-to-previous-word-start", + ["ctrl+right"] = "doc:move-to-next-word-end", + ["ctrl+["] = "doc:move-to-previous-block-start", + ["ctrl+]"] = "doc:move-to-next-block-end", + ["home"] = "doc:move-to-start-of-line", + ["end"] = "doc:move-to-end-of-line", + ["ctrl+home"] = "doc:move-to-start-of-doc", + ["ctrl+end"] = "doc:move-to-end-of-doc", + ["pageup"] = "doc:move-to-previous-page", + ["pagedown"] = "doc:move-to-next-page", + + ["shift+left"] = "doc:select-to-previous-char", + ["shift+right"] = "doc:select-to-next-char", + ["shift+up"] = "doc:select-to-previous-line", + ["shift+down"] = "doc:select-to-next-line", + ["ctrl+shift+left"] = "doc:select-to-previous-word-start", + ["ctrl+shift+right"] = "doc:select-to-next-word-end", + ["ctrl+shift+["] = "doc:select-to-previous-block-start", + ["ctrl+shift+]"] = "doc:select-to-next-block-end", + ["shift+home"] = "doc:select-to-start-of-line", + ["shift+end"] = "doc:select-to-end-of-line", + ["ctrl+shift+home"] = "doc:select-to-start-of-doc", + ["ctrl+shift+end"] = "doc:select-to-end-of-doc", + ["shift+pageup"] = "doc:select-to-previous-page", + ["shift+pagedown"] = "doc:select-to-next-page", +} + +return keymap diff --git a/vendor/lite/data/core/logview.lua b/vendor/lite/data/core/logview.lua new file mode 100644 index 0000000..d7142fb --- /dev/null +++ b/vendor/lite/data/core/logview.lua @@ -0,0 +1,74 @@ +local core = require "core" +local style = require "core.style" +local View = require "core.view" + + +local LogView = View:extend() + + +function LogView:new() + LogView.super.new(self) + self.last_item = core.log_items[#core.log_items] + self.scrollable = true + self.yoffset = 0 +end + + +function LogView:get_name() + return "Log" +end + + +function LogView:update() + local item = core.log_items[#core.log_items] + if self.last_item ~= item then + self.last_item = item + self.scroll.to.y = 0 + self.yoffset = -(style.font:get_height() + style.padding.y) + end + + self:move_towards("yoffset", 0) + + LogView.super.update(self) +end + + +local function draw_text_multiline(font, text, x, y, color) + local th = font:get_height() + local resx, resy = x, y + for line in text:gmatch("[^\n]+") do + resy = y + resx = renderer.draw_text(style.font, line, x, y, color) + y = y + th + end + return resx, resy +end + + +function LogView:draw() + self:draw_background(style.background) + + local ox, oy = self:get_content_offset() + local th = style.font:get_height() + local y = oy + style.padding.y + self.yoffset + + for i = #core.log_items, 1, -1 do + local x = ox + style.padding.x + local item = core.log_items[i] + local time = os.date(nil, item.time) + x = renderer.draw_text(style.font, time, x, y, style.dim) + x = x + style.padding.x + local subx = x + x, y = draw_text_multiline(style.font, item.text, x, y, style.text) + renderer.draw_text(style.font, " at " .. item.at, x, y, style.dim) + y = y + th + if item.info then + subx, y = draw_text_multiline(style.font, item.info, subx, y, style.dim) + y = y + th + end + y = y + style.padding.y + end +end + + +return LogView diff --git a/vendor/lite/data/core/object.lua b/vendor/lite/data/core/object.lua new file mode 100644 index 0000000..af41b7e --- /dev/null +++ b/vendor/lite/data/core/object.lua @@ -0,0 +1,58 @@ +local Object = {} +Object.__index = Object + + +function Object:new() +end + + +function Object:extend() + local cls = {} + for k, v in pairs(self) do + if k:find("__") == 1 then + cls[k] = v + end + end + cls.__index = cls + cls.super = self + setmetatable(cls, self) + return cls +end + + +function Object:implement(...) + for _, cls in pairs({...}) do + for k, v in pairs(cls) do + if self[k] == nil and type(v) == "function" then + self[k] = v + end + end + end +end + + +function Object:is(T) + local mt = getmetatable(self) + while mt do + if mt == T then + return true + end + mt = getmetatable(mt) + end + return false +end + + +function Object:__tostring() + return "Object" +end + + +function Object:__call(...) + local obj = setmetatable({}, self) + obj:new(...) + return obj +end + + +return Object diff --git a/vendor/lite/data/core/rootview.lua b/vendor/lite/data/core/rootview.lua new file mode 100644 index 0000000..ca29726 --- /dev/null +++ b/vendor/lite/data/core/rootview.lua @@ -0,0 +1,508 @@ +local core = require "core" +local common = require "core.common" +local style = require "core.style" +local keymap = require "core.keymap" +local Object = require "core.object" +local View = require "core.view" +local DocView = require "core.docview" + + +local EmptyView = View:extend() + +local function draw_text(x, y, color) + local th = style.big_font:get_height() + local dh = th + style.padding.y * 2 + x = renderer.draw_text(style.big_font, "lite", x, y + (dh - th) / 2, color) + x = x + style.padding.x + renderer.draw_rect(x, y, math.ceil(1 * SCALE), dh, color) + local lines = { + { fmt = "%s to run a command", cmd = "core:find-command" }, + { fmt = "%s to open a file from the project", cmd = "core:find-file" }, + } + th = style.font:get_height() + y = y + (dh - th * 2 - style.padding.y) / 2 + local w = 0 + for _, line in ipairs(lines) do + local text = string.format(line.fmt, keymap.get_binding(line.cmd)) + w = math.max(w, renderer.draw_text(style.font, text, x + style.padding.x, y, color)) + y = y + th + style.padding.y + end + return w, dh +end + +function EmptyView:draw() + self:draw_background(style.background) + local w, h = draw_text(0, 0, { 0, 0, 0, 0 }) + local x = self.position.x + math.max(style.padding.x, (self.size.x - w) / 2) + local y = self.position.y + (self.size.y - h) / 2 + draw_text(x, y, style.dim) +end + + + +local Node = Object:extend() + +function Node:new(type) + self.type = type or "leaf" + self.position = { x = 0, y = 0 } + self.size = { x = 0, y = 0 } + self.views = {} + self.divider = 0.5 + if self.type == "leaf" then + self:add_view(EmptyView()) + end +end + + +function Node:propagate(fn, ...) + self.a[fn](self.a, ...) + self.b[fn](self.b, ...) +end + + +function Node:on_mouse_moved(x, y, ...) + self.hovered_tab = self:get_tab_overlapping_point(x, y) + if self.type == "leaf" then + self.active_view:on_mouse_moved(x, y, ...) + else + self:propagate("on_mouse_moved", x, y, ...) + end +end + + +function Node:on_mouse_released(...) + if self.type == "leaf" then + self.active_view:on_mouse_released(...) + else + self:propagate("on_mouse_released", ...) + end +end + + +function Node:consume(node) + for k, _ in pairs(self) do self[k] = nil end + for k, v in pairs(node) do self[k] = v end +end + + +local type_map = { up="vsplit", down="vsplit", left="hsplit", right="hsplit" } + +function Node:split(dir, view, locked) + assert(self.type == "leaf", "Tried to split non-leaf node") + local type = assert(type_map[dir], "Invalid direction") + local last_active = core.active_view + local child = Node() + child:consume(self) + self:consume(Node(type)) + self.a = child + self.b = Node() + if view then self.b:add_view(view) end + if locked then + self.b.locked = locked + core.set_active_view(last_active) + end + if dir == "up" or dir == "left" then + self.a, self.b = self.b, self.a + end + return child +end + + +function Node:close_active_view(root) + local do_close = function() + if #self.views > 1 then + local idx = self:get_view_idx(self.active_view) + table.remove(self.views, idx) + self:set_active_view(self.views[idx] or self.views[#self.views]) + else + local parent = self:get_parent_node(root) + local is_a = (parent.a == self) + local other = parent[is_a and "b" or "a"] + if other:get_locked_size() then + self.views = {} + self:add_view(EmptyView()) + else + parent:consume(other) + local p = parent + while p.type ~= "leaf" do + p = p[is_a and "a" or "b"] + end + p:set_active_view(p.active_view) + end + end + core.last_active_view = nil + end + self.active_view:try_close(do_close) +end + + +function Node:add_view(view) + assert(self.type == "leaf", "Tried to add view to non-leaf node") + assert(not self.locked, "Tried to add view to locked node") + if self.views[1] and self.views[1]:is(EmptyView) then + table.remove(self.views) + end + table.insert(self.views, view) + self:set_active_view(view) +end + + +function Node:set_active_view(view) + assert(self.type == "leaf", "Tried to set active view on non-leaf node") + self.active_view = view + core.set_active_view(view) +end + + +function Node:get_view_idx(view) + for i, v in ipairs(self.views) do + if v == view then return i end + end +end + + +function Node:get_node_for_view(view) + for _, v in ipairs(self.views) do + if v == view then return self end + end + if self.type ~= "leaf" then + return self.a:get_node_for_view(view) or self.b:get_node_for_view(view) + end +end + + +function Node:get_parent_node(root) + if root.a == self or root.b == self then + return root + elseif root.type ~= "leaf" then + return self:get_parent_node(root.a) or self:get_parent_node(root.b) + end +end + + +function Node:get_children(t) + t = t or {} + for _, view in ipairs(self.views) do + table.insert(t, view) + end + if self.a then self.a:get_children(t) end + if self.b then self.b:get_children(t) end + return t +end + + +function Node:get_divider_overlapping_point(px, py) + if self.type ~= "leaf" then + local p = 6 + local x, y, w, h = self:get_divider_rect() + x, y = x - p, y - p + w, h = w + p * 2, h + p * 2 + if px > x and py > y and px < x + w and py < y + h then + return self + end + return self.a:get_divider_overlapping_point(px, py) + or self.b:get_divider_overlapping_point(px, py) + end +end + + +function Node:get_tab_overlapping_point(px, py) + if #self.views == 1 then return nil end + local x, y, w, h = self:get_tab_rect(1) + if px >= x and py >= y and px < x + w * #self.views and py < y + h then + return math.floor((px - x) / w) + 1 + end +end + + +function Node:get_child_overlapping_point(x, y) + local child + if self.type == "leaf" then + return self + elseif self.type == "hsplit" then + child = (x < self.b.position.x) and self.a or self.b + elseif self.type == "vsplit" then + child = (y < self.b.position.y) and self.a or self.b + end + return child:get_child_overlapping_point(x, y) +end + + +function Node:get_tab_rect(idx) + local tw = math.min(style.tab_width, math.ceil(self.size.x / #self.views)) + local h = style.font:get_height() + style.padding.y * 2 + return self.position.x + (idx-1) * tw, self.position.y, tw, h +end + + +function Node:get_divider_rect() + local x, y = self.position.x, self.position.y + if self.type == "hsplit" then + return x + self.a.size.x, y, style.divider_size, self.size.y + elseif self.type == "vsplit" then + return x, y + self.a.size.y, self.size.x, style.divider_size + end +end + + +function Node:get_locked_size() + if self.type == "leaf" then + if self.locked then + local size = self.active_view.size + return size.x, size.y + end + else + local x1, y1 = self.a:get_locked_size() + local x2, y2 = self.b:get_locked_size() + if x1 and x2 then + local dsx = (x1 < 1 or x2 < 1) and 0 or style.divider_size + local dsy = (y1 < 1 or y2 < 1) and 0 or style.divider_size + return x1 + x2 + dsx, y1 + y2 + dsy + end + end +end + + +local function copy_position_and_size(dst, src) + dst.position.x, dst.position.y = src.position.x, src.position.y + dst.size.x, dst.size.y = src.size.x, src.size.y +end + + +-- calculating the sizes is the same for hsplits and vsplits, except the x/y +-- axis are swapped; this function lets us use the same code for both +local function calc_split_sizes(self, x, y, x1, x2) + local n + local ds = (x1 and x1 < 1 or x2 and x2 < 1) and 0 or style.divider_size + if x1 then + n = x1 + ds + elseif x2 then + n = self.size[x] - x2 + else + n = math.floor(self.size[x] * self.divider) + end + self.a.position[x] = self.position[x] + self.a.position[y] = self.position[y] + self.a.size[x] = n - ds + self.a.size[y] = self.size[y] + self.b.position[x] = self.position[x] + n + self.b.position[y] = self.position[y] + self.b.size[x] = self.size[x] - n + self.b.size[y] = self.size[y] +end + + +function Node:update_layout() + if self.type == "leaf" then + local av = self.active_view + if #self.views > 1 then + local _, _, _, th = self:get_tab_rect(1) + av.position.x, av.position.y = self.position.x, self.position.y + th + av.size.x, av.size.y = self.size.x, self.size.y - th + else + copy_position_and_size(av, self) + end + else + local x1, y1 = self.a:get_locked_size() + local x2, y2 = self.b:get_locked_size() + if self.type == "hsplit" then + calc_split_sizes(self, "x", "y", x1, x2) + elseif self.type == "vsplit" then + calc_split_sizes(self, "y", "x", y1, y2) + end + self.a:update_layout() + self.b:update_layout() + end +end + + +function Node:update() + if self.type == "leaf" then + for _, view in ipairs(self.views) do + view:update() + end + else + self.a:update() + self.b:update() + end +end + + +function Node:draw_tabs() + local x, y, _, h = self:get_tab_rect(1) + local ds = style.divider_size + core.push_clip_rect(x, y, self.size.x, h) + renderer.draw_rect(x, y, self.size.x, h, style.background2) + renderer.draw_rect(x, y + h - ds, self.size.x, ds, style.divider) + + for i, view in ipairs(self.views) do + local x, y, w, h = self:get_tab_rect(i) + local text = view:get_name() + local color = style.dim + if view == self.active_view then + color = style.text + renderer.draw_rect(x, y, w, h, style.background) + renderer.draw_rect(x + w, y, ds, h, style.divider) + renderer.draw_rect(x - ds, y, ds, h, style.divider) + end + if i == self.hovered_tab then + color = style.text + end + core.push_clip_rect(x, y, w, h) + x, w = x + style.padding.x, w - style.padding.x * 2 + local align = style.font:get_width(text) > w and "left" or "center" + common.draw_text(style.font, color, text, align, x, y, w, h) + core.pop_clip_rect() + end + + core.pop_clip_rect() +end + + +function Node:draw() + if self.type == "leaf" then + if #self.views > 1 then + self:draw_tabs() + end + local pos, size = self.active_view.position, self.active_view.size + local clipstate = core.push_clip_rect(pos.x, pos.y, size.x + pos.x % 1, size.y + pos.y % 1) + xpcall(function() self.active_view:draw() end, + function(msg) + love.graphics.setCanvas(nil) + common.draw_text(style.font, { common.color "#ff0000" }, msg .. "\n" .. debug.traceback(), "left", pos.x, pos.y, size.x, size.y) + end) + core.pop_clip_rect_to(clipstate) + else + local x, y, w, h = self:get_divider_rect() + renderer.draw_rect(x, y, w, h, style.divider) + self:propagate("draw") + end +end + + + +local RootView = View:extend() + +function RootView:new() + RootView.super.new(self) + self.root_node = Node() + self.deferred_draws = {} + self.mouse = { x = 0, y = 0 } +end + + +function RootView:defer_draw(fn, ...) + table.insert(self.deferred_draws, 1, { fn = fn, ... }) +end + + +function RootView:get_active_node() + return self.root_node:get_node_for_view(core.active_view) +end + + +function RootView:open_doc(doc) + local node = self:get_active_node() + if node.locked and core.last_active_view then + core.set_active_view(core.last_active_view) + node = self:get_active_node() + end + assert(not node.locked, "Cannot open doc on locked node") + for i, view in ipairs(node.views) do + if view.doc == doc then + node:set_active_view(node.views[i]) + return view + end + end + local view = DocView(doc) + node:add_view(view) + self.root_node:update_layout() + view:scroll_to_line(view.doc:get_selection(), true, true) + return view +end + + +function RootView:on_mouse_pressed(button, x, y, clicks) + local div = self.root_node:get_divider_overlapping_point(x, y) + if div then + self.dragged_divider = div + return + end + local node = self.root_node:get_child_overlapping_point(x, y) + local idx = node:get_tab_overlapping_point(x, y) + if idx then + node:set_active_view(node.views[idx]) + if button == "middle" then + node:close_active_view(self.root_node) + end + else + core.set_active_view(node.active_view) + node.active_view:on_mouse_pressed(button, x, y, clicks) + end +end + + +function RootView:on_mouse_released(...) + if self.dragged_divider then + self.dragged_divider = nil + end + self.root_node:on_mouse_released(...) +end + + +function RootView:on_mouse_moved(x, y, dx, dy) + if self.dragged_divider then + local node = self.dragged_divider + if node.type == "hsplit" then + node.divider = node.divider + dx / node.size.x + else + node.divider = node.divider + dy / node.size.y + end + node.divider = common.clamp(node.divider, 0.01, 0.99) + return + end + + self.mouse.x, self.mouse.y = x, y + self.root_node:on_mouse_moved(x, y, dx, dy) + + local node = self.root_node:get_child_overlapping_point(x, y) + local div = self.root_node:get_divider_overlapping_point(x, y) + if div then + system.set_cursor(div.type == "hsplit" and "sizeh" or "sizev") + elseif node:get_tab_overlapping_point(x, y) then + system.set_cursor("arrow") + else + system.set_cursor(node.active_view.cursor) + end +end + + +function RootView:on_mouse_wheel(...) + local x, y = self.mouse.x, self.mouse.y + local node = self.root_node:get_child_overlapping_point(x, y) + node.active_view:on_mouse_wheel(...) +end + + +function RootView:on_text_input(...) + core.active_view:on_text_input(...) +end + + +function RootView:update() + copy_position_and_size(self.root_node, self) + self.root_node:update() + self.root_node:update_layout() +end + + +function RootView:draw() + self.root_node:draw() + while #self.deferred_draws > 0 do + local t = table.remove(self.deferred_draws) + t.fn(table.unpack(t)) + end +end + + +return RootView diff --git a/vendor/lite/data/core/statusview.lua b/vendor/lite/data/core/statusview.lua new file mode 100644 index 0000000..67a4c8b --- /dev/null +++ b/vendor/lite/data/core/statusview.lua @@ -0,0 +1,141 @@ +local core = require "core" +local common = require "core.common" +local command = require "core.command" +local config = require "core.config" +local style = require "core.style" +local DocView = require "core.docview" +local LogView = require "core.logview" +local View = require "core.view" + + +local StatusView = View:extend() + +StatusView.separator = " " +StatusView.separator2 = " | " + + +function StatusView:new() + StatusView.super.new(self) + self.message_timeout = 0 + self.message = {} +end + + +function StatusView:on_mouse_pressed() + core.set_active_view(core.last_active_view) + if system.get_time() < self.message_timeout + and not core.active_view:is(LogView) then + command.perform "core:open-log" + end +end + + +function StatusView:show_message(icon, icon_color, text) + self.message = { + icon_color, style.icon_font, icon, + style.dim, style.font, StatusView.separator2, style.text, text + } + self.message_timeout = system.get_time() + config.message_timeout +end + + +function StatusView:update() + self.size.y = style.font:get_height() + style.padding.y * 2 + + if system.get_time() < self.message_timeout then + self.scroll.to.y = self.size.y + else + self.scroll.to.y = 0 + end + + StatusView.super.update(self) +end + + +local function draw_items(self, items, x, y, draw_fn) + local font = style.font + local color = style.text + + for _, item in ipairs(items) do + if type(item) == "userdata" then + font = item + elseif type(item) == "table" then + color = item + else + x = draw_fn(font, color, item, nil, x, y, 0, self.size.y) + end + end + + return x +end + + +local function text_width(font, _, text, _, x) + return x + font:get_width(text) +end + + +function StatusView:draw_items(items, right_align, yoffset) + local x, y = self:get_content_offset() + y = y + (yoffset or 0) + if right_align then + local w = draw_items(self, items, 0, 0, text_width) + x = x + self.size.x - w - style.padding.x + draw_items(self, items, x, y, common.draw_text) + else + x = x + style.padding.x + draw_items(self, items, x, y, common.draw_text) + end +end + + +function StatusView:get_items() + if getmetatable(core.active_view) == DocView then + local dv = core.active_view + local line, col = dv.doc:get_selection() + local dirty = dv.doc:is_dirty() + + return { + dirty and style.accent or style.text, style.icon_font, "f", + style.dim, style.font, self.separator2, style.text, + dv.doc.filename and style.text or style.dim, dv.doc:get_name(), + style.text, + self.separator, + "line: ", line, + self.separator, + col > config.line_limit and style.accent or style.text, "col: ", col, + style.text, + self.separator, + string.format("%d%%", line / #dv.doc.lines * 100), + }, { + style.icon_font, "g", + style.font, style.dim, self.separator2, style.text, + #dv.doc.lines, " lines", + self.separator, + dv.doc.crlf and "CRLF" or "LF" + } + end + + return {}, { + style.icon_font, "g", + style.font, style.dim, self.separator2, + #core.docs, style.text, " / ", + #core.project_files, " files" + } +end + + +function StatusView:draw() + self:draw_background(style.background2) + + if self.message then + self:draw_items(self.message, false, self.size.y) + end + + local left, right = self:get_items() + self:draw_items(left) + self:draw_items(right, true) +end + + +return StatusView diff --git a/vendor/lite/data/core/strict.lua b/vendor/lite/data/core/strict.lua new file mode 100644 index 0000000..7d4b9da --- /dev/null +++ b/vendor/lite/data/core/strict.lua @@ -0,0 +1,26 @@ +local strict = {} +strict.defined = {} + + +-- used to define a global variable +function global(t) + for k, v in pairs(t) do + strict.defined[k] = true + rawset(_G, k, v) + end +end + + +function strict.__newindex(t, k, v) + error("cannot set undefined variable: " .. k, 2) +end + + +function strict.__index(t, k) + if not strict.defined[k] then + error("cannot get undefined variable: " .. k, 2) + end +end + + +setmetatable(_G, strict) diff --git a/vendor/lite/data/core/style.lua b/vendor/lite/data/core/style.lua new file mode 100644 index 0000000..ab597c2 --- /dev/null +++ b/vendor/lite/data/core/style.lua @@ -0,0 +1,42 @@ +local common = require "core.common" +local style = {} + +style.padding = { x = common.round(14 * SCALE), y = common.round(7 * SCALE) } +style.divider_size = common.round(1 * SCALE) +style.scrollbar_size = common.round(4 * SCALE) +style.caret_width = common.round(2 * SCALE) +style.tab_width = common.round(170 * SCALE) + +style.font = renderer.font.load(EXEDIR .. "/data/fonts/font.ttf", 14 * SCALE) +style.big_font = renderer.font.load(EXEDIR .. "/data/fonts/font.ttf", 34 * SCALE) +style.icon_font = renderer.font.load(EXEDIR .. "/data/fonts/icons.ttf", 14 * SCALE) +style.code_font = renderer.font.load(EXEDIR .. "/data/fonts/monospace.ttf", 13.5 * SCALE) + +style.background = { common.color "#2e2e32" } +style.background2 = { common.color "#252529" } +style.background3 = { common.color "#252529" } +style.text = { common.color "#97979c" } +style.caret = { common.color "#93DDFA" } +style.accent = { common.color "#e1e1e6" } +style.dim = { common.color "#525257" } +style.divider = { common.color "#202024" } +style.selection = { common.color "#48484f" } +style.line_number = { common.color "#525259" } +style.line_number2 = { common.color "#83838f" } +style.line_highlight = { common.color "#343438" } +style.scrollbar = { common.color "#414146" } +style.scrollbar2 = { common.color "#4b4b52" } + +style.syntax = {} +style.syntax["normal"] = { common.color "#e1e1e6" } +style.syntax["symbol"] = { common.color "#e1e1e6" } +style.syntax["comment"] = { common.color "#676b6f" } +style.syntax["keyword"] = { common.color "#E58AC9" } +style.syntax["keyword2"] = { common.color "#F77483" } +style.syntax["number"] = { common.color "#FFA94D" } +style.syntax["literal"] = { common.color "#FFA94D" } +style.syntax["string"] = { common.color "#f7c95c" } +style.syntax["operator"] = { common.color "#93DDFA" } +style.syntax["function"] = { common.color "#93DDFA" } + +return style diff --git a/vendor/lite/data/core/syntax.lua b/vendor/lite/data/core/syntax.lua new file mode 100644 index 0000000..a763ac7 --- /dev/null +++ b/vendor/lite/data/core/syntax.lua @@ -0,0 +1,30 @@ +local common = require "core.common" + +local syntax = {} +syntax.items = {} + +local plain_text_syntax = { patterns = {}, symbols = {} } + + +function syntax.add(t) + table.insert(syntax.items, t) +end + + +local function find(string, field) + for i = #syntax.items, 1, -1 do + local t = syntax.items[i] + if common.match_pattern(string, t[field] or {}) then + return t + end + end +end + +function syntax.get(filename, header) + return find(filename, "files") + or find(header, "headers") + or plain_text_syntax +end + + +return syntax diff --git a/vendor/lite/data/core/tokenizer.lua b/vendor/lite/data/core/tokenizer.lua new file mode 100644 index 0000000..98aafc7 --- /dev/null +++ b/vendor/lite/data/core/tokenizer.lua @@ -0,0 +1,112 @@ +local tokenizer = {} + + +local function push_token(t, type, text) + local prev_type = t[#t-1] + local prev_text = t[#t] + if prev_type and (prev_type == type or prev_text:find("^%s*$")) then + t[#t-1] = type + t[#t] = prev_text .. text + else + table.insert(t, type) + table.insert(t, text) + end +end + + +local function is_escaped(text, idx, esc) + local byte = esc:byte() + local count = 0 + for i = idx - 1, 1, -1 do + if text:byte(i) ~= byte then break end + count = count + 1 + end + return count % 2 == 1 +end + + +local function find_non_escaped(text, pattern, offset, esc) + while true do + local s, e = text:find(pattern, offset) + if not s then break end + if esc and is_escaped(text, s, esc) then + offset = e + 1 + else + return s, e + end + end +end + + +function tokenizer.tokenize(syntax, text, state) + local res = {} + local i = 1 + + if #syntax.patterns == 0 then + return { "normal", text } + end + + while i <= #text do + -- continue trying to match the end pattern of a pair if we have a state set + if state then + local p = syntax.patterns[state] + local s, e = find_non_escaped(text, p.pattern[2], i, p.pattern[3]) + + if s then + push_token(res, p.type, text:sub(i, e)) + state = nil + i = e + 1 + else + push_token(res, p.type, text:sub(i)) + break + end + end + + -- find matching pattern + local matched = false + for n, p in ipairs(syntax.patterns) do + local pattern = (type(p.pattern) == "table") and p.pattern[1] or p.pattern + local s, e = text:find("^" .. pattern, i) + + if s then + -- matched pattern; make and add token + local t = text:sub(s, e) + push_token(res, syntax.symbols[t] or p.type, t) + + -- update state if this was a start|end pattern pair + if type(p.pattern) == "table" then + state = n + end + + -- move cursor past this token + i = e + 1 + matched = true + break + end + end + + -- consume character if we didn't match + if not matched then + push_token(res, "normal", text:sub(i, i)) + i = i + 1 + end + end + + return res, state +end + + +local function iter(t, i) + i = i + 2 + local type, text = t[i], t[i+1] + if type then + return i, type, text + end +end + +function tokenizer.each_token(t) + return iter, t, -1 +end + + +return tokenizer diff --git a/vendor/lite/data/core/view.lua b/vendor/lite/data/core/view.lua new file mode 100644 index 0000000..ae978a9 --- /dev/null +++ b/vendor/lite/data/core/view.lua @@ -0,0 +1,151 @@ +local core = require "core" +local config = require "core.config" +local style = require "core.style" +local common = require "core.common" +local Object = require "core.object" + + +local View = Object:extend() + + +function View:new() + self.position = { x = 0, y = 0 } + self.size = { x = 0, y = 0 } + self.scroll = { x = 0, y = 0, to = { x = 0, y = 0 } } + self.cursor = "arrow" + self.scrollable = false +end + + +function View:move_towards(t, k, dest, rate) + if type(t) ~= "table" then + return self:move_towards(self, t, k, dest, rate) + end + local val = t[k] + if math.abs(val - dest) < 0.5 then + t[k] = dest + else + t[k] = common.lerp(val, dest, rate or 0.5) + end + if val ~= dest then + core.redraw = true + end +end + + +function View:try_close(do_close) + do_close() +end + + +function View:get_name() + return "---" +end + + +function View:get_scrollable_size() + return math.huge +end + + +function View:get_scrollbar_rect() + local sz = self:get_scrollable_size() + if sz <= self.size.y or sz == math.huge then + return 0, 0, 0, 0 + end + local h = math.max(20, self.size.y * self.size.y / sz) + return + self.position.x + self.size.x - style.scrollbar_size, + self.position.y + self.scroll.y * (self.size.y - h) / (sz - self.size.y), + style.scrollbar_size, + h +end + + +function View:scrollbar_overlaps_point(x, y) + local sx, sy, sw, sh = self:get_scrollbar_rect() + return x >= sx - sw * 3 and x < sx + sw and y >= sy and y < sy + sh +end + + +function View:on_mouse_pressed(button, x, y, clicks) + if self:scrollbar_overlaps_point(x, y) then + self.dragging_scrollbar = true + return true + end +end + + +function View:on_mouse_released(button, x, y) + self.dragging_scrollbar = false +end + + +function View:on_mouse_moved(x, y, dx, dy) + if self.dragging_scrollbar then + local delta = self:get_scrollable_size() / self.size.y * dy + self.scroll.to.y = self.scroll.to.y + delta + end + self.hovered_scrollbar = self:scrollbar_overlaps_point(x, y) +end + + +function View:on_text_input(text) + -- no-op +end + + +function View:on_mouse_wheel(y) + if self.scrollable then + self.scroll.to.y = self.scroll.to.y + y * -config.mouse_wheel_scroll + end +end + + +function View:get_content_bounds() + local x = self.scroll.x + local y = self.scroll.y + return x, y, x + self.size.x, y + self.size.y +end + + +function View:get_content_offset() + local x = common.round(self.position.x - self.scroll.x) + local y = common.round(self.position.y - self.scroll.y) + return x, y +end + + +function View:clamp_scroll_position() + local max = self:get_scrollable_size() - self.size.y + self.scroll.to.y = common.clamp(self.scroll.to.y, 0, max) +end + + +function View:update() + self:clamp_scroll_position() + self:move_towards(self.scroll, "x", self.scroll.to.x, 0.3) + self:move_towards(self.scroll, "y", self.scroll.to.y, 0.3) +end + + +function View:draw_background(color) + local x, y = self.position.x, self.position.y + local w, h = self.size.x, self.size.y + renderer.draw_rect(x, y, w + x % 1, h + y % 1, color) +end + + +function View:draw_scrollbar() + local x, y, w, h = self:get_scrollbar_rect() + local highlight = self.hovered_scrollbar or self.dragging_scrollbar + local color = highlight and style.scrollbar2 or style.scrollbar + renderer.draw_rect(x, y, w, h, color) +end + + +function View:draw() +end + + +return View diff --git a/vendor/lite/data/fonts/font.ttf b/vendor/lite/data/fonts/font.ttf new file mode 100644 index 0000000000000000000000000000000000000000..2b6392ffe8712b9c5450733320cd220d6c0f4bce GIT binary patch literal 171272 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 literal 0 HcmV?d00001 diff --git a/vendor/lite/data/fonts/icons.ttf b/vendor/lite/data/fonts/icons.ttf new file mode 100644 index 0000000000000000000000000000000000000000..d74fe7375b8a975558fcd29eefab25f8b1ceac70 GIT binary patch literal 7644 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 literal 0 HcmV?d00001 diff --git a/vendor/lite/data/fonts/monospace.ttf b/vendor/lite/data/fonts/monospace.ttf new file mode 100644 index 0000000000000000000000000000000000000000..5919b5d1bf061d687f60300fd7ab774c6b06df50 GIT binary patch literal 109212 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 Qit=CXyrr1vyPZG%7iFl@s{jB1 literal 0 HcmV?d00001 diff --git a/vendor/lite/data/plugins/autocomplete.lua b/vendor/lite/data/plugins/autocomplete.lua new file mode 100644 index 0000000..79e4513 --- /dev/null +++ b/vendor/lite/data/plugins/autocomplete.lua @@ -0,0 +1,284 @@ +local core = require "core" +local common = require "core.common" +local config = require "core.config" +local command = require "core.command" +local style = require "core.style" +local keymap = require "core.keymap" +local translate = require "core.doc.translate" +local RootView = require "core.rootview" +local DocView = require "core.docview" + +config.autocomplete_max_suggestions = 6 + +local autocomplete = {} +autocomplete.map = {} + + +local mt = { __tostring = function(t) return t.text end } + +function autocomplete.add(t) + local items = {} + for text, info in pairs(t.items) do + info = (type(info) == "string") and info + table.insert(items, setmetatable({ text = text, info = info }, mt)) + end + autocomplete.map[t.name] = { files = t.files or ".*", items = items } +end + + +core.add_thread(function() + local cache = setmetatable({}, { __mode = "k" }) + + local function get_symbols(doc) + local i = 1 + local s = {} + while i < #doc.lines do + for sym in doc.lines[i]:gmatch(config.symbol_pattern) do + s[sym] = true + end + i = i + 1 + if i % 100 == 0 then coroutine.yield() end + end + return s + end + + local function cache_is_valid(doc) + local c = cache[doc] + return c and c.last_change_id == doc:get_change_id() + end + + while true do + local symbols = {} + + -- lift all symbols from all docs + for _, doc in ipairs(core.docs) do + -- update the cache if the doc has changed since the last iteration + if not cache_is_valid(doc) then + cache[doc] = { + last_change_id = doc:get_change_id(), + symbols = get_symbols(doc) + } + end + -- update symbol set with doc's symbol set + for sym in pairs(cache[doc].symbols) do + symbols[sym] = true + end + coroutine.yield() + end + + -- update symbols list + autocomplete.add { name = "open-docs", items = symbols } + + -- wait for next scan + local valid = true + while valid do + coroutine.yield(1) + for _, doc in ipairs(core.docs) do + if not cache_is_valid(doc) then + valid = false + end + end + end + + end +end) + + +local partial = "" +local suggestions_idx = 1 +local suggestions = {} +local last_line, last_col + + +local function reset_suggestions() + suggestions_idx = 1 + suggestions = {} +end + + +local function update_suggestions() + local doc = core.active_view.doc + local filename = doc and doc.filename or "" + + -- get all relevant suggestions for given filename + local items = {} + for _, v in pairs(autocomplete.map) do + if common.match_pattern(filename, v.files) then + for _, item in pairs(v.items) do + table.insert(items, item) + end + end + end + + -- fuzzy match, remove duplicates and store + items = common.fuzzy_match(items, partial) + local j = 1 + for i = 1, config.autocomplete_max_suggestions do + suggestions[i] = items[j] + while items[j] and items[i].text == items[j].text do + items[i].info = items[i].info or items[j].info + j = j + 1 + end + end +end + + +local function get_partial_symbol() + local doc = core.active_view.doc + local line2, col2 = doc:get_selection() + local line1, col1 = doc:position_offset(line2, col2, translate.start_of_word) + return doc:get_text(line1, col1, line2, col2) +end + + +local function get_active_view() + if getmetatable(core.active_view) == DocView then + return core.active_view + end +end + + +local function get_suggestions_rect(av) + if #suggestions == 0 then + return 0, 0, 0, 0 + end + + local line, col = av.doc:get_selection() + local x, y = av:get_line_screen_position(line) + x = x + av:get_col_x_offset(line, col - #partial) + y = y + av:get_line_height() + style.padding.y + local font = av:get_font() + local th = font:get_height() + + local max_width = 0 + for _, s in ipairs(suggestions) do + local w = font:get_width(s.text) + if s.info then + w = w + style.font:get_width(s.info) + style.padding.x + end + max_width = math.max(max_width, w) + end + + return + x - style.padding.x, + y - style.padding.y, + max_width + style.padding.x * 2, + #suggestions * (th + style.padding.y) + style.padding.y +end + + +local function draw_suggestions_box(av) + -- draw background rect + local rx, ry, rw, rh = get_suggestions_rect(av) + renderer.draw_rect(rx, ry, rw, rh, style.background3) + + -- draw text + local font = av:get_font() + local lh = font:get_height() + style.padding.y + local y = ry + style.padding.y / 2 + for i, s in ipairs(suggestions) do + local color = (i == suggestions_idx) and style.accent or style.text + common.draw_text(font, color, s.text, "left", rx + style.padding.x, y, rw, lh) + if s.info then + color = (i == suggestions_idx) and style.text or style.dim + common.draw_text(style.font, color, s.info, "right", rx, y, rw - style.padding.x, lh) + end + y = y + lh + end +end + + +-- patch event logic into RootView +local on_text_input = RootView.on_text_input +local update = RootView.update +local draw = RootView.draw + + +RootView.on_text_input = function(...) + on_text_input(...) + + local av = get_active_view() + if av then + -- update partial symbol and suggestions + partial = get_partial_symbol() + if #partial >= 3 then + update_suggestions() + last_line, last_col = av.doc:get_selection() + else + reset_suggestions() + end + + -- scroll if rect is out of bounds of view + local _, y, _, h = get_suggestions_rect(av) + local limit = av.position.y + av.size.y + if y + h > limit then + av.scroll.to.y = av.scroll.y + y + h - limit + end + end +end + + +RootView.update = function(...) + update(...) + + local av = get_active_view() + if av then + -- reset suggestions if caret was moved + local line, col = av.doc:get_selection() + if line ~= last_line or col ~= last_col then + reset_suggestions() + end + end +end + + +RootView.draw = function(...) + draw(...) + + local av = get_active_view() + if av then + -- draw suggestions box after everything else + core.root_view:defer_draw(draw_suggestions_box, av) + end +end + + +local function predicate() + return get_active_view() and #suggestions > 0 +end + + +command.add(predicate, { + ["autocomplete:complete"] = function() + local doc = core.active_view.doc + local line, col = doc:get_selection() + local text = suggestions[suggestions_idx].text + doc:insert(line, col, text) + doc:remove(line, col, line, col - #partial) + doc:set_selection(line, col + #text - #partial) + reset_suggestions() + end, + + ["autocomplete:previous"] = function() + suggestions_idx = math.max(suggestions_idx - 1, 1) + end, + + ["autocomplete:next"] = function() + suggestions_idx = math.min(suggestions_idx + 1, #suggestions) + end, + + ["autocomplete:cancel"] = function() + reset_suggestions() + end, +}) + + +keymap.add { + ["tab"] = "autocomplete:complete", + ["up"] = "autocomplete:previous", + ["down"] = "autocomplete:next", + ["escape"] = "autocomplete:cancel", +} + + +return autocomplete diff --git a/vendor/lite/data/plugins/autoinsert.lua b/vendor/lite/data/plugins/autoinsert.lua new file mode 120000 index 0000000..3ab3e0e --- /dev/null +++ b/vendor/lite/data/plugins/autoinsert.lua @@ -0,0 +1 @@ +../../../lite-plugins/plugins/autoinsert.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/autoreload.lua b/vendor/lite/data/plugins/autoreload.lua new file mode 100644 index 0000000..a077b6d --- /dev/null +++ b/vendor/lite/data/plugins/autoreload.lua @@ -0,0 +1,61 @@ +local core = require "core" +local config = require "core.config" +local Doc = require "core.doc" + + +local times = setmetatable({}, { __mode = "k" }) + +local function update_time(doc) + local info = system.get_file_info(doc.filename) + times[doc] = info.modified +end + + +local function reload_doc(doc) + local fp = io.open(doc.filename, "r") + local text = fp:read("*a") + fp:close() + + local sel = { doc:get_selection() } + doc:remove(1, 1, math.huge, math.huge) + doc:insert(1, 1, text:gsub("\r", ""):gsub("\n$", "")) + doc:set_selection(table.unpack(sel)) + + update_time(doc) + doc:clean() + core.log_quiet("Auto-reloaded doc \"%s\"", doc.filename) +end + + +core.add_thread(function() + while true do + -- check all doc modified times + for _, doc in ipairs(core.docs) do + local info = system.get_file_info(doc.filename or "") + if info and times[doc] ~= info.modified then + reload_doc(doc) + end + coroutine.yield() + end + + -- wait for next scan + coroutine.yield(config.project_scan_rate) + end +end) + + +-- patch `Doc.save|load` to store modified time +local load = Doc.load +local save = Doc.save + +Doc.load = function(self, ...) + local res = load(self, ...) + update_time(self) + return res +end + +Doc.save = function(self, ...) + local res = save(self, ...) + update_time(self) + return res +end diff --git a/vendor/lite/data/plugins/betterfind.lua b/vendor/lite/data/plugins/betterfind.lua new file mode 120000 index 0000000..e32350c --- /dev/null +++ b/vendor/lite/data/plugins/betterfind.lua @@ -0,0 +1 @@ +../../../../support/lite/plugins/betterfind.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/bracketmatch.lua b/vendor/lite/data/plugins/bracketmatch.lua new file mode 120000 index 0000000..c0f03a9 --- /dev/null +++ b/vendor/lite/data/plugins/bracketmatch.lua @@ -0,0 +1 @@ +../../../lite-plugins/plugins/bracketmatch.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/language_c.lua b/vendor/lite/data/plugins/language_c.lua new file mode 100644 index 0000000..8e8ee98 --- /dev/null +++ b/vendor/lite/data/plugins/language_c.lua @@ -0,0 +1,59 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.c$", "%.h$", "%.inl$", "%.cpp$", "%.hpp$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { "#", "[^\\]\n" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["do"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["break"] = "keyword", + ["continue"] = "keyword", + ["return"] = "keyword", + ["goto"] = "keyword", + ["struct"] = "keyword", + ["union"] = "keyword", + ["typedef"] = "keyword", + ["enum"] = "keyword", + ["extern"] = "keyword", + ["static"] = "keyword", + ["volatile"] = "keyword", + ["const"] = "keyword", + ["inline"] = "keyword", + ["switch"] = "keyword", + ["case"] = "keyword", + ["default"] = "keyword", + ["auto"] = "keyword", + ["const"] = "keyword", + ["void"] = "keyword", + ["int"] = "keyword2", + ["short"] = "keyword2", + ["long"] = "keyword2", + ["float"] = "keyword2", + ["double"] = "keyword2", + ["char"] = "keyword2", + ["unsigned"] = "keyword2", + ["bool"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["NULL"] = "literal", + }, +} + diff --git a/vendor/lite/data/plugins/language_css.lua b/vendor/lite/data/plugins/language_css.lua new file mode 100644 index 0000000..021c5d3 --- /dev/null +++ b/vendor/lite/data/plugins/language_css.lua @@ -0,0 +1,23 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.css$" }, + patterns = { + { pattern = "\\.", type = "normal" }, + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "[%a][%w-]*%s*%f[:]", type = "keyword" }, + { pattern = "#%x+", type = "string" }, + { pattern = "-?%d+[%d%.]*p[xt]", type = "number" }, + { pattern = "-?%d+[%d%.]*deg", type = "number" }, + { pattern = "-?%d+[%d%.]*", type = "number" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + { pattern = "#[%a][%w_-]*", type = "keyword2" }, + { pattern = "@[%a][%w_-]*", type = "keyword2" }, + { pattern = "%.[%a][%w_-]*", type = "keyword2" }, + { pattern = "[{}:]", type = "operator" }, + }, + symbols = {}, +} diff --git a/vendor/lite/data/plugins/language_fennel.lua b/vendor/lite/data/plugins/language_fennel.lua new file mode 120000 index 0000000..d337b3f --- /dev/null +++ b/vendor/lite/data/plugins/language_fennel.lua @@ -0,0 +1 @@ +../../../lite-plugins/plugins/language_fennel.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/language_js.lua b/vendor/lite/data/plugins/language_js.lua new file mode 100644 index 0000000..cf1b124 --- /dev/null +++ b/vendor/lite/data/plugins/language_js.lua @@ -0,0 +1,67 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.js$", "%.json$", "%.cson$" }, + comment = "//", + patterns = { + { pattern = "//.-\n", type = "comment" }, + { pattern = { "/%*", "%*/" }, type = "comment" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { "`", "`", '\\' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["async"] = "keyword", + ["await"] = "keyword", + ["break"] = "keyword", + ["case"] = "keyword", + ["catch"] = "keyword", + ["class"] = "keyword", + ["const"] = "keyword", + ["continue"] = "keyword", + ["debugger"] = "keyword", + ["default"] = "keyword", + ["delete"] = "keyword", + ["do"] = "keyword", + ["else"] = "keyword", + ["export"] = "keyword", + ["extends"] = "keyword", + ["finally"] = "keyword", + ["for"] = "keyword", + ["function"] = "keyword", + ["get"] = "keyword", + ["if"] = "keyword", + ["import"] = "keyword", + ["in"] = "keyword", + ["instanceof"] = "keyword", + ["let"] = "keyword", + ["new"] = "keyword", + ["return"] = "keyword", + ["set"] = "keyword", + ["static"] = "keyword", + ["super"] = "keyword", + ["switch"] = "keyword", + ["throw"] = "keyword", + ["try"] = "keyword", + ["typeof"] = "keyword", + ["var"] = "keyword", + ["void"] = "keyword", + ["while"] = "keyword", + ["with"] = "keyword", + ["yield"] = "keyword", + ["true"] = "literal", + ["false"] = "literal", + ["null"] = "literal", + ["undefined"] = "literal", + ["arguments"] = "keyword2", + ["Infinity"] = "keyword2", + ["NaN"] = "keyword2", + ["this"] = "keyword2", + }, +} diff --git a/vendor/lite/data/plugins/language_lua.lua b/vendor/lite/data/plugins/language_lua.lua new file mode 100644 index 0000000..915d273 --- /dev/null +++ b/vendor/lite/data/plugins/language_lua.lua @@ -0,0 +1,50 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.lua$", + headers = "^#!.*[ /]lua", + comment = "--", + patterns = { + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = { "%[%[", "%]%]" }, type = "string" }, + { pattern = { "%-%-%[%[", "%]%]"}, type = "comment" }, + { pattern = "%-%-.-\n", type = "comment" }, + { pattern = "-?0x%x+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "<%a+>", type = "keyword2" }, + { pattern = "%.%.%.?", type = "operator" }, + { pattern = "[<>~=]=", type = "operator" }, + { pattern = "[%+%-=/%*%^%%#<>]", type = "operator" }, + { pattern = "[%a_][%w_]*%s*%f[(\"{]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + { pattern = "::[%a_][%w_]*::", type = "function" }, + }, + symbols = { + ["if"] = "keyword", + ["then"] = "keyword", + ["else"] = "keyword", + ["elseif"] = "keyword", + ["end"] = "keyword", + ["do"] = "keyword", + ["function"] = "keyword", + ["repeat"] = "keyword", + ["until"] = "keyword", + ["while"] = "keyword", + ["for"] = "keyword", + ["break"] = "keyword", + ["return"] = "keyword", + ["local"] = "keyword", + ["in"] = "keyword", + ["not"] = "keyword", + ["and"] = "keyword", + ["or"] = "keyword", + ["goto"] = "keyword", + ["self"] = "keyword2", + ["true"] = "literal", + ["false"] = "literal", + ["nil"] = "literal", + }, +} + diff --git a/vendor/lite/data/plugins/language_md.lua b/vendor/lite/data/plugins/language_md.lua new file mode 100644 index 0000000..9f0f14e --- /dev/null +++ b/vendor/lite/data/plugins/language_md.lua @@ -0,0 +1,21 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.md$", "%.markdown$" }, + patterns = { + { pattern = "\\.", type = "normal" }, + { pattern = { "" }, type = "comment" }, + { pattern = { "```", "```" }, type = "string" }, + { pattern = { "``", "``", "\\" }, type = "string" }, + { pattern = { "`", "`", "\\" }, type = "string" }, + { pattern = { "~~", "~~", "\\" }, type = "keyword2" }, + { pattern = "%-%-%-+", type = "comment" }, + { pattern = "%*%s+", type = "operator" }, + { pattern = { "%*", "[%*\n]", "\\" }, type = "operator" }, + { pattern = { "%_", "[%_\n]", "\\" }, type = "keyword2" }, + { pattern = "#.-\n", type = "keyword" }, + { pattern = "!?%[.-%]%(.-%)", type = "function" }, + { pattern = "https?://%S+", type = "function" }, + }, + symbols = { }, +} diff --git a/vendor/lite/data/plugins/language_python.lua b/vendor/lite/data/plugins/language_python.lua new file mode 100644 index 0000000..4a6ada3 --- /dev/null +++ b/vendor/lite/data/plugins/language_python.lua @@ -0,0 +1,55 @@ +local syntax = require "core.syntax" + +syntax.add { + files = "%.py$", + headers = "^#!.*[ /]python", + comment = "#", + patterns = { + { pattern = { "#", "\n" }, type = "comment" }, + { pattern = { '[ruU]?"', '"', '\\' }, type = "string" }, + { pattern = { "[ruU]?'", "'", '\\' }, type = "string" }, + { pattern = { '"""', '"""' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.eE]*", type = "number" }, + { pattern = "-?%.?%d+", type = "number" }, + { pattern = "[%+%-=/%*%^%%<>!~|&]", type = "operator" }, + { pattern = "[%a_][%w_]*%f[(]", type = "function" }, + { pattern = "[%a_][%w_]*", type = "symbol" }, + }, + symbols = { + ["class"] = "keyword", + ["finally"] = "keyword", + ["is"] = "keyword", + ["return"] = "keyword", + ["continue"] = "keyword", + ["for"] = "keyword", + ["lambda"] = "keyword", + ["try"] = "keyword", + ["def"] = "keyword", + ["from"] = "keyword", + ["nonlocal"] = "keyword", + ["while"] = "keyword", + ["and"] = "keyword", + ["global"] = "keyword", + ["not"] = "keyword", + ["with"] = "keyword", + ["as"] = "keyword", + ["elif"] = "keyword", + ["if"] = "keyword", + ["or"] = "keyword", + ["else"] = "keyword", + ["import"] = "keyword", + ["pass"] = "keyword", + ["break"] = "keyword", + ["except"] = "keyword", + ["in"] = "keyword", + ["del"] = "keyword", + ["raise"] = "keyword", + ["yield"] = "keyword", + ["assert"] = "keyword", + ["self"] = "keyword2", + ["None"] = "literal", + ["True"] = "literal", + ["False"] = "literal", + } +} diff --git a/vendor/lite/data/plugins/language_xml.lua b/vendor/lite/data/plugins/language_xml.lua new file mode 100644 index 0000000..5240bdc --- /dev/null +++ b/vendor/lite/data/plugins/language_xml.lua @@ -0,0 +1,21 @@ +local syntax = require "core.syntax" + +syntax.add { + files = { "%.xml$", "%.html?$" }, + headers = "<%?xml", + patterns = { + { pattern = { "" }, type = "comment" }, + { pattern = { '%f[^>][^<]', '%f[<]' }, type = "normal" }, + { pattern = { '"', '"', '\\' }, type = "string" }, + { pattern = { "'", "'", '\\' }, type = "string" }, + { pattern = "0x[%da-fA-F]+", type = "number" }, + { pattern = "-?%d+[%d%.]*f?", type = "number" }, + { pattern = "-?%.?%d+f?", type = "number" }, + { pattern = "%f[^<]![%a_][%w_]*", type = "keyword2" }, + { pattern = "%f[^<][%a_][%w_]*", type = "function" }, + { pattern = "%f[^<]/[%a_][%w_]*", type = "function" }, + { pattern = "[%a_][%w_]*", type = "keyword" }, + { pattern = "[/<>=]", type = "operator" }, + }, + symbols = {}, +} diff --git a/vendor/lite/data/plugins/macro.lua b/vendor/lite/data/plugins/macro.lua new file mode 100644 index 0000000..3458977 --- /dev/null +++ b/vendor/lite/data/plugins/macro.lua @@ -0,0 +1,69 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + +local handled_events = { + ["keypressed"] = true, + ["keyreleased"] = true, + ["textinput"] = true, +} + +local state = "stopped" +local event_buffer = {} +local modkeys = {} + +local on_event = core.on_event + +core.on_event = function(type, ...) + local res = on_event(type, ...) + if state == "recording" and handled_events[type] then + table.insert(event_buffer, { type, ... }) + end + return res +end + + +local function clone(t) + local res = {} + for k, v in pairs(t) do res[k] = v end + return res +end + + +local function predicate() + return state ~= "playing" +end + + +command.add(predicate, { + ["macro:toggle-record"] = function() + if state == "stopped" then + state = "recording" + event_buffer = {} + modkeys = clone(keymap.modkeys) + core.log("Recording macro...") + else + state = "stopped" + core.log("Stopped recording macro (%d events)", #event_buffer) + end + end, + + ["macro:play"] = function() + state = "playing" + core.log("Playing macro... (%d events)", #event_buffer) + local mk = keymap.modkeys + keymap.modkeys = clone(modkeys) + for _, ev in ipairs(event_buffer) do + on_event(table.unpack(ev)) + core.root_view:update() + end + keymap.modkeys = mk + state = "stopped" + end, +}) + + +keymap.add { + ["ctrl+shift+;"] = "macro:toggle-record", + ["ctrl+;"] = "macro:play", +} diff --git a/vendor/lite/data/plugins/projectsearch.lua b/vendor/lite/data/plugins/projectsearch.lua new file mode 100644 index 0000000..884e66a --- /dev/null +++ b/vendor/lite/data/plugins/projectsearch.lua @@ -0,0 +1,271 @@ +local core = require "core" +local common = require "core.common" +local keymap = require "core.keymap" +local command = require "core.command" +local style = require "core.style" +local View = require "core.view" + + +local ResultsView = View:extend() + + +function ResultsView:new(text, fn) + ResultsView.super.new(self) + self.scrollable = true + self.brightness = 0 + self:begin_search(text, fn) +end + + +function ResultsView:get_name() + return "Search Results" +end + + +local function find_all_matches_in_file(t, filename, fn) + local fp = io.open(filename) + if not fp then return t end + local n = 1 + for line in fp:lines() do + local s = fn(line) + if s then + table.insert(t, { file = filename, text = line, line = n, col = s }) + core.redraw = true + end + if n % 100 == 0 then coroutine.yield() end + n = n + 1 + core.redraw = true + end + fp:close() +end + + +function ResultsView:begin_search(text, fn) + self.search_args = { text, fn } + self.results = {} + self.last_file_idx = 1 + self.query = text + self.searching = true + self.selected_idx = 0 + + core.add_thread(function() + for i, file in ipairs(core.project_files) do + if file.type == "file" then + find_all_matches_in_file(self.results, file.filename, fn) + end + self.last_file_idx = i + end + self.searching = false + self.brightness = 100 + core.redraw = true + end, self.results) + + self.scroll.to.y = 0 +end + + +function ResultsView:refresh() + self:begin_search(table.unpack(self.search_args)) +end + + +function ResultsView:on_mouse_moved(mx, my, ...) + ResultsView.super.on_mouse_moved(self, mx, my, ...) + self.selected_idx = 0 + for i, item, x,y,w,h in self:each_visible_result() do + if mx >= x and my >= y and mx < x + w and my < y + h then + self.selected_idx = i + break + end + end +end + + +function ResultsView:on_mouse_pressed(...) + local caught = ResultsView.super.on_mouse_pressed(self, ...) + if not caught then + self:open_selected_result() + end +end + + +function ResultsView:open_selected_result() + local res = self.results[self.selected_idx] + if not res then + return + end + core.try(function() + local dv = core.root_view:open_doc(core.open_doc(res.file)) + core.root_view.root_node:update_layout() + dv.doc:set_selection(res.line, res.col) + dv:scroll_to_line(res.line, false, true) + end) +end + + +function ResultsView:update() + self:move_towards("brightness", 0, 0.1) + ResultsView.super.update(self) +end + + +function ResultsView:get_results_yoffset() + return style.font:get_height() + style.padding.y * 3 +end + + +function ResultsView:get_line_height() + return style.padding.y + style.font:get_height() +end + + +function ResultsView:get_scrollable_size() + return self:get_results_yoffset() + #self.results * self:get_line_height() +end + + +function ResultsView:get_visible_results_range() + local lh = self:get_line_height() + local oy = self:get_results_yoffset() + local min = math.max(1, math.floor((self.scroll.y - oy) / lh)) + return min, min + math.floor(self.size.y / lh) + 1 +end + + +function ResultsView:each_visible_result() + return coroutine.wrap(function() + local lh = self:get_line_height() + local x, y = self:get_content_offset() + local min, max = self:get_visible_results_range() + y = y + self:get_results_yoffset() + lh * (min - 1) + for i = min, max do + local item = self.results[i] + if not item then break end + coroutine.yield(i, item, x, y, self.size.x, lh) + y = y + lh + end + end) +end + + +function ResultsView:scroll_to_make_selected_visible() + local h = self:get_line_height() + local y = self:get_results_yoffset() + h * (self.selected_idx - 1) + self.scroll.to.y = math.min(self.scroll.to.y, y) + self.scroll.to.y = math.max(self.scroll.to.y, y + h - self.size.y) +end + + +function ResultsView:draw() + self:draw_background(style.background) + + -- status + local ox, oy = self:get_content_offset() + local x, y = ox + style.padding.x, oy + style.padding.y + local per = self.last_file_idx / #core.project_files + local text + if self.searching then + text = string.format("Searching %d%% (%d of %d files, %d matches) for %q...", + per * 100, self.last_file_idx, #core.project_files, + #self.results, self.query) + else + text = string.format("Found %d matches for %q", + #self.results, self.query) + end + local color = common.lerp(style.text, style.accent, self.brightness / 100) + renderer.draw_text(style.font, text, x, y, color) + + -- horizontal line + local yoffset = self:get_results_yoffset() + local x = ox + style.padding.x + local w = self.size.x - style.padding.x * 2 + local h = style.divider_size + local color = common.lerp(style.dim, style.text, self.brightness / 100) + renderer.draw_rect(x, oy + yoffset - style.padding.y, w, h, color) + if self.searching then + renderer.draw_rect(x, oy + yoffset - style.padding.y, w * per, h, style.text) + end + + -- results + local y1, y2 = self.position.y, self.position.y + self.size.y + for i, item, x,y,w,h in self:each_visible_result() do + local color = style.text + if i == self.selected_idx then + color = style.accent + renderer.draw_rect(x, y, w, h, style.line_highlight) + end + x = x + style.padding.x + local text = string.format("%s at line %d (col %d): ", item.file, item.line, item.col) + x = common.draw_text(style.font, style.dim, text, "left", x, y, w, h) + x = common.draw_text(style.code_font, color, item.text, "left", x, y, w, h) + end + + self:draw_scrollbar() +end + + +local function begin_search(text, fn) + if text == "" then + core.error("Expected non-empty string") + return + end + local rv = ResultsView(text, fn) + core.root_view:get_active_node():add_view(rv) +end + + +command.add(nil, { + ["project-search:find"] = function() + core.command_view:enter("Find Text In Project", function(text) + text = text:lower() + begin_search(text, function(line_text) + return line_text:lower():find(text, nil, true) + end) + end) + end, + + ["project-search:find-pattern"] = function() + core.command_view:enter("Find Pattern In Project", function(text) + begin_search(text, function(line_text) return line_text:find(text) end) + end) + end, + + ["project-search:fuzzy-find"] = function() + core.command_view:enter("Fuzzy Find Text In Project", function(text) + begin_search(text, function(line_text) + return common.fuzzy_match(line_text, text) and 1 + end) + end) + end, +}) + + +command.add(ResultsView, { + ["project-search:select-previous"] = function() + local view = core.active_view + view.selected_idx = math.max(view.selected_idx - 1, 1) + view:scroll_to_make_selected_visible() + end, + + ["project-search:select-next"] = function() + local view = core.active_view + view.selected_idx = math.min(view.selected_idx + 1, #view.results) + view:scroll_to_make_selected_visible() + end, + + ["project-search:open-selected"] = function() + core.active_view:open_selected_result() + end, + + ["project-search:refresh"] = function() + core.active_view:refresh() + end, +}) + +keymap.add { + ["f5"] = "project-search:refresh", + ["ctrl+shift+f"] = "project-search:find", + ["up"] = "project-search:select-previous", + ["down"] = "project-search:select-next", + ["return"] = "project-search:open-selected", +} diff --git a/vendor/lite/data/plugins/quote.lua b/vendor/lite/data/plugins/quote.lua new file mode 100644 index 0000000..b17407d --- /dev/null +++ b/vendor/lite/data/plugins/quote.lua @@ -0,0 +1,30 @@ +local core = require "core" +local command = require "core.command" +local keymap = require "core.keymap" + + +local escapes = { + ["\\"] = "\\\\", + ["\""] = "\\\"", + ["\n"] = "\\n", + ["\r"] = "\\r", + ["\t"] = "\\t", + ["\b"] = "\\b", +} + +local function replace(chr) + return escapes[chr] or string.format("\\x%02x", chr:byte()) +end + + +command.add("core.docview", { + ["quote:quote"] = function() + core.active_view.doc:replace(function(text) + return '"' .. text:gsub("[\0-\31\\\"]", replace) .. '"' + end) + end, +}) + +keymap.add { + ["ctrl+'"] = "quote:quote", +} diff --git a/vendor/lite/data/plugins/rainbowparen.lua b/vendor/lite/data/plugins/rainbowparen.lua new file mode 120000 index 0000000..a198667 --- /dev/null +++ b/vendor/lite/data/plugins/rainbowparen.lua @@ -0,0 +1 @@ +../../../../support/lite/plugins/rainbowparen.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/reflow.lua b/vendor/lite/data/plugins/reflow.lua new file mode 100644 index 0000000..95090a6 --- /dev/null +++ b/vendor/lite/data/plugins/reflow.lua @@ -0,0 +1,63 @@ +local core = require "core" +local config = require "core.config" +local command = require "core.command" +local keymap = require "core.keymap" + + +local function wordwrap_text(text, limit) + local t = {} + local n = 0 + + for word in text:gmatch("%S+") do + if n + #word > limit then + table.insert(t, "\n") + n = 0 + elseif #t > 0 then + table.insert(t, " ") + end + table.insert(t, word) + n = n + #word + 1 + end + + return table.concat(t) +end + + +command.add("core.docview", { + ["reflow:reflow"] = function() + local doc = core.active_view.doc + doc:replace(function(text) + local prefix_set = "[^%w\n%[%](){}`'\"]*" + + -- get line prefix and trailing whitespace + local prefix1 = text:match("^\n*" .. prefix_set) + local prefix2 = text:match("\n(" .. prefix_set .. ")", #prefix1+1) + local trailing = text:match("%s*$") + if not prefix2 or prefix2 == "" then + prefix2 = prefix1 + end + + -- strip all line prefixes and trailing whitespace + text = text:sub(#prefix1+1, -#trailing - 1):gsub("\n" .. prefix_set, "\n") + + -- split into blocks, wordwrap and join + local line_limit = config.line_limit - #prefix1 + local blocks = {} + text = text:gsub("\n\n", "\0") + for block in text:gmatch("%Z+") do + table.insert(blocks, wordwrap_text(block, line_limit)) + end + text = table.concat(blocks, "\n\n") + + -- add prefix to start of lines + text = prefix1 .. text:gsub("\n", "\n" .. prefix2) .. trailing + + return text + end) + end, +}) + + +keymap.add { + ["ctrl+shift+q"] = "reflow:reflow" +} diff --git a/vendor/lite/data/plugins/selectionhighlight.lua b/vendor/lite/data/plugins/selectionhighlight.lua new file mode 120000 index 0000000..8c8b129 --- /dev/null +++ b/vendor/lite/data/plugins/selectionhighlight.lua @@ -0,0 +1 @@ +../../../lite-plugins/plugins/selectionhighlight.lua \ No newline at end of file diff --git a/vendor/lite/data/plugins/tabularize.lua b/vendor/lite/data/plugins/tabularize.lua new file mode 100644 index 0000000..f4dda1f --- /dev/null +++ b/vendor/lite/data/plugins/tabularize.lua @@ -0,0 +1,60 @@ +local core = require "core" +local command = require "core.command" +local translate = require "core.doc.translate" + + +local function gmatch_to_array(text, ptn) + local res = {} + for x in text:gmatch(ptn) do + table.insert(res, x) + end + return res +end + + +local function tabularize_lines(lines, delim) + local rows = {} + local cols = {} + + -- split lines at delimiters and get maximum width of columns + local ptn = "[^" .. delim:sub(1,1):gsub("%W", "%%%1") .. "]+" + for i, line in ipairs(lines) do + rows[i] = gmatch_to_array(line, ptn) + for j, col in ipairs(rows[i]) do + cols[j] = math.max(#col, cols[j] or 0) + end + end + + -- pad columns with space + for _, row in ipairs(rows) do + for i = 1, #row - 1 do + row[i] = row[i] .. string.rep(" ", cols[i] - #row[i]) + end + end + + -- write columns back to lines array + for i, line in ipairs(lines) do + lines[i] = table.concat(rows[i], delim) + end +end + + +command.add("core.docview", { + ["tabularize:tabularize"] = function() + core.command_view:enter("Tabularize On Delimiter", function(delim) + if delim == "" then delim = " " end + + local doc = core.active_view.doc + local line1, col1, line2, col2, swap = doc:get_selection(true) + line1, col1 = doc:position_offset(line1, col1, translate.start_of_line) + line2, col2 = doc:position_offset(line2, col2, translate.end_of_line) + doc:set_selection(line1, col1, line2, col2, swap) + + doc:replace(function(text) + local lines = gmatch_to_array(text, "[^\n]*\n?") + tabularize_lines(lines, delim) + return table.concat(lines) + end) + end) + end, +}) diff --git a/vendor/lite/data/plugins/treeview.lua b/vendor/lite/data/plugins/treeview.lua new file mode 100644 index 0000000..8aa53ff --- /dev/null +++ b/vendor/lite/data/plugins/treeview.lua @@ -0,0 +1,197 @@ +local core = require "core" +local common = require "core.common" +local command = require "core.command" +local config = require "core.config" +local keymap = require "core.keymap" +local style = require "core.style" +local View = require "core.view" + +config.treeview_size = 200 * SCALE + +local function get_depth(filename) + local n = 0 + for sep in filename:gmatch("[\\/]") do + n = n + 1 + end + return n +end + + +local TreeView = View:extend() + +function TreeView:new() + TreeView.super.new(self) + self.scrollable = true + self.visible = true + self.init_size = true + self.cache = {} +end + + +function TreeView:get_cached(item) + local t = self.cache[item.filename] + if not t then + t = {} + t.filename = item.filename + t.abs_filename = system.absolute_path(item.filename) + t.name = t.filename:match("[^\\/]+$") + t.depth = get_depth(t.filename) + t.type = item.type + self.cache[t.filename] = t + end + return t +end + + +function TreeView:get_name() + return "Project" +end + + +function TreeView:get_item_height() + return style.font:get_height() + style.padding.y +end + + +function TreeView:check_cache() + -- invalidate cache's skip values if project_files has changed + if core.project_files ~= self.last_project_files then + for _, v in pairs(self.cache) do + v.skip = nil + end + self.last_project_files = core.project_files + end +end + + +function TreeView:each_item() + return coroutine.wrap(function() + self:check_cache() + local ox, oy = self:get_content_offset() + local y = oy + style.padding.y + local w = self.size.x + local h = self:get_item_height() + + local i = 1 + while i <= #core.project_files do + local item = core.project_files[i] + local cached = self:get_cached(item) + + coroutine.yield(cached, ox, y, w, h) + y = y + h + i = i + 1 + + if not cached.expanded then + if cached.skip then + i = cached.skip + else + local depth = cached.depth + while i <= #core.project_files do + local filename = core.project_files[i].filename + if get_depth(filename) <= depth then break end + i = i + 1 + end + cached.skip = i + end + end + end + end) +end + + +function TreeView:on_mouse_moved(px, py) + self.hovered_item = nil + for item, x,y,w,h in self:each_item() do + if px > x and py > y and px <= x + w and py <= y + h then + self.hovered_item = item + break + end + end +end + + +function TreeView:on_mouse_pressed(button, x, y) + if not self.hovered_item then + return + elseif self.hovered_item.type == "dir" then + self.hovered_item.expanded = not self.hovered_item.expanded + else + core.try(function() + core.root_view:open_doc(core.open_doc(self.hovered_item.filename)) + end) + end +end + + +function TreeView:update() + -- update width + local dest = self.visible and config.treeview_size or 0 + if self.init_size then + self.size.x = dest + self.init_size = false + else + self:move_towards(self.size, "x", dest) + end + + TreeView.super.update(self) +end + + +function TreeView:draw() + self:draw_background(style.background2) + + local icon_width = style.icon_font:get_width("D") + local spacing = style.font:get_width(" ") * 2 + + local doc = core.active_view.doc + local active_filename = doc and system.absolute_path(doc.filename or "") + + for item, x,y,w,h in self:each_item() do + local color = style.text + + -- highlight active_view doc + if item.abs_filename == active_filename then + color = style.accent + end + + -- hovered item background + if item == self.hovered_item then + renderer.draw_rect(x, y, w, h, style.line_highlight) + color = style.accent + end + + -- icons + x = x + item.depth * style.padding.x + style.padding.x + if item.type == "dir" then + local icon1 = item.expanded and "-" or "+" + local icon2 = item.expanded and "D" or "d" + common.draw_text(style.icon_font, color, icon1, nil, x, y, 0, h) + x = x + style.padding.x + common.draw_text(style.icon_font, color, icon2, nil, x, y, 0, h) + x = x + icon_width + else + x = x + style.padding.x + common.draw_text(style.icon_font, color, "f", nil, x, y, 0, h) + x = x + icon_width + end + + -- text + x = x + spacing + x = common.draw_text(style.font, color, item.name, nil, x, y, 0, h) + end +end + + +-- init +local view = TreeView() +local node = core.root_view:get_active_node() +node:split("left", view, true) + +-- register commands and keymap +command.add(nil, { + ["treeview:toggle"] = function() + view.visible = not view.visible + end, +}) + +keymap.add { ["ctrl+\\"] = "treeview:toggle" } diff --git a/vendor/lite/data/plugins/trimwhitespace.lua b/vendor/lite/data/plugins/trimwhitespace.lua new file mode 100644 index 0000000..d4d25c8 --- /dev/null +++ b/vendor/lite/data/plugins/trimwhitespace.lua @@ -0,0 +1,36 @@ +local core = require "core" +local command = require "core.command" +local Doc = require "core.doc" + + +local function trim_trailing_whitespace(doc) + local cline, ccol = doc:get_selection() + for i = 1, #doc.lines do + local old_text = doc:get_text(i, 1, i, math.huge) + local new_text = old_text:gsub("%s*$", "") + + -- don't remove whitespace which would cause the caret to reposition + if cline == i and ccol > #new_text then + new_text = old_text:sub(1, ccol - 1) + end + + if old_text ~= new_text then + doc:insert(i, 1, new_text) + doc:remove(i, #new_text + 1, i, math.huge) + end + end +end + + +command.add("core.docview", { + ["trim-whitespace:trim-trailing-whitespace"] = function() + trim_trailing_whitespace(core.active_view.doc) + end, +}) + + +local save = Doc.save +Doc.save = function(self, ...) + trim_trailing_whitespace(self) + save(self, ...) +end diff --git a/vendor/lite/data/user/colors/fall.lua b/vendor/lite/data/user/colors/fall.lua new file mode 100644 index 0000000..0cab762 --- /dev/null +++ b/vendor/lite/data/user/colors/fall.lua @@ -0,0 +1,28 @@ +local style = require "core.style" +local common = require "core.common" + +style.background = { common.color "#343233" } +style.background2 = { common.color "#2c2a2b" } +style.background3 = { common.color "#2c2a2b" } +style.text = { common.color "#c4b398" } +style.caret = { common.color "#61efce" } +style.accent = { common.color "#ffd152" } +style.dim = { common.color "#615d5f" } +style.divider = { common.color "#242223" } +style.selection = { common.color "#454244" } +style.line_number = { common.color "#454244" } +style.line_number2 = { common.color "#615d5f" } +style.line_highlight = { common.color "#383637" } +style.scrollbar = { common.color "#454344" } +style.scrollbar2 = { common.color "#524F50" } + +style.syntax["normal"] = { common.color "#efdab9" } +style.syntax["symbol"] = { common.color "#efdab9" } +style.syntax["comment"] = { common.color "#615d5f" } +style.syntax["keyword"] = { common.color "#d36e2d" } +style.syntax["keyword2"] = { common.color "#ef6179" } +style.syntax["number"] = { common.color "#ffd152" } +style.syntax["literal"] = { common.color "#ffd152" } +style.syntax["string"] = { common.color "#ffd152" } +style.syntax["operator"] = { common.color "#efdab9" } +style.syntax["function"] = { common.color "#61efce" } diff --git a/vendor/lite/data/user/colors/summer.lua b/vendor/lite/data/user/colors/summer.lua new file mode 100644 index 0000000..5e48cf7 --- /dev/null +++ b/vendor/lite/data/user/colors/summer.lua @@ -0,0 +1,28 @@ +local style = require "core.style" +local common = require "core.common" + +style.background = { common.color "#fbfbfb" } +style.background2 = { common.color "#f2f2f2" } +style.background3 = { common.color "#f2f2f2" } +style.text = { common.color "#404040" } +style.caret = { common.color "#fc1785" } +style.accent = { common.color "#fc1785" } +style.dim = { common.color "#b0b0b0" } +style.divider = { common.color "#e8e8e8" } +style.selection = { common.color "#b7dce8" } +style.line_number = { common.color "#d0d0d0" } +style.line_number2 = { common.color "#808080" } +style.line_highlight = { common.color "#f2f2f2" } +style.scrollbar = { common.color "#e0e0e0" } +style.scrollbar2 = { common.color "#c0c0c0" } + +style.syntax["normal"] = { common.color "#181818" } +style.syntax["symbol"] = { common.color "#181818" } +style.syntax["comment"] = { common.color "#22a21f" } +style.syntax["keyword"] = { common.color "#fb6620" } +style.syntax["keyword2"] = { common.color "#fc1785" } +style.syntax["number"] = { common.color "#1586d2" } +style.syntax["literal"] = { common.color "#1586d2" } +style.syntax["string"] = { common.color "#1586d2" } +style.syntax["operator"] = { common.color "#fb6620" } +style.syntax["function"] = { common.color "#fc1785" } diff --git a/vendor/lite/data/user/init.lua b/vendor/lite/data/user/init.lua new file mode 100644 index 0000000..2839fe1 --- /dev/null +++ b/vendor/lite/data/user/init.lua @@ -0,0 +1,13 @@ +-- put user settings here +-- this module will be loaded after everything else when the application starts + +local keymap = require "core.keymap" +local config = require "core.config" +local style = require "core.style" + +-- light theme: +-- require "user.colors.summer" + +-- key binding: +-- keymap.add { ["ctrl+escape"] = "core:quit" } + diff --git a/vendor/lite/doc/usage.md b/vendor/lite/doc/usage.md new file mode 100644 index 0000000..3b536cc --- /dev/null +++ b/vendor/lite/doc/usage.md @@ -0,0 +1,146 @@ +# lite + +![screenshot](https://user-images.githubusercontent.com/3920290/81471642-6c165880-91ea-11ea-8cd1-fae7ae8f0bc4.png) + +## Overview +lite is a lightweight text editor written mostly in Lua — it aims to provide +something practical, pretty, *small* and fast, implemented as simply as +possible; easy to modify and extend, or to use without doing either. + + +## Getting Started +When lite is started it's typically opened with a *project directory* — this +is the directory where your project's code and other data resides. The project +directory is set once when lite is started and, for the duration of the +session, cannot be changed. + +To open lite with a specific project directory the directory name can be passed +as a command-line argument *(`.` can be passed to use the current directory)* or +the directory can be dragged onto either the lite executable or a running +instance of lite. + +The main way of opening files in lite is through the `core:find-file` command +— this provides a fuzzy finder over all of the project's files and can be +opened using the **`ctrl+p`** shortcut by default. + +Commands can be run using keyboard shortcuts, or by using the `core:find-command` +command bound to **`ctrl+shift+p`** by default. For example, pressing +`ctrl+shift+p` and typing `newdoc` then pressing `return` would open a new +document. The current keyboard shortcut for a command can be seen to the right +of the command name on the command finder, thus to find the shortcut for a command +`ctrl+shift+p` can be pressed and the command name typed. + + +## User Module +lite can be configured through use of the user module. The user module can be +used for changing options in the config module, adding additional key bindings, +loading custom color themes, modifying the style or changing any other part of +lite to your personal preference. + +The user module is loaded by lite when the application starts, after the plugins +have been loaded. + +The user module can be modified by running the `core:open-user-module` command +or otherwise directly opening the `data/user/init.lua` file. + + +## Project Module +The project module is an optional module which is loaded from the current +project's directory when lite is started. Project modules can be useful for +things like adding custom commands for project-specific build systems, or +loading project-specific plugins. + +The project module is loaded by lite when the application starts, after both the +plugins and user module have been loaded. + +The project module can be edited by running the `core:open-project-module` +command — if the module does not exist for the current project when the +command is run it will be created. + + +## Commands +Commands in lite are used both through the command finder (`ctrl+shift+p`) and +by lite's keyboard shortcut system. Commands consist of 3 components: +* **Name** — The command name in the form of `namespace:action-name`, for + example: `doc:select-all` +* **Predicate** — A function that returns true if the command can be ran, for + example, for any document commands the predicate checks whether the active + view is a document +* **Function** — The function which performs the command itself + +Commands can be added using the `command.add` function provided by the +`core.command` module: +```lua +local core = require "core" +local command = require "core.command" + +command.add("core.docview", { + ["doc:save"] = function() + core.active_view.doc:save() + core.log("Saved '%s', core.active_view.doc.filename) + end +}) +``` + +Commands can be performed programatically (eg. from another command or by your +user module) by calling the `command.perform` function after requiring the +`command` module: +```lua +local command = require "core.command" +command.perform "core:quit" +``` + + +## Keymap +All keyboard shortcuts in lite are handled by the `core.keymap` module. A key +binding in lite maps a "stroke" (eg. `ctrl+q`) to one or more commands (eg. +`core:quit`). When the shortcut is pressed lite will iterate each command +assigned to that key and run the *predicate function* for that command — if the +predicate passes it stops iterating and runs the command. + +An example of where this used is the default binding of the `tab` key: +``` lua + ["tab"] = { "command:complete", "doc:indent" }, +``` +When tab is pressed the `command:complete` command is attempted which will only +succeed if the command-input at the bottom of the window is active. Otherwise +the `doc:indent` command is attempted which will only succeed if we have a +document as our active view. + +A new mapping can be added by your user module as follows: +```lua +local keymap = require "core.keymap" +keymap.add { ["ctrl+q"] = "core:quit" } +``` + + +## Plugins +Plugins in lite are normal lua modules and are treated as such — no +complicated plugin manager is provided, and, once a plugin is loaded, it is never +expected be to have to unload itself. + +To install a plugin simply drop it in the `data/plugins` directory — installed +plugins will be automatically loaded when lite starts. To uninstall a plugin the +plugin file can be deleted — any plugin (including those included with lite's +default installation) can be deleted to remove its functionality. + +If you want to load a plugin only under a certain circumstance (for example, +only on a given project) the plugin can be placed somewhere other than the +`data/plugins` directory so that it is not automatically loaded. The plugin can +then be loaded manually as needed by using the `require` function. + +Plugins can be downloaded from the [plugins repository](https://github.com/rxi/lite-plugins). + + +## Color Themes +Colors themes in lite are lua modules which overwrite the color fields of lite's +`core.style` module. Color themes should be placed in the `data/user/colors` +directory. + +A color theme can be set by requiring it in your user module: +```lua +require "user.colors.winter" +``` + +Color themes can be downloaded from the [color themes repository](https://github.com/rxi/lite-colors). + diff --git a/vendor/lite/icon.ico b/vendor/lite/icon.ico new file mode 100644 index 0000000000000000000000000000000000000000..724cb167f91bc80953e8159321b0e104951e660a GIT binary patch literal 32038 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 literal 0 HcmV?d00001 diff --git a/vendor/lite/icon.inl b/vendor/lite/icon.inl new file mode 100644 index 0000000..673876c --- /dev/null +++ b/vendor/lite/icon.inl @@ -0,0 +1,1369 @@ +static unsigned char icon_rgba[] = { + 0x2e, 0x2e, 0x32, 0x6d, 0x2e, 0x2e, 0x32, 0xe4, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xe4, + 0x2e, 0x2e, 0x32, 0x6d, 0x2e, 0x2e, 0x32, 0xe4, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xe4, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2e, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2d, 0x2d, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x30, 0x2f, 0x33, 0xff, 0x42, 0x35, 0x3a, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x37, 0x3c, 0xff, 0x42, 0x40, 0x44, 0xff, + 0x41, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x38, 0x38, 0x3c, 0xff, + 0x2f, 0x30, 0x34, 0xff, 0x38, 0x3f, 0x46, 0xff, 0x38, 0x3f, 0x46, 0xff, + 0x2f, 0x30, 0x34, 0xff, 0x39, 0x35, 0x33, 0xff, 0x45, 0x3c, 0x35, 0xff, + 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, + 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, 0x42, 0x3a, 0x35, 0xff, + 0x30, 0x2f, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2e, 0x31, 0xff, 0x42, 0x35, 0x3a, 0xff, 0xce, 0x66, 0x72, 0xff, + 0xe2, 0x6d, 0x7b, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xdf, 0x77, 0x84, 0xff, + 0xd0, 0xc3, 0xc9, 0xff, 0xcd, 0xce, 0xd3, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xd1, 0xd1, 0xd5, 0xff, + 0x7d, 0x7d, 0x81, 0xff, 0x35, 0x3c, 0x42, 0xff, 0x7f, 0xba, 0xd2, 0xff, + 0x7f, 0xba, 0xd2, 0xff, 0x34, 0x3d, 0x45, 0xff, 0x8a, 0x64, 0x3d, 0xff, + 0xec, 0x9e, 0x4b, 0xff, 0xe8, 0x9c, 0x4a, 0xff, 0xe8, 0x9c, 0x4a, 0xff, + 0xe8, 0x9c, 0x4a, 0xff, 0xe8, 0x9c, 0x4a, 0xff, 0xea, 0x9c, 0x4a, 0xff, + 0xd4, 0x90, 0x47, 0xff, 0x42, 0x3a, 0x35, 0xff, 0x2d, 0x2d, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2c, 0x2d, 0x31, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0xe4, 0x6d, 0x7b, 0xff, 0xfb, 0x76, 0x85, 0xff, 0xfa, 0x75, 0x84, 0xff, + 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x74, 0x83, 0xff, + 0xf8, 0x81, 0x8f, 0xff, 0xe6, 0xd8, 0xde, 0xff, 0xe3, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe7, 0xe7, 0xec, 0xff, 0x88, 0x88, 0x8c, 0xff, 0x36, 0x3e, 0x45, 0xff, + 0x8a, 0xce, 0xe8, 0xff, 0x8a, 0xce, 0xe8, 0xff, 0x35, 0x3f, 0x48, 0xff, + 0x96, 0x6b, 0x3e, 0xff, 0xff, 0xad, 0x4e, 0xff, 0xff, 0xab, 0x4d, 0xff, + 0xff, 0xab, 0x4d, 0xff, 0xff, 0xab, 0x4d, 0xff, 0xff, 0xab, 0x4d, 0xff, + 0xff, 0xac, 0x4e, 0xff, 0xe8, 0x9d, 0x4a, 0xff, 0x45, 0x3c, 0x35, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2e, 0x31, 0xff, + 0x42, 0x35, 0x3a, 0xff, 0xce, 0x66, 0x72, 0xff, 0xe2, 0x6d, 0x7b, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xdf, 0x77, 0x84, 0xff, 0xd0, 0xc3, 0xc9, 0xff, + 0xcd, 0xce, 0xd3, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xd1, 0xd1, 0xd5, 0xff, 0x7d, 0x7d, 0x81, 0xff, + 0x35, 0x3c, 0x42, 0xff, 0x7f, 0xba, 0xd2, 0xff, 0x7f, 0xba, 0xd2, 0xff, + 0x34, 0x3d, 0x45, 0xff, 0x8a, 0x64, 0x3d, 0xff, 0xec, 0x9e, 0x4b, 0xff, + 0xe8, 0x9c, 0x4a, 0xff, 0xe8, 0x9c, 0x4a, 0xff, 0xe8, 0x9c, 0x4a, 0xff, + 0xe8, 0x9c, 0x4a, 0xff, 0xea, 0x9c, 0x4a, 0xff, 0xd4, 0x90, 0x47, 0xff, + 0x42, 0x3a, 0x35, 0xff, 0x2d, 0x2d, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x30, 0x2f, 0x33, 0xff, 0x42, 0x35, 0x3a, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x37, 0x3c, 0xff, + 0x42, 0x40, 0x44, 0xff, 0x41, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x38, 0x38, 0x3c, 0xff, 0x2f, 0x30, 0x34, 0xff, 0x38, 0x3f, 0x46, 0xff, + 0x38, 0x3f, 0x46, 0xff, 0x2f, 0x30, 0x34, 0xff, 0x39, 0x35, 0x33, 0xff, + 0x45, 0x3c, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, + 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, + 0x42, 0x3a, 0x35, 0xff, 0x30, 0x2f, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2e, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2d, 0x2d, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x35, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x31, 0x31, 0x35, 0xff, + 0x2f, 0x2f, 0x33, 0xff, 0x33, 0x34, 0x38, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x31, 0x31, 0x35, 0xff, 0x2f, 0x2f, 0x33, 0xff, + 0x33, 0x34, 0x38, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x33, 0x34, 0x38, 0xff, 0x2f, 0x2f, 0x33, 0xff, + 0x31, 0x31, 0x35, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x31, 0x31, 0x35, 0xff, + 0x2f, 0x2f, 0x33, 0xff, 0x33, 0x34, 0x38, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x33, 0x34, 0x38, 0xff, 0x2f, 0x2f, 0x33, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x47, 0x49, 0x4d, 0xff, + 0x61, 0x64, 0x68, 0xff, 0x60, 0x63, 0x67, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x47, 0x48, 0x4c, 0xff, 0x32, 0x33, 0x37, 0xff, 0x5a, 0x5e, 0x62, 0xff, + 0x60, 0x64, 0x68, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x61, 0x64, 0x68, 0xff, 0x47, 0x48, 0x4c, 0xff, + 0x32, 0x33, 0x37, 0xff, 0x5a, 0x5e, 0x62, 0xff, 0x60, 0x64, 0x68, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x64, 0x68, 0xff, 0x5a, 0x5e, 0x62, 0xff, + 0x32, 0x33, 0x37, 0xff, 0x47, 0x48, 0x4c, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x47, 0x48, 0x4c, 0xff, 0x32, 0x33, 0x37, 0xff, 0x5a, 0x5e, 0x62, 0xff, + 0x60, 0x64, 0x68, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x64, 0x68, 0xff, 0x5a, 0x5e, 0x62, 0xff, 0x33, 0x34, 0x38, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x32, 0x32, 0x36, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x40, 0x40, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x4a, 0x4c, 0x50, 0xff, 0x68, 0x6c, 0x70, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x68, 0x6c, 0x70, 0xff, 0x4a, 0x4c, 0x50, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x61, 0x64, 0x68, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x68, 0x6c, 0x70, 0xff, + 0x4a, 0x4c, 0x50, 0xff, 0x33, 0x33, 0x37, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x61, 0x64, 0x68, 0xff, 0x33, 0x33, 0x37, 0xff, 0x4a, 0x4c, 0x50, 0xff, + 0x68, 0x6c, 0x70, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x68, 0x6c, 0x70, 0xff, 0x4a, 0x4c, 0x50, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x61, 0x64, 0x68, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, + 0x67, 0x6b, 0x6f, 0xff, 0x67, 0x6b, 0x6f, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x47, 0x49, 0x4d, 0xff, 0x61, 0x64, 0x68, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x61, 0x64, 0x68, 0xff, 0x47, 0x48, 0x4c, 0xff, + 0x32, 0x33, 0x37, 0xff, 0x5a, 0x5e, 0x62, 0xff, 0x60, 0x64, 0x68, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x61, 0x64, 0x68, 0xff, 0x47, 0x48, 0x4c, 0xff, 0x32, 0x33, 0x37, 0xff, + 0x5a, 0x5e, 0x62, 0xff, 0x60, 0x64, 0x68, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x64, 0x68, 0xff, 0x5a, 0x5e, 0x62, 0xff, 0x32, 0x33, 0x37, 0xff, + 0x47, 0x48, 0x4c, 0xff, 0x61, 0x64, 0x68, 0xff, 0x60, 0x63, 0x67, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x61, 0x64, 0x68, 0xff, 0x47, 0x48, 0x4c, 0xff, + 0x32, 0x33, 0x37, 0xff, 0x5a, 0x5e, 0x62, 0xff, 0x60, 0x64, 0x68, 0xff, + 0x60, 0x63, 0x67, 0xff, 0x60, 0x63, 0x67, 0xff, 0x60, 0x64, 0x68, 0xff, + 0x5a, 0x5e, 0x62, 0xff, 0x33, 0x34, 0x38, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x30, 0x31, 0x35, 0xff, + 0x33, 0x34, 0x38, 0xff, 0x33, 0x34, 0x38, 0xff, 0x33, 0x34, 0x38, 0xff, + 0x30, 0x31, 0x35, 0xff, 0x2d, 0x2e, 0x32, 0xff, 0x32, 0x33, 0x37, 0xff, + 0x33, 0x34, 0x38, 0xff, 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x32, 0x33, 0x36, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, 0x32, 0x33, 0x36, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x30, 0x30, 0x34, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, 0x33, 0x33, 0x37, 0xff, + 0x30, 0x31, 0x35, 0xff, 0x2f, 0x2f, 0x33, 0xff, 0x33, 0x34, 0x38, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, 0x34, 0x35, 0x39, 0xff, + 0x34, 0x35, 0x39, 0xff, 0x33, 0x34, 0x38, 0xff, 0x2f, 0x2f, 0x33, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x39, 0x32, 0x36, 0xff, 0x44, 0x35, 0x3b, 0xff, 0x43, 0x35, 0x3a, 0xff, + 0x43, 0x35, 0x3a, 0xff, 0x44, 0x35, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x35, 0x3a, 0xff, 0x42, 0x3b, 0x40, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x46, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x46, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x41, 0x41, 0x46, 0xff, 0x38, 0x38, 0x3c, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2b, 0x2d, 0x31, 0xff, 0x88, 0x4d, 0x56, 0xff, 0xe5, 0x6e, 0x7c, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6b, 0x78, 0xff, 0xd7, 0x9d, 0xa6, 0xff, + 0xcd, 0xcf, 0xd4, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xd1, 0xd1, 0xd5, 0xff, 0x7e, 0x7e, 0x82, 0xff, + 0x2b, 0x2b, 0x2f, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2a, 0x2d, 0x30, 0xff, 0x94, 0x52, 0x5b, 0xff, + 0xfe, 0x76, 0x86, 0xff, 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x75, 0x84, 0xff, + 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x73, 0x82, 0xff, + 0xef, 0xac, 0xb6, 0xff, 0xe3, 0xe6, 0xeb, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe7, 0xe7, 0xec, 0xff, + 0x89, 0x89, 0x8d, 0xff, 0x2b, 0x2b, 0x2f, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2b, 0x2d, 0x31, 0xff, + 0x88, 0x4d, 0x56, 0xff, 0xe5, 0x6e, 0x7c, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6b, 0x78, 0xff, 0xd7, 0x9d, 0xa6, 0xff, 0xcd, 0xcf, 0xd4, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xd1, 0xd1, 0xd5, 0xff, 0x7e, 0x7e, 0x82, 0xff, 0x2b, 0x2b, 0x2f, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x38, 0x31, 0x36, 0xff, 0x43, 0x34, 0x3a, 0xff, + 0x43, 0x34, 0x39, 0xff, 0x43, 0x34, 0x39, 0xff, 0x43, 0x34, 0x39, 0xff, + 0x43, 0x34, 0x39, 0xff, 0x43, 0x34, 0x39, 0xff, 0x41, 0x3a, 0x3f, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, + 0x40, 0x41, 0x44, 0xff, 0x41, 0x41, 0x45, 0xff, 0x36, 0x37, 0x3b, 0xff, + 0x2c, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x37, 0x37, 0x3c, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, + 0x40, 0x40, 0x44, 0xff, 0x40, 0x40, 0x44, 0xff, 0x40, 0x3b, 0x43, 0xff, + 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, + 0x41, 0x37, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x41, 0x3d, 0x44, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x3f, 0x3f, 0x43, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2b, 0x2b, 0x2f, 0xff, + 0x7e, 0x7e, 0x82, 0xff, 0xd1, 0xd1, 0xd5, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcf, 0xd3, 0xff, + 0xcf, 0xa7, 0xc5, 0xff, 0xd1, 0x7e, 0xb8, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd0, 0x7e, 0xb7, 0xff, 0xcc, 0xa5, 0xc3, 0xff, + 0xcf, 0xd0, 0xd4, 0xff, 0xbc, 0xbc, 0xc1, 0xff, 0x3f, 0x3f, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2b, 0x2b, 0x2f, 0xff, 0x89, 0x89, 0x8d, 0xff, 0xe7, 0xe7, 0xec, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe5, 0xe9, 0xff, 0xe6, 0xb8, 0xda, 0xff, 0xe8, 0x8a, 0xcb, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe7, 0x89, 0xca, 0xff, + 0xe2, 0xb6, 0xd7, 0xff, 0xe5, 0xe7, 0xeb, 0xff, 0xd0, 0xd0, 0xd5, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2b, 0x2b, 0x2f, 0xff, 0x7e, 0x7e, 0x82, 0xff, + 0xd1, 0xd1, 0xd5, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcf, 0xd3, 0xff, 0xcf, 0xa7, 0xc5, 0xff, + 0xd1, 0x7e, 0xb8, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd0, 0x7e, 0xb7, 0xff, 0xcc, 0xa5, 0xc3, 0xff, 0xcf, 0xd0, 0xd4, 0xff, + 0xbc, 0xbc, 0xc1, 0xff, 0x3f, 0x3f, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x38, 0x38, 0x3c, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x41, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x44, 0xff, + 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, + 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x41, 0x41, 0x45, 0xff, 0x41, 0x41, 0x46, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, 0x40, 0x41, 0x45, 0xff, + 0x40, 0x41, 0x45, 0xff, 0x41, 0x41, 0x46, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x40, 0x41, 0x44, 0xff, 0x40, 0x41, 0x44, 0xff, 0x41, 0x41, 0x45, 0xff, + 0x42, 0x3d, 0x44, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x41, 0x3d, 0x44, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x3f, 0x3f, 0x43, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2f, 0x2e, 0x32, 0xff, 0x3e, 0x36, 0x3f, 0xff, + 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, + 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, + 0x41, 0x37, 0x41, 0xff, 0x3e, 0x36, 0x3f, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x38, 0x33, 0x32, 0xff, 0x44, 0x3a, 0x34, 0xff, 0x43, 0x3a, 0x34, 0xff, + 0x44, 0x3a, 0x34, 0xff, 0x41, 0x39, 0x33, 0xff, 0x2f, 0x2e, 0x31, 0xff, + 0x36, 0x32, 0x39, 0xff, 0x41, 0x37, 0x41, 0xff, 0x41, 0x37, 0x41, 0xff, + 0x37, 0x32, 0x39, 0xff, 0x2c, 0x2d, 0x30, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x40, 0x37, 0x41, 0xff, + 0xbf, 0x77, 0xaa, 0xff, 0xd2, 0x81, 0xba, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd2, 0x81, 0xba, 0xff, 0xbf, 0x77, 0xaa, 0xff, + 0x3c, 0x35, 0x40, 0xff, 0x8a, 0x64, 0x3d, 0xff, 0xec, 0x9e, 0x4b, 0xff, + 0xe8, 0x9c, 0x4a, 0xff, 0xea, 0x9c, 0x4a, 0xff, 0xd4, 0x90, 0x47, 0xff, + 0x3f, 0x38, 0x32, 0xff, 0x7e, 0x56, 0x75, 0xff, 0xd4, 0x82, 0xbb, 0xff, + 0xd4, 0x82, 0xbb, 0xff, 0x80, 0x57, 0x75, 0xff, 0x2b, 0x2c, 0x2f, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x32, 0x32, 0x36, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x40, 0x40, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x42, 0x38, 0x43, 0xff, 0xd3, 0x81, 0xbb, 0xff, 0xe9, 0x8c, 0xcc, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xe8, 0x8b, 0xcb, 0xff, 0xe9, 0x8c, 0xcc, 0xff, + 0xd3, 0x81, 0xbb, 0xff, 0x3e, 0x36, 0x42, 0xff, 0x95, 0x6c, 0x3f, 0xff, + 0xff, 0xad, 0x4e, 0xff, 0xff, 0xab, 0x4d, 0xff, 0xff, 0xac, 0x4e, 0xff, + 0xe8, 0x9d, 0x4a, 0xff, 0x41, 0x3a, 0x32, 0xff, 0x89, 0x5c, 0x7e, 0xff, + 0xeb, 0x8d, 0xce, 0xff, 0xeb, 0x8d, 0xce, 0xff, 0x8b, 0x5d, 0x7f, 0xff, + 0x2a, 0x2c, 0x2f, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x40, 0x37, 0x41, 0xff, 0xbf, 0x77, 0xaa, 0xff, + 0xd2, 0x81, 0xba, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd2, 0x81, 0xba, 0xff, 0xbf, 0x77, 0xaa, 0xff, 0x3c, 0x35, 0x40, 0xff, + 0x8a, 0x64, 0x3d, 0xff, 0xec, 0x9e, 0x4b, 0xff, 0xe8, 0x9c, 0x4a, 0xff, + 0xea, 0x9c, 0x4a, 0xff, 0xd4, 0x90, 0x47, 0xff, 0x3f, 0x38, 0x32, 0xff, + 0x7e, 0x56, 0x75, 0xff, 0xd4, 0x82, 0xbb, 0xff, 0xd4, 0x82, 0xbb, 0xff, + 0x80, 0x57, 0x75, 0xff, 0x2b, 0x2c, 0x2f, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x30, 0x2f, 0x34, 0xff, + 0x40, 0x37, 0x41, 0xff, 0x42, 0x38, 0x43, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x43, 0xff, 0x40, 0x37, 0x41, 0xff, + 0x30, 0x2f, 0x34, 0xff, 0x39, 0x35, 0x33, 0xff, 0x45, 0x3c, 0x35, 0xff, + 0x45, 0x3b, 0x35, 0xff, 0x45, 0x3b, 0x35, 0xff, 0x42, 0x3a, 0x35, 0xff, + 0x30, 0x2f, 0x32, 0xff, 0x38, 0x33, 0x3a, 0xff, 0x42, 0x38, 0x43, 0xff, + 0x42, 0x38, 0x43, 0xff, 0x38, 0x33, 0x3a, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x32, 0xff, + 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, 0x2c, 0x2d, 0x32, 0xff, + 0x2d, 0x2d, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2e, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2e, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x38, 0x33, 0x3a, 0xff, + 0x42, 0x38, 0x43, 0xff, 0x42, 0x38, 0x42, 0xff, 0x42, 0x38, 0x43, 0xff, + 0x38, 0x33, 0x3a, 0xff, 0x30, 0x2f, 0x33, 0xff, 0x42, 0x35, 0x3a, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x35, 0x3b, 0xff, 0x43, 0x3c, 0x40, 0xff, + 0x41, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x3f, 0x3f, 0x43, 0xff, 0x30, 0x30, 0x34, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, + 0x3e, 0x3e, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2b, 0x2c, 0x2f, 0xff, + 0x80, 0x57, 0x75, 0xff, 0xd4, 0x82, 0xbb, 0xff, 0xd1, 0x80, 0xb9, 0xff, + 0xd4, 0x82, 0xbb, 0xff, 0x7e, 0x57, 0x75, 0xff, 0x3e, 0x33, 0x37, 0xff, + 0xce, 0x66, 0x72, 0xff, 0xe2, 0x6d, 0x7b, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6b, 0x78, 0xff, + 0xd7, 0x9d, 0xa6, 0xff, 0xcd, 0xcf, 0xd4, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcf, 0xcf, 0xd4, 0xff, 0xbc, 0xbc, 0xc1, 0xff, + 0x3f, 0x3f, 0x43, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x4f, 0x4f, 0x55, 0xff, 0x53, 0x53, 0x5a, 0xff, 0x53, 0x53, 0x5a, 0xff, + 0x53, 0x53, 0x5a, 0xff, 0x40, 0x40, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2a, 0x2c, 0x2f, 0xff, 0x8b, 0x5d, 0x7f, 0xff, 0xeb, 0x8d, 0xce, 0xff, + 0xe8, 0x8b, 0xcb, 0xff, 0xeb, 0x8d, 0xce, 0xff, 0x89, 0x5c, 0x7e, 0xff, + 0x41, 0x34, 0x38, 0xff, 0xe4, 0x6d, 0x7b, 0xff, 0xfb, 0x76, 0x85, 0xff, + 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x75, 0x84, 0xff, 0xfa, 0x75, 0x84, 0xff, + 0xfa, 0x73, 0x82, 0xff, 0xef, 0xac, 0xb6, 0xff, 0xe3, 0xe6, 0xeb, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, + 0xe4, 0xe4, 0xe9, 0xff, 0xe4, 0xe4, 0xe9, 0xff, 0xe5, 0xe5, 0xea, 0xff, + 0xd0, 0xd0, 0xd5, 0xff, 0x42, 0x42, 0x46, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x31, 0x31, 0x36, 0xff, 0x4b, 0x4b, 0x51, 0xff, 0x4e, 0x4e, 0x55, 0xff, + 0x4e, 0x4e, 0x55, 0xff, 0x4f, 0x4f, 0x55, 0xff, 0x3e, 0x3e, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2b, 0x2c, 0x2f, 0xff, 0x80, 0x57, 0x75, 0xff, + 0xd4, 0x82, 0xbb, 0xff, 0xd1, 0x80, 0xb9, 0xff, 0xd4, 0x82, 0xbb, 0xff, + 0x7e, 0x57, 0x75, 0xff, 0x3e, 0x33, 0x37, 0xff, 0xce, 0x66, 0x72, 0xff, + 0xe2, 0x6d, 0x7b, 0xff, 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6c, 0x7a, 0xff, + 0xe1, 0x6c, 0x7a, 0xff, 0xe1, 0x6b, 0x78, 0xff, 0xd7, 0x9d, 0xa6, 0xff, + 0xcd, 0xcf, 0xd4, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, 0xcd, 0xcd, 0xd2, 0xff, + 0xcf, 0xcf, 0xd4, 0xff, 0xbc, 0xbc, 0xc1, 0xff, 0x3f, 0x3f, 0x43, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x31, 0x31, 0x36, 0xff, + 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, 0x32, 0x32, 0x36, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x38, 0x33, 0x3a, 0xff, 0x42, 0x38, 0x43, 0xff, 0x42, 0x38, 0x42, 0xff, + 0x42, 0x38, 0x43, 0xff, 0x38, 0x33, 0x3a, 0xff, 0x30, 0x2f, 0x33, 0xff, + 0x42, 0x35, 0x3a, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, + 0x44, 0x36, 0x3b, 0xff, 0x44, 0x36, 0x3b, 0xff, 0x44, 0x35, 0x3b, 0xff, + 0x43, 0x3c, 0x40, 0xff, 0x41, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, + 0x42, 0x42, 0x46, 0xff, 0x42, 0x42, 0x46, 0xff, 0x3f, 0x3f, 0x43, 0xff, + 0x30, 0x30, 0x34, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2e, 0x31, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2d, 0x2e, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, 0x2d, 0x2d, 0x31, 0xff, + 0x2d, 0x2d, 0x31, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xe4, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xe4, + 0x2e, 0x2e, 0x32, 0x6e, 0x2e, 0x2e, 0x32, 0xe4, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, + 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xff, 0x2e, 0x2e, 0x32, 0xe4, + 0x2e, 0x2e, 0x32, 0x6e +}; +static unsigned int icon_rgba_len = 16384; diff --git a/vendor/lite/main.lua b/vendor/lite/main.lua new file mode 100644 index 0000000..2af88cf --- /dev/null +++ b/vendor/lite/main.lua @@ -0,0 +1,318 @@ +renderer = {} + +function renderer.show_debug(show) + -- useful? +end + +function renderer.get_size() + return love.graphics.getWidth(), love.graphics.getHeight() +end + +function renderer.begin_frame() + -- handled in love.run +end + +function renderer.end_frame() + -- handled in love.run +end + +function renderer.set_clip_rect(x, y, w, h) + love.graphics.setScissor(x, y, w, h) +end + +function renderer.set_litecolor(color) + local r, g, b, a = 255, 255, 255, 255 + if color and #color >= 3 then r, g, b = unpack(color, 1, 3) end + if #color >= 4 then a = color[4] end + love.graphics.setColor(r / 255, g / 255, b / 255, a / 255) +end +function renderer.draw_rect(x, y, w, h, color) + renderer.set_litecolor(color) + love.graphics.rectangle("fill", x, y, w, h) +end + +function renderer.draw_text(font, text, x, y, color) + renderer.set_litecolor(color) + love.graphics.setFont(font.font) + if pcall(function() love.graphics.print(text, x, y) end) then + return x + font.font:getWidth(text) + else + return x + end +end + +renderer.font = {} +function renderer.font.load(filename, size) + local font = love.graphics.newFont(filename, size) + return { + font = font, + set_tab_width = function(self, n) + -- todo? Ignore? + end, + get_width = function(self, text) + return self.font:getWidth(text) + end, + get_height = function(self) + return self.font:getHeight() + end + } +end + +system = {} +system.event_queue = {} +function system.enqueue_love_event(ev, a, b, c, d, e, f) + local function button_name(button) + if button == 1 then return 'left' end + if button == 2 then return 'right' end + if button == 3 then return 'middle' end + return '?' + end + local function key_name(key) + if key:sub(1, 2) == "kp" then + return "keypad " .. key:sub(3) + end + if key:sub(2) == "ctrl" or key:sub(2) == "shift" or key:sub(2) == "alt" or key:sub(2) == "gui" then + if key:sub(1, 1) == "l" then return "left " .. key:sub(2) end + return "right " .. key:sub(2) + end + return key + end + local function convert_love_event() + if ev == 'quit' then + return {'quit'} + elseif ev == 'resize' then + return {'resized', a, b} + elseif ev == 'filedropped' then + return {'filedropped', a:getFilename(), love.mouse.getX(), love.mouse.getY()} + elseif ev == 'keypressed' then + return {'keypressed', key_name(a or b)} + elseif ev == 'keyreleased' then + return {'keyreleased', key_name(a or b)} + elseif ev == 'textinput' then + return {'textinput', a} + elseif ev == 'mousepressed' then + return {'mousepressed', button_name(c), a, b, e} + elseif ev == 'mousereleased' then + return {'mousereleased', button_name(c), a, b} + elseif ev == 'mousemoved' then + return {'mousemoved', a, b, c, d} + elseif ev == 'wheelmoved' then + return {'mousewheel', b} + end + end + local liteev = convert_love_event() + if liteev then + table.insert(system.event_queue, liteev) + end +end + +function system.poll_event() + local liteev = table.remove(system.event_queue, 1) + if liteev then + return unpack(liteev) + end +end + +function system.wait_event(n) + -- no love2d equivalent + return false +end + +function system.draw_love_frame() + local core = require("core") + -- update lite & draw + core.redraw = true + core.frame_start = system.get_time() + core.step() + core.run_threads() +end + +function system.set_cursor(cursor) + if cursor == nil then cursor = 'arrow' end + if cursor == 'sizeh' then cursor = 'sizewe' end + if cursor == 'sizev' then cursor = 'sizens' end + love.mouse.setCursor(love.mouse.getSystemCursor(cursor)) +end + +function system.set_window_title(title) + love.window.setTitle(title) +end + +function system.set_window_mode(mode) + love.window.setFullscreen(mode == 'fullscreen') + if mode == nil or mode == 'normal' then love.window.restore() end + if mode == 'maximized' then love.window.maximize() end +end + +function system.window_has_focus() + return love.window.hasFocus() +end + +function system.show_confirm_dialog(title, msg) + return love.window.showMessageBox(title, msg, { 'Yes', 'No', escapebutton = 2 }, 'warning') == 1 +end + +function system.chdir(dir) + -- not possible with love2d +end + +function system.list_dir(path) + if path == '.' then path = '' end + local info = love.filesystem.getInfo(path) + if info and info.type == 'directory' then + return love.filesystem.getDirectoryItems(path) + elseif info and info.type == 'symlink' then + return love.filesystem.getDirectoryItems(path .. "/.") + end + return nil, "Not a directory" +end + +function system.absolute_path(path) + return path -- love.filesystem.getRealDirectory(path) +end + +function system.get_file_info(path) + local info = love.filesystem.getInfo(path) + if info then + local type = nil + if info.type == 'file' then + type = 'file' + elseif info.type == 'directory' then + type = 'dir' + elseif info.type == 'symlink' then + if love.filesystem.read(path, 1) then + type = 'file' + else + type = 'dir' + end + end + return { + modified = info.modtime, + size = info.size, + type = type + } + else + return nil, "Doesn't exist" + end +end + +function system.get_clipboard() + return love.system.getClipboardText() +end + +function system.set_clipboard(text) + love.system.setClipboardText(text) +end + +function system.get_time() + return love.timer.getTime() +end + +function system.sleep(s) + love.timer.sleep(s) +end +function system.exec(cmd) + -- ehhhh todo I guess +end + +function system.fuzzy_match(str, ptn) + local istr = 1 + local iptn = 1 + local score = 0 + local run = 0 + while istr <= str:len() and iptn <= ptn:len() do + while str:sub(istr,istr) == ' ' do istr = istr + 1 end + while ptn:sub(iptn,iptn) == ' ' do iptn = iptn + 1 end + local cstr = str:sub(istr,istr) + local cptn = ptn:sub(iptn,iptn) + if cstr:lower() == cptn:lower() then + score = score + (run * 10) + if cstr ~= cptn then score = score - 1 end + run = run + 1 + iptn = iptn + 1 + else + score = score - 10 + run = 0 + end + istr = istr + 1 + end + if iptn > ptn:len() then + return score - str:len() - istr + 1 + end +end +table.unpack = unpack + + +PATHSEP = package.config:sub(1, 1) +ARGS = love.arg.parseGameArguments(arg) +VERSION = "1.11" +PLATFORM = "love2d" +SCALE = love.graphics.getDPIScale() + +local modname = ... +local ilastdot = modname:reverse():find("%.") +EXEDIR = modname:gsub("%.", PATHSEP) +if ilastdot then + EXEDIR = EXEDIR:sub(1, (-1 - ilastdot)) +else + EXEDIR = "" +end + +local literoot = love.filesystem.getWorkingDirectory() +if #EXEDIR > 0 then + literoot = literoot .. PATHSEP .. EXEDIR +end +package.path = literoot .. '/data/?/init.lua;' .. package.path +package.path = literoot .. '/data/?.lua;' .. package.path + +function love.run() + local core = require('core') + local style = require('core.style') + style.code_font = renderer.font.load(EXEDIR .. "/data/fonts/monospace.ttf", 15 * SCALE) + core.init() + + if love.load then love.load(love.arg.parseGameArguments(arg), arg) end + + -- We don't want the first frame's dt to include time taken by love.load. + if love.timer then love.timer.step() end + + local dt = 0 + -- Main loop time. + return function() + -- Process events. + if love.event then + love.event.pump() + for name, a,b,c,d,e,f in love.event.poll() do + if love.handlers.any then + love.handlers.any(name, a, b, c, d, e, f) + end + if name == "quit" then + if not love.quit or not love.quit() then + return a or 0 + end + end + if rawget(love.handlers, name) then + love.handlers[name](a,b,c,d,e,f) + end + end + end + + -- Update dt, as we'll be passing it to update + if love.timer then dt = love.timer.step() end + + -- Call update and draw + if love.update then love.update(dt) end -- will pass 0 if love.timer is disabled + + if love.graphics and love.graphics.isActive() then + love.graphics.origin() + love.graphics.clear(love.graphics.getBackgroundColor()) + + if love.draw then love.draw() end + + love.graphics.present() + end + + if love.timer then love.timer.sleep(0.001) end + end +end + diff --git a/vendor/lite/res.rc b/vendor/lite/res.rc new file mode 100644 index 0000000..71f99ad --- /dev/null +++ b/vendor/lite/res.rc @@ -0,0 +1,2 @@ +id ICON "icon.ico" + diff --git a/vendor/lite/src/api/api.c b/vendor/lite/src/api/api.c new file mode 100644 index 0000000..34067a9 --- /dev/null +++ b/vendor/lite/src/api/api.c @@ -0,0 +1,18 @@ +#include "api.h" + + +int luaopen_system(lua_State *L); +int luaopen_renderer(lua_State *L); + + +static const luaL_Reg libs[] = { + { "system", luaopen_system }, + { "renderer", luaopen_renderer }, + { NULL, NULL } +}; + +void api_load_libs(lua_State *L) { + for (int i = 0; libs[i].name; i++) { + luaL_requiref(L, libs[i].name, libs[i].func, 1); + } +} diff --git a/vendor/lite/src/api/api.h b/vendor/lite/src/api/api.h new file mode 100644 index 0000000..b6813e5 --- /dev/null +++ b/vendor/lite/src/api/api.h @@ -0,0 +1,12 @@ +#ifndef API_H +#define API_H + +#include "lib/lua52/lua.h" +#include "lib/lua52/lauxlib.h" +#include "lib/lua52/lualib.h" + +#define API_TYPE_FONT "Font" + +void api_load_libs(lua_State *L); + +#endif diff --git a/vendor/lite/src/api/renderer.c b/vendor/lite/src/api/renderer.c new file mode 100644 index 0000000..6b9a98e --- /dev/null +++ b/vendor/lite/src/api/renderer.c @@ -0,0 +1,106 @@ +#include "api.h" +#include "renderer.h" +#include "rencache.h" + + +static RenColor checkcolor(lua_State *L, int idx, int def) { + RenColor color; + if (lua_isnoneornil(L, idx)) { + return (RenColor) { def, def, def, 255 }; + } + lua_rawgeti(L, idx, 1); + lua_rawgeti(L, idx, 2); + lua_rawgeti(L, idx, 3); + lua_rawgeti(L, idx, 4); + color.r = luaL_checknumber(L, -4); + color.g = luaL_checknumber(L, -3); + color.b = luaL_checknumber(L, -2); + color.a = luaL_optnumber(L, -1, 255); + lua_pop(L, 4); + return color; +} + + +static int f_show_debug(lua_State *L) { + luaL_checkany(L, 1); + rencache_show_debug(lua_toboolean(L, 1)); + return 0; +} + + +static int f_get_size(lua_State *L) { + int w, h; + ren_get_size(&w, &h); + lua_pushnumber(L, w); + lua_pushnumber(L, h); + return 2; +} + + +static int f_begin_frame(lua_State *L) { + rencache_begin_frame(); + return 0; +} + + +static int f_end_frame(lua_State *L) { + rencache_end_frame(); + return 0; +} + + +static int f_set_clip_rect(lua_State *L) { + RenRect rect; + rect.x = luaL_checknumber(L, 1); + rect.y = luaL_checknumber(L, 2); + rect.width = luaL_checknumber(L, 3); + rect.height = luaL_checknumber(L, 4); + rencache_set_clip_rect(rect); + return 0; +} + + +static int f_draw_rect(lua_State *L) { + RenRect rect; + rect.x = luaL_checknumber(L, 1); + rect.y = luaL_checknumber(L, 2); + rect.width = luaL_checknumber(L, 3); + rect.height = luaL_checknumber(L, 4); + RenColor color = checkcolor(L, 5, 255); + rencache_draw_rect(rect, color); + return 0; +} + + +static int f_draw_text(lua_State *L) { + RenFont **font = luaL_checkudata(L, 1, API_TYPE_FONT); + const char *text = luaL_checkstring(L, 2); + int x = luaL_checknumber(L, 3); + int y = luaL_checknumber(L, 4); + RenColor color = checkcolor(L, 5, 255); + x = rencache_draw_text(*font, text, x, y, color); + lua_pushnumber(L, x); + return 1; +} + + +static const luaL_Reg lib[] = { + { "show_debug", f_show_debug }, + { "get_size", f_get_size }, + { "begin_frame", f_begin_frame }, + { "end_frame", f_end_frame }, + { "set_clip_rect", f_set_clip_rect }, + { "draw_rect", f_draw_rect }, + { "draw_text", f_draw_text }, + { NULL, NULL } +}; + + +int luaopen_renderer_font(lua_State *L); + +int luaopen_renderer(lua_State *L) { + luaL_newlib(L, lib); + luaopen_renderer_font(L); + lua_setfield(L, -2, "font"); + return 1; +} diff --git a/vendor/lite/src/api/renderer_font.c b/vendor/lite/src/api/renderer_font.c new file mode 100644 index 0000000..452aede --- /dev/null +++ b/vendor/lite/src/api/renderer_font.c @@ -0,0 +1,62 @@ +#include "api.h" +#include "renderer.h" +#include "rencache.h" + + +static int f_load(lua_State *L) { + const char *filename = luaL_checkstring(L, 1); + float size = luaL_checknumber(L, 2); + RenFont **self = lua_newuserdata(L, sizeof(*self)); + luaL_setmetatable(L, API_TYPE_FONT); + *self = ren_load_font(filename, size); + if (!*self) { luaL_error(L, "failed to load font"); } + return 1; +} + + +static int f_set_tab_width(lua_State *L) { + RenFont **self = luaL_checkudata(L, 1, API_TYPE_FONT); + int n = luaL_checknumber(L, 2); + ren_set_font_tab_width(*self, n); + return 0; +} + + +static int f_gc(lua_State *L) { + RenFont **self = luaL_checkudata(L, 1, API_TYPE_FONT); + if (*self) { rencache_free_font(*self); } + return 0; +} + + +static int f_get_width(lua_State *L) { + RenFont **self = luaL_checkudata(L, 1, API_TYPE_FONT); + const char *text = luaL_checkstring(L, 2); + lua_pushnumber(L, ren_get_font_width(*self, text) ); + return 1; +} + + +static int f_get_height(lua_State *L) { + RenFont **self = luaL_checkudata(L, 1, API_TYPE_FONT); + lua_pushnumber(L, ren_get_font_height(*self) ); + return 1; +} + + +static const luaL_Reg lib[] = { + { "__gc", f_gc }, + { "load", f_load }, + { "set_tab_width", f_set_tab_width }, + { "get_width", f_get_width }, + { "get_height", f_get_height }, + { NULL, NULL } +}; + +int luaopen_renderer_font(lua_State *L) { + luaL_newmetatable(L, API_TYPE_FONT); + luaL_setfuncs(L, lib, 0); + lua_pushvalue(L, -1); + lua_setfield(L, -2, "__index"); + return 1; +} diff --git a/vendor/lite/src/api/system.c b/vendor/lite/src/api/system.c new file mode 100644 index 0000000..235d582 --- /dev/null +++ b/vendor/lite/src/api/system.c @@ -0,0 +1,407 @@ +#include +#include +#include +#include +#include +#include +#include +#include "api.h" +#include "rencache.h" +#ifdef _WIN32 + #include +#endif + +extern SDL_Window *window; + + +static const char* button_name(int button) { + switch (button) { + case 1 : return "left"; + case 2 : return "middle"; + case 3 : return "right"; + default : return "?"; + } +} + + +static char* key_name(char *dst, int sym) { + strcpy(dst, SDL_GetKeyName(sym)); + char *p = dst; + while (*p) { + *p = tolower(*p); + p++; + } + return dst; +} + + +static int f_poll_event(lua_State *L) { + char buf[16]; + int mx, my, wx, wy; + SDL_Event e; + +top: + if ( !SDL_PollEvent(&e) ) { + return 0; + } + + switch (e.type) { + case SDL_QUIT: + lua_pushstring(L, "quit"); + return 1; + + case SDL_WINDOWEVENT: + if (e.window.event == SDL_WINDOWEVENT_RESIZED) { + lua_pushstring(L, "resized"); + lua_pushnumber(L, e.window.data1); + lua_pushnumber(L, e.window.data2); + return 3; + } else if (e.window.event == SDL_WINDOWEVENT_EXPOSED) { + rencache_invalidate(); + lua_pushstring(L, "exposed"); + return 1; + } + /* on some systems, when alt-tabbing to the window SDL will queue up + ** several KEYDOWN events for the `tab` key; we flush all keydown + ** events on focus so these are discarded */ + if (e.window.event == SDL_WINDOWEVENT_FOCUS_GAINED) { + SDL_FlushEvent(SDL_KEYDOWN); + } + goto top; + + case SDL_DROPFILE: + SDL_GetGlobalMouseState(&mx, &my); + SDL_GetWindowPosition(window, &wx, &wy); + lua_pushstring(L, "filedropped"); + lua_pushstring(L, e.drop.file); + lua_pushnumber(L, mx - wx); + lua_pushnumber(L, my - wy); + SDL_free(e.drop.file); + return 4; + + case SDL_KEYDOWN: + lua_pushstring(L, "keypressed"); + lua_pushstring(L, key_name(buf, e.key.keysym.sym)); + return 2; + + case SDL_KEYUP: + lua_pushstring(L, "keyreleased"); + lua_pushstring(L, key_name(buf, e.key.keysym.sym)); + return 2; + + case SDL_TEXTINPUT: + lua_pushstring(L, "textinput"); + lua_pushstring(L, e.text.text); + return 2; + + case SDL_MOUSEBUTTONDOWN: + if (e.button.button == 1) { SDL_CaptureMouse(1); } + lua_pushstring(L, "mousepressed"); + lua_pushstring(L, button_name(e.button.button)); + lua_pushnumber(L, e.button.x); + lua_pushnumber(L, e.button.y); + lua_pushnumber(L, e.button.clicks); + return 5; + + case SDL_MOUSEBUTTONUP: + if (e.button.button == 1) { SDL_CaptureMouse(0); } + lua_pushstring(L, "mousereleased"); + lua_pushstring(L, button_name(e.button.button)); + lua_pushnumber(L, e.button.x); + lua_pushnumber(L, e.button.y); + return 4; + + case SDL_MOUSEMOTION: + lua_pushstring(L, "mousemoved"); + lua_pushnumber(L, e.motion.x); + lua_pushnumber(L, e.motion.y); + lua_pushnumber(L, e.motion.xrel); + lua_pushnumber(L, e.motion.yrel); + return 5; + + case SDL_MOUSEWHEEL: + lua_pushstring(L, "mousewheel"); + lua_pushnumber(L, e.wheel.y); + return 2; + + default: + goto top; + } + + return 0; +} + + +static int f_wait_event(lua_State *L) { + double n = luaL_checknumber(L, 1); + lua_pushboolean(L, SDL_WaitEventTimeout(NULL, n * 1000)); + return 1; +} + + +static SDL_Cursor* cursor_cache[SDL_SYSTEM_CURSOR_HAND + 1]; + +static const char *cursor_opts[] = { + "arrow", + "ibeam", + "sizeh", + "sizev", + "hand", + NULL +}; + +static const int cursor_enums[] = { + SDL_SYSTEM_CURSOR_ARROW, + SDL_SYSTEM_CURSOR_IBEAM, + SDL_SYSTEM_CURSOR_SIZEWE, + SDL_SYSTEM_CURSOR_SIZENS, + SDL_SYSTEM_CURSOR_HAND +}; + +static int f_set_cursor(lua_State *L) { + int opt = luaL_checkoption(L, 1, "arrow", cursor_opts); + int n = cursor_enums[opt]; + SDL_Cursor *cursor = cursor_cache[n]; + if (!cursor) { + cursor = SDL_CreateSystemCursor(n); + cursor_cache[n] = cursor; + } + SDL_SetCursor(cursor); + return 0; +} + + +static int f_set_window_title(lua_State *L) { + const char *title = luaL_checkstring(L, 1); + SDL_SetWindowTitle(window, title); + return 0; +} + + +static const char *window_opts[] = { "normal", "maximized", "fullscreen", 0 }; +enum { WIN_NORMAL, WIN_MAXIMIZED, WIN_FULLSCREEN }; + +static int f_set_window_mode(lua_State *L) { + int n = luaL_checkoption(L, 1, "normal", window_opts); + SDL_SetWindowFullscreen(window, + n == WIN_FULLSCREEN ? SDL_WINDOW_FULLSCREEN_DESKTOP : 0); + if (n == WIN_NORMAL) { SDL_RestoreWindow(window); } + if (n == WIN_MAXIMIZED) { SDL_MaximizeWindow(window); } + return 0; +} + + +static int f_window_has_focus(lua_State *L) { + unsigned flags = SDL_GetWindowFlags(window); + lua_pushboolean(L, flags & SDL_WINDOW_INPUT_FOCUS); + return 1; +} + + +static int f_show_confirm_dialog(lua_State *L) { + const char *title = luaL_checkstring(L, 1); + const char *msg = luaL_checkstring(L, 2); + +#if _WIN32 + int id = MessageBox(0, msg, title, MB_YESNO | MB_ICONWARNING); + lua_pushboolean(L, id == IDYES); + +#else + SDL_MessageBoxButtonData buttons[] = { + { SDL_MESSAGEBOX_BUTTON_RETURNKEY_DEFAULT, 1, "Yes" }, + { SDL_MESSAGEBOX_BUTTON_ESCAPEKEY_DEFAULT, 0, "No" }, + }; + SDL_MessageBoxData data = { + .title = title, + .message = msg, + .numbuttons = 2, + .buttons = buttons, + }; + int buttonid; + SDL_ShowMessageBox(&data, &buttonid); + lua_pushboolean(L, buttonid == 1); +#endif + return 1; +} + + +static int f_chdir(lua_State *L) { + const char *path = luaL_checkstring(L, 1); + int err = chdir(path); + if (err) { luaL_error(L, "chdir() failed"); } + return 0; +} + + +static int f_list_dir(lua_State *L) { + const char *path = luaL_checkstring(L, 1); + + DIR *dir = opendir(path); + if (!dir) { + lua_pushnil(L); + lua_pushstring(L, strerror(errno)); + return 2; + } + + lua_newtable(L); + int i = 1; + struct dirent *entry; + while ( (entry = readdir(dir)) ) { + if (strcmp(entry->d_name, "." ) == 0) { continue; } + if (strcmp(entry->d_name, "..") == 0) { continue; } + lua_pushstring(L, entry->d_name); + lua_rawseti(L, -2, i); + i++; + } + + closedir(dir); + return 1; +} + + +#ifdef _WIN32 + #include + #define realpath(x, y) _fullpath(y, x, MAX_PATH) +#endif + +static int f_absolute_path(lua_State *L) { + const char *path = luaL_checkstring(L, 1); + char *res = realpath(path, NULL); + if (!res) { return 0; } + lua_pushstring(L, res); + free(res); + return 1; +} + + +static int f_get_file_info(lua_State *L) { + const char *path = luaL_checkstring(L, 1); + + struct stat s; + int err = stat(path, &s); + if (err < 0) { + lua_pushnil(L); + lua_pushstring(L, strerror(errno)); + return 2; + } + + lua_newtable(L); + lua_pushnumber(L, s.st_mtime); + lua_setfield(L, -2, "modified"); + + lua_pushnumber(L, s.st_size); + lua_setfield(L, -2, "size"); + + if (S_ISREG(s.st_mode)) { + lua_pushstring(L, "file"); + } else if (S_ISDIR(s.st_mode)) { + lua_pushstring(L, "dir"); + } else { + lua_pushnil(L); + } + lua_setfield(L, -2, "type"); + + return 1; +} + + +static int f_get_clipboard(lua_State *L) { + char *text = SDL_GetClipboardText(); + if (!text) { return 0; } + lua_pushstring(L, text); + SDL_free(text); + return 1; +} + + +static int f_set_clipboard(lua_State *L) { + const char *text = luaL_checkstring(L, 1); + SDL_SetClipboardText(text); + return 0; +} + + +static int f_get_time(lua_State *L) { + double n = SDL_GetPerformanceCounter() / (double) SDL_GetPerformanceFrequency(); + lua_pushnumber(L, n); + return 1; +} + + +static int f_sleep(lua_State *L) { + double n = luaL_checknumber(L, 1); + SDL_Delay(n * 1000); + return 0; +} + + +static int f_exec(lua_State *L) { + size_t len; + const char *cmd = luaL_checklstring(L, 1, &len); + char *buf = malloc(len + 32); + if (!buf) { luaL_error(L, "buffer allocation failed"); } +#if _WIN32 + sprintf(buf, "cmd /c \"%s\"", cmd); + WinExec(buf, SW_HIDE); +#else + sprintf(buf, "%s &", cmd); + int res = system(buf); + (void) res; +#endif + free(buf); + return 0; +} + + +static int f_fuzzy_match(lua_State *L) { + const char *str = luaL_checkstring(L, 1); + const char *ptn = luaL_checkstring(L, 2); + int score = 0; + int run = 0; + + while (*str && *ptn) { + while (*str == ' ') { str++; } + while (*ptn == ' ') { ptn++; } + if (tolower(*str) == tolower(*ptn)) { + score += run * 10 - (*str != *ptn); + run++; + ptn++; + } else { + score -= 10; + run = 0; + } + str++; + } + if (*ptn) { return 0; } + + lua_pushnumber(L, score - (int) strlen(str)); + return 1; +} + + +static const luaL_Reg lib[] = { + { "poll_event", f_poll_event }, + { "wait_event", f_wait_event }, + { "set_cursor", f_set_cursor }, + { "set_window_title", f_set_window_title }, + { "set_window_mode", f_set_window_mode }, + { "window_has_focus", f_window_has_focus }, + { "show_confirm_dialog", f_show_confirm_dialog }, + { "chdir", f_chdir }, + { "list_dir", f_list_dir }, + { "absolute_path", f_absolute_path }, + { "get_file_info", f_get_file_info }, + { "get_clipboard", f_get_clipboard }, + { "set_clipboard", f_set_clipboard }, + { "get_time", f_get_time }, + { "sleep", f_sleep }, + { "exec", f_exec }, + { "fuzzy_match", f_fuzzy_match }, + { NULL, NULL } +}; + + +int luaopen_system(lua_State *L) { + luaL_newlib(L, lib); + return 1; +} diff --git a/vendor/lite/src/lib/lua52/lapi.c b/vendor/lite/src/lib/lua52/lapi.c new file mode 100644 index 0000000..d011431 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lapi.c @@ -0,0 +1,1284 @@ +/* +** $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/vendor/lite/src/lib/lua52/lapi.h b/vendor/lite/src/lib/lua52/lapi.h new file mode 100644 index 0000000..c7d34ad --- /dev/null +++ b/vendor/lite/src/lib/lua52/lapi.h @@ -0,0 +1,24 @@ +/* +** $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/vendor/lite/src/lib/lua52/lauxlib.c b/vendor/lite/src/lib/lua52/lauxlib.c new file mode 100644 index 0000000..b00f8c7 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lauxlib.c @@ -0,0 +1,959 @@ +/* +** $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/vendor/lite/src/lib/lua52/lauxlib.h b/vendor/lite/src/lib/lua52/lauxlib.h new file mode 100644 index 0000000..0fb023b --- /dev/null +++ b/vendor/lite/src/lib/lua52/lauxlib.h @@ -0,0 +1,212 @@ +/* +** $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/vendor/lite/src/lib/lua52/lbaselib.c b/vendor/lite/src/lib/lua52/lbaselib.c new file mode 100644 index 0000000..5255b3c --- /dev/null +++ b/vendor/lite/src/lib/lua52/lbaselib.c @@ -0,0 +1,458 @@ +/* +** $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/vendor/lite/src/lib/lua52/lbitlib.c b/vendor/lite/src/lib/lua52/lbitlib.c new file mode 100644 index 0000000..31c7b66 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lbitlib.c @@ -0,0 +1,212 @@ +/* +** $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/vendor/lite/src/lib/lua52/lcode.c b/vendor/lite/src/lib/lua52/lcode.c new file mode 100644 index 0000000..820b95c --- /dev/null +++ b/vendor/lite/src/lib/lua52/lcode.c @@ -0,0 +1,881 @@ +/* +** $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/vendor/lite/src/lib/lua52/lcode.h b/vendor/lite/src/lib/lua52/lcode.h new file mode 100644 index 0000000..6a1424c --- /dev/null +++ b/vendor/lite/src/lib/lua52/lcode.h @@ -0,0 +1,83 @@ +/* +** $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/vendor/lite/src/lib/lua52/lcorolib.c b/vendor/lite/src/lib/lua52/lcorolib.c new file mode 100644 index 0000000..ce4f6ad --- /dev/null +++ b/vendor/lite/src/lib/lua52/lcorolib.c @@ -0,0 +1,155 @@ +/* +** $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/vendor/lite/src/lib/lua52/lctype.c b/vendor/lite/src/lib/lua52/lctype.c new file mode 100644 index 0000000..93f8cad --- /dev/null +++ b/vendor/lite/src/lib/lua52/lctype.c @@ -0,0 +1,52 @@ +/* +** $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/vendor/lite/src/lib/lua52/lctype.h b/vendor/lite/src/lib/lua52/lctype.h new file mode 100644 index 0000000..b09b21a --- /dev/null +++ b/vendor/lite/src/lib/lua52/lctype.h @@ -0,0 +1,95 @@ +/* +** $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/vendor/lite/src/lib/lua52/ldblib.c b/vendor/lite/src/lib/lua52/ldblib.c new file mode 100644 index 0000000..bd8df9d --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldblib.c @@ -0,0 +1,408 @@ +/* +** $Id: ldblib.c,v 1.132.1.2 2015/02/19 17:16:55 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 void checkstack (lua_State *L, lua_State *L1, int n) { + if (L != L1 && !lua_checkstack(L1, n)) + luaL_error(L, "stack overflow"); +} + + +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"); + checkstack(L, L1, 3); + 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"); + checkstack(L, L1, 1); + 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); + checkstack(L, L1, 1); + 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 */ + } + checkstack(L, L1, 1); + 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); + checkstack(L, L1, 1); + 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/vendor/lite/src/lib/lua52/ldebug.c b/vendor/lite/src/lib/lua52/ldebug.c new file mode 100644 index 0000000..9611846 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldebug.c @@ -0,0 +1,610 @@ +/* +** $Id: ldebug.c,v 2.90.1.4 2015/02/19 17:05:13 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)); +} + + +static void swapextra (lua_State *L) { + if (L->status == LUA_YIELD) { + CallInfo *ci = L->ci; /* get function that yielded */ + StkId temp = ci->func; /* exchange its 'func' and 'extra' values */ + ci->func = restorestack(L, ci->extra); + ci->extra = savestack(L, temp); + } +} + + +/* +** 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); + swapextra(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); + } + } + swapextra(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; + lua_lock(L); + swapextra(L); + name = findlocal(L, ar->i_ci, n, &pos); + if (name) + setobjs2s(L, pos, L->top - 1); + L->top--; /* pop value */ + swapextra(L); + 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); + swapextra(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); + } + swapextra(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/vendor/lite/src/lib/lua52/ldebug.h b/vendor/lite/src/lib/lua52/ldebug.h new file mode 100644 index 0000000..6445c76 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldebug.h @@ -0,0 +1,34 @@ +/* +** $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/vendor/lite/src/lib/lua52/ldo.c b/vendor/lite/src/lib/lua52/ldo.c new file mode 100644 index 0000000..e9dd5fa --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldo.c @@ -0,0 +1,681 @@ +/* +** $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/vendor/lite/src/lib/lua52/ldo.h b/vendor/lite/src/lib/lua52/ldo.h new file mode 100644 index 0000000..d3d3082 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldo.h @@ -0,0 +1,46 @@ +/* +** $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/vendor/lite/src/lib/lua52/ldump.c b/vendor/lite/src/lib/lua52/ldump.c new file mode 100644 index 0000000..61fa2cd --- /dev/null +++ b/vendor/lite/src/lib/lua52/ldump.c @@ -0,0 +1,173 @@ +/* +** $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/vendor/lite/src/lib/lua52/lfunc.c b/vendor/lite/src/lib/lua52/lfunc.c new file mode 100644 index 0000000..e90e152 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lfunc.c @@ -0,0 +1,161 @@ +/* +** $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/vendor/lite/src/lib/lua52/lfunc.h b/vendor/lite/src/lib/lua52/lfunc.h new file mode 100644 index 0000000..ca0d3a3 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lfunc.h @@ -0,0 +1,33 @@ +/* +** $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/vendor/lite/src/lib/lua52/lgc.c b/vendor/lite/src/lib/lua52/lgc.c new file mode 100644 index 0000000..553fd17 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lgc.c @@ -0,0 +1,1220 @@ +/* +** $Id: lgc.c,v 2.140.1.3 2014/09/01 16:55:08 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 (g->gcstate != GCSatomic || 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/vendor/lite/src/lib/lua52/lgc.h b/vendor/lite/src/lib/lua52/lgc.h new file mode 100644 index 0000000..84bb1cd --- /dev/null +++ b/vendor/lite/src/lib/lua52/lgc.h @@ -0,0 +1,157 @@ +/* +** $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/vendor/lite/src/lib/lua52/linit.c b/vendor/lite/src/lib/lua52/linit.c new file mode 100644 index 0000000..c1a3830 --- /dev/null +++ b/vendor/lite/src/lib/lua52/linit.c @@ -0,0 +1,67 @@ +/* +** $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/vendor/lite/src/lib/lua52/liolib.c b/vendor/lite/src/lib/lua52/liolib.c new file mode 100644 index 0000000..2a4ec4a --- /dev/null +++ b/vendor/lite/src/lib/lua52/liolib.c @@ -0,0 +1,666 @@ +/* +** $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/vendor/lite/src/lib/lua52/llex.c b/vendor/lite/src/lib/lua52/llex.c new file mode 100644 index 0000000..32cdcf1 --- /dev/null +++ b/vendor/lite/src/lib/lua52/llex.c @@ -0,0 +1,530 @@ +/* +** $Id: llex.c,v 2.63.1.3 2015/02/09 17:56:34 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) + lexerror(ls, "chunk has too many lines", 0); +} + + +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/vendor/lite/src/lib/lua52/llex.h b/vendor/lite/src/lib/lua52/llex.h new file mode 100644 index 0000000..a4acdd3 --- /dev/null +++ b/vendor/lite/src/lib/lua52/llex.h @@ -0,0 +1,78 @@ +/* +** $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/vendor/lite/src/lib/lua52/llimits.h b/vendor/lite/src/lib/lua52/llimits.h new file mode 100644 index 0000000..152dd05 --- /dev/null +++ b/vendor/lite/src/lib/lua52/llimits.h @@ -0,0 +1,309 @@ +/* +** $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/vendor/lite/src/lib/lua52/lmathlib.c b/vendor/lite/src/lib/lua52/lmathlib.c new file mode 100644 index 0000000..fe9fc54 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lmathlib.c @@ -0,0 +1,279 @@ +/* +** $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/vendor/lite/src/lib/lua52/lmem.c b/vendor/lite/src/lib/lua52/lmem.c new file mode 100644 index 0000000..ee343e3 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lmem.c @@ -0,0 +1,99 @@ +/* +** $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/vendor/lite/src/lib/lua52/lmem.h b/vendor/lite/src/lib/lua52/lmem.h new file mode 100644 index 0000000..bd4f4e0 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lmem.h @@ -0,0 +1,57 @@ +/* +** $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/vendor/lite/src/lib/lua52/loadlib.c b/vendor/lite/src/lib/lua52/loadlib.c new file mode 100644 index 0000000..bedbea3 --- /dev/null +++ b/vendor/lite/src/lib/lua52/loadlib.c @@ -0,0 +1,725 @@ +/* +** $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/vendor/lite/src/lib/lua52/lobject.c b/vendor/lite/src/lib/lua52/lobject.c new file mode 100644 index 0000000..882d994 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lobject.c @@ -0,0 +1,287 @@ +/* +** $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/vendor/lite/src/lib/lua52/lobject.h b/vendor/lite/src/lib/lua52/lobject.h new file mode 100644 index 0000000..bc0bb69 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lobject.h @@ -0,0 +1,607 @@ +/* +** $Id: lobject.h,v 2.71.1.2 2014/05/07 14:14:58 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<

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 z⩔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%0DF)9vOeuY0$weR>w-e@_m99ET@=Mt71{_ zH7HbxAg4j$x+of>Wc2}+Dj|fuXg?S=s}CquiJ`3iHHuarP^%I|{~vqrA0Ksf<^N}r z0VX*59_lDjqXdcFq@qn~T1knO9|2NOh!y#v6m9ELJ}b7a&HyT6=p;Jtoer{XZS9X; z?bhwu-R{!eZNaLwBuD^hl^<0TkY8GH-i!+3%5RhJ^L6igCJ8~?e!t&+eE<3Kc#wI& z-}l$K=bU@ax#ymHuhXn>QK~YkRtYFpi6W=D-6j}is{~Z5gc0#2Ho>S{C7@g-j+|!A zhp5UZTqU4lC6HqG^U;$ZD%qSMw zFuWOskI)z2@J{mxQIBFg*%D^#MS5sETj#QP(g4g&9akMNTlUx=c5 zLjI4ZORuo@MJV+ttr4~b-8)XYlTX%mu=cJz)R29Wc)ZQd1EVmOkv#;AUL>J_nWI0ne3o<}%>`pdx<8!ZwXS{#H+Gaob zd%!uS2SBw~BGbaO*M+@8drZ7B)nk~nGHYYG_R75%C`kG&wvh-LYx7`+cVxbE02{u| zdr+ghtMY_b%hn`y7z8%B%%lkB%1^T%dd9b!12PKgy#@;9@zrMP--V6+XG0P5siC$19{2yb${s{SOqEwvf$^#Ygo^a?*R0 zw^w`h`0jP^kR$oM5o*;eH!RiKhS|$*l7BP~t;Yb@*Q*Z;a>+s#E}clQ$cfbHTp(vi zU6C^+h^J1wnf8%G%v?c@BjwHFG>Iknvo`xW^}N(5x7IBol{3fxv?ohb3*&=}_@iAj zYYu{zYvmm6+!Q8Ry1;~OtnI+XH^#W*=z@X%>pjrl$|KZ{0AIa&pmFc_pUz;Mmlv7N zlo!$&GxT4eGpe3K>H-BT(xsopLh$`^PV=|5&v6u1`DnhCyCLntxnJL=^!VrQm8IY` z&o`fqkM3Ss3*O8g{L{*G*V@b);;ABM`8dP}bxuzWbF7{~DV##9^r+)E`I{d0Vs78lFstA@Bkm{)1_5VV@&NXk(H?! zH20mJ*5vva{x0{RrT0KRzniBv>U0J4E^;cu*3=3Yj&VDu&PR>3f*(ld1;gt5X zb$`wdCmZGdbec!l&xXp$*=Hsj5(Uz3CL-$@ek&`O&L)B`dK=F{uw{dB;9j74Ad`=9JzVrttsR8rtAA|DXr%hj>H~ z8>N?%k5>6bt@4ZZQGVco8Y?I<(&g^!fVK?Q2ez1VeVcDpn?|$4{P8H^CY=*PJK4TbM{*}dS0^KXBll~0Cq8r9{3V?e!aL`bhx}qMk&9wcibaVl z`K2*lP5qsj&OLq`p`8;#yS<$q_Y97Qb`EG#u*q6Jb!_OkEXj+Szl<%kuae5+f3X|6 z^PS!AF5LdApSL%>v>#H{of~&}J3H?Q#|Q81=p67(Q)lOzj*Xog1zk_Yf0%l*dnXI- zyN;>u8GhZ1BE5h%@g}yd+}CX8h7W~*#p&R`oo0Oa4{@rY;9nGe^|D7yUcqncw_mbv zv0u!`&FTB|*oXEf*rz`_LD94ou{G!5-?+ASd%3UKOpZY8m+3_tVP?sfz!Nmt+xbrC z#@+Ak>{vLkV}PgwRW%-S`3<~lgkzPOs8V3Jf3aMf6gT+wvYyOa z1bGqZBQLzsUpa00T>nZ*?gQ_M$sd{jRg(MU-}KS-|NNBt5wpSXS8uM|?DMbQ6Pc>S z(PHPjYq;(tFYBzxTY*UC5b7hkBJR7Kqg%#uQt{?q`BXmL@MyYmPvY45&bYRI@$0FT+-AcF$VgI|%$B{MVofACb~FNh~#-%dZxNK;T88KIyuzu zV1?hoQ~UQSW`f_pm-_VYu3Z1z53;Ls14Q!oC9dq|a;…^Kg6fJ>}Lq*ZE+zvek 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�Ap0!pTrdF~zcyz_Yf;Gx4E?`p^YbXHUbuAe|d7B(&#CSX}PG`%w~(1hRF z>79|l2Kx{|r>4N@oO-#S{z>n&kQy(P`*`|3%Co@QQ$*F<2M9FRpJB9(iscOhb=%kJ zw#T7kj5l*V2ImVrIX-s*uejEQa|WW`*eSbvxs%2W**={{298N)#U zKFzth~xe|E2Ty6 z6RQAddrR}j<5KM9||>a2xU(rN#QEs8%=`J={z17;)N zB$7?y)W?0yD9L=2D)VF+Q%-WXZ6P^>=_SkIqJpof0>!U+8N=@!`kn5_%B!brlR3;b ziFJ?B0HXwCXOj{0kohLMX5z_MK#m?h=lGPq%5@SvUGQxwpVD8!po4a;fKTbT_>_L8 zeM%Md-I&^UQ_j!Sg1MIn7Ni!K89}HNk`JT(V&7T$yHp;qnJ_n}($u@bpCpW%x-&=M ziIeyb4zCgw-vShj!>IC^!)OJRKYr7W&H=R7B3{d=8^@>@xKDBj?dNm|*MF*PNANzL zI!z{eDD9jkld?8zIMQQcKD&-C2G7%Uw**Ywtjp$3K-pZ#+x6PXM2Ax;*7i7KI)fj= z*YrAnUXOc_;wg!7@HH9BX27$r(m-Z}xiH-;Y9nHQLwlQW=A+G)->LX{*fVZBh+58a zU9>(Mr`?T)^?@Vsf)uAu0($_Jc_EL`C_N1Hmx9c&XW7U>FX0a?)aw-jxz7Kgc&IwtP_dsd(f@De`;w@e zzhzJiI1bGB25u^xdj@9F<#|?H8?sLV`P6G!f3D%O0F6&PE7z%pR%d@ZHQ`Yme+6RqnH8p^A$k9U#OE;p z=BVp|GVApnKvgUk?|+a0{*IwwO8v?H!?`5YgN%aHZL2>s%{{Yjzb*Ou_T>K*T2u3^ zJ0jMCnDuDfx}_Moim){@78X)IF;()PxlP7kjK-+s zKXca^N7KgU)y9GidB*z~(aXl?(njklW6`+xn>%Vd7R^E;s4eCZqw-CoGTW#;&!{Xj zDoc#H$C6Db{FZ0jcZ3bzhi29qM_)BIuQWEVm&O(}qrtVt`>*N-pR8zyHm&}z^uC62S+k^yI}>f457e0&C*y#VBdDrV2_$A4+t(S}n~albU;{WYDqk`x zE830i*S8xFH3y9CEAfa3)#G2s@gEPI?0)=rW1RMJjB=@ufAg&yU{lNDC-pKLS&yKHY(=Ek@!?hmqR%sxP)bhn}=p0p2+270*Euh@2=gqTwL% z1Uv^W#p*GS1EV(@%LBπ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 literal 0 HcmV?d00001 diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/sdl2-config b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/sdl2-config new file mode 100755 index 0000000..18acfa7 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/sdl2-config @@ -0,0 +1,60 @@ +#!/bin/sh + +prefix=/opt/local/i686-w64-mingw32 +exec_prefix=${prefix} +exec_prefix_set=no +libdir=${exec_prefix}/lib + +#usage="\ +#Usage: $0 [--prefix[=DIR]] [--exec-prefix[=DIR]] [--version] [--cflags] [--libs]" +usage="\ +Usage: $0 [--prefix[=DIR]] [--exec-prefix[=DIR]] [--version] [--cflags] [--libs] [--static-libs]" + +if test $# -eq 0; then + echo "${usage}" 1>&2 + exit 1 +fi + +while test $# -gt 0; do + case "$1" in + -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;; + *) optarg= ;; + esac + + case $1 in + --prefix=*) + prefix=$optarg + if test $exec_prefix_set = no ; then + exec_prefix=$optarg + fi + ;; + --prefix) + echo $prefix + ;; + --exec-prefix=*) + exec_prefix=$optarg + exec_prefix_set=yes + ;; + --exec-prefix) + echo $exec_prefix + ;; + --version) + echo 2.0.10 + ;; + --cflags) + echo -I${prefix}/include/SDL2 -Dmain=SDL_main + ;; + --libs) + echo -L${exec_prefix}/lib -lmingw32 -lSDL2main -lSDL2 -mwindows + ;; + --static-libs) +# --libs|--static-libs) + echo -L${exec_prefix}/lib -lmingw32 -lSDL2main -lSDL2 -mwindows -Wl,--no-undefined -Wl,--dynamicbase -Wl,--nxcompat -lm -ldinput8 -ldxguid -ldxerr8 -luser32 -lgdi32 -lwinmm -limm32 -lole32 -loleaut32 -lshell32 -lsetupapi -lversion -luuid -static-libgcc + ;; + *) + echo "${usage}" 1>&2 + exit 1 + ;; + esac + shift +done diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL.h new file mode 100644 index 0000000..88dce0c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL.h @@ -0,0 +1,135 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL.h + * + * Main include header for the SDL library + */ + + +#ifndef SDL_h_ +#define SDL_h_ + +#include "SDL_main.h" +#include "SDL_stdinc.h" +#include "SDL_assert.h" +#include "SDL_atomic.h" +#include "SDL_audio.h" +#include "SDL_clipboard.h" +#include "SDL_cpuinfo.h" +#include "SDL_endian.h" +#include "SDL_error.h" +#include "SDL_events.h" +#include "SDL_filesystem.h" +#include "SDL_gamecontroller.h" +#include "SDL_haptic.h" +#include "SDL_hints.h" +#include "SDL_joystick.h" +#include "SDL_loadso.h" +#include "SDL_log.h" +#include "SDL_messagebox.h" +#include "SDL_mutex.h" +#include "SDL_power.h" +#include "SDL_render.h" +#include "SDL_rwops.h" +#include "SDL_sensor.h" +#include "SDL_shape.h" +#include "SDL_system.h" +#include "SDL_thread.h" +#include "SDL_timer.h" +#include "SDL_version.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* As of version 0.5, SDL is loaded dynamically into the application */ + +/** + * \name SDL_INIT_* + * + * These are the flags which may be passed to SDL_Init(). You should + * specify the subsystems which you will be using in your application. + */ +/* @{ */ +#define SDL_INIT_TIMER 0x00000001u +#define SDL_INIT_AUDIO 0x00000010u +#define SDL_INIT_VIDEO 0x00000020u /**< SDL_INIT_VIDEO implies SDL_INIT_EVENTS */ +#define SDL_INIT_JOYSTICK 0x00000200u /**< SDL_INIT_JOYSTICK implies SDL_INIT_EVENTS */ +#define SDL_INIT_HAPTIC 0x00001000u +#define SDL_INIT_GAMECONTROLLER 0x00002000u /**< SDL_INIT_GAMECONTROLLER implies SDL_INIT_JOYSTICK */ +#define SDL_INIT_EVENTS 0x00004000u +#define SDL_INIT_SENSOR 0x00008000u +#define SDL_INIT_NOPARACHUTE 0x00100000u /**< compatibility; this flag is ignored. */ +#define SDL_INIT_EVERYTHING ( \ + SDL_INIT_TIMER | SDL_INIT_AUDIO | SDL_INIT_VIDEO | SDL_INIT_EVENTS | \ + SDL_INIT_JOYSTICK | SDL_INIT_HAPTIC | SDL_INIT_GAMECONTROLLER | SDL_INIT_SENSOR \ + ) +/* @} */ + +/** + * This function initializes the subsystems specified by \c flags + */ +extern DECLSPEC int SDLCALL SDL_Init(Uint32 flags); + +/** + * This function initializes specific SDL subsystems + * + * Subsystem initialization is ref-counted, you must call + * SDL_QuitSubSystem() for each SDL_InitSubSystem() to correctly + * shutdown a subsystem manually (or call SDL_Quit() to force shutdown). + * If a subsystem is already loaded then this call will + * increase the ref-count and return. + */ +extern DECLSPEC int SDLCALL SDL_InitSubSystem(Uint32 flags); + +/** + * This function cleans up specific SDL subsystems + */ +extern DECLSPEC void SDLCALL SDL_QuitSubSystem(Uint32 flags); + +/** + * This function returns a mask of the specified subsystems which have + * previously been initialized. + * + * If \c flags is 0, it returns a mask of all initialized subsystems. + */ +extern DECLSPEC Uint32 SDLCALL SDL_WasInit(Uint32 flags); + +/** + * This function cleans up all initialized subsystems. You should + * call it upon all exit conditions. + */ +extern DECLSPEC void SDLCALL SDL_Quit(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_assert.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_assert.h new file mode 100644 index 0000000..8baecb6 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_assert.h @@ -0,0 +1,291 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_assert_h_ +#define SDL_assert_h_ + +#include "SDL_config.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +#ifndef SDL_ASSERT_LEVEL +#ifdef SDL_DEFAULT_ASSERT_LEVEL +#define SDL_ASSERT_LEVEL SDL_DEFAULT_ASSERT_LEVEL +#elif defined(_DEBUG) || defined(DEBUG) || \ + (defined(__GNUC__) && !defined(__OPTIMIZE__)) +#define SDL_ASSERT_LEVEL 2 +#else +#define SDL_ASSERT_LEVEL 1 +#endif +#endif /* SDL_ASSERT_LEVEL */ + +/* +These are macros and not first class functions so that the debugger breaks +on the assertion line and not in some random guts of SDL, and so each +assert can have unique static variables associated with it. +*/ + +#if defined(_MSC_VER) +/* Don't include intrin.h here because it contains C++ code */ + extern void __cdecl __debugbreak(void); + #define SDL_TriggerBreakpoint() __debugbreak() +#elif ( (!defined(__NACL__)) && ((defined(__GNUC__) || defined(__clang__)) && (defined(__i386__) || defined(__x86_64__))) ) + #define SDL_TriggerBreakpoint() __asm__ __volatile__ ( "int $3\n\t" ) +#elif defined(__386__) && defined(__WATCOMC__) + #define SDL_TriggerBreakpoint() { _asm { int 0x03 } } +#elif defined(HAVE_SIGNAL_H) && !defined(__WATCOMC__) + #include + #define SDL_TriggerBreakpoint() raise(SIGTRAP) +#else + /* How do we trigger breakpoints on this platform? */ + #define SDL_TriggerBreakpoint() +#endif + +#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) /* C99 supports __func__ as a standard. */ +# define SDL_FUNCTION __func__ +#elif ((__GNUC__ >= 2) || defined(_MSC_VER) || defined (__WATCOMC__)) +# define SDL_FUNCTION __FUNCTION__ +#else +# define SDL_FUNCTION "???" +#endif +#define SDL_FILE __FILE__ +#define SDL_LINE __LINE__ + +/* +sizeof (x) makes the compiler still parse the expression even without +assertions enabled, so the code is always checked at compile time, but +doesn't actually generate code for it, so there are no side effects or +expensive checks at run time, just the constant size of what x WOULD be, +which presumably gets optimized out as unused. +This also solves the problem of... + + int somevalue = blah(); + SDL_assert(somevalue == 1); + +...which would cause compiles to complain that somevalue is unused if we +disable assertions. +*/ + +/* "while (0,0)" fools Microsoft's compiler's /W4 warning level into thinking + this condition isn't constant. And looks like an owl's face! */ +#ifdef _MSC_VER /* stupid /W4 warnings. */ +#define SDL_NULL_WHILE_LOOP_CONDITION (0,0) +#else +#define SDL_NULL_WHILE_LOOP_CONDITION (0) +#endif + +#define SDL_disabled_assert(condition) \ + do { (void) sizeof ((condition)); } while (SDL_NULL_WHILE_LOOP_CONDITION) + +typedef enum +{ + SDL_ASSERTION_RETRY, /**< Retry the assert immediately. */ + SDL_ASSERTION_BREAK, /**< Make the debugger trigger a breakpoint. */ + SDL_ASSERTION_ABORT, /**< Terminate the program. */ + SDL_ASSERTION_IGNORE, /**< Ignore the assert. */ + SDL_ASSERTION_ALWAYS_IGNORE /**< Ignore the assert from now on. */ +} SDL_AssertState; + +typedef struct SDL_AssertData +{ + int always_ignore; + unsigned int trigger_count; + const char *condition; + const char *filename; + int linenum; + const char *function; + const struct SDL_AssertData *next; +} SDL_AssertData; + +#if (SDL_ASSERT_LEVEL > 0) + +/* Never call this directly. Use the SDL_assert* macros. */ +extern DECLSPEC SDL_AssertState SDLCALL SDL_ReportAssertion(SDL_AssertData *, + const char *, + const char *, int) +#if defined(__clang__) +#if __has_feature(attribute_analyzer_noreturn) +/* this tells Clang's static analysis that we're a custom assert function, + and that the analyzer should assume the condition was always true past this + SDL_assert test. */ + __attribute__((analyzer_noreturn)) +#endif +#endif +; + +/* the do {} while(0) avoids dangling else problems: + if (x) SDL_assert(y); else blah(); + ... without the do/while, the "else" could attach to this macro's "if". + We try to handle just the minimum we need here in a macro...the loop, + the static vars, and break points. The heavy lifting is handled in + SDL_ReportAssertion(), in SDL_assert.c. +*/ +#define SDL_enabled_assert(condition) \ + do { \ + while ( !(condition) ) { \ + static struct SDL_AssertData sdl_assert_data = { \ + 0, 0, #condition, 0, 0, 0, 0 \ + }; \ + const SDL_AssertState sdl_assert_state = SDL_ReportAssertion(&sdl_assert_data, SDL_FUNCTION, SDL_FILE, SDL_LINE); \ + if (sdl_assert_state == SDL_ASSERTION_RETRY) { \ + continue; /* go again. */ \ + } else if (sdl_assert_state == SDL_ASSERTION_BREAK) { \ + SDL_TriggerBreakpoint(); \ + } \ + break; /* not retrying. */ \ + } \ + } while (SDL_NULL_WHILE_LOOP_CONDITION) + +#endif /* enabled assertions support code */ + +/* Enable various levels of assertions. */ +#if SDL_ASSERT_LEVEL == 0 /* assertions disabled */ +# define SDL_assert(condition) SDL_disabled_assert(condition) +# define SDL_assert_release(condition) SDL_disabled_assert(condition) +# define SDL_assert_paranoid(condition) SDL_disabled_assert(condition) +#elif SDL_ASSERT_LEVEL == 1 /* release settings. */ +# define SDL_assert(condition) SDL_disabled_assert(condition) +# define SDL_assert_release(condition) SDL_enabled_assert(condition) +# define SDL_assert_paranoid(condition) SDL_disabled_assert(condition) +#elif SDL_ASSERT_LEVEL == 2 /* normal settings. */ +# define SDL_assert(condition) SDL_enabled_assert(condition) +# define SDL_assert_release(condition) SDL_enabled_assert(condition) +# define SDL_assert_paranoid(condition) SDL_disabled_assert(condition) +#elif SDL_ASSERT_LEVEL == 3 /* paranoid settings. */ +# define SDL_assert(condition) SDL_enabled_assert(condition) +# define SDL_assert_release(condition) SDL_enabled_assert(condition) +# define SDL_assert_paranoid(condition) SDL_enabled_assert(condition) +#else +# error Unknown assertion level. +#endif + +/* this assertion is never disabled at any level. */ +#define SDL_assert_always(condition) SDL_enabled_assert(condition) + + +typedef SDL_AssertState (SDLCALL *SDL_AssertionHandler)( + const SDL_AssertData* data, void* userdata); + +/** + * \brief Set an application-defined assertion handler. + * + * This allows an app to show its own assertion UI and/or force the + * response to an assertion failure. If the app doesn't provide this, SDL + * will try to do the right thing, popping up a system-specific GUI dialog, + * and probably minimizing any fullscreen windows. + * + * This callback may fire from any thread, but it runs wrapped in a mutex, so + * it will only fire from one thread at a time. + * + * Setting the callback to NULL restores SDL's original internal handler. + * + * This callback is NOT reset to SDL's internal handler upon SDL_Quit()! + * + * Return SDL_AssertState value of how to handle the assertion failure. + * + * \param handler Callback function, called when an assertion fails. + * \param userdata A pointer passed to the callback as-is. + */ +extern DECLSPEC void SDLCALL SDL_SetAssertionHandler( + SDL_AssertionHandler handler, + void *userdata); + +/** + * \brief Get the default assertion handler. + * + * This returns the function pointer that is called by default when an + * assertion is triggered. This is an internal function provided by SDL, + * that is used for assertions when SDL_SetAssertionHandler() hasn't been + * used to provide a different function. + * + * \return The default SDL_AssertionHandler that is called when an assert triggers. + */ +extern DECLSPEC SDL_AssertionHandler SDLCALL SDL_GetDefaultAssertionHandler(void); + +/** + * \brief Get the current assertion handler. + * + * This returns the function pointer that is called when an assertion is + * triggered. This is either the value last passed to + * SDL_SetAssertionHandler(), or if no application-specified function is + * set, is equivalent to calling SDL_GetDefaultAssertionHandler(). + * + * \param puserdata Pointer to a void*, which will store the "userdata" + * pointer that was passed to SDL_SetAssertionHandler(). + * This value will always be NULL for the default handler. + * If you don't care about this data, it is safe to pass + * a NULL pointer to this function to ignore it. + * \return The SDL_AssertionHandler that is called when an assert triggers. + */ +extern DECLSPEC SDL_AssertionHandler SDLCALL SDL_GetAssertionHandler(void **puserdata); + +/** + * \brief Get a list of all assertion failures. + * + * Get all assertions triggered since last call to SDL_ResetAssertionReport(), + * or the start of the program. + * + * The proper way to examine this data looks something like this: + * + * + * const SDL_AssertData *item = SDL_GetAssertionReport(); + * while (item) { + * printf("'%s', %s (%s:%d), triggered %u times, always ignore: %s.\\n", + * item->condition, item->function, item->filename, + * item->linenum, item->trigger_count, + * item->always_ignore ? "yes" : "no"); + * item = item->next; + * } + * + * + * \return List of all assertions. + * \sa SDL_ResetAssertionReport + */ +extern DECLSPEC const SDL_AssertData * SDLCALL SDL_GetAssertionReport(void); + +/** + * \brief Reset the list of all assertion failures. + * + * Reset list of all assertions triggered. + * + * \sa SDL_GetAssertionReport + */ +extern DECLSPEC void SDLCALL SDL_ResetAssertionReport(void); + + +/* these had wrong naming conventions until 2.0.4. Please update your app! */ +#define SDL_assert_state SDL_AssertState +#define SDL_assert_data SDL_AssertData + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_assert_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_atomic.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_atomic.h new file mode 100644 index 0000000..deee35f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_atomic.h @@ -0,0 +1,295 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_atomic.h + * + * Atomic operations. + * + * IMPORTANT: + * If you are not an expert in concurrent lockless programming, you should + * only be using the atomic lock and reference counting functions in this + * file. In all other cases you should be protecting your data structures + * with full mutexes. + * + * The list of "safe" functions to use are: + * SDL_AtomicLock() + * SDL_AtomicUnlock() + * SDL_AtomicIncRef() + * SDL_AtomicDecRef() + * + * Seriously, here be dragons! + * ^^^^^^^^^^^^^^^^^^^^^^^^^^^ + * + * You can find out a little more about lockless programming and the + * subtle issues that can arise here: + * http://msdn.microsoft.com/en-us/library/ee418650%28v=vs.85%29.aspx + * + * There's also lots of good information here: + * http://www.1024cores.net/home/lock-free-algorithms + * http://preshing.com/ + * + * These operations may or may not actually be implemented using + * processor specific atomic operations. When possible they are + * implemented as true processor specific atomic operations. When that + * is not possible the are implemented using locks that *do* use the + * available atomic operations. + * + * All of the atomic operations that modify memory are full memory barriers. + */ + +#ifndef SDL_atomic_h_ +#define SDL_atomic_h_ + +#include "SDL_stdinc.h" +#include "SDL_platform.h" + +#include "begin_code.h" + +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \name SDL AtomicLock + * + * The atomic locks are efficient spinlocks using CPU instructions, + * but are vulnerable to starvation and can spin forever if a thread + * holding a lock has been terminated. For this reason you should + * minimize the code executed inside an atomic lock and never do + * expensive things like API or system calls while holding them. + * + * The atomic locks are not safe to lock recursively. + * + * Porting Note: + * The spin lock functions and type are required and can not be + * emulated because they are used in the atomic emulation code. + */ +/* @{ */ + +typedef int SDL_SpinLock; + +/** + * \brief Try to lock a spin lock by setting it to a non-zero value. + * + * \param lock Points to the lock. + * + * \return SDL_TRUE if the lock succeeded, SDL_FALSE if the lock is already held. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_AtomicTryLock(SDL_SpinLock *lock); + +/** + * \brief Lock a spin lock by setting it to a non-zero value. + * + * \param lock Points to the lock. + */ +extern DECLSPEC void SDLCALL SDL_AtomicLock(SDL_SpinLock *lock); + +/** + * \brief Unlock a spin lock by setting it to 0. Always returns immediately + * + * \param lock Points to the lock. + */ +extern DECLSPEC void SDLCALL SDL_AtomicUnlock(SDL_SpinLock *lock); + +/* @} *//* SDL AtomicLock */ + + +/** + * The compiler barrier prevents the compiler from reordering + * reads and writes to globally visible variables across the call. + */ +#if defined(_MSC_VER) && (_MSC_VER > 1200) && !defined(__clang__) +void _ReadWriteBarrier(void); +#pragma intrinsic(_ReadWriteBarrier) +#define SDL_CompilerBarrier() _ReadWriteBarrier() +#elif (defined(__GNUC__) && !defined(__EMSCRIPTEN__)) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x5120)) +/* This is correct for all CPUs when using GCC or Solaris Studio 12.1+. */ +#define SDL_CompilerBarrier() __asm__ __volatile__ ("" : : : "memory") +#elif defined(__WATCOMC__) +extern _inline void SDL_CompilerBarrier (void); +#pragma aux SDL_CompilerBarrier = "" parm [] modify exact []; +#else +#define SDL_CompilerBarrier() \ +{ SDL_SpinLock _tmp = 0; SDL_AtomicLock(&_tmp); SDL_AtomicUnlock(&_tmp); } +#endif + +/** + * Memory barriers are designed to prevent reads and writes from being + * reordered by the compiler and being seen out of order on multi-core CPUs. + * + * A typical pattern would be for thread A to write some data and a flag, + * and for thread B to read the flag and get the data. In this case you + * would insert a release barrier between writing the data and the flag, + * guaranteeing that the data write completes no later than the flag is + * written, and you would insert an acquire barrier between reading the + * flag and reading the data, to ensure that all the reads associated + * with the flag have completed. + * + * In this pattern you should always see a release barrier paired with + * an acquire barrier and you should gate the data reads/writes with a + * single flag variable. + * + * For more information on these semantics, take a look at the blog post: + * http://preshing.com/20120913/acquire-and-release-semantics + */ +extern DECLSPEC void SDLCALL SDL_MemoryBarrierReleaseFunction(void); +extern DECLSPEC void SDLCALL SDL_MemoryBarrierAcquireFunction(void); + +#if defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__)) +#define SDL_MemoryBarrierRelease() __asm__ __volatile__ ("lwsync" : : : "memory") +#define SDL_MemoryBarrierAcquire() __asm__ __volatile__ ("lwsync" : : : "memory") +#elif defined(__GNUC__) && defined(__aarch64__) +#define SDL_MemoryBarrierRelease() __asm__ __volatile__ ("dmb ish" : : : "memory") +#define SDL_MemoryBarrierAcquire() __asm__ __volatile__ ("dmb ish" : : : "memory") +#elif defined(__GNUC__) && defined(__arm__) +#if 0 /* defined(__LINUX__) || defined(__ANDROID__) */ +/* Information from: + https://chromium.googlesource.com/chromium/chromium/+/trunk/base/atomicops_internals_arm_gcc.h#19 + + The Linux kernel provides a helper function which provides the right code for a memory barrier, + hard-coded at address 0xffff0fa0 +*/ +typedef void (*SDL_KernelMemoryBarrierFunc)(); +#define SDL_MemoryBarrierRelease() ((SDL_KernelMemoryBarrierFunc)0xffff0fa0)() +#define SDL_MemoryBarrierAcquire() ((SDL_KernelMemoryBarrierFunc)0xffff0fa0)() +#elif 0 /* defined(__QNXNTO__) */ +#include + +#define SDL_MemoryBarrierRelease() __cpu_membarrier() +#define SDL_MemoryBarrierAcquire() __cpu_membarrier() +#else +#if defined(__ARM_ARCH_7__) || defined(__ARM_ARCH_7A__) || defined(__ARM_ARCH_7EM__) || defined(__ARM_ARCH_7R__) || defined(__ARM_ARCH_7M__) || defined(__ARM_ARCH_7S__) || defined(__ARM_ARCH_8A__) +#define SDL_MemoryBarrierRelease() __asm__ __volatile__ ("dmb ish" : : : "memory") +#define SDL_MemoryBarrierAcquire() __asm__ __volatile__ ("dmb ish" : : : "memory") +#elif defined(__ARM_ARCH_6__) || defined(__ARM_ARCH_6J__) || defined(__ARM_ARCH_6K__) || defined(__ARM_ARCH_6T2__) || defined(__ARM_ARCH_6Z__) || defined(__ARM_ARCH_6ZK__) || defined(__ARM_ARCH_5TE__) +#ifdef __thumb__ +/* The mcr instruction isn't available in thumb mode, use real functions */ +#define SDL_MEMORY_BARRIER_USES_FUNCTION +#define SDL_MemoryBarrierRelease() SDL_MemoryBarrierReleaseFunction() +#define SDL_MemoryBarrierAcquire() SDL_MemoryBarrierAcquireFunction() +#else +#define SDL_MemoryBarrierRelease() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 5" : : "r"(0) : "memory") +#define SDL_MemoryBarrierAcquire() __asm__ __volatile__ ("mcr p15, 0, %0, c7, c10, 5" : : "r"(0) : "memory") +#endif /* __thumb__ */ +#else +#define SDL_MemoryBarrierRelease() __asm__ __volatile__ ("" : : : "memory") +#define SDL_MemoryBarrierAcquire() __asm__ __volatile__ ("" : : : "memory") +#endif /* __LINUX__ || __ANDROID__ */ +#endif /* __GNUC__ && __arm__ */ +#else +#if (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x5120)) +/* This is correct for all CPUs on Solaris when using Solaris Studio 12.1+. */ +#include +#define SDL_MemoryBarrierRelease() __machine_rel_barrier() +#define SDL_MemoryBarrierAcquire() __machine_acq_barrier() +#else +/* This is correct for the x86 and x64 CPUs, and we'll expand this over time. */ +#define SDL_MemoryBarrierRelease() SDL_CompilerBarrier() +#define SDL_MemoryBarrierAcquire() SDL_CompilerBarrier() +#endif +#endif + +/** + * \brief A type representing an atomic integer value. It is a struct + * so people don't accidentally use numeric operations on it. + */ +typedef struct { int value; } SDL_atomic_t; + +/** + * \brief Set an atomic variable to a new value if it is currently an old value. + * + * \return SDL_TRUE if the atomic variable was set, SDL_FALSE otherwise. + * + * \note If you don't know what this function is for, you shouldn't use it! +*/ +extern DECLSPEC SDL_bool SDLCALL SDL_AtomicCAS(SDL_atomic_t *a, int oldval, int newval); + +/** + * \brief Set an atomic variable to a value. + * + * \return The previous value of the atomic variable. + */ +extern DECLSPEC int SDLCALL SDL_AtomicSet(SDL_atomic_t *a, int v); + +/** + * \brief Get the value of an atomic variable + */ +extern DECLSPEC int SDLCALL SDL_AtomicGet(SDL_atomic_t *a); + +/** + * \brief Add to an atomic variable. + * + * \return The previous value of the atomic variable. + * + * \note This same style can be used for any number operation + */ +extern DECLSPEC int SDLCALL SDL_AtomicAdd(SDL_atomic_t *a, int v); + +/** + * \brief Increment an atomic variable used as a reference count. + */ +#ifndef SDL_AtomicIncRef +#define SDL_AtomicIncRef(a) SDL_AtomicAdd(a, 1) +#endif + +/** + * \brief Decrement an atomic variable used as a reference count. + * + * \return SDL_TRUE if the variable reached zero after decrementing, + * SDL_FALSE otherwise + */ +#ifndef SDL_AtomicDecRef +#define SDL_AtomicDecRef(a) (SDL_AtomicAdd(a, -1) == 1) +#endif + +/** + * \brief Set a pointer to a new value if it is currently an old value. + * + * \return SDL_TRUE if the pointer was set, SDL_FALSE otherwise. + * + * \note If you don't know what this function is for, you shouldn't use it! +*/ +extern DECLSPEC SDL_bool SDLCALL SDL_AtomicCASPtr(void **a, void *oldval, void *newval); + +/** + * \brief Set a pointer to a value atomically. + * + * \return The previous value of the pointer. + */ +extern DECLSPEC void* SDLCALL SDL_AtomicSetPtr(void **a, void* v); + +/** + * \brief Get the value of a pointer atomically. + */ +extern DECLSPEC void* SDLCALL SDL_AtomicGetPtr(void **a); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif + +#include "close_code.h" + +#endif /* SDL_atomic_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_audio.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_audio.h new file mode 100644 index 0000000..305c01a --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_audio.h @@ -0,0 +1,859 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_audio.h + * + * Access to the raw audio mixing buffer for the SDL library. + */ + +#ifndef SDL_audio_h_ +#define SDL_audio_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_endian.h" +#include "SDL_mutex.h" +#include "SDL_thread.h" +#include "SDL_rwops.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Audio format flags. + * + * These are what the 16 bits in SDL_AudioFormat currently mean... + * (Unspecified bits are always zero). + * + * \verbatim + ++-----------------------sample is signed if set + || + || ++-----------sample is bigendian if set + || || + || || ++---sample is float if set + || || || + || || || +---sample bit size---+ + || || || | | + 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 + \endverbatim + * + * There are macros in SDL 2.0 and later to query these bits. + */ +typedef Uint16 SDL_AudioFormat; + +/** + * \name Audio flags + */ +/* @{ */ + +#define SDL_AUDIO_MASK_BITSIZE (0xFF) +#define SDL_AUDIO_MASK_DATATYPE (1<<8) +#define SDL_AUDIO_MASK_ENDIAN (1<<12) +#define SDL_AUDIO_MASK_SIGNED (1<<15) +#define SDL_AUDIO_BITSIZE(x) (x & SDL_AUDIO_MASK_BITSIZE) +#define SDL_AUDIO_ISFLOAT(x) (x & SDL_AUDIO_MASK_DATATYPE) +#define SDL_AUDIO_ISBIGENDIAN(x) (x & SDL_AUDIO_MASK_ENDIAN) +#define SDL_AUDIO_ISSIGNED(x) (x & SDL_AUDIO_MASK_SIGNED) +#define SDL_AUDIO_ISINT(x) (!SDL_AUDIO_ISFLOAT(x)) +#define SDL_AUDIO_ISLITTLEENDIAN(x) (!SDL_AUDIO_ISBIGENDIAN(x)) +#define SDL_AUDIO_ISUNSIGNED(x) (!SDL_AUDIO_ISSIGNED(x)) + +/** + * \name Audio format flags + * + * Defaults to LSB byte order. + */ +/* @{ */ +#define AUDIO_U8 0x0008 /**< Unsigned 8-bit samples */ +#define AUDIO_S8 0x8008 /**< Signed 8-bit samples */ +#define AUDIO_U16LSB 0x0010 /**< Unsigned 16-bit samples */ +#define AUDIO_S16LSB 0x8010 /**< Signed 16-bit samples */ +#define AUDIO_U16MSB 0x1010 /**< As above, but big-endian byte order */ +#define AUDIO_S16MSB 0x9010 /**< As above, but big-endian byte order */ +#define AUDIO_U16 AUDIO_U16LSB +#define AUDIO_S16 AUDIO_S16LSB +/* @} */ + +/** + * \name int32 support + */ +/* @{ */ +#define AUDIO_S32LSB 0x8020 /**< 32-bit integer samples */ +#define AUDIO_S32MSB 0x9020 /**< As above, but big-endian byte order */ +#define AUDIO_S32 AUDIO_S32LSB +/* @} */ + +/** + * \name float32 support + */ +/* @{ */ +#define AUDIO_F32LSB 0x8120 /**< 32-bit floating point samples */ +#define AUDIO_F32MSB 0x9120 /**< As above, but big-endian byte order */ +#define AUDIO_F32 AUDIO_F32LSB +/* @} */ + +/** + * \name Native audio byte ordering + */ +/* @{ */ +#if SDL_BYTEORDER == SDL_LIL_ENDIAN +#define AUDIO_U16SYS AUDIO_U16LSB +#define AUDIO_S16SYS AUDIO_S16LSB +#define AUDIO_S32SYS AUDIO_S32LSB +#define AUDIO_F32SYS AUDIO_F32LSB +#else +#define AUDIO_U16SYS AUDIO_U16MSB +#define AUDIO_S16SYS AUDIO_S16MSB +#define AUDIO_S32SYS AUDIO_S32MSB +#define AUDIO_F32SYS AUDIO_F32MSB +#endif +/* @} */ + +/** + * \name Allow change flags + * + * Which audio format changes are allowed when opening a device. + */ +/* @{ */ +#define SDL_AUDIO_ALLOW_FREQUENCY_CHANGE 0x00000001 +#define SDL_AUDIO_ALLOW_FORMAT_CHANGE 0x00000002 +#define SDL_AUDIO_ALLOW_CHANNELS_CHANGE 0x00000004 +#define SDL_AUDIO_ALLOW_SAMPLES_CHANGE 0x00000008 +#define SDL_AUDIO_ALLOW_ANY_CHANGE (SDL_AUDIO_ALLOW_FREQUENCY_CHANGE|SDL_AUDIO_ALLOW_FORMAT_CHANGE|SDL_AUDIO_ALLOW_CHANNELS_CHANGE|SDL_AUDIO_ALLOW_SAMPLES_CHANGE) +/* @} */ + +/* @} *//* Audio flags */ + +/** + * This function is called when the audio device needs more data. + * + * \param userdata An application-specific parameter saved in + * the SDL_AudioSpec structure + * \param stream A pointer to the audio data buffer. + * \param len The length of that buffer in bytes. + * + * Once the callback returns, the buffer will no longer be valid. + * Stereo samples are stored in a LRLRLR ordering. + * + * You can choose to avoid callbacks and use SDL_QueueAudio() instead, if + * you like. Just open your audio device with a NULL callback. + */ +typedef void (SDLCALL * SDL_AudioCallback) (void *userdata, Uint8 * stream, + int len); + +/** + * The calculated values in this structure are calculated by SDL_OpenAudio(). + * + * For multi-channel audio, the default SDL channel mapping is: + * 2: FL FR (stereo) + * 3: FL FR LFE (2.1 surround) + * 4: FL FR BL BR (quad) + * 5: FL FR FC BL BR (quad + center) + * 6: FL FR FC LFE SL SR (5.1 surround - last two can also be BL BR) + * 7: FL FR FC LFE BC SL SR (6.1 surround) + * 8: FL FR FC LFE BL BR SL SR (7.1 surround) + */ +typedef struct SDL_AudioSpec +{ + int freq; /**< DSP frequency -- samples per second */ + SDL_AudioFormat format; /**< Audio data format */ + Uint8 channels; /**< Number of channels: 1 mono, 2 stereo */ + Uint8 silence; /**< Audio buffer silence value (calculated) */ + Uint16 samples; /**< Audio buffer size in sample FRAMES (total samples divided by channel count) */ + Uint16 padding; /**< Necessary for some compile environments */ + Uint32 size; /**< Audio buffer size in bytes (calculated) */ + SDL_AudioCallback callback; /**< Callback that feeds the audio device (NULL to use SDL_QueueAudio()). */ + void *userdata; /**< Userdata passed to callback (ignored for NULL callbacks). */ +} SDL_AudioSpec; + + +struct SDL_AudioCVT; +typedef void (SDLCALL * SDL_AudioFilter) (struct SDL_AudioCVT * cvt, + SDL_AudioFormat format); + +/** + * \brief Upper limit of filters in SDL_AudioCVT + * + * The maximum number of SDL_AudioFilter functions in SDL_AudioCVT is + * currently limited to 9. The SDL_AudioCVT.filters array has 10 pointers, + * one of which is the terminating NULL pointer. + */ +#define SDL_AUDIOCVT_MAX_FILTERS 9 + +/** + * \struct SDL_AudioCVT + * \brief A structure to hold a set of audio conversion filters and buffers. + * + * Note that various parts of the conversion pipeline can take advantage + * of SIMD operations (like SSE2, for example). SDL_AudioCVT doesn't require + * you to pass it aligned data, but can possibly run much faster if you + * set both its (buf) field to a pointer that is aligned to 16 bytes, and its + * (len) field to something that's a multiple of 16, if possible. + */ +#ifdef __GNUC__ +/* This structure is 84 bytes on 32-bit architectures, make sure GCC doesn't + pad it out to 88 bytes to guarantee ABI compatibility between compilers. + vvv + The next time we rev the ABI, make sure to size the ints and add padding. +*/ +#define SDL_AUDIOCVT_PACKED __attribute__((packed)) +#else +#define SDL_AUDIOCVT_PACKED +#endif +/* */ +typedef struct SDL_AudioCVT +{ + int needed; /**< Set to 1 if conversion possible */ + SDL_AudioFormat src_format; /**< Source audio format */ + SDL_AudioFormat dst_format; /**< Target audio format */ + double rate_incr; /**< Rate conversion increment */ + Uint8 *buf; /**< Buffer to hold entire audio data */ + int len; /**< Length of original audio buffer */ + int len_cvt; /**< Length of converted audio buffer */ + int len_mult; /**< buffer must be len*len_mult big */ + double len_ratio; /**< Given len, final size is len*len_ratio */ + SDL_AudioFilter filters[SDL_AUDIOCVT_MAX_FILTERS + 1]; /**< NULL-terminated list of filter functions */ + int filter_index; /**< Current audio conversion function */ +} SDL_AUDIOCVT_PACKED SDL_AudioCVT; + + +/* Function prototypes */ + +/** + * \name Driver discovery functions + * + * These functions return the list of built in audio drivers, in the + * order that they are normally initialized by default. + */ +/* @{ */ +extern DECLSPEC int SDLCALL SDL_GetNumAudioDrivers(void); +extern DECLSPEC const char *SDLCALL SDL_GetAudioDriver(int index); +/* @} */ + +/** + * \name Initialization and cleanup + * + * \internal These functions are used internally, and should not be used unless + * you have a specific need to specify the audio driver you want to + * use. You should normally use SDL_Init() or SDL_InitSubSystem(). + */ +/* @{ */ +extern DECLSPEC int SDLCALL SDL_AudioInit(const char *driver_name); +extern DECLSPEC void SDLCALL SDL_AudioQuit(void); +/* @} */ + +/** + * This function returns the name of the current audio driver, or NULL + * if no driver has been initialized. + */ +extern DECLSPEC const char *SDLCALL SDL_GetCurrentAudioDriver(void); + +/** + * This function opens the audio device with the desired parameters, and + * returns 0 if successful, placing the actual hardware parameters in the + * structure pointed to by \c obtained. If \c obtained is NULL, the audio + * data passed to the callback function will be guaranteed to be in the + * requested format, and will be automatically converted to the hardware + * audio format if necessary. This function returns -1 if it failed + * to open the audio device, or couldn't set up the audio thread. + * + * When filling in the desired audio spec structure, + * - \c desired->freq should be the desired audio frequency in samples-per- + * second. + * - \c desired->format should be the desired audio format. + * - \c desired->samples is the desired size of the audio buffer, in + * samples. This number should be a power of two, and may be adjusted by + * the audio driver to a value more suitable for the hardware. Good values + * seem to range between 512 and 8096 inclusive, depending on the + * application and CPU speed. Smaller values yield faster response time, + * but can lead to underflow if the application is doing heavy processing + * and cannot fill the audio buffer in time. A stereo sample consists of + * both right and left channels in LR ordering. + * Note that the number of samples is directly related to time by the + * following formula: \code ms = (samples*1000)/freq \endcode + * - \c desired->size is the size in bytes of the audio buffer, and is + * calculated by SDL_OpenAudio(). + * - \c desired->silence is the value used to set the buffer to silence, + * and is calculated by SDL_OpenAudio(). + * - \c desired->callback should be set to a function that will be called + * when the audio device is ready for more data. It is passed a pointer + * to the audio buffer, and the length in bytes of the audio buffer. + * This function usually runs in a separate thread, and so you should + * protect data structures that it accesses by calling SDL_LockAudio() + * and SDL_UnlockAudio() in your code. Alternately, you may pass a NULL + * pointer here, and call SDL_QueueAudio() with some frequency, to queue + * more audio samples to be played (or for capture devices, call + * SDL_DequeueAudio() with some frequency, to obtain audio samples). + * - \c desired->userdata is passed as the first parameter to your callback + * function. If you passed a NULL callback, this value is ignored. + * + * The audio device starts out playing silence when it's opened, and should + * be enabled for playing by calling \c SDL_PauseAudio(0) when you are ready + * for your audio callback function to be called. Since the audio driver + * may modify the requested size of the audio buffer, you should allocate + * any local mixing buffers after you open the audio device. + */ +extern DECLSPEC int SDLCALL SDL_OpenAudio(SDL_AudioSpec * desired, + SDL_AudioSpec * obtained); + +/** + * SDL Audio Device IDs. + * + * A successful call to SDL_OpenAudio() is always device id 1, and legacy + * SDL audio APIs assume you want this device ID. SDL_OpenAudioDevice() calls + * always returns devices >= 2 on success. The legacy calls are good both + * for backwards compatibility and when you don't care about multiple, + * specific, or capture devices. + */ +typedef Uint32 SDL_AudioDeviceID; + +/** + * Get the number of available devices exposed by the current driver. + * Only valid after a successfully initializing the audio subsystem. + * Returns -1 if an explicit list of devices can't be determined; this is + * not an error. For example, if SDL is set up to talk to a remote audio + * server, it can't list every one available on the Internet, but it will + * still allow a specific host to be specified to SDL_OpenAudioDevice(). + * + * In many common cases, when this function returns a value <= 0, it can still + * successfully open the default device (NULL for first argument of + * SDL_OpenAudioDevice()). + */ +extern DECLSPEC int SDLCALL SDL_GetNumAudioDevices(int iscapture); + +/** + * Get the human-readable name of a specific audio device. + * Must be a value between 0 and (number of audio devices-1). + * Only valid after a successfully initializing the audio subsystem. + * The values returned by this function reflect the latest call to + * SDL_GetNumAudioDevices(); recall that function to redetect available + * hardware. + * + * The string returned by this function is UTF-8 encoded, read-only, and + * managed internally. You are not to free it. If you need to keep the + * string for any length of time, you should make your own copy of it, as it + * will be invalid next time any of several other SDL functions is called. + */ +extern DECLSPEC const char *SDLCALL SDL_GetAudioDeviceName(int index, + int iscapture); + + +/** + * Open a specific audio device. Passing in a device name of NULL requests + * the most reasonable default (and is equivalent to calling SDL_OpenAudio()). + * + * The device name is a UTF-8 string reported by SDL_GetAudioDeviceName(), but + * some drivers allow arbitrary and driver-specific strings, such as a + * hostname/IP address for a remote audio server, or a filename in the + * diskaudio driver. + * + * \return 0 on error, a valid device ID that is >= 2 on success. + * + * SDL_OpenAudio(), unlike this function, always acts on device ID 1. + */ +extern DECLSPEC SDL_AudioDeviceID SDLCALL SDL_OpenAudioDevice(const char + *device, + int iscapture, + const + SDL_AudioSpec * + desired, + SDL_AudioSpec * + obtained, + int + allowed_changes); + + + +/** + * \name Audio state + * + * Get the current audio state. + */ +/* @{ */ +typedef enum +{ + SDL_AUDIO_STOPPED = 0, + SDL_AUDIO_PLAYING, + SDL_AUDIO_PAUSED +} SDL_AudioStatus; +extern DECLSPEC SDL_AudioStatus SDLCALL SDL_GetAudioStatus(void); + +extern DECLSPEC SDL_AudioStatus SDLCALL +SDL_GetAudioDeviceStatus(SDL_AudioDeviceID dev); +/* @} *//* Audio State */ + +/** + * \name Pause audio functions + * + * These functions pause and unpause the audio callback processing. + * They should be called with a parameter of 0 after opening the audio + * device to start playing sound. This is so you can safely initialize + * data for your callback function after opening the audio device. + * Silence will be written to the audio device during the pause. + */ +/* @{ */ +extern DECLSPEC void SDLCALL SDL_PauseAudio(int pause_on); +extern DECLSPEC void SDLCALL SDL_PauseAudioDevice(SDL_AudioDeviceID dev, + int pause_on); +/* @} *//* Pause audio functions */ + +/** + * \brief Load the audio data of a WAVE file into memory + * + * Loading a WAVE file requires \c src, \c spec, \c audio_buf and \c audio_len + * to be valid pointers. The entire data portion of the file is then loaded + * into memory and decoded if necessary. + * + * If \c freesrc is non-zero, the data source gets automatically closed and + * freed before the function returns. + * + * Supported are RIFF WAVE files with the formats PCM (8, 16, 24, and 32 bits), + * IEEE Float (32 bits), Microsoft ADPCM and IMA ADPCM (4 bits), and A-law and + * µ-law (8 bits). Other formats are currently unsupported and cause an error. + * + * If this function succeeds, the pointer returned by it is equal to \c spec + * and the pointer to the audio data allocated by the function is written to + * \c audio_buf and its length in bytes to \c audio_len. The \ref SDL_AudioSpec + * members \c freq, \c channels, and \c format are set to the values of the + * audio data in the buffer. The \c samples member is set to a sane default and + * all others are set to zero. + * + * It's necessary to use SDL_FreeWAV() to free the audio data returned in + * \c audio_buf when it is no longer used. + * + * Because of the underspecification of the Waveform format, there are many + * problematic files in the wild that cause issues with strict decoders. To + * provide compatibility with these files, this decoder is lenient in regards + * to the truncation of the file, the fact chunk, and the size of the RIFF + * chunk. The hints SDL_HINT_WAVE_RIFF_CHUNK_SIZE, SDL_HINT_WAVE_TRUNCATION, + * and SDL_HINT_WAVE_FACT_CHUNK can be used to tune the behavior of the + * loading process. + * + * Any file that is invalid (due to truncation, corruption, or wrong values in + * the headers), too big, or unsupported causes an error. Additionally, any + * critical I/O error from the data source will terminate the loading process + * with an error. The function returns NULL on error and in all cases (with the + * exception of \c src being NULL), an appropriate error message will be set. + * + * It is required that the data source supports seeking. + * + * Example: + * \code + * SDL_LoadWAV_RW(SDL_RWFromFile("sample.wav", "rb"), 1, ...); + * \endcode + * + * \param src The data source with the WAVE data + * \param freesrc A integer value that makes the function close the data source if non-zero + * \param spec A pointer filled with the audio format of the audio data + * \param audio_buf A pointer filled with the audio data allocated by the function + * \param audio_len A pointer filled with the length of the audio data buffer in bytes + * \return NULL on error, or non-NULL on success. + */ +extern DECLSPEC SDL_AudioSpec *SDLCALL SDL_LoadWAV_RW(SDL_RWops * src, + int freesrc, + SDL_AudioSpec * spec, + Uint8 ** audio_buf, + Uint32 * audio_len); + +/** + * Loads a WAV from a file. + * Compatibility convenience function. + */ +#define SDL_LoadWAV(file, spec, audio_buf, audio_len) \ + SDL_LoadWAV_RW(SDL_RWFromFile(file, "rb"),1, spec,audio_buf,audio_len) + +/** + * This function frees data previously allocated with SDL_LoadWAV_RW() + */ +extern DECLSPEC void SDLCALL SDL_FreeWAV(Uint8 * audio_buf); + +/** + * This function takes a source format and rate and a destination format + * and rate, and initializes the \c cvt structure with information needed + * by SDL_ConvertAudio() to convert a buffer of audio data from one format + * to the other. An unsupported format causes an error and -1 will be returned. + * + * \return 0 if no conversion is needed, 1 if the audio filter is set up, + * or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_BuildAudioCVT(SDL_AudioCVT * cvt, + SDL_AudioFormat src_format, + Uint8 src_channels, + int src_rate, + SDL_AudioFormat dst_format, + Uint8 dst_channels, + int dst_rate); + +/** + * Once you have initialized the \c cvt structure using SDL_BuildAudioCVT(), + * created an audio buffer \c cvt->buf, and filled it with \c cvt->len bytes of + * audio data in the source format, this function will convert it in-place + * to the desired format. + * + * The data conversion may expand the size of the audio data, so the buffer + * \c cvt->buf should be allocated after the \c cvt structure is initialized by + * SDL_BuildAudioCVT(), and should be \c cvt->len*cvt->len_mult bytes long. + * + * \return 0 on success or -1 if \c cvt->buf is NULL. + */ +extern DECLSPEC int SDLCALL SDL_ConvertAudio(SDL_AudioCVT * cvt); + +/* SDL_AudioStream is a new audio conversion interface. + The benefits vs SDL_AudioCVT: + - it can handle resampling data in chunks without generating + artifacts, when it doesn't have the complete buffer available. + - it can handle incoming data in any variable size. + - You push data as you have it, and pull it when you need it + */ +/* this is opaque to the outside world. */ +struct _SDL_AudioStream; +typedef struct _SDL_AudioStream SDL_AudioStream; + +/** + * Create a new audio stream + * + * \param src_format The format of the source audio + * \param src_channels The number of channels of the source audio + * \param src_rate The sampling rate of the source audio + * \param dst_format The format of the desired audio output + * \param dst_channels The number of channels of the desired audio output + * \param dst_rate The sampling rate of the desired audio output + * \return 0 on success, or -1 on error. + * + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamFlush + * \sa SDL_AudioStreamClear + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC SDL_AudioStream * SDLCALL SDL_NewAudioStream(const SDL_AudioFormat src_format, + const Uint8 src_channels, + const int src_rate, + const SDL_AudioFormat dst_format, + const Uint8 dst_channels, + const int dst_rate); + +/** + * Add data to be converted/resampled to the stream + * + * \param stream The stream the audio data is being added to + * \param buf A pointer to the audio data to add + * \param len The number of bytes to write to the stream + * \return 0 on success, or -1 on error. + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamFlush + * \sa SDL_AudioStreamClear + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC int SDLCALL SDL_AudioStreamPut(SDL_AudioStream *stream, const void *buf, int len); + +/** + * Get converted/resampled data from the stream + * + * \param stream The stream the audio is being requested from + * \param buf A buffer to fill with audio data + * \param len The maximum number of bytes to fill + * \return The number of bytes read from the stream, or -1 on error + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamFlush + * \sa SDL_AudioStreamClear + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC int SDLCALL SDL_AudioStreamGet(SDL_AudioStream *stream, void *buf, int len); + +/** + * Get the number of converted/resampled bytes available. The stream may be + * buffering data behind the scenes until it has enough to resample + * correctly, so this number might be lower than what you expect, or even + * be zero. Add more data or flush the stream if you need the data now. + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamFlush + * \sa SDL_AudioStreamClear + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC int SDLCALL SDL_AudioStreamAvailable(SDL_AudioStream *stream); + +/** + * Tell the stream that you're done sending data, and anything being buffered + * should be converted/resampled and made available immediately. + * + * It is legal to add more data to a stream after flushing, but there will + * be audio gaps in the output. Generally this is intended to signal the + * end of input, so the complete output becomes available. + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamClear + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC int SDLCALL SDL_AudioStreamFlush(SDL_AudioStream *stream); + +/** + * Clear any pending data in the stream without converting it + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamFlush + * \sa SDL_FreeAudioStream + */ +extern DECLSPEC void SDLCALL SDL_AudioStreamClear(SDL_AudioStream *stream); + +/** + * Free an audio stream + * + * \sa SDL_NewAudioStream + * \sa SDL_AudioStreamPut + * \sa SDL_AudioStreamGet + * \sa SDL_AudioStreamAvailable + * \sa SDL_AudioStreamFlush + * \sa SDL_AudioStreamClear + */ +extern DECLSPEC void SDLCALL SDL_FreeAudioStream(SDL_AudioStream *stream); + +#define SDL_MIX_MAXVOLUME 128 +/** + * This takes two audio buffers of the playing audio format and mixes + * them, performing addition, volume adjustment, and overflow clipping. + * The volume ranges from 0 - 128, and should be set to ::SDL_MIX_MAXVOLUME + * for full audio volume. Note this does not change hardware volume. + * This is provided for convenience -- you can mix your own audio data. + */ +extern DECLSPEC void SDLCALL SDL_MixAudio(Uint8 * dst, const Uint8 * src, + Uint32 len, int volume); + +/** + * This works like SDL_MixAudio(), but you specify the audio format instead of + * using the format of audio device 1. Thus it can be used when no audio + * device is open at all. + */ +extern DECLSPEC void SDLCALL SDL_MixAudioFormat(Uint8 * dst, + const Uint8 * src, + SDL_AudioFormat format, + Uint32 len, int volume); + +/** + * Queue more audio on non-callback devices. + * + * (If you are looking to retrieve queued audio from a non-callback capture + * device, you want SDL_DequeueAudio() instead. This will return -1 to + * signify an error if you use it with capture devices.) + * + * SDL offers two ways to feed audio to the device: you can either supply a + * callback that SDL triggers with some frequency to obtain more audio + * (pull method), or you can supply no callback, and then SDL will expect + * you to supply data at regular intervals (push method) with this function. + * + * There are no limits on the amount of data you can queue, short of + * exhaustion of address space. Queued data will drain to the device as + * necessary without further intervention from you. If the device needs + * audio but there is not enough queued, it will play silence to make up + * the difference. This means you will have skips in your audio playback + * if you aren't routinely queueing sufficient data. + * + * This function copies the supplied data, so you are safe to free it when + * the function returns. This function is thread-safe, but queueing to the + * same device from two threads at once does not promise which buffer will + * be queued first. + * + * You may not queue audio on a device that is using an application-supplied + * callback; doing so returns an error. You have to use the audio callback + * or queue audio with this function, but not both. + * + * You should not call SDL_LockAudio() on the device before queueing; SDL + * handles locking internally for this function. + * + * \param dev The device ID to which we will queue audio. + * \param data The data to queue to the device for later playback. + * \param len The number of bytes (not samples!) to which (data) points. + * \return 0 on success, or -1 on error. + * + * \sa SDL_GetQueuedAudioSize + * \sa SDL_ClearQueuedAudio + */ +extern DECLSPEC int SDLCALL SDL_QueueAudio(SDL_AudioDeviceID dev, const void *data, Uint32 len); + +/** + * Dequeue more audio on non-callback devices. + * + * (If you are looking to queue audio for output on a non-callback playback + * device, you want SDL_QueueAudio() instead. This will always return 0 + * if you use it with playback devices.) + * + * SDL offers two ways to retrieve audio from a capture device: you can + * either supply a callback that SDL triggers with some frequency as the + * device records more audio data, (push method), or you can supply no + * callback, and then SDL will expect you to retrieve data at regular + * intervals (pull method) with this function. + * + * There are no limits on the amount of data you can queue, short of + * exhaustion of address space. Data from the device will keep queuing as + * necessary without further intervention from you. This means you will + * eventually run out of memory if you aren't routinely dequeueing data. + * + * Capture devices will not queue data when paused; if you are expecting + * to not need captured audio for some length of time, use + * SDL_PauseAudioDevice() to stop the capture device from queueing more + * data. This can be useful during, say, level loading times. When + * unpaused, capture devices will start queueing data from that point, + * having flushed any capturable data available while paused. + * + * This function is thread-safe, but dequeueing from the same device from + * two threads at once does not promise which thread will dequeued data + * first. + * + * You may not dequeue audio from a device that is using an + * application-supplied callback; doing so returns an error. You have to use + * the audio callback, or dequeue audio with this function, but not both. + * + * You should not call SDL_LockAudio() on the device before queueing; SDL + * handles locking internally for this function. + * + * \param dev The device ID from which we will dequeue audio. + * \param data A pointer into where audio data should be copied. + * \param len The number of bytes (not samples!) to which (data) points. + * \return number of bytes dequeued, which could be less than requested. + * + * \sa SDL_GetQueuedAudioSize + * \sa SDL_ClearQueuedAudio + */ +extern DECLSPEC Uint32 SDLCALL SDL_DequeueAudio(SDL_AudioDeviceID dev, void *data, Uint32 len); + +/** + * Get the number of bytes of still-queued audio. + * + * For playback device: + * + * This is the number of bytes that have been queued for playback with + * SDL_QueueAudio(), but have not yet been sent to the hardware. This + * number may shrink at any time, so this only informs of pending data. + * + * Once we've sent it to the hardware, this function can not decide the + * exact byte boundary of what has been played. It's possible that we just + * gave the hardware several kilobytes right before you called this + * function, but it hasn't played any of it yet, or maybe half of it, etc. + * + * For capture devices: + * + * This is the number of bytes that have been captured by the device and + * are waiting for you to dequeue. This number may grow at any time, so + * this only informs of the lower-bound of available data. + * + * You may not queue audio on a device that is using an application-supplied + * callback; calling this function on such a device always returns 0. + * You have to queue audio with SDL_QueueAudio()/SDL_DequeueAudio(), or use + * the audio callback, but not both. + * + * You should not call SDL_LockAudio() on the device before querying; SDL + * handles locking internally for this function. + * + * \param dev The device ID of which we will query queued audio size. + * \return Number of bytes (not samples!) of queued audio. + * + * \sa SDL_QueueAudio + * \sa SDL_ClearQueuedAudio + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetQueuedAudioSize(SDL_AudioDeviceID dev); + +/** + * Drop any queued audio data. For playback devices, this is any queued data + * still waiting to be submitted to the hardware. For capture devices, this + * is any data that was queued by the device that hasn't yet been dequeued by + * the application. + * + * Immediately after this call, SDL_GetQueuedAudioSize() will return 0. For + * playback devices, the hardware will start playing silence if more audio + * isn't queued. Unpaused capture devices will start filling the queue again + * as soon as they have more data available (which, depending on the state + * of the hardware and the thread, could be before this function call + * returns!). + * + * This will not prevent playback of queued audio that's already been sent + * to the hardware, as we can not undo that, so expect there to be some + * fraction of a second of audio that might still be heard. This can be + * useful if you want to, say, drop any pending music during a level change + * in your game. + * + * You may not queue audio on a device that is using an application-supplied + * callback; calling this function on such a device is always a no-op. + * You have to queue audio with SDL_QueueAudio()/SDL_DequeueAudio(), or use + * the audio callback, but not both. + * + * You should not call SDL_LockAudio() on the device before clearing the + * queue; SDL handles locking internally for this function. + * + * This function always succeeds and thus returns void. + * + * \param dev The device ID of which to clear the audio queue. + * + * \sa SDL_QueueAudio + * \sa SDL_GetQueuedAudioSize + */ +extern DECLSPEC void SDLCALL SDL_ClearQueuedAudio(SDL_AudioDeviceID dev); + + +/** + * \name Audio lock functions + * + * The lock manipulated by these functions protects the callback function. + * During a SDL_LockAudio()/SDL_UnlockAudio() pair, you can be guaranteed that + * the callback function is not running. Do not call these from the callback + * function or you will cause deadlock. + */ +/* @{ */ +extern DECLSPEC void SDLCALL SDL_LockAudio(void); +extern DECLSPEC void SDLCALL SDL_LockAudioDevice(SDL_AudioDeviceID dev); +extern DECLSPEC void SDLCALL SDL_UnlockAudio(void); +extern DECLSPEC void SDLCALL SDL_UnlockAudioDevice(SDL_AudioDeviceID dev); +/* @} *//* Audio lock functions */ + +/** + * This function shuts down audio processing and closes the audio device. + */ +extern DECLSPEC void SDLCALL SDL_CloseAudio(void); +extern DECLSPEC void SDLCALL SDL_CloseAudioDevice(SDL_AudioDeviceID dev); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_audio_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_bits.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_bits.h new file mode 100644 index 0000000..b116cc8 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_bits.h @@ -0,0 +1,121 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_bits.h + * + * Functions for fiddling with bits and bitmasks. + */ + +#ifndef SDL_bits_h_ +#define SDL_bits_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \file SDL_bits.h + */ + +/** + * Get the index of the most significant bit. Result is undefined when called + * with 0. This operation can also be stated as "count leading zeroes" and + * "log base 2". + * + * \return Index of the most significant bit, or -1 if the value is 0. + */ +#if defined(__WATCOMC__) && defined(__386__) +extern _inline int _SDL_clz_watcom (Uint32); +#pragma aux _SDL_clz_watcom = \ + "bsr eax, eax" \ + "xor eax, 31" \ + parm [eax] nomemory \ + value [eax] \ + modify exact [eax] nomemory; +#endif + +SDL_FORCE_INLINE int +SDL_MostSignificantBitIndex32(Uint32 x) +{ +#if defined(__GNUC__) && (__GNUC__ >= 4 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)) + /* Count Leading Zeroes builtin in GCC. + * http://gcc.gnu.org/onlinedocs/gcc-4.3.4/gcc/Other-Builtins.html + */ + if (x == 0) { + return -1; + } + return 31 - __builtin_clz(x); +#elif defined(__WATCOMC__) && defined(__386__) + if (x == 0) { + return -1; + } + return 31 - _SDL_clz_watcom(x); +#else + /* Based off of Bit Twiddling Hacks by Sean Eron Anderson + * , released in the public domain. + * http://graphics.stanford.edu/~seander/bithacks.html#IntegerLog + */ + const Uint32 b[] = {0x2, 0xC, 0xF0, 0xFF00, 0xFFFF0000}; + const int S[] = {1, 2, 4, 8, 16}; + + int msbIndex = 0; + int i; + + if (x == 0) { + return -1; + } + + for (i = 4; i >= 0; i--) + { + if (x & b[i]) + { + x >>= S[i]; + msbIndex |= S[i]; + } + } + + return msbIndex; +#endif +} + +SDL_FORCE_INLINE SDL_bool +SDL_HasExactlyOneBitSet32(Uint32 x) +{ + if (x && !(x & (x - 1))) { + return SDL_TRUE; + } + return SDL_FALSE; +} + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_bits_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_blendmode.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_blendmode.h new file mode 100644 index 0000000..6f0a22b --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_blendmode.h @@ -0,0 +1,120 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_blendmode.h + * + * Header file declaring the SDL_BlendMode enumeration + */ + +#ifndef SDL_blendmode_h_ +#define SDL_blendmode_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief The blend mode used in SDL_RenderCopy() and drawing operations. + */ +typedef enum +{ + SDL_BLENDMODE_NONE = 0x00000000, /**< no blending + dstRGBA = srcRGBA */ + SDL_BLENDMODE_BLEND = 0x00000001, /**< alpha blending + dstRGB = (srcRGB * srcA) + (dstRGB * (1-srcA)) + dstA = srcA + (dstA * (1-srcA)) */ + SDL_BLENDMODE_ADD = 0x00000002, /**< additive blending + dstRGB = (srcRGB * srcA) + dstRGB + dstA = dstA */ + SDL_BLENDMODE_MOD = 0x00000004, /**< color modulate + dstRGB = srcRGB * dstRGB + dstA = dstA */ + SDL_BLENDMODE_INVALID = 0x7FFFFFFF + + /* Additional custom blend modes can be returned by SDL_ComposeCustomBlendMode() */ + +} SDL_BlendMode; + +/** + * \brief The blend operation used when combining source and destination pixel components + */ +typedef enum +{ + SDL_BLENDOPERATION_ADD = 0x1, /**< dst + src: supported by all renderers */ + SDL_BLENDOPERATION_SUBTRACT = 0x2, /**< dst - src : supported by D3D9, D3D11, OpenGL, OpenGLES */ + SDL_BLENDOPERATION_REV_SUBTRACT = 0x3, /**< src - dst : supported by D3D9, D3D11, OpenGL, OpenGLES */ + SDL_BLENDOPERATION_MINIMUM = 0x4, /**< min(dst, src) : supported by D3D11 */ + SDL_BLENDOPERATION_MAXIMUM = 0x5 /**< max(dst, src) : supported by D3D11 */ + +} SDL_BlendOperation; + +/** + * \brief The normalized factor used to multiply pixel components + */ +typedef enum +{ + SDL_BLENDFACTOR_ZERO = 0x1, /**< 0, 0, 0, 0 */ + SDL_BLENDFACTOR_ONE = 0x2, /**< 1, 1, 1, 1 */ + SDL_BLENDFACTOR_SRC_COLOR = 0x3, /**< srcR, srcG, srcB, srcA */ + SDL_BLENDFACTOR_ONE_MINUS_SRC_COLOR = 0x4, /**< 1-srcR, 1-srcG, 1-srcB, 1-srcA */ + SDL_BLENDFACTOR_SRC_ALPHA = 0x5, /**< srcA, srcA, srcA, srcA */ + SDL_BLENDFACTOR_ONE_MINUS_SRC_ALPHA = 0x6, /**< 1-srcA, 1-srcA, 1-srcA, 1-srcA */ + SDL_BLENDFACTOR_DST_COLOR = 0x7, /**< dstR, dstG, dstB, dstA */ + SDL_BLENDFACTOR_ONE_MINUS_DST_COLOR = 0x8, /**< 1-dstR, 1-dstG, 1-dstB, 1-dstA */ + SDL_BLENDFACTOR_DST_ALPHA = 0x9, /**< dstA, dstA, dstA, dstA */ + SDL_BLENDFACTOR_ONE_MINUS_DST_ALPHA = 0xA /**< 1-dstA, 1-dstA, 1-dstA, 1-dstA */ + +} SDL_BlendFactor; + +/** + * \brief Create a custom blend mode, which may or may not be supported by a given renderer + * + * \param srcColorFactor source color factor + * \param dstColorFactor destination color factor + * \param colorOperation color operation + * \param srcAlphaFactor source alpha factor + * \param dstAlphaFactor destination alpha factor + * \param alphaOperation alpha operation + * + * The result of the blend mode operation will be: + * dstRGB = dstRGB * dstColorFactor colorOperation srcRGB * srcColorFactor + * and + * dstA = dstA * dstAlphaFactor alphaOperation srcA * srcAlphaFactor + */ +extern DECLSPEC SDL_BlendMode SDLCALL SDL_ComposeCustomBlendMode(SDL_BlendFactor srcColorFactor, + SDL_BlendFactor dstColorFactor, + SDL_BlendOperation colorOperation, + SDL_BlendFactor srcAlphaFactor, + SDL_BlendFactor dstAlphaFactor, + SDL_BlendOperation alphaOperation); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_blendmode_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_clipboard.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_clipboard.h new file mode 100644 index 0000000..c4f8766 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_clipboard.h @@ -0,0 +1,71 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_clipboard.h + * + * Include file for SDL clipboard handling + */ + +#ifndef SDL_clipboard_h_ +#define SDL_clipboard_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* Function prototypes */ + +/** + * \brief Put UTF-8 text into the clipboard + * + * \sa SDL_GetClipboardText() + */ +extern DECLSPEC int SDLCALL SDL_SetClipboardText(const char *text); + +/** + * \brief Get UTF-8 text from the clipboard, which must be freed with SDL_free() + * + * \sa SDL_SetClipboardText() + */ +extern DECLSPEC char * SDLCALL SDL_GetClipboardText(void); + +/** + * \brief Returns a flag indicating whether the clipboard exists and contains a text string that is non-empty + * + * \sa SDL_GetClipboardText() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasClipboardText(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_clipboard_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_config.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_config.h new file mode 100644 index 0000000..395ad7c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_config.h @@ -0,0 +1,257 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_config_windows_h_ +#define SDL_config_windows_h_ +#define SDL_config_h_ + +#include "SDL_platform.h" + +/* This is a set of defines to configure the SDL features */ + +#if !defined(_STDINT_H_) && (!defined(HAVE_STDINT_H) || !_HAVE_STDINT_H) +#if defined(__GNUC__) || defined(__DMC__) || defined(__WATCOMC__) +#define HAVE_STDINT_H 1 +#elif defined(_MSC_VER) +typedef signed __int8 int8_t; +typedef unsigned __int8 uint8_t; +typedef signed __int16 int16_t; +typedef unsigned __int16 uint16_t; +typedef signed __int32 int32_t; +typedef unsigned __int32 uint32_t; +typedef signed __int64 int64_t; +typedef unsigned __int64 uint64_t; +#ifndef _UINTPTR_T_DEFINED +#ifdef _WIN64 +typedef unsigned __int64 uintptr_t; +#else +typedef unsigned int uintptr_t; +#endif +#define _UINTPTR_T_DEFINED +#endif +/* Older Visual C++ headers don't have the Win64-compatible typedefs... */ +#if ((_MSC_VER <= 1200) && (!defined(DWORD_PTR))) +#define DWORD_PTR DWORD +#endif +#if ((_MSC_VER <= 1200) && (!defined(LONG_PTR))) +#define LONG_PTR LONG +#endif +#else /* !__GNUC__ && !_MSC_VER */ +typedef signed char int8_t; +typedef unsigned char uint8_t; +typedef signed short int16_t; +typedef unsigned short uint16_t; +typedef signed int int32_t; +typedef unsigned int uint32_t; +typedef signed long long int64_t; +typedef unsigned long long uint64_t; +#ifndef _SIZE_T_DEFINED_ +#define _SIZE_T_DEFINED_ +typedef unsigned int size_t; +#endif +typedef unsigned int uintptr_t; +#endif /* __GNUC__ || _MSC_VER */ +#endif /* !_STDINT_H_ && !HAVE_STDINT_H */ + +#ifdef _WIN64 +# define SIZEOF_VOIDP 8 +#else +# define SIZEOF_VOIDP 4 +#endif + +#define HAVE_DDRAW_H 1 +#define HAVE_DINPUT_H 1 +#define HAVE_DSOUND_H 1 +#define HAVE_DXGI_H 1 +#define HAVE_XINPUT_H 1 +#define HAVE_MMDEVICEAPI_H 1 +#define HAVE_AUDIOCLIENT_H 1 +#define HAVE_ENDPOINTVOLUME_H 1 + +/* This is disabled by default to avoid C runtime dependencies and manifest requirements */ +#ifdef HAVE_LIBC +/* Useful headers */ +#define STDC_HEADERS 1 +#define HAVE_CTYPE_H 1 +#define HAVE_FLOAT_H 1 +#define HAVE_LIMITS_H 1 +#define HAVE_MATH_H 1 +#define HAVE_SIGNAL_H 1 +#define HAVE_STDIO_H 1 +#define HAVE_STRING_H 1 + +/* C library functions */ +#define HAVE_MALLOC 1 +#define HAVE_CALLOC 1 +#define HAVE_REALLOC 1 +#define HAVE_FREE 1 +#define HAVE_ALLOCA 1 +#define HAVE_QSORT 1 +#define HAVE_ABS 1 +#define HAVE_MEMSET 1 +#define HAVE_MEMCPY 1 +#define HAVE_MEMMOVE 1 +#define HAVE_MEMCMP 1 +#define HAVE_STRLEN 1 +#define HAVE__STRREV 1 +/* These functions have security warnings, so we won't use them */ +/* #undef HAVE__STRUPR */ +/* #undef HAVE__STRLWR */ +#define HAVE_STRCHR 1 +#define HAVE_STRRCHR 1 +#define HAVE_STRSTR 1 +/* These functions have security warnings, so we won't use them */ +/* #undef HAVE__LTOA */ +/* #undef HAVE__ULTOA */ +#define HAVE_STRTOL 1 +#define HAVE_STRTOUL 1 +#define HAVE_STRTOD 1 +#define HAVE_ATOI 1 +#define HAVE_ATOF 1 +#define HAVE_STRCMP 1 +#define HAVE_STRNCMP 1 +#define HAVE__STRICMP 1 +#define HAVE__STRNICMP 1 +#define HAVE_ACOS 1 +#define HAVE_ACOSF 1 +#define HAVE_ASIN 1 +#define HAVE_ASINF 1 +#define HAVE_ATAN 1 +#define HAVE_ATANF 1 +#define HAVE_ATAN2 1 +#define HAVE_ATAN2F 1 +#define HAVE_CEILF 1 +#define HAVE__COPYSIGN 1 +#define HAVE_COS 1 +#define HAVE_COSF 1 +#define HAVE_EXP 1 +#define HAVE_EXPF 1 +#define HAVE_FABS 1 +#define HAVE_FABSF 1 +#define HAVE_FLOOR 1 +#define HAVE_FLOORF 1 +#define HAVE_FMOD 1 +#define HAVE_FMODF 1 +#define HAVE_LOG 1 +#define HAVE_LOGF 1 +#define HAVE_LOG10 1 +#define HAVE_LOG10F 1 +#define HAVE_POW 1 +#define HAVE_POWF 1 +#define HAVE_SIN 1 +#define HAVE_SINF 1 +#define HAVE_SQRT 1 +#define HAVE_SQRTF 1 +#define HAVE_TAN 1 +#define HAVE_TANF 1 +#if defined(_MSC_VER) +/* These functions were added with the VC++ 2013 C runtime library */ +#if _MSC_VER >= 1800 +#define HAVE_STRTOLL 1 +#define HAVE_VSSCANF 1 +#define HAVE_SCALBN 1 +#define HAVE_SCALBNF 1 +#endif +/* This function is available with at least the VC++ 2008 C runtime library */ +#if _MSC_VER >= 1400 +#define HAVE__FSEEKI64 1 +#endif +#endif +#if !defined(_MSC_VER) || defined(_USE_MATH_DEFINES) +#define HAVE_M_PI 1 +#endif +#else +#define HAVE_STDARG_H 1 +#define HAVE_STDDEF_H 1 +#endif + +/* Enable various audio drivers */ +#define SDL_AUDIO_DRIVER_WASAPI 1 +#define SDL_AUDIO_DRIVER_DSOUND 1 +#define SDL_AUDIO_DRIVER_WINMM 1 +#define SDL_AUDIO_DRIVER_DISK 1 +#define SDL_AUDIO_DRIVER_DUMMY 1 + +/* Enable various input drivers */ +#define SDL_JOYSTICK_DINPUT 1 +#define SDL_JOYSTICK_XINPUT 1 +#define SDL_JOYSTICK_HIDAPI 1 +#define SDL_HAPTIC_DINPUT 1 +#define SDL_HAPTIC_XINPUT 1 + +/* Enable the dummy sensor driver */ +#define SDL_SENSOR_DUMMY 1 + +/* Enable various shared object loading systems */ +#define SDL_LOADSO_WINDOWS 1 + +/* Enable various threading systems */ +#define SDL_THREAD_WINDOWS 1 + +/* Enable various timer systems */ +#define SDL_TIMER_WINDOWS 1 + +/* Enable various video drivers */ +#define SDL_VIDEO_DRIVER_DUMMY 1 +#define SDL_VIDEO_DRIVER_WINDOWS 1 + +#ifndef SDL_VIDEO_RENDER_D3D +#define SDL_VIDEO_RENDER_D3D 1 +#endif +#ifndef SDL_VIDEO_RENDER_D3D11 +#define SDL_VIDEO_RENDER_D3D11 0 +#endif + +/* Enable OpenGL support */ +#ifndef SDL_VIDEO_OPENGL +#define SDL_VIDEO_OPENGL 1 +#endif +#ifndef SDL_VIDEO_OPENGL_WGL +#define SDL_VIDEO_OPENGL_WGL 1 +#endif +#ifndef SDL_VIDEO_RENDER_OGL +#define SDL_VIDEO_RENDER_OGL 1 +#endif +#ifndef SDL_VIDEO_RENDER_OGL_ES2 +#define SDL_VIDEO_RENDER_OGL_ES2 1 +#endif +#ifndef SDL_VIDEO_OPENGL_ES2 +#define SDL_VIDEO_OPENGL_ES2 1 +#endif +#ifndef SDL_VIDEO_OPENGL_EGL +#define SDL_VIDEO_OPENGL_EGL 1 +#endif + +/* Enable Vulkan support */ +#define SDL_VIDEO_VULKAN 1 + +/* Enable system power support */ +#define SDL_POWER_WINDOWS 1 + +/* Enable filesystem support */ +#define SDL_FILESYSTEM_WINDOWS 1 + +/* Enable assembly routines (Win64 doesn't have inline asm) */ +#ifndef _WIN64 +#define SDL_ASSEMBLY_ROUTINES 1 +#endif + +#endif /* SDL_config_windows_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_cpuinfo.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_cpuinfo.h new file mode 100644 index 0000000..296df01 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_cpuinfo.h @@ -0,0 +1,270 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_cpuinfo.h + * + * CPU feature detection for SDL. + */ + +#ifndef SDL_cpuinfo_h_ +#define SDL_cpuinfo_h_ + +#include "SDL_stdinc.h" + +/* Need to do this here because intrin.h has C++ code in it */ +/* Visual Studio 2005 has a bug where intrin.h conflicts with winnt.h */ +#if defined(_MSC_VER) && (_MSC_VER >= 1500) && (defined(_M_IX86) || defined(_M_X64)) +#ifdef __clang__ +/* Many of the intrinsics SDL uses are not implemented by clang with Visual Studio */ +#undef __MMX__ +#undef __SSE__ +#undef __SSE2__ +#else +#include +#ifndef _WIN64 +#ifndef __MMX__ +#define __MMX__ +#endif +#ifndef __3dNOW__ +#define __3dNOW__ +#endif +#endif +#ifndef __SSE__ +#define __SSE__ +#endif +#ifndef __SSE2__ +#define __SSE2__ +#endif +#endif /* __clang__ */ +#elif defined(__MINGW64_VERSION_MAJOR) +#include +#else +/* altivec.h redefining bool causes a number of problems, see bugs 3993 and 4392, so you need to explicitly define SDL_ENABLE_ALTIVEC_H to have it included. */ +#if defined(HAVE_ALTIVEC_H) && defined(__ALTIVEC__) && !defined(__APPLE_ALTIVEC__) && defined(SDL_ENABLE_ALTIVEC_H) +#include +#endif +#if !defined(SDL_DISABLE_ARM_NEON_H) +# if defined(__ARM_NEON) +# include +# elif defined(__WINDOWS__) || defined(__WINRT__) +/* Visual Studio doesn't define __ARM_ARCH, but _M_ARM (if set, always 7), and _M_ARM64 (if set, always 1). */ +# if defined(_M_ARM) +# include +# include +# define __ARM_NEON 1 /* Set __ARM_NEON so that it can be used elsewhere, at compile time */ +# endif +# if defined (_M_ARM64) +# include +# include +# define __ARM_NEON 1 /* Set __ARM_NEON so that it can be used elsewhere, at compile time */ +# endif +# endif +#endif +#if defined(__3dNOW__) && !defined(SDL_DISABLE_MM3DNOW_H) +#include +#endif +#if defined(HAVE_IMMINTRIN_H) && !defined(SDL_DISABLE_IMMINTRIN_H) +#include +#else +#if defined(__MMX__) && !defined(SDL_DISABLE_MMINTRIN_H) +#include +#endif +#if defined(__SSE__) && !defined(SDL_DISABLE_XMMINTRIN_H) +#include +#endif +#if defined(__SSE2__) && !defined(SDL_DISABLE_EMMINTRIN_H) +#include +#endif +#if defined(__SSE3__) && !defined(SDL_DISABLE_PMMINTRIN_H) +#include +#endif +#endif /* HAVE_IMMINTRIN_H */ +#endif /* compiler version */ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* This is a guess for the cacheline size used for padding. + * Most x86 processors have a 64 byte cache line. + * The 64-bit PowerPC processors have a 128 byte cache line. + * We'll use the larger value to be generally safe. + */ +#define SDL_CACHELINE_SIZE 128 + +/** + * This function returns the number of CPU cores available. + */ +extern DECLSPEC int SDLCALL SDL_GetCPUCount(void); + +/** + * This function returns the L1 cache line size of the CPU + * + * This is useful for determining multi-threaded structure padding + * or SIMD prefetch sizes. + */ +extern DECLSPEC int SDLCALL SDL_GetCPUCacheLineSize(void); + +/** + * This function returns true if the CPU has the RDTSC instruction. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasRDTSC(void); + +/** + * This function returns true if the CPU has AltiVec features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasAltiVec(void); + +/** + * This function returns true if the CPU has MMX features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasMMX(void); + +/** + * This function returns true if the CPU has 3DNow! features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_Has3DNow(void); + +/** + * This function returns true if the CPU has SSE features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE(void); + +/** + * This function returns true if the CPU has SSE2 features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE2(void); + +/** + * This function returns true if the CPU has SSE3 features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE3(void); + +/** + * This function returns true if the CPU has SSE4.1 features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE41(void); + +/** + * This function returns true if the CPU has SSE4.2 features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE42(void); + +/** + * This function returns true if the CPU has AVX features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasAVX(void); + +/** + * This function returns true if the CPU has AVX2 features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasAVX2(void); + +/** + * This function returns true if the CPU has AVX-512F (foundation) features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasAVX512F(void); + +/** + * This function returns true if the CPU has NEON (ARM SIMD) features. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasNEON(void); + +/** + * This function returns the amount of RAM configured in the system, in MB. + */ +extern DECLSPEC int SDLCALL SDL_GetSystemRAM(void); + +/** + * \brief Report the alignment this system needs for SIMD allocations. + * + * This will return the minimum number of bytes to which a pointer must be + * aligned to be compatible with SIMD instructions on the current machine. + * For example, if the machine supports SSE only, it will return 16, but if + * it supports AVX-512F, it'll return 64 (etc). This only reports values for + * instruction sets SDL knows about, so if your SDL build doesn't have + * SDL_HasAVX512F(), then it might return 16 for the SSE support it sees and + * not 64 for the AVX-512 instructions that exist but SDL doesn't know about. + * Plan accordingly. + */ +extern DECLSPEC size_t SDLCALL SDL_SIMDGetAlignment(void); + +/** + * \brief Allocate memory in a SIMD-friendly way. + * + * This will allocate a block of memory that is suitable for use with SIMD + * instructions. Specifically, it will be properly aligned and padded for + * the system's supported vector instructions. + * + * The memory returned will be padded such that it is safe to read or write + * an incomplete vector at the end of the memory block. This can be useful + * so you don't have to drop back to a scalar fallback at the end of your + * SIMD processing loop to deal with the final elements without overflowing + * the allocated buffer. + * + * You must free this memory with SDL_FreeSIMD(), not free() or SDL_free() + * or delete[], etc. + * + * Note that SDL will only deal with SIMD instruction sets it is aware of; + * for example, SDL 2.0.8 knows that SSE wants 16-byte vectors + * (SDL_HasSSE()), and AVX2 wants 32 bytes (SDL_HasAVX2()), but doesn't + * know that AVX-512 wants 64. To be clear: if you can't decide to use an + * instruction set with an SDL_Has*() function, don't use that instruction + * set with memory allocated through here. + * + * SDL_AllocSIMD(0) will return a non-NULL pointer, assuming the system isn't + * out of memory. + * + * \param len The length, in bytes, of the block to allocated. The actual + * allocated block might be larger due to padding, etc. + * \return Pointer to newly-allocated block, NULL if out of memory. + * + * \sa SDL_SIMDAlignment + * \sa SDL_SIMDFree + */ +extern DECLSPEC void * SDLCALL SDL_SIMDAlloc(const size_t len); + +/** + * \brief Deallocate memory obtained from SDL_SIMDAlloc + * + * It is not valid to use this function on a pointer from anything but + * SDL_SIMDAlloc(). It can't be used on pointers from malloc, realloc, + * SDL_malloc, memalign, new[], etc. + * + * However, SDL_SIMDFree(NULL) is a legal no-op. + * + * \sa SDL_SIMDAlloc + */ +extern DECLSPEC void SDLCALL SDL_SIMDFree(void *ptr); + +/* vi: set ts=4 sw=4 expandtab: */ +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_cpuinfo_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_egl.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_egl.h new file mode 100644 index 0000000..f50fa5c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_egl.h @@ -0,0 +1,1673 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_egl.h + * + * This is a simple file to encapsulate the EGL API headers. + */ +#if !defined(_MSC_VER) && !defined(__ANDROID__) + +#include +#include + +#else /* _MSC_VER */ + +/* EGL headers for Visual Studio */ + +#ifndef __khrplatform_h_ +#define __khrplatform_h_ + +/* +** Copyright (c) 2008-2009 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. +*/ + +/* Khronos platform-specific types and definitions. +* +* $Revision: 23298 $ on $Date: 2013-09-30 17:07:13 -0700 (Mon, 30 Sep 2013) $ +* +* Adopters may modify this file to suit their platform. Adopters are +* encouraged to submit platform specific modifications to the Khronos +* group so that they can be included in future versions of this file. +* Please submit changes by sending them to the public Khronos Bugzilla +* (http://khronos.org/bugzilla) by filing a bug against product +* "Khronos (general)" component "Registry". +* +* A predefined template which fills in some of the bug fields can be +* reached using http://tinyurl.com/khrplatform-h-bugreport, but you +* must create a Bugzilla login first. +* +* +* See the Implementer's Guidelines for information about where this file +* should be located on your system and for more details of its use: +* http://www.khronos.org/registry/implementers_guide.pdf +* +* This file should be included as +* #include +* by Khronos client API header files that use its types and defines. +* +* The types in khrplatform.h should only be used to define API-specific types. +* +* Types defined in khrplatform.h: +* khronos_int8_t signed 8 bit +* khronos_uint8_t unsigned 8 bit +* khronos_int16_t signed 16 bit +* khronos_uint16_t unsigned 16 bit +* khronos_int32_t signed 32 bit +* khronos_uint32_t unsigned 32 bit +* khronos_int64_t signed 64 bit +* khronos_uint64_t unsigned 64 bit +* khronos_intptr_t signed same number of bits as a pointer +* khronos_uintptr_t unsigned same number of bits as a pointer +* khronos_ssize_t signed size +* khronos_usize_t unsigned size +* khronos_float_t signed 32 bit floating point +* khronos_time_ns_t unsigned 64 bit time in nanoseconds +* khronos_utime_nanoseconds_t unsigned time interval or absolute time in +* nanoseconds +* khronos_stime_nanoseconds_t signed time interval in nanoseconds +* khronos_boolean_enum_t enumerated boolean type. This should +* only be used as a base type when a client API's boolean type is +* an enum. Client APIs which use an integer or other type for +* booleans cannot use this as the base type for their boolean. +* +* Tokens defined in khrplatform.h: +* +* KHRONOS_FALSE, KHRONOS_TRUE Enumerated boolean false/true values. +* +* KHRONOS_SUPPORT_INT64 is 1 if 64 bit integers are supported; otherwise 0. +* KHRONOS_SUPPORT_FLOAT is 1 if floats are supported; otherwise 0. +* +* Calling convention macros defined in this file: +* KHRONOS_APICALL +* KHRONOS_APIENTRY +* KHRONOS_APIATTRIBUTES +* +* These may be used in function prototypes as: +* +* KHRONOS_APICALL void KHRONOS_APIENTRY funcname( +* int arg1, +* int arg2) KHRONOS_APIATTRIBUTES; +*/ + +/*------------------------------------------------------------------------- +* Definition of KHRONOS_APICALL +*------------------------------------------------------------------------- +* This precedes the return type of the function in the function prototype. +*/ +#if defined(_WIN32) && !defined(__SCITECH_SNAP__) && !defined(SDL_VIDEO_STATIC_ANGLE) +# define KHRONOS_APICALL __declspec(dllimport) +#elif defined (__SYMBIAN32__) +# define KHRONOS_APICALL IMPORT_C +#else +# define KHRONOS_APICALL +#endif + +/*------------------------------------------------------------------------- +* Definition of KHRONOS_APIENTRY +*------------------------------------------------------------------------- +* This follows the return type of the function and precedes the function +* name in the function prototype. +*/ +#if defined(_WIN32) && !defined(_WIN32_WCE) && !defined(__SCITECH_SNAP__) +/* Win32 but not WinCE */ +# define KHRONOS_APIENTRY __stdcall +#else +# define KHRONOS_APIENTRY +#endif + +/*------------------------------------------------------------------------- +* Definition of KHRONOS_APIATTRIBUTES +*------------------------------------------------------------------------- +* This follows the closing parenthesis of the function prototype arguments. +*/ +#if defined (__ARMCC_2__) +#define KHRONOS_APIATTRIBUTES __softfp +#else +#define KHRONOS_APIATTRIBUTES +#endif + +/*------------------------------------------------------------------------- +* basic type definitions +*-----------------------------------------------------------------------*/ +#if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || defined(__GNUC__) || defined(__SCO__) || defined(__USLC__) + + +/* +* Using +*/ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(__VMS ) || defined(__sgi) + +/* +* Using +*/ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(_WIN32) && !defined(__SCITECH_SNAP__) + +/* +* Win32 +*/ +typedef __int32 khronos_int32_t; +typedef unsigned __int32 khronos_uint32_t; +typedef __int64 khronos_int64_t; +typedef unsigned __int64 khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(__sun__) || defined(__digital__) + +/* +* Sun or Digital +*/ +typedef int khronos_int32_t; +typedef unsigned int khronos_uint32_t; +#if defined(__arch64__) || defined(_LP64) +typedef long int khronos_int64_t; +typedef unsigned long int khronos_uint64_t; +#else +typedef long long int khronos_int64_t; +typedef unsigned long long int khronos_uint64_t; +#endif /* __arch64__ */ +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif 0 + +/* +* Hypothetical platform with no float or int64 support +*/ +typedef int khronos_int32_t; +typedef unsigned int khronos_uint32_t; +#define KHRONOS_SUPPORT_INT64 0 +#define KHRONOS_SUPPORT_FLOAT 0 + +#else + +/* +* Generic fallback +*/ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#endif + + +/* +* Types that are (so far) the same on all platforms +*/ +typedef signed char khronos_int8_t; +typedef unsigned char khronos_uint8_t; +typedef signed short int khronos_int16_t; +typedef unsigned short int khronos_uint16_t; + +/* +* Types that differ between LLP64 and LP64 architectures - in LLP64, +* pointers are 64 bits, but 'long' is still 32 bits. Win64 appears +* to be the only LLP64 architecture in current use. +*/ +#ifdef _WIN64 +typedef signed long long int khronos_intptr_t; +typedef unsigned long long int khronos_uintptr_t; +typedef signed long long int khronos_ssize_t; +typedef unsigned long long int khronos_usize_t; +#else +typedef signed long int khronos_intptr_t; +typedef unsigned long int khronos_uintptr_t; +typedef signed long int khronos_ssize_t; +typedef unsigned long int khronos_usize_t; +#endif + +#if KHRONOS_SUPPORT_FLOAT +/* +* Float type +*/ +typedef float khronos_float_t; +#endif + +#if KHRONOS_SUPPORT_INT64 +/* Time types +* +* These types can be used to represent a time interval in nanoseconds or +* an absolute Unadjusted System Time. Unadjusted System Time is the number +* of nanoseconds since some arbitrary system event (e.g. since the last +* time the system booted). The Unadjusted System Time is an unsigned +* 64 bit value that wraps back to 0 every 584 years. Time intervals +* may be either signed or unsigned. +*/ +typedef khronos_uint64_t khronos_utime_nanoseconds_t; +typedef khronos_int64_t khronos_stime_nanoseconds_t; +#endif + +/* +* Dummy value used to pad enum types to 32 bits. +*/ +#ifndef KHRONOS_MAX_ENUM +#define KHRONOS_MAX_ENUM 0x7FFFFFFF +#endif + +/* +* Enumerated boolean type +* +* Values other than zero should be considered to be true. Therefore +* comparisons should not be made against KHRONOS_TRUE. +*/ +typedef enum { + KHRONOS_FALSE = 0, + KHRONOS_TRUE = 1, + KHRONOS_BOOLEAN_ENUM_FORCE_SIZE = KHRONOS_MAX_ENUM +} khronos_boolean_enum_t; + +#endif /* __khrplatform_h_ */ + + +#ifndef __eglplatform_h_ +#define __eglplatform_h_ + +/* +** Copyright (c) 2007-2009 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. +*/ + +/* Platform-specific types and definitions for egl.h +* $Revision: 12306 $ on $Date: 2010-08-25 09:51:28 -0700 (Wed, 25 Aug 2010) $ +* +* Adopters may modify khrplatform.h and this file to suit their platform. +* You are encouraged to submit all modifications to the Khronos group so that +* they can be included in future versions of this file. Please submit changes +* by sending them to the public Khronos Bugzilla (http://khronos.org/bugzilla) +* by filing a bug against product "EGL" component "Registry". +*/ + +/*#include */ + +/* Macros used in EGL function prototype declarations. +* +* EGL functions should be prototyped as: +* +* EGLAPI return-type EGLAPIENTRY eglFunction(arguments); +* typedef return-type (EXPAPIENTRYP PFNEGLFUNCTIONPROC) (arguments); +* +* KHRONOS_APICALL and KHRONOS_APIENTRY are defined in KHR/khrplatform.h +*/ + +#ifndef EGLAPI +#define EGLAPI KHRONOS_APICALL +#endif + +#ifndef EGLAPIENTRY +#define EGLAPIENTRY KHRONOS_APIENTRY +#endif +#define EGLAPIENTRYP EGLAPIENTRY* + +/* The types NativeDisplayType, NativeWindowType, and NativePixmapType +* are aliases of window-system-dependent types, such as X Display * or +* Windows Device Context. They must be defined in platform-specific +* code below. The EGL-prefixed versions of Native*Type are the same +* types, renamed in EGL 1.3 so all types in the API start with "EGL". +* +* Khronos STRONGLY RECOMMENDS that you use the default definitions +* provided below, since these changes affect both binary and source +* portability of applications using EGL running on different EGL +* implementations. +*/ + +#if defined(_WIN32) || defined(__VC32__) && !defined(__CYGWIN__) && !defined(__SCITECH_SNAP__) /* Win32 and WinCE */ +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN 1 +#endif +#include + +#if __WINRT__ +#include +typedef IUnknown * EGLNativeWindowType; +typedef IUnknown * EGLNativePixmapType; +typedef IUnknown * EGLNativeDisplayType; +#else +typedef HDC EGLNativeDisplayType; +typedef HBITMAP EGLNativePixmapType; +typedef HWND EGLNativeWindowType; +#endif + +#elif defined(__WINSCW__) || defined(__SYMBIAN32__) /* Symbian */ + +typedef int EGLNativeDisplayType; +typedef void *EGLNativeWindowType; +typedef void *EGLNativePixmapType; + +#elif defined(WL_EGL_PLATFORM) + +typedef struct wl_display *EGLNativeDisplayType; +typedef struct wl_egl_pixmap *EGLNativePixmapType; +typedef struct wl_egl_window *EGLNativeWindowType; + +#elif defined(__GBM__) + +typedef struct gbm_device *EGLNativeDisplayType; +typedef struct gbm_bo *EGLNativePixmapType; +typedef void *EGLNativeWindowType; + +#elif defined(__ANDROID__) /* Android */ + +struct ANativeWindow; +struct egl_native_pixmap_t; + +typedef struct ANativeWindow *EGLNativeWindowType; +typedef struct egl_native_pixmap_t *EGLNativePixmapType; +typedef void *EGLNativeDisplayType; + +#elif defined(MIR_EGL_PLATFORM) + +#include +typedef MirEGLNativeDisplayType EGLNativeDisplayType; +typedef void *EGLNativePixmapType; +typedef MirEGLNativeWindowType EGLNativeWindowType; + +#elif defined(__unix__) + +#ifdef MESA_EGL_NO_X11_HEADERS + +typedef void *EGLNativeDisplayType; +typedef khronos_uintptr_t EGLNativePixmapType; +typedef khronos_uintptr_t EGLNativeWindowType; + +#else + +/* X11 (tentative) */ +#include +#include + +typedef Display *EGLNativeDisplayType; +typedef Pixmap EGLNativePixmapType; +typedef Window EGLNativeWindowType; + +#endif /* MESA_EGL_NO_X11_HEADERS */ + +#else +#error "Platform not recognized" +#endif + +/* EGL 1.2 types, renamed for consistency in EGL 1.3 */ +typedef EGLNativeDisplayType NativeDisplayType; +typedef EGLNativePixmapType NativePixmapType; +typedef EGLNativeWindowType NativeWindowType; + + +/* Define EGLint. This must be a signed integral type large enough to contain +* all legal attribute names and values passed into and out of EGL, whether +* their type is boolean, bitmask, enumerant (symbolic constant), integer, +* handle, or other. While in general a 32-bit integer will suffice, if +* handles are 64 bit types, then EGLint should be defined as a signed 64-bit +* integer type. +*/ +typedef khronos_int32_t EGLint; + +#endif /* __eglplatform_h */ + +#ifndef __egl_h_ +#define __egl_h_ 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/* +** Copyright (c) 2013-2015 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. +*/ +/* +** This header is generated from the Khronos OpenGL / OpenGL ES XML +** API Registry. The current version of the Registry, generator scripts +** used to make the header, and the header can be found at +** http://www.opengl.org/registry/ +** +** Khronos $Revision: 31566 $ on $Date: 2015-06-23 08:48:48 -0700 (Tue, 23 Jun 2015) $ +*/ + +/*#include */ + +/* Generated on date 20150623 */ + +/* Generated C header for: + * API: egl + * Versions considered: .* + * Versions emitted: .* + * Default extensions included: None + * Additional extensions included: _nomatch_^ + * Extensions removed: _nomatch_^ + */ + +#ifndef EGL_VERSION_1_0 +#define EGL_VERSION_1_0 1 +typedef unsigned int EGLBoolean; +typedef void *EGLDisplay; +typedef void *EGLConfig; +typedef void *EGLSurface; +typedef void *EGLContext; +typedef void (*__eglMustCastToProperFunctionPointerType)(void); +#define EGL_ALPHA_SIZE 0x3021 +#define EGL_BAD_ACCESS 0x3002 +#define EGL_BAD_ALLOC 0x3003 +#define EGL_BAD_ATTRIBUTE 0x3004 +#define EGL_BAD_CONFIG 0x3005 +#define EGL_BAD_CONTEXT 0x3006 +#define EGL_BAD_CURRENT_SURFACE 0x3007 +#define EGL_BAD_DISPLAY 0x3008 +#define EGL_BAD_MATCH 0x3009 +#define EGL_BAD_NATIVE_PIXMAP 0x300A +#define EGL_BAD_NATIVE_WINDOW 0x300B +#define EGL_BAD_PARAMETER 0x300C +#define EGL_BAD_SURFACE 0x300D +#define EGL_BLUE_SIZE 0x3022 +#define EGL_BUFFER_SIZE 0x3020 +#define EGL_CONFIG_CAVEAT 0x3027 +#define EGL_CONFIG_ID 0x3028 +#define EGL_CORE_NATIVE_ENGINE 0x305B +#define EGL_DEPTH_SIZE 0x3025 +#define EGL_DONT_CARE ((EGLint)-1) +#define EGL_DRAW 0x3059 +#define EGL_EXTENSIONS 0x3055 +#define EGL_FALSE 0 +#define EGL_GREEN_SIZE 0x3023 +#define EGL_HEIGHT 0x3056 +#define EGL_LARGEST_PBUFFER 0x3058 +#define EGL_LEVEL 0x3029 +#define EGL_MAX_PBUFFER_HEIGHT 0x302A +#define EGL_MAX_PBUFFER_PIXELS 0x302B +#define EGL_MAX_PBUFFER_WIDTH 0x302C +#define EGL_NATIVE_RENDERABLE 0x302D +#define EGL_NATIVE_VISUAL_ID 0x302E +#define EGL_NATIVE_VISUAL_TYPE 0x302F +#define EGL_NONE 0x3038 +#define EGL_NON_CONFORMANT_CONFIG 0x3051 +#define EGL_NOT_INITIALIZED 0x3001 +#define EGL_NO_CONTEXT ((EGLContext)0) +#define EGL_NO_DISPLAY ((EGLDisplay)0) +#define EGL_NO_SURFACE ((EGLSurface)0) +#define EGL_PBUFFER_BIT 0x0001 +#define EGL_PIXMAP_BIT 0x0002 +#define EGL_READ 0x305A +#define EGL_RED_SIZE 0x3024 +#define EGL_SAMPLES 0x3031 +#define EGL_SAMPLE_BUFFERS 0x3032 +#define EGL_SLOW_CONFIG 0x3050 +#define EGL_STENCIL_SIZE 0x3026 +#define EGL_SUCCESS 0x3000 +#define EGL_SURFACE_TYPE 0x3033 +#define EGL_TRANSPARENT_BLUE_VALUE 0x3035 +#define EGL_TRANSPARENT_GREEN_VALUE 0x3036 +#define EGL_TRANSPARENT_RED_VALUE 0x3037 +#define EGL_TRANSPARENT_RGB 0x3052 +#define EGL_TRANSPARENT_TYPE 0x3034 +#define EGL_TRUE 1 +#define EGL_VENDOR 0x3053 +#define EGL_VERSION 0x3054 +#define EGL_WIDTH 0x3057 +#define EGL_WINDOW_BIT 0x0004 +EGLAPI EGLBoolean EGLAPIENTRY eglChooseConfig (EGLDisplay dpy, const EGLint *attrib_list, EGLConfig *configs, EGLint config_size, EGLint *num_config); +EGLAPI EGLBoolean EGLAPIENTRY eglCopyBuffers (EGLDisplay dpy, EGLSurface surface, EGLNativePixmapType target); +EGLAPI EGLContext EGLAPIENTRY eglCreateContext (EGLDisplay dpy, EGLConfig config, EGLContext share_context, const EGLint *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePbufferSurface (EGLDisplay dpy, EGLConfig config, const EGLint *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePixmapSurface (EGLDisplay dpy, EGLConfig config, EGLNativePixmapType pixmap, const EGLint *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreateWindowSurface (EGLDisplay dpy, EGLConfig config, EGLNativeWindowType win, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroyContext (EGLDisplay dpy, EGLContext ctx); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroySurface (EGLDisplay dpy, EGLSurface surface); +EGLAPI EGLBoolean EGLAPIENTRY eglGetConfigAttrib (EGLDisplay dpy, EGLConfig config, EGLint attribute, EGLint *value); +EGLAPI EGLBoolean EGLAPIENTRY eglGetConfigs (EGLDisplay dpy, EGLConfig *configs, EGLint config_size, EGLint *num_config); +EGLAPI EGLDisplay EGLAPIENTRY eglGetCurrentDisplay (void); +EGLAPI EGLSurface EGLAPIENTRY eglGetCurrentSurface (EGLint readdraw); +EGLAPI EGLDisplay EGLAPIENTRY eglGetDisplay (EGLNativeDisplayType display_id); +EGLAPI EGLint EGLAPIENTRY eglGetError (void); +EGLAPI __eglMustCastToProperFunctionPointerType EGLAPIENTRY eglGetProcAddress (const char *procname); +EGLAPI EGLBoolean EGLAPIENTRY eglInitialize (EGLDisplay dpy, EGLint *major, EGLint *minor); +EGLAPI EGLBoolean EGLAPIENTRY eglMakeCurrent (EGLDisplay dpy, EGLSurface draw, EGLSurface read, EGLContext ctx); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryContext (EGLDisplay dpy, EGLContext ctx, EGLint attribute, EGLint *value); +EGLAPI const char *EGLAPIENTRY eglQueryString (EGLDisplay dpy, EGLint name); +EGLAPI EGLBoolean EGLAPIENTRY eglQuerySurface (EGLDisplay dpy, EGLSurface surface, EGLint attribute, EGLint *value); +EGLAPI EGLBoolean EGLAPIENTRY eglSwapBuffers (EGLDisplay dpy, EGLSurface surface); +EGLAPI EGLBoolean EGLAPIENTRY eglTerminate (EGLDisplay dpy); +EGLAPI EGLBoolean EGLAPIENTRY eglWaitGL (void); +EGLAPI EGLBoolean EGLAPIENTRY eglWaitNative (EGLint engine); +#endif /* EGL_VERSION_1_0 */ + +#ifndef EGL_VERSION_1_1 +#define EGL_VERSION_1_1 1 +#define EGL_BACK_BUFFER 0x3084 +#define EGL_BIND_TO_TEXTURE_RGB 0x3039 +#define EGL_BIND_TO_TEXTURE_RGBA 0x303A +#define EGL_CONTEXT_LOST 0x300E +#define EGL_MIN_SWAP_INTERVAL 0x303B +#define EGL_MAX_SWAP_INTERVAL 0x303C +#define EGL_MIPMAP_TEXTURE 0x3082 +#define EGL_MIPMAP_LEVEL 0x3083 +#define EGL_NO_TEXTURE 0x305C +#define EGL_TEXTURE_2D 0x305F +#define EGL_TEXTURE_FORMAT 0x3080 +#define EGL_TEXTURE_RGB 0x305D +#define EGL_TEXTURE_RGBA 0x305E +#define EGL_TEXTURE_TARGET 0x3081 +EGLAPI EGLBoolean EGLAPIENTRY eglBindTexImage (EGLDisplay dpy, EGLSurface surface, EGLint buffer); +EGLAPI EGLBoolean EGLAPIENTRY eglReleaseTexImage (EGLDisplay dpy, EGLSurface surface, EGLint buffer); +EGLAPI EGLBoolean EGLAPIENTRY eglSurfaceAttrib (EGLDisplay dpy, EGLSurface surface, EGLint attribute, EGLint value); +EGLAPI EGLBoolean EGLAPIENTRY eglSwapInterval (EGLDisplay dpy, EGLint interval); +#endif /* EGL_VERSION_1_1 */ + +#ifndef EGL_VERSION_1_2 +#define EGL_VERSION_1_2 1 +typedef unsigned int EGLenum; +typedef void *EGLClientBuffer; +#define EGL_ALPHA_FORMAT 0x3088 +#define EGL_ALPHA_FORMAT_NONPRE 0x308B +#define EGL_ALPHA_FORMAT_PRE 0x308C +#define EGL_ALPHA_MASK_SIZE 0x303E +#define EGL_BUFFER_PRESERVED 0x3094 +#define EGL_BUFFER_DESTROYED 0x3095 +#define EGL_CLIENT_APIS 0x308D +#define EGL_COLORSPACE 0x3087 +#define EGL_COLORSPACE_sRGB 0x3089 +#define EGL_COLORSPACE_LINEAR 0x308A +#define EGL_COLOR_BUFFER_TYPE 0x303F +#define EGL_CONTEXT_CLIENT_TYPE 0x3097 +#define EGL_DISPLAY_SCALING 10000 +#define EGL_HORIZONTAL_RESOLUTION 0x3090 +#define EGL_LUMINANCE_BUFFER 0x308F +#define EGL_LUMINANCE_SIZE 0x303D +#define EGL_OPENGL_ES_BIT 0x0001 +#define EGL_OPENVG_BIT 0x0002 +#define EGL_OPENGL_ES_API 0x30A0 +#define EGL_OPENVG_API 0x30A1 +#define EGL_OPENVG_IMAGE 0x3096 +#define EGL_PIXEL_ASPECT_RATIO 0x3092 +#define EGL_RENDERABLE_TYPE 0x3040 +#define EGL_RENDER_BUFFER 0x3086 +#define EGL_RGB_BUFFER 0x308E +#define EGL_SINGLE_BUFFER 0x3085 +#define EGL_SWAP_BEHAVIOR 0x3093 +#define EGL_UNKNOWN ((EGLint)-1) +#define EGL_VERTICAL_RESOLUTION 0x3091 +EGLAPI EGLBoolean EGLAPIENTRY eglBindAPI (EGLenum api); +EGLAPI EGLenum EGLAPIENTRY eglQueryAPI (void); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePbufferFromClientBuffer (EGLDisplay dpy, EGLenum buftype, EGLClientBuffer buffer, EGLConfig config, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglReleaseThread (void); +EGLAPI EGLBoolean EGLAPIENTRY eglWaitClient (void); +#endif /* EGL_VERSION_1_2 */ + +#ifndef EGL_VERSION_1_3 +#define EGL_VERSION_1_3 1 +#define EGL_CONFORMANT 0x3042 +#define EGL_CONTEXT_CLIENT_VERSION 0x3098 +#define EGL_MATCH_NATIVE_PIXMAP 0x3041 +#define EGL_OPENGL_ES2_BIT 0x0004 +#define EGL_VG_ALPHA_FORMAT 0x3088 +#define EGL_VG_ALPHA_FORMAT_NONPRE 0x308B +#define EGL_VG_ALPHA_FORMAT_PRE 0x308C +#define EGL_VG_ALPHA_FORMAT_PRE_BIT 0x0040 +#define EGL_VG_COLORSPACE 0x3087 +#define EGL_VG_COLORSPACE_sRGB 0x3089 +#define EGL_VG_COLORSPACE_LINEAR 0x308A +#define EGL_VG_COLORSPACE_LINEAR_BIT 0x0020 +#endif /* EGL_VERSION_1_3 */ + +#ifndef EGL_VERSION_1_4 +#define EGL_VERSION_1_4 1 +#define EGL_DEFAULT_DISPLAY ((EGLNativeDisplayType)0) +#define EGL_MULTISAMPLE_RESOLVE_BOX_BIT 0x0200 +#define EGL_MULTISAMPLE_RESOLVE 0x3099 +#define EGL_MULTISAMPLE_RESOLVE_DEFAULT 0x309A +#define EGL_MULTISAMPLE_RESOLVE_BOX 0x309B +#define EGL_OPENGL_API 0x30A2 +#define EGL_OPENGL_BIT 0x0008 +#define EGL_SWAP_BEHAVIOR_PRESERVED_BIT 0x0400 +EGLAPI EGLContext EGLAPIENTRY eglGetCurrentContext (void); +#endif /* EGL_VERSION_1_4 */ + +#ifndef EGL_VERSION_1_5 +#define EGL_VERSION_1_5 1 +typedef void *EGLSync; +typedef intptr_t EGLAttrib; +typedef khronos_utime_nanoseconds_t EGLTime; +typedef void *EGLImage; +#define EGL_CONTEXT_MAJOR_VERSION 0x3098 +#define EGL_CONTEXT_MINOR_VERSION 0x30FB +#define EGL_CONTEXT_OPENGL_PROFILE_MASK 0x30FD +#define EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY 0x31BD +#define EGL_NO_RESET_NOTIFICATION 0x31BE +#define EGL_LOSE_CONTEXT_ON_RESET 0x31BF +#define EGL_CONTEXT_OPENGL_CORE_PROFILE_BIT 0x00000001 +#define EGL_CONTEXT_OPENGL_COMPATIBILITY_PROFILE_BIT 0x00000002 +#define EGL_CONTEXT_OPENGL_DEBUG 0x31B0 +#define EGL_CONTEXT_OPENGL_FORWARD_COMPATIBLE 0x31B1 +#define EGL_CONTEXT_OPENGL_ROBUST_ACCESS 0x31B2 +#define EGL_OPENGL_ES3_BIT 0x00000040 +#define EGL_CL_EVENT_HANDLE 0x309C +#define EGL_SYNC_CL_EVENT 0x30FE +#define EGL_SYNC_CL_EVENT_COMPLETE 0x30FF +#define EGL_SYNC_PRIOR_COMMANDS_COMPLETE 0x30F0 +#define EGL_SYNC_TYPE 0x30F7 +#define EGL_SYNC_STATUS 0x30F1 +#define EGL_SYNC_CONDITION 0x30F8 +#define EGL_SIGNALED 0x30F2 +#define EGL_UNSIGNALED 0x30F3 +#define EGL_SYNC_FLUSH_COMMANDS_BIT 0x0001 +#define EGL_FOREVER 0xFFFFFFFFFFFFFFFFull +#define EGL_TIMEOUT_EXPIRED 0x30F5 +#define EGL_CONDITION_SATISFIED 0x30F6 +#define EGL_NO_SYNC ((EGLSync)0) +#define EGL_SYNC_FENCE 0x30F9 +#define EGL_GL_COLORSPACE 0x309D +#define EGL_GL_COLORSPACE_SRGB 0x3089 +#define EGL_GL_COLORSPACE_LINEAR 0x308A +#define EGL_GL_RENDERBUFFER 0x30B9 +#define EGL_GL_TEXTURE_2D 0x30B1 +#define EGL_GL_TEXTURE_LEVEL 0x30BC +#define EGL_GL_TEXTURE_3D 0x30B2 +#define EGL_GL_TEXTURE_ZOFFSET 0x30BD +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_X 0x30B3 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_X 0x30B4 +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_Y 0x30B5 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_Y 0x30B6 +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_Z 0x30B7 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_Z 0x30B8 +#define EGL_IMAGE_PRESERVED 0x30D2 +#define EGL_NO_IMAGE ((EGLImage)0) +EGLAPI EGLSync EGLAPIENTRY eglCreateSync (EGLDisplay dpy, EGLenum type, const EGLAttrib *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroySync (EGLDisplay dpy, EGLSync sync); +EGLAPI EGLint EGLAPIENTRY eglClientWaitSync (EGLDisplay dpy, EGLSync sync, EGLint flags, EGLTime timeout); +EGLAPI EGLBoolean EGLAPIENTRY eglGetSyncAttrib (EGLDisplay dpy, EGLSync sync, EGLint attribute, EGLAttrib *value); +EGLAPI EGLImage EGLAPIENTRY eglCreateImage (EGLDisplay dpy, EGLContext ctx, EGLenum target, EGLClientBuffer buffer, const EGLAttrib *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroyImage (EGLDisplay dpy, EGLImage image); +EGLAPI EGLDisplay EGLAPIENTRY eglGetPlatformDisplay (EGLenum platform, void *native_display, const EGLAttrib *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePlatformWindowSurface (EGLDisplay dpy, EGLConfig config, void *native_window, const EGLAttrib *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePlatformPixmapSurface (EGLDisplay dpy, EGLConfig config, void *native_pixmap, const EGLAttrib *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglWaitSync (EGLDisplay dpy, EGLSync sync, EGLint flags); +#endif /* EGL_VERSION_1_5 */ + +#ifdef __cplusplus +} +#endif + +#endif /* __egl_h_ */ + + + +#ifndef __eglext_h_ +#define __eglext_h_ 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/* +** Copyright (c) 2013-2015 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. +*/ +/* +** This header is generated from the Khronos OpenGL / OpenGL ES XML +** API Registry. The current version of the Registry, generator scripts +** used to make the header, and the header can be found at +** http://www.opengl.org/registry/ +** +** Khronos $Revision: 31566 $ on $Date: 2015-06-23 08:48:48 -0700 (Tue, 23 Jun 2015) $ +*/ + +/*#include */ + +#define EGL_EGLEXT_VERSION 20150623 + +/* Generated C header for: + * API: egl + * Versions considered: .* + * Versions emitted: _nomatch_^ + * Default extensions included: egl + * Additional extensions included: _nomatch_^ + * Extensions removed: _nomatch_^ + */ + +#ifndef EGL_KHR_cl_event +#define EGL_KHR_cl_event 1 +#define EGL_CL_EVENT_HANDLE_KHR 0x309C +#define EGL_SYNC_CL_EVENT_KHR 0x30FE +#define EGL_SYNC_CL_EVENT_COMPLETE_KHR 0x30FF +#endif /* EGL_KHR_cl_event */ + +#ifndef EGL_KHR_cl_event2 +#define EGL_KHR_cl_event2 1 +typedef void *EGLSyncKHR; +typedef intptr_t EGLAttribKHR; +typedef EGLSyncKHR (EGLAPIENTRYP PFNEGLCREATESYNC64KHRPROC) (EGLDisplay dpy, EGLenum type, const EGLAttribKHR *attrib_list); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSyncKHR EGLAPIENTRY eglCreateSync64KHR (EGLDisplay dpy, EGLenum type, const EGLAttribKHR *attrib_list); +#endif +#endif /* EGL_KHR_cl_event2 */ + +#ifndef EGL_KHR_client_get_all_proc_addresses +#define EGL_KHR_client_get_all_proc_addresses 1 +#endif /* EGL_KHR_client_get_all_proc_addresses */ + +#ifndef EGL_KHR_config_attribs +#define EGL_KHR_config_attribs 1 +#define EGL_CONFORMANT_KHR 0x3042 +#define EGL_VG_COLORSPACE_LINEAR_BIT_KHR 0x0020 +#define EGL_VG_ALPHA_FORMAT_PRE_BIT_KHR 0x0040 +#endif /* EGL_KHR_config_attribs */ + +#ifndef EGL_KHR_create_context +#define EGL_KHR_create_context 1 +#define EGL_CONTEXT_MAJOR_VERSION_KHR 0x3098 +#define EGL_CONTEXT_MINOR_VERSION_KHR 0x30FB +#define EGL_CONTEXT_FLAGS_KHR 0x30FC +#define EGL_CONTEXT_OPENGL_PROFILE_MASK_KHR 0x30FD +#define EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR 0x31BD +#define EGL_NO_RESET_NOTIFICATION_KHR 0x31BE +#define EGL_LOSE_CONTEXT_ON_RESET_KHR 0x31BF +#define EGL_CONTEXT_OPENGL_DEBUG_BIT_KHR 0x00000001 +#define EGL_CONTEXT_OPENGL_FORWARD_COMPATIBLE_BIT_KHR 0x00000002 +#define EGL_CONTEXT_OPENGL_ROBUST_ACCESS_BIT_KHR 0x00000004 +#define EGL_CONTEXT_OPENGL_CORE_PROFILE_BIT_KHR 0x00000001 +#define EGL_CONTEXT_OPENGL_COMPATIBILITY_PROFILE_BIT_KHR 0x00000002 +#define EGL_OPENGL_ES3_BIT_KHR 0x00000040 +#endif /* EGL_KHR_create_context */ + +#ifndef EGL_KHR_create_context_no_error +#define EGL_KHR_create_context_no_error 1 +#define EGL_CONTEXT_OPENGL_NO_ERROR_KHR 0x31B3 +#endif /* EGL_KHR_create_context_no_error */ + +#ifndef EGL_KHR_fence_sync +#define EGL_KHR_fence_sync 1 +typedef khronos_utime_nanoseconds_t EGLTimeKHR; +#ifdef KHRONOS_SUPPORT_INT64 +#define EGL_SYNC_PRIOR_COMMANDS_COMPLETE_KHR 0x30F0 +#define EGL_SYNC_CONDITION_KHR 0x30F8 +#define EGL_SYNC_FENCE_KHR 0x30F9 +typedef EGLSyncKHR (EGLAPIENTRYP PFNEGLCREATESYNCKHRPROC) (EGLDisplay dpy, EGLenum type, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLDESTROYSYNCKHRPROC) (EGLDisplay dpy, EGLSyncKHR sync); +typedef EGLint (EGLAPIENTRYP PFNEGLCLIENTWAITSYNCKHRPROC) (EGLDisplay dpy, EGLSyncKHR sync, EGLint flags, EGLTimeKHR timeout); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLGETSYNCATTRIBKHRPROC) (EGLDisplay dpy, EGLSyncKHR sync, EGLint attribute, EGLint *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSyncKHR EGLAPIENTRY eglCreateSyncKHR (EGLDisplay dpy, EGLenum type, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroySyncKHR (EGLDisplay dpy, EGLSyncKHR sync); +EGLAPI EGLint EGLAPIENTRY eglClientWaitSyncKHR (EGLDisplay dpy, EGLSyncKHR sync, EGLint flags, EGLTimeKHR timeout); +EGLAPI EGLBoolean EGLAPIENTRY eglGetSyncAttribKHR (EGLDisplay dpy, EGLSyncKHR sync, EGLint attribute, EGLint *value); +#endif +#endif /* KHRONOS_SUPPORT_INT64 */ +#endif /* EGL_KHR_fence_sync */ + +#ifndef EGL_KHR_get_all_proc_addresses +#define EGL_KHR_get_all_proc_addresses 1 +#endif /* EGL_KHR_get_all_proc_addresses */ + +#ifndef EGL_KHR_gl_colorspace +#define EGL_KHR_gl_colorspace 1 +#define EGL_GL_COLORSPACE_KHR 0x309D +#define EGL_GL_COLORSPACE_SRGB_KHR 0x3089 +#define EGL_GL_COLORSPACE_LINEAR_KHR 0x308A +#endif /* EGL_KHR_gl_colorspace */ + +#ifndef EGL_KHR_gl_renderbuffer_image +#define EGL_KHR_gl_renderbuffer_image 1 +#define EGL_GL_RENDERBUFFER_KHR 0x30B9 +#endif /* EGL_KHR_gl_renderbuffer_image */ + +#ifndef EGL_KHR_gl_texture_2D_image +#define EGL_KHR_gl_texture_2D_image 1 +#define EGL_GL_TEXTURE_2D_KHR 0x30B1 +#define EGL_GL_TEXTURE_LEVEL_KHR 0x30BC +#endif /* EGL_KHR_gl_texture_2D_image */ + +#ifndef EGL_KHR_gl_texture_3D_image +#define EGL_KHR_gl_texture_3D_image 1 +#define EGL_GL_TEXTURE_3D_KHR 0x30B2 +#define EGL_GL_TEXTURE_ZOFFSET_KHR 0x30BD +#endif /* EGL_KHR_gl_texture_3D_image */ + +#ifndef EGL_KHR_gl_texture_cubemap_image +#define EGL_KHR_gl_texture_cubemap_image 1 +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_X_KHR 0x30B3 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_X_KHR 0x30B4 +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_Y_KHR 0x30B5 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_Y_KHR 0x30B6 +#define EGL_GL_TEXTURE_CUBE_MAP_POSITIVE_Z_KHR 0x30B7 +#define EGL_GL_TEXTURE_CUBE_MAP_NEGATIVE_Z_KHR 0x30B8 +#endif /* EGL_KHR_gl_texture_cubemap_image */ + +#ifndef EGL_KHR_image +#define EGL_KHR_image 1 +typedef void *EGLImageKHR; +#define EGL_NATIVE_PIXMAP_KHR 0x30B0 +#define EGL_NO_IMAGE_KHR ((EGLImageKHR)0) +typedef EGLImageKHR (EGLAPIENTRYP PFNEGLCREATEIMAGEKHRPROC) (EGLDisplay dpy, EGLContext ctx, EGLenum target, EGLClientBuffer buffer, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLDESTROYIMAGEKHRPROC) (EGLDisplay dpy, EGLImageKHR image); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLImageKHR EGLAPIENTRY eglCreateImageKHR (EGLDisplay dpy, EGLContext ctx, EGLenum target, EGLClientBuffer buffer, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroyImageKHR (EGLDisplay dpy, EGLImageKHR image); +#endif +#endif /* EGL_KHR_image */ + +#ifndef EGL_KHR_image_base +#define EGL_KHR_image_base 1 +#define EGL_IMAGE_PRESERVED_KHR 0x30D2 +#endif /* EGL_KHR_image_base */ + +#ifndef EGL_KHR_image_pixmap +#define EGL_KHR_image_pixmap 1 +#endif /* EGL_KHR_image_pixmap */ + +#ifndef EGL_KHR_lock_surface +#define EGL_KHR_lock_surface 1 +#define EGL_READ_SURFACE_BIT_KHR 0x0001 +#define EGL_WRITE_SURFACE_BIT_KHR 0x0002 +#define EGL_LOCK_SURFACE_BIT_KHR 0x0080 +#define EGL_OPTIMAL_FORMAT_BIT_KHR 0x0100 +#define EGL_MATCH_FORMAT_KHR 0x3043 +#define EGL_FORMAT_RGB_565_EXACT_KHR 0x30C0 +#define EGL_FORMAT_RGB_565_KHR 0x30C1 +#define EGL_FORMAT_RGBA_8888_EXACT_KHR 0x30C2 +#define EGL_FORMAT_RGBA_8888_KHR 0x30C3 +#define EGL_MAP_PRESERVE_PIXELS_KHR 0x30C4 +#define EGL_LOCK_USAGE_HINT_KHR 0x30C5 +#define EGL_BITMAP_POINTER_KHR 0x30C6 +#define EGL_BITMAP_PITCH_KHR 0x30C7 +#define EGL_BITMAP_ORIGIN_KHR 0x30C8 +#define EGL_BITMAP_PIXEL_RED_OFFSET_KHR 0x30C9 +#define EGL_BITMAP_PIXEL_GREEN_OFFSET_KHR 0x30CA +#define EGL_BITMAP_PIXEL_BLUE_OFFSET_KHR 0x30CB +#define EGL_BITMAP_PIXEL_ALPHA_OFFSET_KHR 0x30CC +#define EGL_BITMAP_PIXEL_LUMINANCE_OFFSET_KHR 0x30CD +#define EGL_LOWER_LEFT_KHR 0x30CE +#define EGL_UPPER_LEFT_KHR 0x30CF +typedef EGLBoolean (EGLAPIENTRYP PFNEGLLOCKSURFACEKHRPROC) (EGLDisplay dpy, EGLSurface surface, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLUNLOCKSURFACEKHRPROC) (EGLDisplay dpy, EGLSurface surface); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglLockSurfaceKHR (EGLDisplay dpy, EGLSurface surface, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglUnlockSurfaceKHR (EGLDisplay dpy, EGLSurface surface); +#endif +#endif /* EGL_KHR_lock_surface */ + +#ifndef EGL_KHR_lock_surface2 +#define EGL_KHR_lock_surface2 1 +#define EGL_BITMAP_PIXEL_SIZE_KHR 0x3110 +#endif /* EGL_KHR_lock_surface2 */ + +#ifndef EGL_KHR_lock_surface3 +#define EGL_KHR_lock_surface3 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYSURFACE64KHRPROC) (EGLDisplay dpy, EGLSurface surface, EGLint attribute, EGLAttribKHR *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglQuerySurface64KHR (EGLDisplay dpy, EGLSurface surface, EGLint attribute, EGLAttribKHR *value); +#endif +#endif /* EGL_KHR_lock_surface3 */ + +#ifndef EGL_KHR_partial_update +#define EGL_KHR_partial_update 1 +#define EGL_BUFFER_AGE_KHR 0x313D +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSETDAMAGEREGIONKHRPROC) (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSetDamageRegionKHR (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#endif +#endif /* EGL_KHR_partial_update */ + +#ifndef EGL_KHR_platform_android +#define EGL_KHR_platform_android 1 +#define EGL_PLATFORM_ANDROID_KHR 0x3141 +#endif /* EGL_KHR_platform_android */ + +#ifndef EGL_KHR_platform_gbm +#define EGL_KHR_platform_gbm 1 +#define EGL_PLATFORM_GBM_KHR 0x31D7 +#endif /* EGL_KHR_platform_gbm */ + +#ifndef EGL_KHR_platform_wayland +#define EGL_KHR_platform_wayland 1 +#define EGL_PLATFORM_WAYLAND_KHR 0x31D8 +#endif /* EGL_KHR_platform_wayland */ + +#ifndef EGL_KHR_platform_x11 +#define EGL_KHR_platform_x11 1 +#define EGL_PLATFORM_X11_KHR 0x31D5 +#define EGL_PLATFORM_X11_SCREEN_KHR 0x31D6 +#endif /* EGL_KHR_platform_x11 */ + +#ifndef EGL_KHR_reusable_sync +#define EGL_KHR_reusable_sync 1 +#ifdef KHRONOS_SUPPORT_INT64 +#define EGL_SYNC_STATUS_KHR 0x30F1 +#define EGL_SIGNALED_KHR 0x30F2 +#define EGL_UNSIGNALED_KHR 0x30F3 +#define EGL_TIMEOUT_EXPIRED_KHR 0x30F5 +#define EGL_CONDITION_SATISFIED_KHR 0x30F6 +#define EGL_SYNC_TYPE_KHR 0x30F7 +#define EGL_SYNC_REUSABLE_KHR 0x30FA +#define EGL_SYNC_FLUSH_COMMANDS_BIT_KHR 0x0001 +#define EGL_FOREVER_KHR 0xFFFFFFFFFFFFFFFFull +#define EGL_NO_SYNC_KHR ((EGLSyncKHR)0) +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSIGNALSYNCKHRPROC) (EGLDisplay dpy, EGLSyncKHR sync, EGLenum mode); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSignalSyncKHR (EGLDisplay dpy, EGLSyncKHR sync, EGLenum mode); +#endif +#endif /* KHRONOS_SUPPORT_INT64 */ +#endif /* EGL_KHR_reusable_sync */ + +#ifndef EGL_KHR_stream +#define EGL_KHR_stream 1 +typedef void *EGLStreamKHR; +typedef khronos_uint64_t EGLuint64KHR; +#ifdef KHRONOS_SUPPORT_INT64 +#define EGL_NO_STREAM_KHR ((EGLStreamKHR)0) +#define EGL_CONSUMER_LATENCY_USEC_KHR 0x3210 +#define EGL_PRODUCER_FRAME_KHR 0x3212 +#define EGL_CONSUMER_FRAME_KHR 0x3213 +#define EGL_STREAM_STATE_KHR 0x3214 +#define EGL_STREAM_STATE_CREATED_KHR 0x3215 +#define EGL_STREAM_STATE_CONNECTING_KHR 0x3216 +#define EGL_STREAM_STATE_EMPTY_KHR 0x3217 +#define EGL_STREAM_STATE_NEW_FRAME_AVAILABLE_KHR 0x3218 +#define EGL_STREAM_STATE_OLD_FRAME_AVAILABLE_KHR 0x3219 +#define EGL_STREAM_STATE_DISCONNECTED_KHR 0x321A +#define EGL_BAD_STREAM_KHR 0x321B +#define EGL_BAD_STATE_KHR 0x321C +typedef EGLStreamKHR (EGLAPIENTRYP PFNEGLCREATESTREAMKHRPROC) (EGLDisplay dpy, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLDESTROYSTREAMKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSTREAMATTRIBKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLint value); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYSTREAMKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLint *value); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYSTREAMU64KHRPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLuint64KHR *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLStreamKHR EGLAPIENTRY eglCreateStreamKHR (EGLDisplay dpy, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroyStreamKHR (EGLDisplay dpy, EGLStreamKHR stream); +EGLAPI EGLBoolean EGLAPIENTRY eglStreamAttribKHR (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLint value); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryStreamKHR (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLint *value); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryStreamu64KHR (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLuint64KHR *value); +#endif +#endif /* KHRONOS_SUPPORT_INT64 */ +#endif /* EGL_KHR_stream */ + +#ifndef EGL_KHR_stream_consumer_gltexture +#define EGL_KHR_stream_consumer_gltexture 1 +#ifdef EGL_KHR_stream +#define EGL_CONSUMER_ACQUIRE_TIMEOUT_USEC_KHR 0x321E +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSTREAMCONSUMERGLTEXTUREEXTERNALKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSTREAMCONSUMERACQUIREKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSTREAMCONSUMERRELEASEKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglStreamConsumerGLTextureExternalKHR (EGLDisplay dpy, EGLStreamKHR stream); +EGLAPI EGLBoolean EGLAPIENTRY eglStreamConsumerAcquireKHR (EGLDisplay dpy, EGLStreamKHR stream); +EGLAPI EGLBoolean EGLAPIENTRY eglStreamConsumerReleaseKHR (EGLDisplay dpy, EGLStreamKHR stream); +#endif +#endif /* EGL_KHR_stream */ +#endif /* EGL_KHR_stream_consumer_gltexture */ + +#ifndef EGL_KHR_stream_cross_process_fd +#define EGL_KHR_stream_cross_process_fd 1 +typedef int EGLNativeFileDescriptorKHR; +#ifdef EGL_KHR_stream +#define EGL_NO_FILE_DESCRIPTOR_KHR ((EGLNativeFileDescriptorKHR)(-1)) +typedef EGLNativeFileDescriptorKHR (EGLAPIENTRYP PFNEGLGETSTREAMFILEDESCRIPTORKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream); +typedef EGLStreamKHR (EGLAPIENTRYP PFNEGLCREATESTREAMFROMFILEDESCRIPTORKHRPROC) (EGLDisplay dpy, EGLNativeFileDescriptorKHR file_descriptor); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLNativeFileDescriptorKHR EGLAPIENTRY eglGetStreamFileDescriptorKHR (EGLDisplay dpy, EGLStreamKHR stream); +EGLAPI EGLStreamKHR EGLAPIENTRY eglCreateStreamFromFileDescriptorKHR (EGLDisplay dpy, EGLNativeFileDescriptorKHR file_descriptor); +#endif +#endif /* EGL_KHR_stream */ +#endif /* EGL_KHR_stream_cross_process_fd */ + +#ifndef EGL_KHR_stream_fifo +#define EGL_KHR_stream_fifo 1 +#ifdef EGL_KHR_stream +#define EGL_STREAM_FIFO_LENGTH_KHR 0x31FC +#define EGL_STREAM_TIME_NOW_KHR 0x31FD +#define EGL_STREAM_TIME_CONSUMER_KHR 0x31FE +#define EGL_STREAM_TIME_PRODUCER_KHR 0x31FF +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYSTREAMTIMEKHRPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLTimeKHR *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglQueryStreamTimeKHR (EGLDisplay dpy, EGLStreamKHR stream, EGLenum attribute, EGLTimeKHR *value); +#endif +#endif /* EGL_KHR_stream */ +#endif /* EGL_KHR_stream_fifo */ + +#ifndef EGL_KHR_stream_producer_aldatalocator +#define EGL_KHR_stream_producer_aldatalocator 1 +#ifdef EGL_KHR_stream +#endif /* EGL_KHR_stream */ +#endif /* EGL_KHR_stream_producer_aldatalocator */ + +#ifndef EGL_KHR_stream_producer_eglsurface +#define EGL_KHR_stream_producer_eglsurface 1 +#ifdef EGL_KHR_stream +#define EGL_STREAM_BIT_KHR 0x0800 +typedef EGLSurface (EGLAPIENTRYP PFNEGLCREATESTREAMPRODUCERSURFACEKHRPROC) (EGLDisplay dpy, EGLConfig config, EGLStreamKHR stream, const EGLint *attrib_list); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSurface EGLAPIENTRY eglCreateStreamProducerSurfaceKHR (EGLDisplay dpy, EGLConfig config, EGLStreamKHR stream, const EGLint *attrib_list); +#endif +#endif /* EGL_KHR_stream */ +#endif /* EGL_KHR_stream_producer_eglsurface */ + +#ifndef EGL_KHR_surfaceless_context +#define EGL_KHR_surfaceless_context 1 +#endif /* EGL_KHR_surfaceless_context */ + +#ifndef EGL_KHR_swap_buffers_with_damage +#define EGL_KHR_swap_buffers_with_damage 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSWAPBUFFERSWITHDAMAGEKHRPROC) (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSwapBuffersWithDamageKHR (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#endif +#endif /* EGL_KHR_swap_buffers_with_damage */ + +#ifndef EGL_KHR_vg_parent_image +#define EGL_KHR_vg_parent_image 1 +#define EGL_VG_PARENT_IMAGE_KHR 0x30BA +#endif /* EGL_KHR_vg_parent_image */ + +#ifndef EGL_KHR_wait_sync +#define EGL_KHR_wait_sync 1 +typedef EGLint (EGLAPIENTRYP PFNEGLWAITSYNCKHRPROC) (EGLDisplay dpy, EGLSyncKHR sync, EGLint flags); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLint EGLAPIENTRY eglWaitSyncKHR (EGLDisplay dpy, EGLSyncKHR sync, EGLint flags); +#endif +#endif /* EGL_KHR_wait_sync */ + +#ifndef EGL_ANDROID_blob_cache +#define EGL_ANDROID_blob_cache 1 +typedef khronos_ssize_t EGLsizeiANDROID; +typedef void (*EGLSetBlobFuncANDROID) (const void *key, EGLsizeiANDROID keySize, const void *value, EGLsizeiANDROID valueSize); +typedef EGLsizeiANDROID (*EGLGetBlobFuncANDROID) (const void *key, EGLsizeiANDROID keySize, void *value, EGLsizeiANDROID valueSize); +typedef void (EGLAPIENTRYP PFNEGLSETBLOBCACHEFUNCSANDROIDPROC) (EGLDisplay dpy, EGLSetBlobFuncANDROID set, EGLGetBlobFuncANDROID get); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI void EGLAPIENTRY eglSetBlobCacheFuncsANDROID (EGLDisplay dpy, EGLSetBlobFuncANDROID set, EGLGetBlobFuncANDROID get); +#endif +#endif /* EGL_ANDROID_blob_cache */ + +#ifndef EGL_ANDROID_framebuffer_target +#define EGL_ANDROID_framebuffer_target 1 +#define EGL_FRAMEBUFFER_TARGET_ANDROID 0x3147 +#endif /* EGL_ANDROID_framebuffer_target */ + +#ifndef EGL_ANDROID_image_native_buffer +#define EGL_ANDROID_image_native_buffer 1 +#define EGL_NATIVE_BUFFER_ANDROID 0x3140 +#endif /* EGL_ANDROID_image_native_buffer */ + +#ifndef EGL_ANDROID_native_fence_sync +#define EGL_ANDROID_native_fence_sync 1 +#define EGL_SYNC_NATIVE_FENCE_ANDROID 0x3144 +#define EGL_SYNC_NATIVE_FENCE_FD_ANDROID 0x3145 +#define EGL_SYNC_NATIVE_FENCE_SIGNALED_ANDROID 0x3146 +#define EGL_NO_NATIVE_FENCE_FD_ANDROID -1 +typedef EGLint (EGLAPIENTRYP PFNEGLDUPNATIVEFENCEFDANDROIDPROC) (EGLDisplay dpy, EGLSyncKHR sync); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLint EGLAPIENTRY eglDupNativeFenceFDANDROID (EGLDisplay dpy, EGLSyncKHR sync); +#endif +#endif /* EGL_ANDROID_native_fence_sync */ + +#ifndef EGL_ANDROID_recordable +#define EGL_ANDROID_recordable 1 +#define EGL_RECORDABLE_ANDROID 0x3142 +#endif /* EGL_ANDROID_recordable */ + +#ifndef EGL_ANGLE_d3d_share_handle_client_buffer +#define EGL_ANGLE_d3d_share_handle_client_buffer 1 +#define EGL_D3D_TEXTURE_2D_SHARE_HANDLE_ANGLE 0x3200 +#endif /* EGL_ANGLE_d3d_share_handle_client_buffer */ + +#ifndef EGL_ANGLE_device_d3d +#define EGL_ANGLE_device_d3d 1 +#define EGL_D3D9_DEVICE_ANGLE 0x33A0 +#define EGL_D3D11_DEVICE_ANGLE 0x33A1 +#endif /* EGL_ANGLE_device_d3d */ + +#ifndef EGL_ANGLE_query_surface_pointer +#define EGL_ANGLE_query_surface_pointer 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYSURFACEPOINTERANGLEPROC) (EGLDisplay dpy, EGLSurface surface, EGLint attribute, void **value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglQuerySurfacePointerANGLE (EGLDisplay dpy, EGLSurface surface, EGLint attribute, void **value); +#endif +#endif /* EGL_ANGLE_query_surface_pointer */ + +#ifndef EGL_ANGLE_surface_d3d_texture_2d_share_handle +#define EGL_ANGLE_surface_d3d_texture_2d_share_handle 1 +#endif /* EGL_ANGLE_surface_d3d_texture_2d_share_handle */ + +#ifndef EGL_ANGLE_window_fixed_size +#define EGL_ANGLE_window_fixed_size 1 +#define EGL_FIXED_SIZE_ANGLE 0x3201 +#endif /* EGL_ANGLE_window_fixed_size */ + +#ifndef EGL_ARM_pixmap_multisample_discard +#define EGL_ARM_pixmap_multisample_discard 1 +#define EGL_DISCARD_SAMPLES_ARM 0x3286 +#endif /* EGL_ARM_pixmap_multisample_discard */ + +#ifndef EGL_EXT_buffer_age +#define EGL_EXT_buffer_age 1 +#define EGL_BUFFER_AGE_EXT 0x313D +#endif /* EGL_EXT_buffer_age */ + +#ifndef EGL_EXT_client_extensions +#define EGL_EXT_client_extensions 1 +#endif /* EGL_EXT_client_extensions */ + +#ifndef EGL_EXT_create_context_robustness +#define EGL_EXT_create_context_robustness 1 +#define EGL_CONTEXT_OPENGL_ROBUST_ACCESS_EXT 0x30BF +#define EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_EXT 0x3138 +#define EGL_NO_RESET_NOTIFICATION_EXT 0x31BE +#define EGL_LOSE_CONTEXT_ON_RESET_EXT 0x31BF +#endif /* EGL_EXT_create_context_robustness */ + +#ifndef EGL_EXT_device_base +#define EGL_EXT_device_base 1 +typedef void *EGLDeviceEXT; +#define EGL_NO_DEVICE_EXT ((EGLDeviceEXT)(0)) +#define EGL_BAD_DEVICE_EXT 0x322B +#define EGL_DEVICE_EXT 0x322C +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYDEVICEATTRIBEXTPROC) (EGLDeviceEXT device, EGLint attribute, EGLAttrib *value); +typedef const char *(EGLAPIENTRYP PFNEGLQUERYDEVICESTRINGEXTPROC) (EGLDeviceEXT device, EGLint name); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYDEVICESEXTPROC) (EGLint max_devices, EGLDeviceEXT *devices, EGLint *num_devices); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYDISPLAYATTRIBEXTPROC) (EGLDisplay dpy, EGLint attribute, EGLAttrib *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglQueryDeviceAttribEXT (EGLDeviceEXT device, EGLint attribute, EGLAttrib *value); +EGLAPI const char *EGLAPIENTRY eglQueryDeviceStringEXT (EGLDeviceEXT device, EGLint name); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryDevicesEXT (EGLint max_devices, EGLDeviceEXT *devices, EGLint *num_devices); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryDisplayAttribEXT (EGLDisplay dpy, EGLint attribute, EGLAttrib *value); +#endif +#endif /* EGL_EXT_device_base */ + +#ifndef EGL_EXT_device_drm +#define EGL_EXT_device_drm 1 +#define EGL_DRM_DEVICE_FILE_EXT 0x3233 +#endif /* EGL_EXT_device_drm */ + +#ifndef EGL_EXT_device_enumeration +#define EGL_EXT_device_enumeration 1 +#endif /* EGL_EXT_device_enumeration */ + +#ifndef EGL_EXT_device_openwf +#define EGL_EXT_device_openwf 1 +#define EGL_OPENWF_DEVICE_ID_EXT 0x3237 +#endif /* EGL_EXT_device_openwf */ + +#ifndef EGL_EXT_device_query +#define EGL_EXT_device_query 1 +#endif /* EGL_EXT_device_query */ + +#ifndef EGL_EXT_image_dma_buf_import +#define EGL_EXT_image_dma_buf_import 1 +#define EGL_LINUX_DMA_BUF_EXT 0x3270 +#define EGL_LINUX_DRM_FOURCC_EXT 0x3271 +#define EGL_DMA_BUF_PLANE0_FD_EXT 0x3272 +#define EGL_DMA_BUF_PLANE0_OFFSET_EXT 0x3273 +#define EGL_DMA_BUF_PLANE0_PITCH_EXT 0x3274 +#define EGL_DMA_BUF_PLANE1_FD_EXT 0x3275 +#define EGL_DMA_BUF_PLANE1_OFFSET_EXT 0x3276 +#define EGL_DMA_BUF_PLANE1_PITCH_EXT 0x3277 +#define EGL_DMA_BUF_PLANE2_FD_EXT 0x3278 +#define EGL_DMA_BUF_PLANE2_OFFSET_EXT 0x3279 +#define EGL_DMA_BUF_PLANE2_PITCH_EXT 0x327A +#define EGL_YUV_COLOR_SPACE_HINT_EXT 0x327B +#define EGL_SAMPLE_RANGE_HINT_EXT 0x327C +#define EGL_YUV_CHROMA_HORIZONTAL_SITING_HINT_EXT 0x327D +#define EGL_YUV_CHROMA_VERTICAL_SITING_HINT_EXT 0x327E +#define EGL_ITU_REC601_EXT 0x327F +#define EGL_ITU_REC709_EXT 0x3280 +#define EGL_ITU_REC2020_EXT 0x3281 +#define EGL_YUV_FULL_RANGE_EXT 0x3282 +#define EGL_YUV_NARROW_RANGE_EXT 0x3283 +#define EGL_YUV_CHROMA_SITING_0_EXT 0x3284 +#define EGL_YUV_CHROMA_SITING_0_5_EXT 0x3285 +#endif /* EGL_EXT_image_dma_buf_import */ + +#ifndef EGL_EXT_multiview_window +#define EGL_EXT_multiview_window 1 +#define EGL_MULTIVIEW_VIEW_COUNT_EXT 0x3134 +#endif /* EGL_EXT_multiview_window */ + +#ifndef EGL_EXT_output_base +#define EGL_EXT_output_base 1 +typedef void *EGLOutputLayerEXT; +typedef void *EGLOutputPortEXT; +#define EGL_NO_OUTPUT_LAYER_EXT ((EGLOutputLayerEXT)0) +#define EGL_NO_OUTPUT_PORT_EXT ((EGLOutputPortEXT)0) +#define EGL_BAD_OUTPUT_LAYER_EXT 0x322D +#define EGL_BAD_OUTPUT_PORT_EXT 0x322E +#define EGL_SWAP_INTERVAL_EXT 0x322F +typedef EGLBoolean (EGLAPIENTRYP PFNEGLGETOUTPUTLAYERSEXTPROC) (EGLDisplay dpy, const EGLAttrib *attrib_list, EGLOutputLayerEXT *layers, EGLint max_layers, EGLint *num_layers); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLGETOUTPUTPORTSEXTPROC) (EGLDisplay dpy, const EGLAttrib *attrib_list, EGLOutputPortEXT *ports, EGLint max_ports, EGLint *num_ports); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLOUTPUTLAYERATTRIBEXTPROC) (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint attribute, EGLAttrib value); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYOUTPUTLAYERATTRIBEXTPROC) (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint attribute, EGLAttrib *value); +typedef const char *(EGLAPIENTRYP PFNEGLQUERYOUTPUTLAYERSTRINGEXTPROC) (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint name); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLOUTPUTPORTATTRIBEXTPROC) (EGLDisplay dpy, EGLOutputPortEXT port, EGLint attribute, EGLAttrib value); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYOUTPUTPORTATTRIBEXTPROC) (EGLDisplay dpy, EGLOutputPortEXT port, EGLint attribute, EGLAttrib *value); +typedef const char *(EGLAPIENTRYP PFNEGLQUERYOUTPUTPORTSTRINGEXTPROC) (EGLDisplay dpy, EGLOutputPortEXT port, EGLint name); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglGetOutputLayersEXT (EGLDisplay dpy, const EGLAttrib *attrib_list, EGLOutputLayerEXT *layers, EGLint max_layers, EGLint *num_layers); +EGLAPI EGLBoolean EGLAPIENTRY eglGetOutputPortsEXT (EGLDisplay dpy, const EGLAttrib *attrib_list, EGLOutputPortEXT *ports, EGLint max_ports, EGLint *num_ports); +EGLAPI EGLBoolean EGLAPIENTRY eglOutputLayerAttribEXT (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint attribute, EGLAttrib value); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryOutputLayerAttribEXT (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint attribute, EGLAttrib *value); +EGLAPI const char *EGLAPIENTRY eglQueryOutputLayerStringEXT (EGLDisplay dpy, EGLOutputLayerEXT layer, EGLint name); +EGLAPI EGLBoolean EGLAPIENTRY eglOutputPortAttribEXT (EGLDisplay dpy, EGLOutputPortEXT port, EGLint attribute, EGLAttrib value); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryOutputPortAttribEXT (EGLDisplay dpy, EGLOutputPortEXT port, EGLint attribute, EGLAttrib *value); +EGLAPI const char *EGLAPIENTRY eglQueryOutputPortStringEXT (EGLDisplay dpy, EGLOutputPortEXT port, EGLint name); +#endif +#endif /* EGL_EXT_output_base */ + +#ifndef EGL_EXT_output_drm +#define EGL_EXT_output_drm 1 +#define EGL_DRM_CRTC_EXT 0x3234 +#define EGL_DRM_PLANE_EXT 0x3235 +#define EGL_DRM_CONNECTOR_EXT 0x3236 +#endif /* EGL_EXT_output_drm */ + +#ifndef EGL_EXT_output_openwf +#define EGL_EXT_output_openwf 1 +#define EGL_OPENWF_PIPELINE_ID_EXT 0x3238 +#define EGL_OPENWF_PORT_ID_EXT 0x3239 +#endif /* EGL_EXT_output_openwf */ + +#ifndef EGL_EXT_platform_base +#define EGL_EXT_platform_base 1 +typedef EGLDisplay (EGLAPIENTRYP PFNEGLGETPLATFORMDISPLAYEXTPROC) (EGLenum platform, void *native_display, const EGLint *attrib_list); +typedef EGLSurface (EGLAPIENTRYP PFNEGLCREATEPLATFORMWINDOWSURFACEEXTPROC) (EGLDisplay dpy, EGLConfig config, void *native_window, const EGLint *attrib_list); +typedef EGLSurface (EGLAPIENTRYP PFNEGLCREATEPLATFORMPIXMAPSURFACEEXTPROC) (EGLDisplay dpy, EGLConfig config, void *native_pixmap, const EGLint *attrib_list); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLDisplay EGLAPIENTRY eglGetPlatformDisplayEXT (EGLenum platform, void *native_display, const EGLint *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePlatformWindowSurfaceEXT (EGLDisplay dpy, EGLConfig config, void *native_window, const EGLint *attrib_list); +EGLAPI EGLSurface EGLAPIENTRY eglCreatePlatformPixmapSurfaceEXT (EGLDisplay dpy, EGLConfig config, void *native_pixmap, const EGLint *attrib_list); +#endif +#endif /* EGL_EXT_platform_base */ + +#ifndef EGL_EXT_platform_device +#define EGL_EXT_platform_device 1 +#define EGL_PLATFORM_DEVICE_EXT 0x313F +#endif /* EGL_EXT_platform_device */ + +#ifndef EGL_EXT_platform_wayland +#define EGL_EXT_platform_wayland 1 +#define EGL_PLATFORM_WAYLAND_EXT 0x31D8 +#endif /* EGL_EXT_platform_wayland */ + +#ifndef EGL_EXT_platform_x11 +#define EGL_EXT_platform_x11 1 +#define EGL_PLATFORM_X11_EXT 0x31D5 +#define EGL_PLATFORM_X11_SCREEN_EXT 0x31D6 +#endif /* EGL_EXT_platform_x11 */ + +#ifndef EGL_EXT_protected_surface +#define EGL_EXT_protected_surface 1 +#define EGL_PROTECTED_CONTENT_EXT 0x32C0 +#endif /* EGL_EXT_protected_surface */ + +#ifndef EGL_EXT_stream_consumer_egloutput +#define EGL_EXT_stream_consumer_egloutput 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSTREAMCONSUMEROUTPUTEXTPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLOutputLayerEXT layer); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglStreamConsumerOutputEXT (EGLDisplay dpy, EGLStreamKHR stream, EGLOutputLayerEXT layer); +#endif +#endif /* EGL_EXT_stream_consumer_egloutput */ + +#ifndef EGL_EXT_swap_buffers_with_damage +#define EGL_EXT_swap_buffers_with_damage 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSWAPBUFFERSWITHDAMAGEEXTPROC) (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSwapBuffersWithDamageEXT (EGLDisplay dpy, EGLSurface surface, EGLint *rects, EGLint n_rects); +#endif +#endif /* EGL_EXT_swap_buffers_with_damage */ + +#ifndef EGL_EXT_yuv_surface +#define EGL_EXT_yuv_surface 1 +#define EGL_YUV_ORDER_EXT 0x3301 +#define EGL_YUV_NUMBER_OF_PLANES_EXT 0x3311 +#define EGL_YUV_SUBSAMPLE_EXT 0x3312 +#define EGL_YUV_DEPTH_RANGE_EXT 0x3317 +#define EGL_YUV_CSC_STANDARD_EXT 0x330A +#define EGL_YUV_PLANE_BPP_EXT 0x331A +#define EGL_YUV_BUFFER_EXT 0x3300 +#define EGL_YUV_ORDER_YUV_EXT 0x3302 +#define EGL_YUV_ORDER_YVU_EXT 0x3303 +#define EGL_YUV_ORDER_YUYV_EXT 0x3304 +#define EGL_YUV_ORDER_UYVY_EXT 0x3305 +#define EGL_YUV_ORDER_YVYU_EXT 0x3306 +#define EGL_YUV_ORDER_VYUY_EXT 0x3307 +#define EGL_YUV_ORDER_AYUV_EXT 0x3308 +#define EGL_YUV_SUBSAMPLE_4_2_0_EXT 0x3313 +#define EGL_YUV_SUBSAMPLE_4_2_2_EXT 0x3314 +#define EGL_YUV_SUBSAMPLE_4_4_4_EXT 0x3315 +#define EGL_YUV_DEPTH_RANGE_LIMITED_EXT 0x3318 +#define EGL_YUV_DEPTH_RANGE_FULL_EXT 0x3319 +#define EGL_YUV_CSC_STANDARD_601_EXT 0x330B +#define EGL_YUV_CSC_STANDARD_709_EXT 0x330C +#define EGL_YUV_CSC_STANDARD_2020_EXT 0x330D +#define EGL_YUV_PLANE_BPP_0_EXT 0x331B +#define EGL_YUV_PLANE_BPP_8_EXT 0x331C +#define EGL_YUV_PLANE_BPP_10_EXT 0x331D +#endif /* EGL_EXT_yuv_surface */ + +#ifndef EGL_HI_clientpixmap +#define EGL_HI_clientpixmap 1 +struct EGLClientPixmapHI { + void *pData; + EGLint iWidth; + EGLint iHeight; + EGLint iStride; +}; +#define EGL_CLIENT_PIXMAP_POINTER_HI 0x8F74 +typedef EGLSurface (EGLAPIENTRYP PFNEGLCREATEPIXMAPSURFACEHIPROC) (EGLDisplay dpy, EGLConfig config, struct EGLClientPixmapHI *pixmap); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSurface EGLAPIENTRY eglCreatePixmapSurfaceHI (EGLDisplay dpy, EGLConfig config, struct EGLClientPixmapHI *pixmap); +#endif +#endif /* EGL_HI_clientpixmap */ + +#ifndef EGL_HI_colorformats +#define EGL_HI_colorformats 1 +#define EGL_COLOR_FORMAT_HI 0x8F70 +#define EGL_COLOR_RGB_HI 0x8F71 +#define EGL_COLOR_RGBA_HI 0x8F72 +#define EGL_COLOR_ARGB_HI 0x8F73 +#endif /* EGL_HI_colorformats */ + +#ifndef EGL_IMG_context_priority +#define EGL_IMG_context_priority 1 +#define EGL_CONTEXT_PRIORITY_LEVEL_IMG 0x3100 +#define EGL_CONTEXT_PRIORITY_HIGH_IMG 0x3101 +#define EGL_CONTEXT_PRIORITY_MEDIUM_IMG 0x3102 +#define EGL_CONTEXT_PRIORITY_LOW_IMG 0x3103 +#endif /* EGL_IMG_context_priority */ + +#ifndef EGL_MESA_drm_image +#define EGL_MESA_drm_image 1 +#define EGL_DRM_BUFFER_FORMAT_MESA 0x31D0 +#define EGL_DRM_BUFFER_USE_MESA 0x31D1 +#define EGL_DRM_BUFFER_FORMAT_ARGB32_MESA 0x31D2 +#define EGL_DRM_BUFFER_MESA 0x31D3 +#define EGL_DRM_BUFFER_STRIDE_MESA 0x31D4 +#define EGL_DRM_BUFFER_USE_SCANOUT_MESA 0x00000001 +#define EGL_DRM_BUFFER_USE_SHARE_MESA 0x00000002 +typedef EGLImageKHR (EGLAPIENTRYP PFNEGLCREATEDRMIMAGEMESAPROC) (EGLDisplay dpy, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLEXPORTDRMIMAGEMESAPROC) (EGLDisplay dpy, EGLImageKHR image, EGLint *name, EGLint *handle, EGLint *stride); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLImageKHR EGLAPIENTRY eglCreateDRMImageMESA (EGLDisplay dpy, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglExportDRMImageMESA (EGLDisplay dpy, EGLImageKHR image, EGLint *name, EGLint *handle, EGLint *stride); +#endif +#endif /* EGL_MESA_drm_image */ + +#ifndef EGL_MESA_image_dma_buf_export +#define EGL_MESA_image_dma_buf_export 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLEXPORTDMABUFIMAGEQUERYMESAPROC) (EGLDisplay dpy, EGLImageKHR image, int *fourcc, int *num_planes, EGLuint64KHR *modifiers); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLEXPORTDMABUFIMAGEMESAPROC) (EGLDisplay dpy, EGLImageKHR image, int *fds, EGLint *strides, EGLint *offsets); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglExportDMABUFImageQueryMESA (EGLDisplay dpy, EGLImageKHR image, int *fourcc, int *num_planes, EGLuint64KHR *modifiers); +EGLAPI EGLBoolean EGLAPIENTRY eglExportDMABUFImageMESA (EGLDisplay dpy, EGLImageKHR image, int *fds, EGLint *strides, EGLint *offsets); +#endif +#endif /* EGL_MESA_image_dma_buf_export */ + +#ifndef EGL_MESA_platform_gbm +#define EGL_MESA_platform_gbm 1 +#define EGL_PLATFORM_GBM_MESA 0x31D7 +#endif /* EGL_MESA_platform_gbm */ + +#ifndef EGL_NOK_swap_region +#define EGL_NOK_swap_region 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSWAPBUFFERSREGIONNOKPROC) (EGLDisplay dpy, EGLSurface surface, EGLint numRects, const EGLint *rects); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSwapBuffersRegionNOK (EGLDisplay dpy, EGLSurface surface, EGLint numRects, const EGLint *rects); +#endif +#endif /* EGL_NOK_swap_region */ + +#ifndef EGL_NOK_swap_region2 +#define EGL_NOK_swap_region2 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSWAPBUFFERSREGION2NOKPROC) (EGLDisplay dpy, EGLSurface surface, EGLint numRects, const EGLint *rects); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglSwapBuffersRegion2NOK (EGLDisplay dpy, EGLSurface surface, EGLint numRects, const EGLint *rects); +#endif +#endif /* EGL_NOK_swap_region2 */ + +#ifndef EGL_NOK_texture_from_pixmap +#define EGL_NOK_texture_from_pixmap 1 +#define EGL_Y_INVERTED_NOK 0x307F +#endif /* EGL_NOK_texture_from_pixmap */ + +#ifndef EGL_NV_3dvision_surface +#define EGL_NV_3dvision_surface 1 +#define EGL_AUTO_STEREO_NV 0x3136 +#endif /* EGL_NV_3dvision_surface */ + +#ifndef EGL_NV_coverage_sample +#define EGL_NV_coverage_sample 1 +#define EGL_COVERAGE_BUFFERS_NV 0x30E0 +#define EGL_COVERAGE_SAMPLES_NV 0x30E1 +#endif /* EGL_NV_coverage_sample */ + +#ifndef EGL_NV_coverage_sample_resolve +#define EGL_NV_coverage_sample_resolve 1 +#define EGL_COVERAGE_SAMPLE_RESOLVE_NV 0x3131 +#define EGL_COVERAGE_SAMPLE_RESOLVE_DEFAULT_NV 0x3132 +#define EGL_COVERAGE_SAMPLE_RESOLVE_NONE_NV 0x3133 +#endif /* EGL_NV_coverage_sample_resolve */ + +#ifndef EGL_NV_cuda_event +#define EGL_NV_cuda_event 1 +#define EGL_CUDA_EVENT_HANDLE_NV 0x323B +#define EGL_SYNC_CUDA_EVENT_NV 0x323C +#define EGL_SYNC_CUDA_EVENT_COMPLETE_NV 0x323D +#endif /* EGL_NV_cuda_event */ + +#ifndef EGL_NV_depth_nonlinear +#define EGL_NV_depth_nonlinear 1 +#define EGL_DEPTH_ENCODING_NV 0x30E2 +#define EGL_DEPTH_ENCODING_NONE_NV 0 +#define EGL_DEPTH_ENCODING_NONLINEAR_NV 0x30E3 +#endif /* EGL_NV_depth_nonlinear */ + +#ifndef EGL_NV_device_cuda +#define EGL_NV_device_cuda 1 +#define EGL_CUDA_DEVICE_NV 0x323A +#endif /* EGL_NV_device_cuda */ + +#ifndef EGL_NV_native_query +#define EGL_NV_native_query 1 +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYNATIVEDISPLAYNVPROC) (EGLDisplay dpy, EGLNativeDisplayType *display_id); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYNATIVEWINDOWNVPROC) (EGLDisplay dpy, EGLSurface surf, EGLNativeWindowType *window); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLQUERYNATIVEPIXMAPNVPROC) (EGLDisplay dpy, EGLSurface surf, EGLNativePixmapType *pixmap); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglQueryNativeDisplayNV (EGLDisplay dpy, EGLNativeDisplayType *display_id); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryNativeWindowNV (EGLDisplay dpy, EGLSurface surf, EGLNativeWindowType *window); +EGLAPI EGLBoolean EGLAPIENTRY eglQueryNativePixmapNV (EGLDisplay dpy, EGLSurface surf, EGLNativePixmapType *pixmap); +#endif +#endif /* EGL_NV_native_query */ + +#ifndef EGL_NV_post_convert_rounding +#define EGL_NV_post_convert_rounding 1 +#endif /* EGL_NV_post_convert_rounding */ + +#ifndef EGL_NV_post_sub_buffer +#define EGL_NV_post_sub_buffer 1 +#define EGL_POST_SUB_BUFFER_SUPPORTED_NV 0x30BE +typedef EGLBoolean (EGLAPIENTRYP PFNEGLPOSTSUBBUFFERNVPROC) (EGLDisplay dpy, EGLSurface surface, EGLint x, EGLint y, EGLint width, EGLint height); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLBoolean EGLAPIENTRY eglPostSubBufferNV (EGLDisplay dpy, EGLSurface surface, EGLint x, EGLint y, EGLint width, EGLint height); +#endif +#endif /* EGL_NV_post_sub_buffer */ + +#ifndef EGL_NV_stream_sync +#define EGL_NV_stream_sync 1 +#define EGL_SYNC_NEW_FRAME_NV 0x321F +typedef EGLSyncKHR (EGLAPIENTRYP PFNEGLCREATESTREAMSYNCNVPROC) (EGLDisplay dpy, EGLStreamKHR stream, EGLenum type, const EGLint *attrib_list); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSyncKHR EGLAPIENTRY eglCreateStreamSyncNV (EGLDisplay dpy, EGLStreamKHR stream, EGLenum type, const EGLint *attrib_list); +#endif +#endif /* EGL_NV_stream_sync */ + +#ifndef EGL_NV_sync +#define EGL_NV_sync 1 +typedef void *EGLSyncNV; +typedef khronos_utime_nanoseconds_t EGLTimeNV; +#ifdef KHRONOS_SUPPORT_INT64 +#define EGL_SYNC_PRIOR_COMMANDS_COMPLETE_NV 0x30E6 +#define EGL_SYNC_STATUS_NV 0x30E7 +#define EGL_SIGNALED_NV 0x30E8 +#define EGL_UNSIGNALED_NV 0x30E9 +#define EGL_SYNC_FLUSH_COMMANDS_BIT_NV 0x0001 +#define EGL_FOREVER_NV 0xFFFFFFFFFFFFFFFFull +#define EGL_ALREADY_SIGNALED_NV 0x30EA +#define EGL_TIMEOUT_EXPIRED_NV 0x30EB +#define EGL_CONDITION_SATISFIED_NV 0x30EC +#define EGL_SYNC_TYPE_NV 0x30ED +#define EGL_SYNC_CONDITION_NV 0x30EE +#define EGL_SYNC_FENCE_NV 0x30EF +#define EGL_NO_SYNC_NV ((EGLSyncNV)0) +typedef EGLSyncNV (EGLAPIENTRYP PFNEGLCREATEFENCESYNCNVPROC) (EGLDisplay dpy, EGLenum condition, const EGLint *attrib_list); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLDESTROYSYNCNVPROC) (EGLSyncNV sync); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLFENCENVPROC) (EGLSyncNV sync); +typedef EGLint (EGLAPIENTRYP PFNEGLCLIENTWAITSYNCNVPROC) (EGLSyncNV sync, EGLint flags, EGLTimeNV timeout); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLSIGNALSYNCNVPROC) (EGLSyncNV sync, EGLenum mode); +typedef EGLBoolean (EGLAPIENTRYP PFNEGLGETSYNCATTRIBNVPROC) (EGLSyncNV sync, EGLint attribute, EGLint *value); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLSyncNV EGLAPIENTRY eglCreateFenceSyncNV (EGLDisplay dpy, EGLenum condition, const EGLint *attrib_list); +EGLAPI EGLBoolean EGLAPIENTRY eglDestroySyncNV (EGLSyncNV sync); +EGLAPI EGLBoolean EGLAPIENTRY eglFenceNV (EGLSyncNV sync); +EGLAPI EGLint EGLAPIENTRY eglClientWaitSyncNV (EGLSyncNV sync, EGLint flags, EGLTimeNV timeout); +EGLAPI EGLBoolean EGLAPIENTRY eglSignalSyncNV (EGLSyncNV sync, EGLenum mode); +EGLAPI EGLBoolean EGLAPIENTRY eglGetSyncAttribNV (EGLSyncNV sync, EGLint attribute, EGLint *value); +#endif +#endif /* KHRONOS_SUPPORT_INT64 */ +#endif /* EGL_NV_sync */ + +#ifndef EGL_NV_system_time +#define EGL_NV_system_time 1 +typedef khronos_utime_nanoseconds_t EGLuint64NV; +#ifdef KHRONOS_SUPPORT_INT64 +typedef EGLuint64NV (EGLAPIENTRYP PFNEGLGETSYSTEMTIMEFREQUENCYNVPROC) (void); +typedef EGLuint64NV (EGLAPIENTRYP PFNEGLGETSYSTEMTIMENVPROC) (void); +#ifdef EGL_EGLEXT_PROTOTYPES +EGLAPI EGLuint64NV EGLAPIENTRY eglGetSystemTimeFrequencyNV (void); +EGLAPI EGLuint64NV EGLAPIENTRY eglGetSystemTimeNV (void); +#endif +#endif /* KHRONOS_SUPPORT_INT64 */ +#endif /* EGL_NV_system_time */ + +#ifndef EGL_TIZEN_image_native_buffer +#define EGL_TIZEN_image_native_buffer 1 +#define EGL_NATIVE_BUFFER_TIZEN 0x32A0 +#endif /* EGL_TIZEN_image_native_buffer */ + +#ifndef EGL_TIZEN_image_native_surface +#define EGL_TIZEN_image_native_surface 1 +#define EGL_NATIVE_SURFACE_TIZEN 0x32A1 +#endif /* EGL_TIZEN_image_native_surface */ + +#ifdef __cplusplus +} +#endif + +#endif /* __eglext_h_ */ + + +#endif /* _MSC_VER */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_endian.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_endian.h new file mode 100644 index 0000000..54d5d48 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_endian.h @@ -0,0 +1,260 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_endian.h + * + * Functions for reading and writing endian-specific values + */ + +#ifndef SDL_endian_h_ +#define SDL_endian_h_ + +#include "SDL_stdinc.h" + +/** + * \name The two types of endianness + */ +/* @{ */ +#define SDL_LIL_ENDIAN 1234 +#define SDL_BIG_ENDIAN 4321 +/* @} */ + +#ifndef SDL_BYTEORDER /* Not defined in SDL_config.h? */ +#ifdef __linux__ +#include +#define SDL_BYTEORDER __BYTE_ORDER +#else /* __linux__ */ +#if defined(__hppa__) || \ + defined(__m68k__) || defined(mc68000) || defined(_M_M68K) || \ + (defined(__MIPS__) && defined(__MISPEB__)) || \ + defined(__ppc__) || defined(__POWERPC__) || defined(_M_PPC) || \ + defined(__sparc__) +#define SDL_BYTEORDER SDL_BIG_ENDIAN +#else +#define SDL_BYTEORDER SDL_LIL_ENDIAN +#endif +#endif /* __linux__ */ +#endif /* !SDL_BYTEORDER */ + + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \file SDL_endian.h + */ +#if defined(__GNUC__) && defined(__i386__) && \ + !(__GNUC__ == 2 && __GNUC_MINOR__ == 95 /* broken gcc version */) +SDL_FORCE_INLINE Uint16 +SDL_Swap16(Uint16 x) +{ + __asm__("xchgb %b0,%h0": "=q"(x):"0"(x)); + return x; +} +#elif defined(__GNUC__) && defined(__x86_64__) +SDL_FORCE_INLINE Uint16 +SDL_Swap16(Uint16 x) +{ + __asm__("xchgb %b0,%h0": "=Q"(x):"0"(x)); + return x; +} +#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__)) +SDL_FORCE_INLINE Uint16 +SDL_Swap16(Uint16 x) +{ + int result; + + __asm__("rlwimi %0,%2,8,16,23": "=&r"(result):"0"(x >> 8), "r"(x)); + return (Uint16)result; +} +#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__)) && !defined(__mcoldfire__) +SDL_FORCE_INLINE Uint16 +SDL_Swap16(Uint16 x) +{ + __asm__("rorw #8,%0": "=d"(x): "0"(x):"cc"); + return x; +} +#elif defined(__WATCOMC__) && defined(__386__) +extern _inline Uint16 SDL_Swap16(Uint16); +#pragma aux SDL_Swap16 = \ + "xchg al, ah" \ + parm [ax] \ + modify [ax]; +#else +SDL_FORCE_INLINE Uint16 +SDL_Swap16(Uint16 x) +{ + return SDL_static_cast(Uint16, ((x << 8) | (x >> 8))); +} +#endif + +#if defined(__GNUC__) && defined(__i386__) +SDL_FORCE_INLINE Uint32 +SDL_Swap32(Uint32 x) +{ + __asm__("bswap %0": "=r"(x):"0"(x)); + return x; +} +#elif defined(__GNUC__) && defined(__x86_64__) +SDL_FORCE_INLINE Uint32 +SDL_Swap32(Uint32 x) +{ + __asm__("bswapl %0": "=r"(x):"0"(x)); + return x; +} +#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__)) +SDL_FORCE_INLINE Uint32 +SDL_Swap32(Uint32 x) +{ + Uint32 result; + + __asm__("rlwimi %0,%2,24,16,23": "=&r"(result):"0"(x >> 24), "r"(x)); + __asm__("rlwimi %0,%2,8,8,15": "=&r"(result):"0"(result), "r"(x)); + __asm__("rlwimi %0,%2,24,0,7": "=&r"(result):"0"(result), "r"(x)); + return result; +} +#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__)) && !defined(__mcoldfire__) +SDL_FORCE_INLINE Uint32 +SDL_Swap32(Uint32 x) +{ + __asm__("rorw #8,%0\n\tswap %0\n\trorw #8,%0": "=d"(x): "0"(x):"cc"); + return x; +} +#elif defined(__WATCOMC__) && defined(__386__) +extern _inline Uint32 SDL_Swap32(Uint32); +#ifndef __SW_3 /* 486+ */ +#pragma aux SDL_Swap32 = \ + "bswap eax" \ + parm [eax] \ + modify [eax]; +#else /* 386-only */ +#pragma aux SDL_Swap32 = \ + "xchg al, ah" \ + "ror eax, 16" \ + "xchg al, ah" \ + parm [eax] \ + modify [eax]; +#endif +#else +SDL_FORCE_INLINE Uint32 +SDL_Swap32(Uint32 x) +{ + return SDL_static_cast(Uint32, ((x << 24) | ((x << 8) & 0x00FF0000) | + ((x >> 8) & 0x0000FF00) | (x >> 24))); +} +#endif + +#if defined(__GNUC__) && defined(__i386__) +SDL_FORCE_INLINE Uint64 +SDL_Swap64(Uint64 x) +{ + union + { + struct + { + Uint32 a, b; + } s; + Uint64 u; + } v; + v.u = x; + __asm__("bswapl %0 ; bswapl %1 ; xchgl %0,%1": "=r"(v.s.a), "=r"(v.s.b):"0"(v.s.a), + "1"(v.s. + b)); + return v.u; +} +#elif defined(__GNUC__) && defined(__x86_64__) +SDL_FORCE_INLINE Uint64 +SDL_Swap64(Uint64 x) +{ + __asm__("bswapq %0": "=r"(x):"0"(x)); + return x; +} +#else +SDL_FORCE_INLINE Uint64 +SDL_Swap64(Uint64 x) +{ + Uint32 hi, lo; + + /* Separate into high and low 32-bit values and swap them */ + lo = SDL_static_cast(Uint32, x & 0xFFFFFFFF); + x >>= 32; + hi = SDL_static_cast(Uint32, x & 0xFFFFFFFF); + x = SDL_Swap32(lo); + x <<= 32; + x |= SDL_Swap32(hi); + return (x); +} +#endif + + +SDL_FORCE_INLINE float +SDL_SwapFloat(float x) +{ + union + { + float f; + Uint32 ui32; + } swapper; + swapper.f = x; + swapper.ui32 = SDL_Swap32(swapper.ui32); + return swapper.f; +} + + +/** + * \name Swap to native + * Byteswap item from the specified endianness to the native endianness. + */ +/* @{ */ +#if SDL_BYTEORDER == SDL_LIL_ENDIAN +#define SDL_SwapLE16(X) (X) +#define SDL_SwapLE32(X) (X) +#define SDL_SwapLE64(X) (X) +#define SDL_SwapFloatLE(X) (X) +#define SDL_SwapBE16(X) SDL_Swap16(X) +#define SDL_SwapBE32(X) SDL_Swap32(X) +#define SDL_SwapBE64(X) SDL_Swap64(X) +#define SDL_SwapFloatBE(X) SDL_SwapFloat(X) +#else +#define SDL_SwapLE16(X) SDL_Swap16(X) +#define SDL_SwapLE32(X) SDL_Swap32(X) +#define SDL_SwapLE64(X) SDL_Swap64(X) +#define SDL_SwapFloatLE(X) SDL_SwapFloat(X) +#define SDL_SwapBE16(X) (X) +#define SDL_SwapBE32(X) (X) +#define SDL_SwapBE64(X) (X) +#define SDL_SwapFloatBE(X) (X) +#endif +/* @} *//* Swap to native */ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_endian_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_error.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_error.h new file mode 100644 index 0000000..24416e6 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_error.h @@ -0,0 +1,76 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_error.h + * + * Simple error message routines for SDL. + */ + +#ifndef SDL_error_h_ +#define SDL_error_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* Public functions */ +/* SDL_SetError() unconditionally returns -1. */ +extern DECLSPEC int SDLCALL SDL_SetError(SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(1); +extern DECLSPEC const char *SDLCALL SDL_GetError(void); +extern DECLSPEC void SDLCALL SDL_ClearError(void); + +/** + * \name Internal error functions + * + * \internal + * Private error reporting function - used internally. + */ +/* @{ */ +#define SDL_OutOfMemory() SDL_Error(SDL_ENOMEM) +#define SDL_Unsupported() SDL_Error(SDL_UNSUPPORTED) +#define SDL_InvalidParamError(param) SDL_SetError("Parameter '%s' is invalid", (param)) +typedef enum +{ + SDL_ENOMEM, + SDL_EFREAD, + SDL_EFWRITE, + SDL_EFSEEK, + SDL_UNSUPPORTED, + SDL_LASTERROR +} SDL_errorcode; +/* SDL_Error() unconditionally returns -1. */ +extern DECLSPEC int SDLCALL SDL_Error(SDL_errorcode code); +/* @} *//* Internal error functions */ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_error_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_events.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_events.h new file mode 100644 index 0000000..282b9fb --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_events.h @@ -0,0 +1,791 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_events.h + * + * Include file for SDL event handling. + */ + +#ifndef SDL_events_h_ +#define SDL_events_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" +#include "SDL_keyboard.h" +#include "SDL_mouse.h" +#include "SDL_joystick.h" +#include "SDL_gamecontroller.h" +#include "SDL_quit.h" +#include "SDL_gesture.h" +#include "SDL_touch.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* General keyboard/mouse state definitions */ +#define SDL_RELEASED 0 +#define SDL_PRESSED 1 + +/** + * \brief The types of events that can be delivered. + */ +typedef enum +{ + SDL_FIRSTEVENT = 0, /**< Unused (do not remove) */ + + /* Application events */ + SDL_QUIT = 0x100, /**< User-requested quit */ + + /* These application events have special meaning on iOS, see README-ios.md for details */ + SDL_APP_TERMINATING, /**< The application is being terminated by the OS + Called on iOS in applicationWillTerminate() + Called on Android in onDestroy() + */ + SDL_APP_LOWMEMORY, /**< The application is low on memory, free memory if possible. + Called on iOS in applicationDidReceiveMemoryWarning() + Called on Android in onLowMemory() + */ + SDL_APP_WILLENTERBACKGROUND, /**< The application is about to enter the background + Called on iOS in applicationWillResignActive() + Called on Android in onPause() + */ + SDL_APP_DIDENTERBACKGROUND, /**< The application did enter the background and may not get CPU for some time + Called on iOS in applicationDidEnterBackground() + Called on Android in onPause() + */ + SDL_APP_WILLENTERFOREGROUND, /**< The application is about to enter the foreground + Called on iOS in applicationWillEnterForeground() + Called on Android in onResume() + */ + SDL_APP_DIDENTERFOREGROUND, /**< The application is now interactive + Called on iOS in applicationDidBecomeActive() + Called on Android in onResume() + */ + + /* Display events */ + SDL_DISPLAYEVENT = 0x150, /**< Display state change */ + + /* Window events */ + SDL_WINDOWEVENT = 0x200, /**< Window state change */ + SDL_SYSWMEVENT, /**< System specific event */ + + /* Keyboard events */ + SDL_KEYDOWN = 0x300, /**< Key pressed */ + SDL_KEYUP, /**< Key released */ + SDL_TEXTEDITING, /**< Keyboard text editing (composition) */ + SDL_TEXTINPUT, /**< Keyboard text input */ + SDL_KEYMAPCHANGED, /**< Keymap changed due to a system event such as an + input language or keyboard layout change. + */ + + /* Mouse events */ + SDL_MOUSEMOTION = 0x400, /**< Mouse moved */ + SDL_MOUSEBUTTONDOWN, /**< Mouse button pressed */ + SDL_MOUSEBUTTONUP, /**< Mouse button released */ + SDL_MOUSEWHEEL, /**< Mouse wheel motion */ + + /* Joystick events */ + SDL_JOYAXISMOTION = 0x600, /**< Joystick axis motion */ + SDL_JOYBALLMOTION, /**< Joystick trackball motion */ + SDL_JOYHATMOTION, /**< Joystick hat position change */ + SDL_JOYBUTTONDOWN, /**< Joystick button pressed */ + SDL_JOYBUTTONUP, /**< Joystick button released */ + SDL_JOYDEVICEADDED, /**< A new joystick has been inserted into the system */ + SDL_JOYDEVICEREMOVED, /**< An opened joystick has been removed */ + + /* Game controller events */ + SDL_CONTROLLERAXISMOTION = 0x650, /**< Game controller axis motion */ + SDL_CONTROLLERBUTTONDOWN, /**< Game controller button pressed */ + SDL_CONTROLLERBUTTONUP, /**< Game controller button released */ + SDL_CONTROLLERDEVICEADDED, /**< A new Game controller has been inserted into the system */ + SDL_CONTROLLERDEVICEREMOVED, /**< An opened Game controller has been removed */ + SDL_CONTROLLERDEVICEREMAPPED, /**< The controller mapping was updated */ + + /* Touch events */ + SDL_FINGERDOWN = 0x700, + SDL_FINGERUP, + SDL_FINGERMOTION, + + /* Gesture events */ + SDL_DOLLARGESTURE = 0x800, + SDL_DOLLARRECORD, + SDL_MULTIGESTURE, + + /* Clipboard events */ + SDL_CLIPBOARDUPDATE = 0x900, /**< The clipboard changed */ + + /* Drag and drop events */ + SDL_DROPFILE = 0x1000, /**< The system requests a file open */ + SDL_DROPTEXT, /**< text/plain drag-and-drop event */ + SDL_DROPBEGIN, /**< A new set of drops is beginning (NULL filename) */ + SDL_DROPCOMPLETE, /**< Current set of drops is now complete (NULL filename) */ + + /* Audio hotplug events */ + SDL_AUDIODEVICEADDED = 0x1100, /**< A new audio device is available */ + SDL_AUDIODEVICEREMOVED, /**< An audio device has been removed. */ + + /* Sensor events */ + SDL_SENSORUPDATE = 0x1200, /**< A sensor was updated */ + + /* Render events */ + SDL_RENDER_TARGETS_RESET = 0x2000, /**< The render targets have been reset and their contents need to be updated */ + SDL_RENDER_DEVICE_RESET, /**< The device has been reset and all textures need to be recreated */ + + /** Events ::SDL_USEREVENT through ::SDL_LASTEVENT are for your use, + * and should be allocated with SDL_RegisterEvents() + */ + SDL_USEREVENT = 0x8000, + + /** + * This last event is only for bounding internal arrays + */ + SDL_LASTEVENT = 0xFFFF +} SDL_EventType; + +/** + * \brief Fields shared by every event + */ +typedef struct SDL_CommonEvent +{ + Uint32 type; + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ +} SDL_CommonEvent; + +/** + * \brief Display state change event data (event.display.*) + */ +typedef struct SDL_DisplayEvent +{ + Uint32 type; /**< ::SDL_DISPLAYEVENT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 display; /**< The associated display index */ + Uint8 event; /**< ::SDL_DisplayEventID */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; + Sint32 data1; /**< event dependent data */ +} SDL_DisplayEvent; + +/** + * \brief Window state change event data (event.window.*) + */ +typedef struct SDL_WindowEvent +{ + Uint32 type; /**< ::SDL_WINDOWEVENT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The associated window */ + Uint8 event; /**< ::SDL_WindowEventID */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; + Sint32 data1; /**< event dependent data */ + Sint32 data2; /**< event dependent data */ +} SDL_WindowEvent; + +/** + * \brief Keyboard button event structure (event.key.*) + */ +typedef struct SDL_KeyboardEvent +{ + Uint32 type; /**< ::SDL_KEYDOWN or ::SDL_KEYUP */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with keyboard focus, if any */ + Uint8 state; /**< ::SDL_PRESSED or ::SDL_RELEASED */ + Uint8 repeat; /**< Non-zero if this is a key repeat */ + Uint8 padding2; + Uint8 padding3; + SDL_Keysym keysym; /**< The key that was pressed or released */ +} SDL_KeyboardEvent; + +#define SDL_TEXTEDITINGEVENT_TEXT_SIZE (32) +/** + * \brief Keyboard text editing event structure (event.edit.*) + */ +typedef struct SDL_TextEditingEvent +{ + Uint32 type; /**< ::SDL_TEXTEDITING */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with keyboard focus, if any */ + char text[SDL_TEXTEDITINGEVENT_TEXT_SIZE]; /**< The editing text */ + Sint32 start; /**< The start cursor of selected editing text */ + Sint32 length; /**< The length of selected editing text */ +} SDL_TextEditingEvent; + + +#define SDL_TEXTINPUTEVENT_TEXT_SIZE (32) +/** + * \brief Keyboard text input event structure (event.text.*) + */ +typedef struct SDL_TextInputEvent +{ + Uint32 type; /**< ::SDL_TEXTINPUT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with keyboard focus, if any */ + char text[SDL_TEXTINPUTEVENT_TEXT_SIZE]; /**< The input text */ +} SDL_TextInputEvent; + +/** + * \brief Mouse motion event structure (event.motion.*) + */ +typedef struct SDL_MouseMotionEvent +{ + Uint32 type; /**< ::SDL_MOUSEMOTION */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with mouse focus, if any */ + Uint32 which; /**< The mouse instance id, or SDL_TOUCH_MOUSEID */ + Uint32 state; /**< The current button state */ + Sint32 x; /**< X coordinate, relative to window */ + Sint32 y; /**< Y coordinate, relative to window */ + Sint32 xrel; /**< The relative motion in the X direction */ + Sint32 yrel; /**< The relative motion in the Y direction */ +} SDL_MouseMotionEvent; + +/** + * \brief Mouse button event structure (event.button.*) + */ +typedef struct SDL_MouseButtonEvent +{ + Uint32 type; /**< ::SDL_MOUSEBUTTONDOWN or ::SDL_MOUSEBUTTONUP */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with mouse focus, if any */ + Uint32 which; /**< The mouse instance id, or SDL_TOUCH_MOUSEID */ + Uint8 button; /**< The mouse button index */ + Uint8 state; /**< ::SDL_PRESSED or ::SDL_RELEASED */ + Uint8 clicks; /**< 1 for single-click, 2 for double-click, etc. */ + Uint8 padding1; + Sint32 x; /**< X coordinate, relative to window */ + Sint32 y; /**< Y coordinate, relative to window */ +} SDL_MouseButtonEvent; + +/** + * \brief Mouse wheel event structure (event.wheel.*) + */ +typedef struct SDL_MouseWheelEvent +{ + Uint32 type; /**< ::SDL_MOUSEWHEEL */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The window with mouse focus, if any */ + Uint32 which; /**< The mouse instance id, or SDL_TOUCH_MOUSEID */ + Sint32 x; /**< The amount scrolled horizontally, positive to the right and negative to the left */ + Sint32 y; /**< The amount scrolled vertically, positive away from the user and negative toward the user */ + Uint32 direction; /**< Set to one of the SDL_MOUSEWHEEL_* defines. When FLIPPED the values in X and Y will be opposite. Multiply by -1 to change them back */ +} SDL_MouseWheelEvent; + +/** + * \brief Joystick axis motion event structure (event.jaxis.*) + */ +typedef struct SDL_JoyAxisEvent +{ + Uint32 type; /**< ::SDL_JOYAXISMOTION */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 axis; /**< The joystick axis index */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; + Sint16 value; /**< The axis value (range: -32768 to 32767) */ + Uint16 padding4; +} SDL_JoyAxisEvent; + +/** + * \brief Joystick trackball motion event structure (event.jball.*) + */ +typedef struct SDL_JoyBallEvent +{ + Uint32 type; /**< ::SDL_JOYBALLMOTION */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 ball; /**< The joystick trackball index */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; + Sint16 xrel; /**< The relative motion in the X direction */ + Sint16 yrel; /**< The relative motion in the Y direction */ +} SDL_JoyBallEvent; + +/** + * \brief Joystick hat position change event structure (event.jhat.*) + */ +typedef struct SDL_JoyHatEvent +{ + Uint32 type; /**< ::SDL_JOYHATMOTION */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 hat; /**< The joystick hat index */ + Uint8 value; /**< The hat position value. + * \sa ::SDL_HAT_LEFTUP ::SDL_HAT_UP ::SDL_HAT_RIGHTUP + * \sa ::SDL_HAT_LEFT ::SDL_HAT_CENTERED ::SDL_HAT_RIGHT + * \sa ::SDL_HAT_LEFTDOWN ::SDL_HAT_DOWN ::SDL_HAT_RIGHTDOWN + * + * Note that zero means the POV is centered. + */ + Uint8 padding1; + Uint8 padding2; +} SDL_JoyHatEvent; + +/** + * \brief Joystick button event structure (event.jbutton.*) + */ +typedef struct SDL_JoyButtonEvent +{ + Uint32 type; /**< ::SDL_JOYBUTTONDOWN or ::SDL_JOYBUTTONUP */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 button; /**< The joystick button index */ + Uint8 state; /**< ::SDL_PRESSED or ::SDL_RELEASED */ + Uint8 padding1; + Uint8 padding2; +} SDL_JoyButtonEvent; + +/** + * \brief Joystick device event structure (event.jdevice.*) + */ +typedef struct SDL_JoyDeviceEvent +{ + Uint32 type; /**< ::SDL_JOYDEVICEADDED or ::SDL_JOYDEVICEREMOVED */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Sint32 which; /**< The joystick device index for the ADDED event, instance id for the REMOVED event */ +} SDL_JoyDeviceEvent; + + +/** + * \brief Game controller axis motion event structure (event.caxis.*) + */ +typedef struct SDL_ControllerAxisEvent +{ + Uint32 type; /**< ::SDL_CONTROLLERAXISMOTION */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 axis; /**< The controller axis (SDL_GameControllerAxis) */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; + Sint16 value; /**< The axis value (range: -32768 to 32767) */ + Uint16 padding4; +} SDL_ControllerAxisEvent; + + +/** + * \brief Game controller button event structure (event.cbutton.*) + */ +typedef struct SDL_ControllerButtonEvent +{ + Uint32 type; /**< ::SDL_CONTROLLERBUTTONDOWN or ::SDL_CONTROLLERBUTTONUP */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_JoystickID which; /**< The joystick instance id */ + Uint8 button; /**< The controller button (SDL_GameControllerButton) */ + Uint8 state; /**< ::SDL_PRESSED or ::SDL_RELEASED */ + Uint8 padding1; + Uint8 padding2; +} SDL_ControllerButtonEvent; + + +/** + * \brief Controller device event structure (event.cdevice.*) + */ +typedef struct SDL_ControllerDeviceEvent +{ + Uint32 type; /**< ::SDL_CONTROLLERDEVICEADDED, ::SDL_CONTROLLERDEVICEREMOVED, or ::SDL_CONTROLLERDEVICEREMAPPED */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Sint32 which; /**< The joystick device index for the ADDED event, instance id for the REMOVED or REMAPPED event */ +} SDL_ControllerDeviceEvent; + +/** + * \brief Audio device event structure (event.adevice.*) + */ +typedef struct SDL_AudioDeviceEvent +{ + Uint32 type; /**< ::SDL_AUDIODEVICEADDED, or ::SDL_AUDIODEVICEREMOVED */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 which; /**< The audio device index for the ADDED event (valid until next SDL_GetNumAudioDevices() call), SDL_AudioDeviceID for the REMOVED event */ + Uint8 iscapture; /**< zero if an output device, non-zero if a capture device. */ + Uint8 padding1; + Uint8 padding2; + Uint8 padding3; +} SDL_AudioDeviceEvent; + + +/** + * \brief Touch finger event structure (event.tfinger.*) + */ +typedef struct SDL_TouchFingerEvent +{ + Uint32 type; /**< ::SDL_FINGERMOTION or ::SDL_FINGERDOWN or ::SDL_FINGERUP */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_TouchID touchId; /**< The touch device id */ + SDL_FingerID fingerId; + float x; /**< Normalized in the range 0...1 */ + float y; /**< Normalized in the range 0...1 */ + float dx; /**< Normalized in the range -1...1 */ + float dy; /**< Normalized in the range -1...1 */ + float pressure; /**< Normalized in the range 0...1 */ +} SDL_TouchFingerEvent; + + +/** + * \brief Multiple Finger Gesture Event (event.mgesture.*) + */ +typedef struct SDL_MultiGestureEvent +{ + Uint32 type; /**< ::SDL_MULTIGESTURE */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_TouchID touchId; /**< The touch device id */ + float dTheta; + float dDist; + float x; + float y; + Uint16 numFingers; + Uint16 padding; +} SDL_MultiGestureEvent; + + +/** + * \brief Dollar Gesture Event (event.dgesture.*) + */ +typedef struct SDL_DollarGestureEvent +{ + Uint32 type; /**< ::SDL_DOLLARGESTURE or ::SDL_DOLLARRECORD */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_TouchID touchId; /**< The touch device id */ + SDL_GestureID gestureId; + Uint32 numFingers; + float error; + float x; /**< Normalized center of gesture */ + float y; /**< Normalized center of gesture */ +} SDL_DollarGestureEvent; + + +/** + * \brief An event used to request a file open by the system (event.drop.*) + * This event is enabled by default, you can disable it with SDL_EventState(). + * \note If this event is enabled, you must free the filename in the event. + */ +typedef struct SDL_DropEvent +{ + Uint32 type; /**< ::SDL_DROPBEGIN or ::SDL_DROPFILE or ::SDL_DROPTEXT or ::SDL_DROPCOMPLETE */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + char *file; /**< The file name, which should be freed with SDL_free(), is NULL on begin/complete */ + Uint32 windowID; /**< The window that was dropped on, if any */ +} SDL_DropEvent; + + +/** + * \brief Sensor event structure (event.sensor.*) + */ +typedef struct SDL_SensorEvent +{ + Uint32 type; /**< ::SDL_SENSORUPDATE */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Sint32 which; /**< The instance ID of the sensor */ + float data[6]; /**< Up to 6 values from the sensor - additional values can be queried using SDL_SensorGetData() */ +} SDL_SensorEvent; + +/** + * \brief The "quit requested" event + */ +typedef struct SDL_QuitEvent +{ + Uint32 type; /**< ::SDL_QUIT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ +} SDL_QuitEvent; + +/** + * \brief OS Specific event + */ +typedef struct SDL_OSEvent +{ + Uint32 type; /**< ::SDL_QUIT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ +} SDL_OSEvent; + +/** + * \brief A user-defined event type (event.user.*) + */ +typedef struct SDL_UserEvent +{ + Uint32 type; /**< ::SDL_USEREVENT through ::SDL_LASTEVENT-1 */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + Uint32 windowID; /**< The associated window if any */ + Sint32 code; /**< User defined event code */ + void *data1; /**< User defined data pointer */ + void *data2; /**< User defined data pointer */ +} SDL_UserEvent; + + +struct SDL_SysWMmsg; +typedef struct SDL_SysWMmsg SDL_SysWMmsg; + +/** + * \brief A video driver dependent system event (event.syswm.*) + * This event is disabled by default, you can enable it with SDL_EventState() + * + * \note If you want to use this event, you should include SDL_syswm.h. + */ +typedef struct SDL_SysWMEvent +{ + Uint32 type; /**< ::SDL_SYSWMEVENT */ + Uint32 timestamp; /**< In milliseconds, populated using SDL_GetTicks() */ + SDL_SysWMmsg *msg; /**< driver dependent data, defined in SDL_syswm.h */ +} SDL_SysWMEvent; + +/** + * \brief General event structure + */ +typedef union SDL_Event +{ + Uint32 type; /**< Event type, shared with all events */ + SDL_CommonEvent common; /**< Common event data */ + SDL_DisplayEvent display; /**< Window event data */ + SDL_WindowEvent window; /**< Window event data */ + SDL_KeyboardEvent key; /**< Keyboard event data */ + SDL_TextEditingEvent edit; /**< Text editing event data */ + SDL_TextInputEvent text; /**< Text input event data */ + SDL_MouseMotionEvent motion; /**< Mouse motion event data */ + SDL_MouseButtonEvent button; /**< Mouse button event data */ + SDL_MouseWheelEvent wheel; /**< Mouse wheel event data */ + SDL_JoyAxisEvent jaxis; /**< Joystick axis event data */ + SDL_JoyBallEvent jball; /**< Joystick ball event data */ + SDL_JoyHatEvent jhat; /**< Joystick hat event data */ + SDL_JoyButtonEvent jbutton; /**< Joystick button event data */ + SDL_JoyDeviceEvent jdevice; /**< Joystick device change event data */ + SDL_ControllerAxisEvent caxis; /**< Game Controller axis event data */ + SDL_ControllerButtonEvent cbutton; /**< Game Controller button event data */ + SDL_ControllerDeviceEvent cdevice; /**< Game Controller device event data */ + SDL_AudioDeviceEvent adevice; /**< Audio device event data */ + SDL_SensorEvent sensor; /**< Sensor event data */ + SDL_QuitEvent quit; /**< Quit request event data */ + SDL_UserEvent user; /**< Custom event data */ + SDL_SysWMEvent syswm; /**< System dependent window event data */ + SDL_TouchFingerEvent tfinger; /**< Touch finger event data */ + SDL_MultiGestureEvent mgesture; /**< Gesture event data */ + SDL_DollarGestureEvent dgesture; /**< Gesture event data */ + SDL_DropEvent drop; /**< Drag and drop event data */ + + /* This is necessary for ABI compatibility between Visual C++ and GCC + Visual C++ will respect the push pack pragma and use 52 bytes for + this structure, and GCC will use the alignment of the largest datatype + within the union, which is 8 bytes. + + So... we'll add padding to force the size to be 56 bytes for both. + */ + Uint8 padding[56]; +} SDL_Event; + +/* Make sure we haven't broken binary compatibility */ +SDL_COMPILE_TIME_ASSERT(SDL_Event, sizeof(SDL_Event) == 56); + + +/* Function prototypes */ + +/** + * Pumps the event loop, gathering events from the input devices. + * + * This function updates the event queue and internal input device state. + * + * This should only be run in the thread that sets the video mode. + */ +extern DECLSPEC void SDLCALL SDL_PumpEvents(void); + +/* @{ */ +typedef enum +{ + SDL_ADDEVENT, + SDL_PEEKEVENT, + SDL_GETEVENT +} SDL_eventaction; + +/** + * Checks the event queue for messages and optionally returns them. + * + * If \c action is ::SDL_ADDEVENT, up to \c numevents events will be added to + * the back of the event queue. + * + * If \c action is ::SDL_PEEKEVENT, up to \c numevents events at the front + * of the event queue, within the specified minimum and maximum type, + * will be returned and will not be removed from the queue. + * + * If \c action is ::SDL_GETEVENT, up to \c numevents events at the front + * of the event queue, within the specified minimum and maximum type, + * will be returned and will be removed from the queue. + * + * \return The number of events actually stored, or -1 if there was an error. + * + * This function is thread-safe. + */ +extern DECLSPEC int SDLCALL SDL_PeepEvents(SDL_Event * events, int numevents, + SDL_eventaction action, + Uint32 minType, Uint32 maxType); +/* @} */ + +/** + * Checks to see if certain event types are in the event queue. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasEvent(Uint32 type); +extern DECLSPEC SDL_bool SDLCALL SDL_HasEvents(Uint32 minType, Uint32 maxType); + +/** + * This function clears events from the event queue + * This function only affects currently queued events. If you want to make + * sure that all pending OS events are flushed, you can call SDL_PumpEvents() + * on the main thread immediately before the flush call. + */ +extern DECLSPEC void SDLCALL SDL_FlushEvent(Uint32 type); +extern DECLSPEC void SDLCALL SDL_FlushEvents(Uint32 minType, Uint32 maxType); + +/** + * \brief Polls for currently pending events. + * + * \return 1 if there are any pending events, or 0 if there are none available. + * + * \param event If not NULL, the next event is removed from the queue and + * stored in that area. + */ +extern DECLSPEC int SDLCALL SDL_PollEvent(SDL_Event * event); + +/** + * \brief Waits indefinitely for the next available event. + * + * \return 1, or 0 if there was an error while waiting for events. + * + * \param event If not NULL, the next event is removed from the queue and + * stored in that area. + */ +extern DECLSPEC int SDLCALL SDL_WaitEvent(SDL_Event * event); + +/** + * \brief Waits until the specified timeout (in milliseconds) for the next + * available event. + * + * \return 1, or 0 if there was an error while waiting for events. + * + * \param event If not NULL, the next event is removed from the queue and + * stored in that area. + * \param timeout The timeout (in milliseconds) to wait for next event. + */ +extern DECLSPEC int SDLCALL SDL_WaitEventTimeout(SDL_Event * event, + int timeout); + +/** + * \brief Add an event to the event queue. + * + * \return 1 on success, 0 if the event was filtered, or -1 if the event queue + * was full or there was some other error. + */ +extern DECLSPEC int SDLCALL SDL_PushEvent(SDL_Event * event); + +typedef int (SDLCALL * SDL_EventFilter) (void *userdata, SDL_Event * event); + +/** + * Sets up a filter to process all events before they change internal state and + * are posted to the internal event queue. + * + * The filter is prototyped as: + * \code + * int SDL_EventFilter(void *userdata, SDL_Event * event); + * \endcode + * + * If the filter returns 1, then the event will be added to the internal queue. + * If it returns 0, then the event will be dropped from the queue, but the + * internal state will still be updated. This allows selective filtering of + * dynamically arriving events. + * + * \warning Be very careful of what you do in the event filter function, as + * it may run in a different thread! + * + * There is one caveat when dealing with the ::SDL_QuitEvent event type. The + * event filter is only called when the window manager desires to close the + * application window. If the event filter returns 1, then the window will + * be closed, otherwise the window will remain open if possible. + * + * If the quit event is generated by an interrupt signal, it will bypass the + * internal queue and be delivered to the application at the next event poll. + */ +extern DECLSPEC void SDLCALL SDL_SetEventFilter(SDL_EventFilter filter, + void *userdata); + +/** + * Return the current event filter - can be used to "chain" filters. + * If there is no event filter set, this function returns SDL_FALSE. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_GetEventFilter(SDL_EventFilter * filter, + void **userdata); + +/** + * Add a function which is called when an event is added to the queue. + */ +extern DECLSPEC void SDLCALL SDL_AddEventWatch(SDL_EventFilter filter, + void *userdata); + +/** + * Remove an event watch function added with SDL_AddEventWatch() + */ +extern DECLSPEC void SDLCALL SDL_DelEventWatch(SDL_EventFilter filter, + void *userdata); + +/** + * Run the filter function on the current event queue, removing any + * events for which the filter returns 0. + */ +extern DECLSPEC void SDLCALL SDL_FilterEvents(SDL_EventFilter filter, + void *userdata); + +/* @{ */ +#define SDL_QUERY -1 +#define SDL_IGNORE 0 +#define SDL_DISABLE 0 +#define SDL_ENABLE 1 + +/** + * This function allows you to set the state of processing certain events. + * - If \c state is set to ::SDL_IGNORE, that event will be automatically + * dropped from the event queue and will not be filtered. + * - If \c state is set to ::SDL_ENABLE, that event will be processed + * normally. + * - If \c state is set to ::SDL_QUERY, SDL_EventState() will return the + * current processing state of the specified event. + */ +extern DECLSPEC Uint8 SDLCALL SDL_EventState(Uint32 type, int state); +/* @} */ +#define SDL_GetEventState(type) SDL_EventState(type, SDL_QUERY) + +/** + * This function allocates a set of user-defined events, and returns + * the beginning event number for that set of events. + * + * If there aren't enough user-defined events left, this function + * returns (Uint32)-1 + */ +extern DECLSPEC Uint32 SDLCALL SDL_RegisterEvents(int numevents); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_events_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_filesystem.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_filesystem.h new file mode 100644 index 0000000..6d97e58 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_filesystem.h @@ -0,0 +1,136 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_filesystem.h + * + * \brief Include file for filesystem SDL API functions + */ + +#ifndef SDL_filesystem_h_ +#define SDL_filesystem_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" + +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Get the path where the application resides. + * + * Get the "base path". This is the directory where the application was run + * from, which is probably the installation directory, and may or may not + * be the process's current working directory. + * + * This returns an absolute path in UTF-8 encoding, and is guaranteed to + * end with a path separator ('\\' on Windows, '/' most other places). + * + * The pointer returned by this function is owned by you. Please call + * SDL_free() on the pointer when you are done with it, or it will be a + * memory leak. This is not necessarily a fast call, though, so you should + * call this once near startup and save the string if you need it. + * + * Some platforms can't determine the application's path, and on other + * platforms, this might be meaningless. In such cases, this function will + * return NULL. + * + * \return String of base dir in UTF-8 encoding, or NULL on error. + * + * \sa SDL_GetPrefPath + */ +extern DECLSPEC char *SDLCALL SDL_GetBasePath(void); + +/** + * \brief Get the user-and-app-specific path where files can be written. + * + * Get the "pref dir". This is meant to be where users can write personal + * files (preferences and save games, etc) that are specific to your + * application. This directory is unique per user, per application. + * + * This function will decide the appropriate location in the native filesystem, + * create the directory if necessary, and return a string of the absolute + * path to the directory in UTF-8 encoding. + * + * On Windows, the string might look like: + * "C:\\Users\\bob\\AppData\\Roaming\\My Company\\My Program Name\\" + * + * On Linux, the string might look like: + * "/home/bob/.local/share/My Program Name/" + * + * On Mac OS X, the string might look like: + * "/Users/bob/Library/Application Support/My Program Name/" + * + * (etc.) + * + * You specify the name of your organization (if it's not a real organization, + * your name or an Internet domain you own might do) and the name of your + * application. These should be untranslated proper names. + * + * Both the org and app strings may become part of a directory name, so + * please follow these rules: + * + * - Try to use the same org string (including case-sensitivity) for + * all your applications that use this function. + * - Always use a unique app string for each one, and make sure it never + * changes for an app once you've decided on it. + * - Unicode characters are legal, as long as it's UTF-8 encoded, but... + * - ...only use letters, numbers, and spaces. Avoid punctuation like + * "Game Name 2: Bad Guy's Revenge!" ... "Game Name 2" is sufficient. + * + * This returns an absolute path in UTF-8 encoding, and is guaranteed to + * end with a path separator ('\\' on Windows, '/' most other places). + * + * The pointer returned by this function is owned by you. Please call + * SDL_free() on the pointer when you are done with it, or it will be a + * memory leak. This is not necessarily a fast call, though, so you should + * call this once near startup and save the string if you need it. + * + * You should assume the path returned by this function is the only safe + * place to write files (and that SDL_GetBasePath(), while it might be + * writable, or even the parent of the returned path, aren't where you + * should be writing things). + * + * Some platforms can't determine the pref path, and on other + * platforms, this might be meaningless. In such cases, this function will + * return NULL. + * + * \param org The name of your organization. + * \param app The name of your application. + * \return UTF-8 string of user dir in platform-dependent notation. NULL + * if there's a problem (creating directory failed, etc). + * + * \sa SDL_GetBasePath + */ +extern DECLSPEC char *SDLCALL SDL_GetPrefPath(const char *org, const char *app); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_filesystem_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gamecontroller.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gamecontroller.h new file mode 100644 index 0000000..ebde387 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gamecontroller.h @@ -0,0 +1,390 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_gamecontroller.h + * + * Include file for SDL game controller event handling + */ + +#ifndef SDL_gamecontroller_h_ +#define SDL_gamecontroller_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_rwops.h" +#include "SDL_joystick.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \file SDL_gamecontroller.h + * + * In order to use these functions, SDL_Init() must have been called + * with the ::SDL_INIT_GAMECONTROLLER flag. This causes SDL to scan the system + * for game controllers, and load appropriate drivers. + * + * If you would like to receive controller updates while the application + * is in the background, you should set the following hint before calling + * SDL_Init(): SDL_HINT_JOYSTICK_ALLOW_BACKGROUND_EVENTS + */ + +/** + * The gamecontroller structure used to identify an SDL game controller + */ +struct _SDL_GameController; +typedef struct _SDL_GameController SDL_GameController; + + +typedef enum +{ + SDL_CONTROLLER_BINDTYPE_NONE = 0, + SDL_CONTROLLER_BINDTYPE_BUTTON, + SDL_CONTROLLER_BINDTYPE_AXIS, + SDL_CONTROLLER_BINDTYPE_HAT +} SDL_GameControllerBindType; + +/** + * Get the SDL joystick layer binding for this controller button/axis mapping + */ +typedef struct SDL_GameControllerButtonBind +{ + SDL_GameControllerBindType bindType; + union + { + int button; + int axis; + struct { + int hat; + int hat_mask; + } hat; + } value; + +} SDL_GameControllerButtonBind; + + +/** + * To count the number of game controllers in the system for the following: + * int nJoysticks = SDL_NumJoysticks(); + * int nGameControllers = 0; + * for (int i = 0; i < nJoysticks; i++) { + * if (SDL_IsGameController(i)) { + * nGameControllers++; + * } + * } + * + * Using the SDL_HINT_GAMECONTROLLERCONFIG hint or the SDL_GameControllerAddMapping() you can add support for controllers SDL is unaware of or cause an existing controller to have a different binding. The format is: + * guid,name,mappings + * + * Where GUID is the string value from SDL_JoystickGetGUIDString(), name is the human readable string for the device and mappings are controller mappings to joystick ones. + * Under Windows there is a reserved GUID of "xinput" that covers any XInput devices. + * The mapping format for joystick is: + * bX - a joystick button, index X + * hX.Y - hat X with value Y + * aX - axis X of the joystick + * Buttons can be used as a controller axis and vice versa. + * + * This string shows an example of a valid mapping for a controller + * "03000000341a00003608000000000000,PS3 Controller,a:b1,b:b2,y:b3,x:b0,start:b9,guide:b12,back:b8,dpup:h0.1,dpleft:h0.8,dpdown:h0.4,dpright:h0.2,leftshoulder:b4,rightshoulder:b5,leftstick:b10,rightstick:b11,leftx:a0,lefty:a1,rightx:a2,righty:a3,lefttrigger:b6,righttrigger:b7", + * + */ + +/** + * Load a set of mappings from a seekable SDL data stream (memory or file), filtered by the current SDL_GetPlatform() + * A community sourced database of controllers is available at https://raw.github.com/gabomdq/SDL_GameControllerDB/master/gamecontrollerdb.txt + * + * If \c freerw is non-zero, the stream will be closed after being read. + * + * \return number of mappings added, -1 on error + */ +extern DECLSPEC int SDLCALL SDL_GameControllerAddMappingsFromRW(SDL_RWops * rw, int freerw); + +/** + * Load a set of mappings from a file, filtered by the current SDL_GetPlatform() + * + * Convenience macro. + */ +#define SDL_GameControllerAddMappingsFromFile(file) SDL_GameControllerAddMappingsFromRW(SDL_RWFromFile(file, "rb"), 1) + +/** + * Add or update an existing mapping configuration + * + * \return 1 if mapping is added, 0 if updated, -1 on error + */ +extern DECLSPEC int SDLCALL SDL_GameControllerAddMapping(const char* mappingString); + +/** + * Get the number of mappings installed + * + * \return the number of mappings + */ +extern DECLSPEC int SDLCALL SDL_GameControllerNumMappings(void); + +/** + * Get the mapping at a particular index. + * + * \return the mapping string. Must be freed with SDL_free(). Returns NULL if the index is out of range. + */ +extern DECLSPEC char * SDLCALL SDL_GameControllerMappingForIndex(int mapping_index); + +/** + * Get a mapping string for a GUID + * + * \return the mapping string. Must be freed with SDL_free(). Returns NULL if no mapping is available + */ +extern DECLSPEC char * SDLCALL SDL_GameControllerMappingForGUID(SDL_JoystickGUID guid); + +/** + * Get a mapping string for an open GameController + * + * \return the mapping string. Must be freed with SDL_free(). Returns NULL if no mapping is available + */ +extern DECLSPEC char * SDLCALL SDL_GameControllerMapping(SDL_GameController * gamecontroller); + +/** + * Is the joystick on this index supported by the game controller interface? + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsGameController(int joystick_index); + +/** + * Get the implementation dependent name of a game controller. + * This can be called before any controllers are opened. + * If no name can be found, this function returns NULL. + */ +extern DECLSPEC const char *SDLCALL SDL_GameControllerNameForIndex(int joystick_index); + +/** + * Get the mapping of a game controller. + * This can be called before any controllers are opened. + * + * \return the mapping string. Must be freed with SDL_free(). Returns NULL if no mapping is available + */ +extern DECLSPEC char *SDLCALL SDL_GameControllerMappingForDeviceIndex(int joystick_index); + +/** + * Open a game controller for use. + * The index passed as an argument refers to the N'th game controller on the system. + * This index is not the value which will identify this controller in future + * controller events. The joystick's instance id (::SDL_JoystickID) will be + * used there instead. + * + * \return A controller identifier, or NULL if an error occurred. + */ +extern DECLSPEC SDL_GameController *SDLCALL SDL_GameControllerOpen(int joystick_index); + +/** + * Return the SDL_GameController associated with an instance id. + */ +extern DECLSPEC SDL_GameController *SDLCALL SDL_GameControllerFromInstanceID(SDL_JoystickID joyid); + +/** + * Return the name for this currently opened controller + */ +extern DECLSPEC const char *SDLCALL SDL_GameControllerName(SDL_GameController *gamecontroller); + +/** + * Get the player index of an opened game controller, or -1 if it's not available + * + * For XInput controllers this returns the XInput user index. + */ +extern DECLSPEC int SDLCALL SDL_GameControllerGetPlayerIndex(SDL_GameController *gamecontroller); + +/** + * Get the USB vendor ID of an opened controller, if available. + * If the vendor ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_GameControllerGetVendor(SDL_GameController * gamecontroller); + +/** + * Get the USB product ID of an opened controller, if available. + * If the product ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_GameControllerGetProduct(SDL_GameController * gamecontroller); + +/** + * Get the product version of an opened controller, if available. + * If the product version isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_GameControllerGetProductVersion(SDL_GameController * gamecontroller); + +/** + * Returns SDL_TRUE if the controller has been opened and currently connected, + * or SDL_FALSE if it has not. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_GameControllerGetAttached(SDL_GameController *gamecontroller); + +/** + * Get the underlying joystick object used by a controller + */ +extern DECLSPEC SDL_Joystick *SDLCALL SDL_GameControllerGetJoystick(SDL_GameController *gamecontroller); + +/** + * Enable/disable controller event polling. + * + * If controller events are disabled, you must call SDL_GameControllerUpdate() + * yourself and check the state of the controller when you want controller + * information. + * + * The state can be one of ::SDL_QUERY, ::SDL_ENABLE or ::SDL_IGNORE. + */ +extern DECLSPEC int SDLCALL SDL_GameControllerEventState(int state); + +/** + * Update the current state of the open game controllers. + * + * This is called automatically by the event loop if any game controller + * events are enabled. + */ +extern DECLSPEC void SDLCALL SDL_GameControllerUpdate(void); + + +/** + * The list of axes available from a controller + * + * Thumbstick axis values range from SDL_JOYSTICK_AXIS_MIN to SDL_JOYSTICK_AXIS_MAX, + * and are centered within ~8000 of zero, though advanced UI will allow users to set + * or autodetect the dead zone, which varies between controllers. + * + * Trigger axis values range from 0 to SDL_JOYSTICK_AXIS_MAX. + */ +typedef enum +{ + SDL_CONTROLLER_AXIS_INVALID = -1, + SDL_CONTROLLER_AXIS_LEFTX, + SDL_CONTROLLER_AXIS_LEFTY, + SDL_CONTROLLER_AXIS_RIGHTX, + SDL_CONTROLLER_AXIS_RIGHTY, + SDL_CONTROLLER_AXIS_TRIGGERLEFT, + SDL_CONTROLLER_AXIS_TRIGGERRIGHT, + SDL_CONTROLLER_AXIS_MAX +} SDL_GameControllerAxis; + +/** + * turn this string into a axis mapping + */ +extern DECLSPEC SDL_GameControllerAxis SDLCALL SDL_GameControllerGetAxisFromString(const char *pchString); + +/** + * turn this axis enum into a string mapping + */ +extern DECLSPEC const char* SDLCALL SDL_GameControllerGetStringForAxis(SDL_GameControllerAxis axis); + +/** + * Get the SDL joystick layer binding for this controller button mapping + */ +extern DECLSPEC SDL_GameControllerButtonBind SDLCALL +SDL_GameControllerGetBindForAxis(SDL_GameController *gamecontroller, + SDL_GameControllerAxis axis); + +/** + * Get the current state of an axis control on a game controller. + * + * The state is a value ranging from -32768 to 32767 (except for the triggers, + * which range from 0 to 32767). + * + * The axis indices start at index 0. + */ +extern DECLSPEC Sint16 SDLCALL +SDL_GameControllerGetAxis(SDL_GameController *gamecontroller, + SDL_GameControllerAxis axis); + +/** + * The list of buttons available from a controller + */ +typedef enum +{ + SDL_CONTROLLER_BUTTON_INVALID = -1, + SDL_CONTROLLER_BUTTON_A, + SDL_CONTROLLER_BUTTON_B, + SDL_CONTROLLER_BUTTON_X, + SDL_CONTROLLER_BUTTON_Y, + SDL_CONTROLLER_BUTTON_BACK, + SDL_CONTROLLER_BUTTON_GUIDE, + SDL_CONTROLLER_BUTTON_START, + SDL_CONTROLLER_BUTTON_LEFTSTICK, + SDL_CONTROLLER_BUTTON_RIGHTSTICK, + SDL_CONTROLLER_BUTTON_LEFTSHOULDER, + SDL_CONTROLLER_BUTTON_RIGHTSHOULDER, + SDL_CONTROLLER_BUTTON_DPAD_UP, + SDL_CONTROLLER_BUTTON_DPAD_DOWN, + SDL_CONTROLLER_BUTTON_DPAD_LEFT, + SDL_CONTROLLER_BUTTON_DPAD_RIGHT, + SDL_CONTROLLER_BUTTON_MAX +} SDL_GameControllerButton; + +/** + * turn this string into a button mapping + */ +extern DECLSPEC SDL_GameControllerButton SDLCALL SDL_GameControllerGetButtonFromString(const char *pchString); + +/** + * turn this button enum into a string mapping + */ +extern DECLSPEC const char* SDLCALL SDL_GameControllerGetStringForButton(SDL_GameControllerButton button); + +/** + * Get the SDL joystick layer binding for this controller button mapping + */ +extern DECLSPEC SDL_GameControllerButtonBind SDLCALL +SDL_GameControllerGetBindForButton(SDL_GameController *gamecontroller, + SDL_GameControllerButton button); + + +/** + * Get the current state of a button on a game controller. + * + * The button indices start at index 0. + */ +extern DECLSPEC Uint8 SDLCALL SDL_GameControllerGetButton(SDL_GameController *gamecontroller, + SDL_GameControllerButton button); + +/** + * Trigger a rumble effect + * Each call to this function cancels any previous rumble effect, and calling it with 0 intensity stops any rumbling. + * + * \param gamecontroller The controller to vibrate + * \param low_frequency_rumble The intensity of the low frequency (left) rumble motor, from 0 to 0xFFFF + * \param high_frequency_rumble The intensity of the high frequency (right) rumble motor, from 0 to 0xFFFF + * \param duration_ms The duration of the rumble effect, in milliseconds + * + * \return 0, or -1 if rumble isn't supported on this joystick + */ +extern DECLSPEC int SDLCALL SDL_GameControllerRumble(SDL_GameController *gamecontroller, Uint16 low_frequency_rumble, Uint16 high_frequency_rumble, Uint32 duration_ms); + +/** + * Close a controller previously opened with SDL_GameControllerOpen(). + */ +extern DECLSPEC void SDLCALL SDL_GameControllerClose(SDL_GameController *gamecontroller); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_gamecontroller_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gesture.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gesture.h new file mode 100644 index 0000000..9d25e9c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_gesture.h @@ -0,0 +1,87 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_gesture.h + * + * Include file for SDL gesture event handling. + */ + +#ifndef SDL_gesture_h_ +#define SDL_gesture_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" + +#include "SDL_touch.h" + + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +typedef Sint64 SDL_GestureID; + +/* Function prototypes */ + +/** + * \brief Begin Recording a gesture on the specified touch, or all touches (-1) + * + * + */ +extern DECLSPEC int SDLCALL SDL_RecordGesture(SDL_TouchID touchId); + + +/** + * \brief Save all currently loaded Dollar Gesture templates + * + * + */ +extern DECLSPEC int SDLCALL SDL_SaveAllDollarTemplates(SDL_RWops *dst); + +/** + * \brief Save a currently loaded Dollar Gesture template + * + * + */ +extern DECLSPEC int SDLCALL SDL_SaveDollarTemplate(SDL_GestureID gestureId,SDL_RWops *dst); + + +/** + * \brief Load Dollar Gesture templates from a file + * + * + */ +extern DECLSPEC int SDLCALL SDL_LoadDollarTemplates(SDL_TouchID touchId, SDL_RWops *src); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_gesture_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_haptic.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_haptic.h new file mode 100644 index 0000000..0756276 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_haptic.h @@ -0,0 +1,1238 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_haptic.h + * + * \brief The SDL haptic subsystem allows you to control haptic (force feedback) + * devices. + * + * The basic usage is as follows: + * - Initialize the subsystem (::SDL_INIT_HAPTIC). + * - Open a haptic device. + * - SDL_HapticOpen() to open from index. + * - SDL_HapticOpenFromJoystick() to open from an existing joystick. + * - Create an effect (::SDL_HapticEffect). + * - Upload the effect with SDL_HapticNewEffect(). + * - Run the effect with SDL_HapticRunEffect(). + * - (optional) Free the effect with SDL_HapticDestroyEffect(). + * - Close the haptic device with SDL_HapticClose(). + * + * \par Simple rumble example: + * \code + * SDL_Haptic *haptic; + * + * // Open the device + * haptic = SDL_HapticOpen( 0 ); + * if (haptic == NULL) + * return -1; + * + * // Initialize simple rumble + * if (SDL_HapticRumbleInit( haptic ) != 0) + * return -1; + * + * // Play effect at 50% strength for 2 seconds + * if (SDL_HapticRumblePlay( haptic, 0.5, 2000 ) != 0) + * return -1; + * SDL_Delay( 2000 ); + * + * // Clean up + * SDL_HapticClose( haptic ); + * \endcode + * + * \par Complete example: + * \code + * int test_haptic( SDL_Joystick * joystick ) { + * SDL_Haptic *haptic; + * SDL_HapticEffect effect; + * int effect_id; + * + * // Open the device + * haptic = SDL_HapticOpenFromJoystick( joystick ); + * if (haptic == NULL) return -1; // Most likely joystick isn't haptic + * + * // See if it can do sine waves + * if ((SDL_HapticQuery(haptic) & SDL_HAPTIC_SINE)==0) { + * SDL_HapticClose(haptic); // No sine effect + * return -1; + * } + * + * // Create the effect + * memset( &effect, 0, sizeof(SDL_HapticEffect) ); // 0 is safe default + * effect.type = SDL_HAPTIC_SINE; + * effect.periodic.direction.type = SDL_HAPTIC_POLAR; // Polar coordinates + * effect.periodic.direction.dir[0] = 18000; // Force comes from south + * effect.periodic.period = 1000; // 1000 ms + * effect.periodic.magnitude = 20000; // 20000/32767 strength + * effect.periodic.length = 5000; // 5 seconds long + * effect.periodic.attack_length = 1000; // Takes 1 second to get max strength + * effect.periodic.fade_length = 1000; // Takes 1 second to fade away + * + * // Upload the effect + * effect_id = SDL_HapticNewEffect( haptic, &effect ); + * + * // Test the effect + * SDL_HapticRunEffect( haptic, effect_id, 1 ); + * SDL_Delay( 5000); // Wait for the effect to finish + * + * // We destroy the effect, although closing the device also does this + * SDL_HapticDestroyEffect( haptic, effect_id ); + * + * // Close the device + * SDL_HapticClose(haptic); + * + * return 0; // Success + * } + * \endcode + */ + +#ifndef SDL_haptic_h_ +#define SDL_haptic_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_joystick.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif /* __cplusplus */ + +/* FIXME: For SDL 2.1, adjust all the magnitude variables to be Uint16 (0xFFFF). + * + * At the moment the magnitude variables are mixed between signed/unsigned, and + * it is also not made clear that ALL of those variables expect a max of 0x7FFF. + * + * Some platforms may have higher precision than that (Linux FF, Windows XInput) + * so we should fix the inconsistency in favor of higher possible precision, + * adjusting for platforms that use different scales. + * -flibit + */ + +/** + * \typedef SDL_Haptic + * + * \brief The haptic structure used to identify an SDL haptic. + * + * \sa SDL_HapticOpen + * \sa SDL_HapticOpenFromJoystick + * \sa SDL_HapticClose + */ +struct _SDL_Haptic; +typedef struct _SDL_Haptic SDL_Haptic; + + +/** + * \name Haptic features + * + * Different haptic features a device can have. + */ +/* @{ */ + +/** + * \name Haptic effects + */ +/* @{ */ + +/** + * \brief Constant effect supported. + * + * Constant haptic effect. + * + * \sa SDL_HapticCondition + */ +#define SDL_HAPTIC_CONSTANT (1u<<0) + +/** + * \brief Sine wave effect supported. + * + * Periodic haptic effect that simulates sine waves. + * + * \sa SDL_HapticPeriodic + */ +#define SDL_HAPTIC_SINE (1u<<1) + +/** + * \brief Left/Right effect supported. + * + * Haptic effect for direct control over high/low frequency motors. + * + * \sa SDL_HapticLeftRight + * \warning this value was SDL_HAPTIC_SQUARE right before 2.0.0 shipped. Sorry, + * we ran out of bits, and this is important for XInput devices. + */ +#define SDL_HAPTIC_LEFTRIGHT (1u<<2) + +/* !!! FIXME: put this back when we have more bits in 2.1 */ +/* #define SDL_HAPTIC_SQUARE (1<<2) */ + +/** + * \brief Triangle wave effect supported. + * + * Periodic haptic effect that simulates triangular waves. + * + * \sa SDL_HapticPeriodic + */ +#define SDL_HAPTIC_TRIANGLE (1u<<3) + +/** + * \brief Sawtoothup wave effect supported. + * + * Periodic haptic effect that simulates saw tooth up waves. + * + * \sa SDL_HapticPeriodic + */ +#define SDL_HAPTIC_SAWTOOTHUP (1u<<4) + +/** + * \brief Sawtoothdown wave effect supported. + * + * Periodic haptic effect that simulates saw tooth down waves. + * + * \sa SDL_HapticPeriodic + */ +#define SDL_HAPTIC_SAWTOOTHDOWN (1u<<5) + +/** + * \brief Ramp effect supported. + * + * Ramp haptic effect. + * + * \sa SDL_HapticRamp + */ +#define SDL_HAPTIC_RAMP (1u<<6) + +/** + * \brief Spring effect supported - uses axes position. + * + * Condition haptic effect that simulates a spring. Effect is based on the + * axes position. + * + * \sa SDL_HapticCondition + */ +#define SDL_HAPTIC_SPRING (1u<<7) + +/** + * \brief Damper effect supported - uses axes velocity. + * + * Condition haptic effect that simulates dampening. Effect is based on the + * axes velocity. + * + * \sa SDL_HapticCondition + */ +#define SDL_HAPTIC_DAMPER (1u<<8) + +/** + * \brief Inertia effect supported - uses axes acceleration. + * + * Condition haptic effect that simulates inertia. Effect is based on the axes + * acceleration. + * + * \sa SDL_HapticCondition + */ +#define SDL_HAPTIC_INERTIA (1u<<9) + +/** + * \brief Friction effect supported - uses axes movement. + * + * Condition haptic effect that simulates friction. Effect is based on the + * axes movement. + * + * \sa SDL_HapticCondition + */ +#define SDL_HAPTIC_FRICTION (1u<<10) + +/** + * \brief Custom effect is supported. + * + * User defined custom haptic effect. + */ +#define SDL_HAPTIC_CUSTOM (1u<<11) + +/* @} *//* Haptic effects */ + +/* These last few are features the device has, not effects */ + +/** + * \brief Device can set global gain. + * + * Device supports setting the global gain. + * + * \sa SDL_HapticSetGain + */ +#define SDL_HAPTIC_GAIN (1u<<12) + +/** + * \brief Device can set autocenter. + * + * Device supports setting autocenter. + * + * \sa SDL_HapticSetAutocenter + */ +#define SDL_HAPTIC_AUTOCENTER (1u<<13) + +/** + * \brief Device can be queried for effect status. + * + * Device supports querying effect status. + * + * \sa SDL_HapticGetEffectStatus + */ +#define SDL_HAPTIC_STATUS (1u<<14) + +/** + * \brief Device can be paused. + * + * Devices supports being paused. + * + * \sa SDL_HapticPause + * \sa SDL_HapticUnpause + */ +#define SDL_HAPTIC_PAUSE (1u<<15) + + +/** + * \name Direction encodings + */ +/* @{ */ + +/** + * \brief Uses polar coordinates for the direction. + * + * \sa SDL_HapticDirection + */ +#define SDL_HAPTIC_POLAR 0 + +/** + * \brief Uses cartesian coordinates for the direction. + * + * \sa SDL_HapticDirection + */ +#define SDL_HAPTIC_CARTESIAN 1 + +/** + * \brief Uses spherical coordinates for the direction. + * + * \sa SDL_HapticDirection + */ +#define SDL_HAPTIC_SPHERICAL 2 + +/* @} *//* Direction encodings */ + +/* @} *//* Haptic features */ + +/* + * Misc defines. + */ + +/** + * \brief Used to play a device an infinite number of times. + * + * \sa SDL_HapticRunEffect + */ +#define SDL_HAPTIC_INFINITY 4294967295U + + +/** + * \brief Structure that represents a haptic direction. + * + * This is the direction where the force comes from, + * instead of the direction in which the force is exerted. + * + * Directions can be specified by: + * - ::SDL_HAPTIC_POLAR : Specified by polar coordinates. + * - ::SDL_HAPTIC_CARTESIAN : Specified by cartesian coordinates. + * - ::SDL_HAPTIC_SPHERICAL : Specified by spherical coordinates. + * + * Cardinal directions of the haptic device are relative to the positioning + * of the device. North is considered to be away from the user. + * + * The following diagram represents the cardinal directions: + * \verbatim + .--. + |__| .-------. + |=.| |.-----.| + |--| || || + | | |'-----'| + |__|~')_____(' + [ COMPUTER ] + + + North (0,-1) + ^ + | + | + (-1,0) West <----[ HAPTIC ]----> East (1,0) + | + | + v + South (0,1) + + + [ USER ] + \|||/ + (o o) + ---ooO-(_)-Ooo--- + \endverbatim + * + * If type is ::SDL_HAPTIC_POLAR, direction is encoded by hundredths of a + * degree starting north and turning clockwise. ::SDL_HAPTIC_POLAR only uses + * the first \c dir parameter. The cardinal directions would be: + * - North: 0 (0 degrees) + * - East: 9000 (90 degrees) + * - South: 18000 (180 degrees) + * - West: 27000 (270 degrees) + * + * If type is ::SDL_HAPTIC_CARTESIAN, direction is encoded by three positions + * (X axis, Y axis and Z axis (with 3 axes)). ::SDL_HAPTIC_CARTESIAN uses + * the first three \c dir parameters. The cardinal directions would be: + * - North: 0,-1, 0 + * - East: 1, 0, 0 + * - South: 0, 1, 0 + * - West: -1, 0, 0 + * + * The Z axis represents the height of the effect if supported, otherwise + * it's unused. In cartesian encoding (1, 2) would be the same as (2, 4), you + * can use any multiple you want, only the direction matters. + * + * If type is ::SDL_HAPTIC_SPHERICAL, direction is encoded by two rotations. + * The first two \c dir parameters are used. The \c dir parameters are as + * follows (all values are in hundredths of degrees): + * - Degrees from (1, 0) rotated towards (0, 1). + * - Degrees towards (0, 0, 1) (device needs at least 3 axes). + * + * + * Example of force coming from the south with all encodings (force coming + * from the south means the user will have to pull the stick to counteract): + * \code + * SDL_HapticDirection direction; + * + * // Cartesian directions + * direction.type = SDL_HAPTIC_CARTESIAN; // Using cartesian direction encoding. + * direction.dir[0] = 0; // X position + * direction.dir[1] = 1; // Y position + * // Assuming the device has 2 axes, we don't need to specify third parameter. + * + * // Polar directions + * direction.type = SDL_HAPTIC_POLAR; // We'll be using polar direction encoding. + * direction.dir[0] = 18000; // Polar only uses first parameter + * + * // Spherical coordinates + * direction.type = SDL_HAPTIC_SPHERICAL; // Spherical encoding + * direction.dir[0] = 9000; // Since we only have two axes we don't need more parameters. + * \endcode + * + * \sa SDL_HAPTIC_POLAR + * \sa SDL_HAPTIC_CARTESIAN + * \sa SDL_HAPTIC_SPHERICAL + * \sa SDL_HapticEffect + * \sa SDL_HapticNumAxes + */ +typedef struct SDL_HapticDirection +{ + Uint8 type; /**< The type of encoding. */ + Sint32 dir[3]; /**< The encoded direction. */ +} SDL_HapticDirection; + + +/** + * \brief A structure containing a template for a Constant effect. + * + * This struct is exclusively for the ::SDL_HAPTIC_CONSTANT effect. + * + * A constant effect applies a constant force in the specified direction + * to the joystick. + * + * \sa SDL_HAPTIC_CONSTANT + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticConstant +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_CONSTANT */ + SDL_HapticDirection direction; /**< Direction of the effect. */ + + /* Replay */ + Uint32 length; /**< Duration of the effect. */ + Uint16 delay; /**< Delay before starting the effect. */ + + /* Trigger */ + Uint16 button; /**< Button that triggers the effect. */ + Uint16 interval; /**< How soon it can be triggered again after button. */ + + /* Constant */ + Sint16 level; /**< Strength of the constant effect. */ + + /* Envelope */ + Uint16 attack_length; /**< Duration of the attack. */ + Uint16 attack_level; /**< Level at the start of the attack. */ + Uint16 fade_length; /**< Duration of the fade. */ + Uint16 fade_level; /**< Level at the end of the fade. */ +} SDL_HapticConstant; + +/** + * \brief A structure containing a template for a Periodic effect. + * + * The struct handles the following effects: + * - ::SDL_HAPTIC_SINE + * - ::SDL_HAPTIC_LEFTRIGHT + * - ::SDL_HAPTIC_TRIANGLE + * - ::SDL_HAPTIC_SAWTOOTHUP + * - ::SDL_HAPTIC_SAWTOOTHDOWN + * + * A periodic effect consists in a wave-shaped effect that repeats itself + * over time. The type determines the shape of the wave and the parameters + * determine the dimensions of the wave. + * + * Phase is given by hundredth of a degree meaning that giving the phase a value + * of 9000 will displace it 25% of its period. Here are sample values: + * - 0: No phase displacement. + * - 9000: Displaced 25% of its period. + * - 18000: Displaced 50% of its period. + * - 27000: Displaced 75% of its period. + * - 36000: Displaced 100% of its period, same as 0, but 0 is preferred. + * + * Examples: + * \verbatim + SDL_HAPTIC_SINE + __ __ __ __ + / \ / \ / \ / + / \__/ \__/ \__/ + + SDL_HAPTIC_SQUARE + __ __ __ __ __ + | | | | | | | | | | + | |__| |__| |__| |__| | + + SDL_HAPTIC_TRIANGLE + /\ /\ /\ /\ /\ + / \ / \ / \ / \ / + / \/ \/ \/ \/ + + SDL_HAPTIC_SAWTOOTHUP + /| /| /| /| /| /| /| + / | / | / | / | / | / | / | + / |/ |/ |/ |/ |/ |/ | + + SDL_HAPTIC_SAWTOOTHDOWN + \ |\ |\ |\ |\ |\ |\ | + \ | \ | \ | \ | \ | \ | \ | + \| \| \| \| \| \| \| + \endverbatim + * + * \sa SDL_HAPTIC_SINE + * \sa SDL_HAPTIC_LEFTRIGHT + * \sa SDL_HAPTIC_TRIANGLE + * \sa SDL_HAPTIC_SAWTOOTHUP + * \sa SDL_HAPTIC_SAWTOOTHDOWN + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticPeriodic +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_SINE, ::SDL_HAPTIC_LEFTRIGHT, + ::SDL_HAPTIC_TRIANGLE, ::SDL_HAPTIC_SAWTOOTHUP or + ::SDL_HAPTIC_SAWTOOTHDOWN */ + SDL_HapticDirection direction; /**< Direction of the effect. */ + + /* Replay */ + Uint32 length; /**< Duration of the effect. */ + Uint16 delay; /**< Delay before starting the effect. */ + + /* Trigger */ + Uint16 button; /**< Button that triggers the effect. */ + Uint16 interval; /**< How soon it can be triggered again after button. */ + + /* Periodic */ + Uint16 period; /**< Period of the wave. */ + Sint16 magnitude; /**< Peak value; if negative, equivalent to 180 degrees extra phase shift. */ + Sint16 offset; /**< Mean value of the wave. */ + Uint16 phase; /**< Positive phase shift given by hundredth of a degree. */ + + /* Envelope */ + Uint16 attack_length; /**< Duration of the attack. */ + Uint16 attack_level; /**< Level at the start of the attack. */ + Uint16 fade_length; /**< Duration of the fade. */ + Uint16 fade_level; /**< Level at the end of the fade. */ +} SDL_HapticPeriodic; + +/** + * \brief A structure containing a template for a Condition effect. + * + * The struct handles the following effects: + * - ::SDL_HAPTIC_SPRING: Effect based on axes position. + * - ::SDL_HAPTIC_DAMPER: Effect based on axes velocity. + * - ::SDL_HAPTIC_INERTIA: Effect based on axes acceleration. + * - ::SDL_HAPTIC_FRICTION: Effect based on axes movement. + * + * Direction is handled by condition internals instead of a direction member. + * The condition effect specific members have three parameters. The first + * refers to the X axis, the second refers to the Y axis and the third + * refers to the Z axis. The right terms refer to the positive side of the + * axis and the left terms refer to the negative side of the axis. Please + * refer to the ::SDL_HapticDirection diagram for which side is positive and + * which is negative. + * + * \sa SDL_HapticDirection + * \sa SDL_HAPTIC_SPRING + * \sa SDL_HAPTIC_DAMPER + * \sa SDL_HAPTIC_INERTIA + * \sa SDL_HAPTIC_FRICTION + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticCondition +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_SPRING, ::SDL_HAPTIC_DAMPER, + ::SDL_HAPTIC_INERTIA or ::SDL_HAPTIC_FRICTION */ + SDL_HapticDirection direction; /**< Direction of the effect - Not used ATM. */ + + /* Replay */ + Uint32 length; /**< Duration of the effect. */ + Uint16 delay; /**< Delay before starting the effect. */ + + /* Trigger */ + Uint16 button; /**< Button that triggers the effect. */ + Uint16 interval; /**< How soon it can be triggered again after button. */ + + /* Condition */ + Uint16 right_sat[3]; /**< Level when joystick is to the positive side; max 0xFFFF. */ + Uint16 left_sat[3]; /**< Level when joystick is to the negative side; max 0xFFFF. */ + Sint16 right_coeff[3]; /**< How fast to increase the force towards the positive side. */ + Sint16 left_coeff[3]; /**< How fast to increase the force towards the negative side. */ + Uint16 deadband[3]; /**< Size of the dead zone; max 0xFFFF: whole axis-range when 0-centered. */ + Sint16 center[3]; /**< Position of the dead zone. */ +} SDL_HapticCondition; + +/** + * \brief A structure containing a template for a Ramp effect. + * + * This struct is exclusively for the ::SDL_HAPTIC_RAMP effect. + * + * The ramp effect starts at start strength and ends at end strength. + * It augments in linear fashion. If you use attack and fade with a ramp + * the effects get added to the ramp effect making the effect become + * quadratic instead of linear. + * + * \sa SDL_HAPTIC_RAMP + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticRamp +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_RAMP */ + SDL_HapticDirection direction; /**< Direction of the effect. */ + + /* Replay */ + Uint32 length; /**< Duration of the effect. */ + Uint16 delay; /**< Delay before starting the effect. */ + + /* Trigger */ + Uint16 button; /**< Button that triggers the effect. */ + Uint16 interval; /**< How soon it can be triggered again after button. */ + + /* Ramp */ + Sint16 start; /**< Beginning strength level. */ + Sint16 end; /**< Ending strength level. */ + + /* Envelope */ + Uint16 attack_length; /**< Duration of the attack. */ + Uint16 attack_level; /**< Level at the start of the attack. */ + Uint16 fade_length; /**< Duration of the fade. */ + Uint16 fade_level; /**< Level at the end of the fade. */ +} SDL_HapticRamp; + +/** + * \brief A structure containing a template for a Left/Right effect. + * + * This struct is exclusively for the ::SDL_HAPTIC_LEFTRIGHT effect. + * + * The Left/Right effect is used to explicitly control the large and small + * motors, commonly found in modern game controllers. The small (right) motor + * is high frequency, and the large (left) motor is low frequency. + * + * \sa SDL_HAPTIC_LEFTRIGHT + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticLeftRight +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_LEFTRIGHT */ + + /* Replay */ + Uint32 length; /**< Duration of the effect in milliseconds. */ + + /* Rumble */ + Uint16 large_magnitude; /**< Control of the large controller motor. */ + Uint16 small_magnitude; /**< Control of the small controller motor. */ +} SDL_HapticLeftRight; + +/** + * \brief A structure containing a template for the ::SDL_HAPTIC_CUSTOM effect. + * + * This struct is exclusively for the ::SDL_HAPTIC_CUSTOM effect. + * + * A custom force feedback effect is much like a periodic effect, where the + * application can define its exact shape. You will have to allocate the + * data yourself. Data should consist of channels * samples Uint16 samples. + * + * If channels is one, the effect is rotated using the defined direction. + * Otherwise it uses the samples in data for the different axes. + * + * \sa SDL_HAPTIC_CUSTOM + * \sa SDL_HapticEffect + */ +typedef struct SDL_HapticCustom +{ + /* Header */ + Uint16 type; /**< ::SDL_HAPTIC_CUSTOM */ + SDL_HapticDirection direction; /**< Direction of the effect. */ + + /* Replay */ + Uint32 length; /**< Duration of the effect. */ + Uint16 delay; /**< Delay before starting the effect. */ + + /* Trigger */ + Uint16 button; /**< Button that triggers the effect. */ + Uint16 interval; /**< How soon it can be triggered again after button. */ + + /* Custom */ + Uint8 channels; /**< Axes to use, minimum of one. */ + Uint16 period; /**< Sample periods. */ + Uint16 samples; /**< Amount of samples. */ + Uint16 *data; /**< Should contain channels*samples items. */ + + /* Envelope */ + Uint16 attack_length; /**< Duration of the attack. */ + Uint16 attack_level; /**< Level at the start of the attack. */ + Uint16 fade_length; /**< Duration of the fade. */ + Uint16 fade_level; /**< Level at the end of the fade. */ +} SDL_HapticCustom; + +/** + * \brief The generic template for any haptic effect. + * + * All values max at 32767 (0x7FFF). Signed values also can be negative. + * Time values unless specified otherwise are in milliseconds. + * + * You can also pass ::SDL_HAPTIC_INFINITY to length instead of a 0-32767 + * value. Neither delay, interval, attack_length nor fade_length support + * ::SDL_HAPTIC_INFINITY. Fade will also not be used since effect never ends. + * + * Additionally, the ::SDL_HAPTIC_RAMP effect does not support a duration of + * ::SDL_HAPTIC_INFINITY. + * + * Button triggers may not be supported on all devices, it is advised to not + * use them if possible. Buttons start at index 1 instead of index 0 like + * the joystick. + * + * If both attack_length and fade_level are 0, the envelope is not used, + * otherwise both values are used. + * + * Common parts: + * \code + * // Replay - All effects have this + * Uint32 length; // Duration of effect (ms). + * Uint16 delay; // Delay before starting effect. + * + * // Trigger - All effects have this + * Uint16 button; // Button that triggers effect. + * Uint16 interval; // How soon before effect can be triggered again. + * + * // Envelope - All effects except condition effects have this + * Uint16 attack_length; // Duration of the attack (ms). + * Uint16 attack_level; // Level at the start of the attack. + * Uint16 fade_length; // Duration of the fade out (ms). + * Uint16 fade_level; // Level at the end of the fade. + * \endcode + * + * + * Here we have an example of a constant effect evolution in time: + * \verbatim + Strength + ^ + | + | effect level --> _________________ + | / \ + | / \ + | / \ + | / \ + | attack_level --> | \ + | | | <--- fade_level + | + +--------------------------------------------------> Time + [--] [---] + attack_length fade_length + + [------------------][-----------------------] + delay length + \endverbatim + * + * Note either the attack_level or the fade_level may be above the actual + * effect level. + * + * \sa SDL_HapticConstant + * \sa SDL_HapticPeriodic + * \sa SDL_HapticCondition + * \sa SDL_HapticRamp + * \sa SDL_HapticLeftRight + * \sa SDL_HapticCustom + */ +typedef union SDL_HapticEffect +{ + /* Common for all force feedback effects */ + Uint16 type; /**< Effect type. */ + SDL_HapticConstant constant; /**< Constant effect. */ + SDL_HapticPeriodic periodic; /**< Periodic effect. */ + SDL_HapticCondition condition; /**< Condition effect. */ + SDL_HapticRamp ramp; /**< Ramp effect. */ + SDL_HapticLeftRight leftright; /**< Left/Right effect. */ + SDL_HapticCustom custom; /**< Custom effect. */ +} SDL_HapticEffect; + + +/* Function prototypes */ +/** + * \brief Count the number of haptic devices attached to the system. + * + * \return Number of haptic devices detected on the system. + */ +extern DECLSPEC int SDLCALL SDL_NumHaptics(void); + +/** + * \brief Get the implementation dependent name of a haptic device. + * + * This can be called before any joysticks are opened. + * If no name can be found, this function returns NULL. + * + * \param device_index Index of the device to get its name. + * \return Name of the device or NULL on error. + * + * \sa SDL_NumHaptics + */ +extern DECLSPEC const char *SDLCALL SDL_HapticName(int device_index); + +/** + * \brief Opens a haptic device for use. + * + * The index passed as an argument refers to the N'th haptic device on this + * system. + * + * When opening a haptic device, its gain will be set to maximum and + * autocenter will be disabled. To modify these values use + * SDL_HapticSetGain() and SDL_HapticSetAutocenter(). + * + * \param device_index Index of the device to open. + * \return Device identifier or NULL on error. + * + * \sa SDL_HapticIndex + * \sa SDL_HapticOpenFromMouse + * \sa SDL_HapticOpenFromJoystick + * \sa SDL_HapticClose + * \sa SDL_HapticSetGain + * \sa SDL_HapticSetAutocenter + * \sa SDL_HapticPause + * \sa SDL_HapticStopAll + */ +extern DECLSPEC SDL_Haptic *SDLCALL SDL_HapticOpen(int device_index); + +/** + * \brief Checks if the haptic device at index has been opened. + * + * \param device_index Index to check to see if it has been opened. + * \return 1 if it has been opened or 0 if it hasn't. + * + * \sa SDL_HapticOpen + * \sa SDL_HapticIndex + */ +extern DECLSPEC int SDLCALL SDL_HapticOpened(int device_index); + +/** + * \brief Gets the index of a haptic device. + * + * \param haptic Haptic device to get the index of. + * \return The index of the haptic device or -1 on error. + * + * \sa SDL_HapticOpen + * \sa SDL_HapticOpened + */ +extern DECLSPEC int SDLCALL SDL_HapticIndex(SDL_Haptic * haptic); + +/** + * \brief Gets whether or not the current mouse has haptic capabilities. + * + * \return SDL_TRUE if the mouse is haptic, SDL_FALSE if it isn't. + * + * \sa SDL_HapticOpenFromMouse + */ +extern DECLSPEC int SDLCALL SDL_MouseIsHaptic(void); + +/** + * \brief Tries to open a haptic device from the current mouse. + * + * \return The haptic device identifier or NULL on error. + * + * \sa SDL_MouseIsHaptic + * \sa SDL_HapticOpen + */ +extern DECLSPEC SDL_Haptic *SDLCALL SDL_HapticOpenFromMouse(void); + +/** + * \brief Checks to see if a joystick has haptic features. + * + * \param joystick Joystick to test for haptic capabilities. + * \return SDL_TRUE if the joystick is haptic, SDL_FALSE if it isn't + * or -1 if an error occurred. + * + * \sa SDL_HapticOpenFromJoystick + */ +extern DECLSPEC int SDLCALL SDL_JoystickIsHaptic(SDL_Joystick * joystick); + +/** + * \brief Opens a haptic device for use from a joystick device. + * + * You must still close the haptic device separately. It will not be closed + * with the joystick. + * + * When opening from a joystick you should first close the haptic device before + * closing the joystick device. If not, on some implementations the haptic + * device will also get unallocated and you'll be unable to use force feedback + * on that device. + * + * \param joystick Joystick to create a haptic device from. + * \return A valid haptic device identifier on success or NULL on error. + * + * \sa SDL_HapticOpen + * \sa SDL_HapticClose + */ +extern DECLSPEC SDL_Haptic *SDLCALL SDL_HapticOpenFromJoystick(SDL_Joystick * + joystick); + +/** + * \brief Closes a haptic device previously opened with SDL_HapticOpen(). + * + * \param haptic Haptic device to close. + */ +extern DECLSPEC void SDLCALL SDL_HapticClose(SDL_Haptic * haptic); + +/** + * \brief Returns the number of effects a haptic device can store. + * + * On some platforms this isn't fully supported, and therefore is an + * approximation. Always check to see if your created effect was actually + * created and do not rely solely on SDL_HapticNumEffects(). + * + * \param haptic The haptic device to query effect max. + * \return The number of effects the haptic device can store or + * -1 on error. + * + * \sa SDL_HapticNumEffectsPlaying + * \sa SDL_HapticQuery + */ +extern DECLSPEC int SDLCALL SDL_HapticNumEffects(SDL_Haptic * haptic); + +/** + * \brief Returns the number of effects a haptic device can play at the same + * time. + * + * This is not supported on all platforms, but will always return a value. + * Added here for the sake of completeness. + * + * \param haptic The haptic device to query maximum playing effects. + * \return The number of effects the haptic device can play at the same time + * or -1 on error. + * + * \sa SDL_HapticNumEffects + * \sa SDL_HapticQuery + */ +extern DECLSPEC int SDLCALL SDL_HapticNumEffectsPlaying(SDL_Haptic * haptic); + +/** + * \brief Gets the haptic device's supported features in bitwise manner. + * + * Example: + * \code + * if (SDL_HapticQuery(haptic) & SDL_HAPTIC_CONSTANT) { + * printf("We have constant haptic effect!\n"); + * } + * \endcode + * + * \param haptic The haptic device to query. + * \return Haptic features in bitwise manner (OR'd). + * + * \sa SDL_HapticNumEffects + * \sa SDL_HapticEffectSupported + */ +extern DECLSPEC unsigned int SDLCALL SDL_HapticQuery(SDL_Haptic * haptic); + + +/** + * \brief Gets the number of haptic axes the device has. + * + * \sa SDL_HapticDirection + */ +extern DECLSPEC int SDLCALL SDL_HapticNumAxes(SDL_Haptic * haptic); + +/** + * \brief Checks to see if effect is supported by haptic. + * + * \param haptic Haptic device to check on. + * \param effect Effect to check to see if it is supported. + * \return SDL_TRUE if effect is supported, SDL_FALSE if it isn't or -1 on error. + * + * \sa SDL_HapticQuery + * \sa SDL_HapticNewEffect + */ +extern DECLSPEC int SDLCALL SDL_HapticEffectSupported(SDL_Haptic * haptic, + SDL_HapticEffect * + effect); + +/** + * \brief Creates a new haptic effect on the device. + * + * \param haptic Haptic device to create the effect on. + * \param effect Properties of the effect to create. + * \return The identifier of the effect on success or -1 on error. + * + * \sa SDL_HapticUpdateEffect + * \sa SDL_HapticRunEffect + * \sa SDL_HapticDestroyEffect + */ +extern DECLSPEC int SDLCALL SDL_HapticNewEffect(SDL_Haptic * haptic, + SDL_HapticEffect * effect); + +/** + * \brief Updates the properties of an effect. + * + * Can be used dynamically, although behavior when dynamically changing + * direction may be strange. Specifically the effect may reupload itself + * and start playing from the start. You cannot change the type either when + * running SDL_HapticUpdateEffect(). + * + * \param haptic Haptic device that has the effect. + * \param effect Identifier of the effect to update. + * \param data New effect properties to use. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticNewEffect + * \sa SDL_HapticRunEffect + * \sa SDL_HapticDestroyEffect + */ +extern DECLSPEC int SDLCALL SDL_HapticUpdateEffect(SDL_Haptic * haptic, + int effect, + SDL_HapticEffect * data); + +/** + * \brief Runs the haptic effect on its associated haptic device. + * + * If iterations are ::SDL_HAPTIC_INFINITY, it'll run the effect over and over + * repeating the envelope (attack and fade) every time. If you only want the + * effect to last forever, set ::SDL_HAPTIC_INFINITY in the effect's length + * parameter. + * + * \param haptic Haptic device to run the effect on. + * \param effect Identifier of the haptic effect to run. + * \param iterations Number of iterations to run the effect. Use + * ::SDL_HAPTIC_INFINITY for infinity. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticStopEffect + * \sa SDL_HapticDestroyEffect + * \sa SDL_HapticGetEffectStatus + */ +extern DECLSPEC int SDLCALL SDL_HapticRunEffect(SDL_Haptic * haptic, + int effect, + Uint32 iterations); + +/** + * \brief Stops the haptic effect on its associated haptic device. + * + * \param haptic Haptic device to stop the effect on. + * \param effect Identifier of the effect to stop. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticRunEffect + * \sa SDL_HapticDestroyEffect + */ +extern DECLSPEC int SDLCALL SDL_HapticStopEffect(SDL_Haptic * haptic, + int effect); + +/** + * \brief Destroys a haptic effect on the device. + * + * This will stop the effect if it's running. Effects are automatically + * destroyed when the device is closed. + * + * \param haptic Device to destroy the effect on. + * \param effect Identifier of the effect to destroy. + * + * \sa SDL_HapticNewEffect + */ +extern DECLSPEC void SDLCALL SDL_HapticDestroyEffect(SDL_Haptic * haptic, + int effect); + +/** + * \brief Gets the status of the current effect on the haptic device. + * + * Device must support the ::SDL_HAPTIC_STATUS feature. + * + * \param haptic Haptic device to query the effect status on. + * \param effect Identifier of the effect to query its status. + * \return 0 if it isn't playing, 1 if it is playing or -1 on error. + * + * \sa SDL_HapticRunEffect + * \sa SDL_HapticStopEffect + */ +extern DECLSPEC int SDLCALL SDL_HapticGetEffectStatus(SDL_Haptic * haptic, + int effect); + +/** + * \brief Sets the global gain of the device. + * + * Device must support the ::SDL_HAPTIC_GAIN feature. + * + * The user may specify the maximum gain by setting the environment variable + * SDL_HAPTIC_GAIN_MAX which should be between 0 and 100. All calls to + * SDL_HapticSetGain() will scale linearly using SDL_HAPTIC_GAIN_MAX as the + * maximum. + * + * \param haptic Haptic device to set the gain on. + * \param gain Value to set the gain to, should be between 0 and 100. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticQuery + */ +extern DECLSPEC int SDLCALL SDL_HapticSetGain(SDL_Haptic * haptic, int gain); + +/** + * \brief Sets the global autocenter of the device. + * + * Autocenter should be between 0 and 100. Setting it to 0 will disable + * autocentering. + * + * Device must support the ::SDL_HAPTIC_AUTOCENTER feature. + * + * \param haptic Haptic device to set autocentering on. + * \param autocenter Value to set autocenter to, 0 disables autocentering. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticQuery + */ +extern DECLSPEC int SDLCALL SDL_HapticSetAutocenter(SDL_Haptic * haptic, + int autocenter); + +/** + * \brief Pauses a haptic device. + * + * Device must support the ::SDL_HAPTIC_PAUSE feature. Call + * SDL_HapticUnpause() to resume playback. + * + * Do not modify the effects nor add new ones while the device is paused. + * That can cause all sorts of weird errors. + * + * \param haptic Haptic device to pause. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticUnpause + */ +extern DECLSPEC int SDLCALL SDL_HapticPause(SDL_Haptic * haptic); + +/** + * \brief Unpauses a haptic device. + * + * Call to unpause after SDL_HapticPause(). + * + * \param haptic Haptic device to unpause. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticPause + */ +extern DECLSPEC int SDLCALL SDL_HapticUnpause(SDL_Haptic * haptic); + +/** + * \brief Stops all the currently playing effects on a haptic device. + * + * \param haptic Haptic device to stop. + * \return 0 on success or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_HapticStopAll(SDL_Haptic * haptic); + +/** + * \brief Checks to see if rumble is supported on a haptic device. + * + * \param haptic Haptic device to check to see if it supports rumble. + * \return SDL_TRUE if effect is supported, SDL_FALSE if it isn't or -1 on error. + * + * \sa SDL_HapticRumbleInit + * \sa SDL_HapticRumblePlay + * \sa SDL_HapticRumbleStop + */ +extern DECLSPEC int SDLCALL SDL_HapticRumbleSupported(SDL_Haptic * haptic); + +/** + * \brief Initializes the haptic device for simple rumble playback. + * + * \param haptic Haptic device to initialize for simple rumble playback. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticOpen + * \sa SDL_HapticRumbleSupported + * \sa SDL_HapticRumblePlay + * \sa SDL_HapticRumbleStop + */ +extern DECLSPEC int SDLCALL SDL_HapticRumbleInit(SDL_Haptic * haptic); + +/** + * \brief Runs simple rumble on a haptic device + * + * \param haptic Haptic device to play rumble effect on. + * \param strength Strength of the rumble to play as a 0-1 float value. + * \param length Length of the rumble to play in milliseconds. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticRumbleSupported + * \sa SDL_HapticRumbleInit + * \sa SDL_HapticRumbleStop + */ +extern DECLSPEC int SDLCALL SDL_HapticRumblePlay(SDL_Haptic * haptic, float strength, Uint32 length ); + +/** + * \brief Stops the simple rumble on a haptic device. + * + * \param haptic Haptic to stop the rumble on. + * \return 0 on success or -1 on error. + * + * \sa SDL_HapticRumbleSupported + * \sa SDL_HapticRumbleInit + * \sa SDL_HapticRumblePlay + */ +extern DECLSPEC int SDLCALL SDL_HapticRumbleStop(SDL_Haptic * haptic); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_haptic_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_hints.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_hints.h new file mode 100644 index 0000000..8fa0dd6 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_hints.h @@ -0,0 +1,1266 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_hints.h + * + * Official documentation for SDL configuration variables + * + * This file contains functions to set and get configuration hints, + * as well as listing each of them alphabetically. + * + * The convention for naming hints is SDL_HINT_X, where "SDL_X" is + * the environment variable that can be used to override the default. + * + * In general these hints are just that - they may or may not be + * supported or applicable on any given platform, but they provide + * a way for an application or user to give the library a hint as + * to how they would like the library to work. + */ + +#ifndef SDL_hints_h_ +#define SDL_hints_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief A variable controlling how 3D acceleration is used to accelerate the SDL screen surface. + * + * SDL can try to accelerate the SDL screen surface by using streaming + * textures with a 3D rendering engine. This variable controls whether and + * how this is done. + * + * This variable can be set to the following values: + * "0" - Disable 3D acceleration + * "1" - Enable 3D acceleration, using the default renderer. + * "X" - Enable 3D acceleration, using X where X is one of the valid rendering drivers. (e.g. "direct3d", "opengl", etc.) + * + * By default SDL tries to make a best guess for each platform whether + * to use acceleration or not. + */ +#define SDL_HINT_FRAMEBUFFER_ACCELERATION "SDL_FRAMEBUFFER_ACCELERATION" + +/** + * \brief A variable specifying which render driver to use. + * + * If the application doesn't pick a specific renderer to use, this variable + * specifies the name of the preferred renderer. If the preferred renderer + * can't be initialized, the normal default renderer is used. + * + * This variable is case insensitive and can be set to the following values: + * "direct3d" + * "opengl" + * "opengles2" + * "opengles" + * "metal" + * "software" + * + * The default varies by platform, but it's the first one in the list that + * is available on the current platform. + */ +#define SDL_HINT_RENDER_DRIVER "SDL_RENDER_DRIVER" + +/** + * \brief A variable controlling whether the OpenGL render driver uses shaders if they are available. + * + * This variable can be set to the following values: + * "0" - Disable shaders + * "1" - Enable shaders + * + * By default shaders are used if OpenGL supports them. + */ +#define SDL_HINT_RENDER_OPENGL_SHADERS "SDL_RENDER_OPENGL_SHADERS" + +/** + * \brief A variable controlling whether the Direct3D device is initialized for thread-safe operations. + * + * This variable can be set to the following values: + * "0" - Thread-safety is not enabled (faster) + * "1" - Thread-safety is enabled + * + * By default the Direct3D device is created with thread-safety disabled. + */ +#define SDL_HINT_RENDER_DIRECT3D_THREADSAFE "SDL_RENDER_DIRECT3D_THREADSAFE" + +/** + * \brief A variable controlling whether to enable Direct3D 11+'s Debug Layer. + * + * This variable does not have any effect on the Direct3D 9 based renderer. + * + * This variable can be set to the following values: + * "0" - Disable Debug Layer use + * "1" - Enable Debug Layer use + * + * By default, SDL does not use Direct3D Debug Layer. + */ +#define SDL_HINT_RENDER_DIRECT3D11_DEBUG "SDL_RENDER_DIRECT3D11_DEBUG" + +/** + * \brief A variable controlling the scaling policy for SDL_RenderSetLogicalSize. + * + * This variable can be set to the following values: + * "0" or "letterbox" - Uses letterbox/sidebars to fit the entire rendering on screen + * "1" or "overscan" - Will zoom the rendering so it fills the entire screen, allowing edges to be drawn offscreen + * + * By default letterbox is used + */ +#define SDL_HINT_RENDER_LOGICAL_SIZE_MODE "SDL_RENDER_LOGICAL_SIZE_MODE" + +/** + * \brief A variable controlling the scaling quality + * + * This variable can be set to the following values: + * "0" or "nearest" - Nearest pixel sampling + * "1" or "linear" - Linear filtering (supported by OpenGL and Direct3D) + * "2" or "best" - Currently this is the same as "linear" + * + * By default nearest pixel sampling is used + */ +#define SDL_HINT_RENDER_SCALE_QUALITY "SDL_RENDER_SCALE_QUALITY" + +/** + * \brief A variable controlling whether updates to the SDL screen surface should be synchronized with the vertical refresh, to avoid tearing. + * + * This variable can be set to the following values: + * "0" - Disable vsync + * "1" - Enable vsync + * + * By default SDL does not sync screen surface updates with vertical refresh. + */ +#define SDL_HINT_RENDER_VSYNC "SDL_RENDER_VSYNC" + +/** + * \brief A variable controlling whether the screensaver is enabled. + * + * This variable can be set to the following values: + * "0" - Disable screensaver + * "1" - Enable screensaver + * + * By default SDL will disable the screensaver. + */ +#define SDL_HINT_VIDEO_ALLOW_SCREENSAVER "SDL_VIDEO_ALLOW_SCREENSAVER" + +/** + * \brief A variable controlling whether the X11 VidMode extension should be used. + * + * This variable can be set to the following values: + * "0" - Disable XVidMode + * "1" - Enable XVidMode + * + * By default SDL will use XVidMode if it is available. + */ +#define SDL_HINT_VIDEO_X11_XVIDMODE "SDL_VIDEO_X11_XVIDMODE" + +/** + * \brief A variable controlling whether the X11 Xinerama extension should be used. + * + * This variable can be set to the following values: + * "0" - Disable Xinerama + * "1" - Enable Xinerama + * + * By default SDL will use Xinerama if it is available. + */ +#define SDL_HINT_VIDEO_X11_XINERAMA "SDL_VIDEO_X11_XINERAMA" + +/** + * \brief A variable controlling whether the X11 XRandR extension should be used. + * + * This variable can be set to the following values: + * "0" - Disable XRandR + * "1" - Enable XRandR + * + * By default SDL will not use XRandR because of window manager issues. + */ +#define SDL_HINT_VIDEO_X11_XRANDR "SDL_VIDEO_X11_XRANDR" + +/** + * \brief A variable controlling whether the X11 _NET_WM_PING protocol should be supported. + * + * This variable can be set to the following values: + * "0" - Disable _NET_WM_PING + * "1" - Enable _NET_WM_PING + * + * By default SDL will use _NET_WM_PING, but for applications that know they + * will not always be able to respond to ping requests in a timely manner they can + * turn it off to avoid the window manager thinking the app is hung. + * The hint is checked in CreateWindow. + */ +#define SDL_HINT_VIDEO_X11_NET_WM_PING "SDL_VIDEO_X11_NET_WM_PING" + +/** + * \brief A variable controlling whether the X11 _NET_WM_BYPASS_COMPOSITOR hint should be used. + * + * This variable can be set to the following values: + * "0" - Disable _NET_WM_BYPASS_COMPOSITOR + * "1" - Enable _NET_WM_BYPASS_COMPOSITOR + * + * By default SDL will use _NET_WM_BYPASS_COMPOSITOR + * + */ +#define SDL_HINT_VIDEO_X11_NET_WM_BYPASS_COMPOSITOR "SDL_VIDEO_X11_NET_WM_BYPASS_COMPOSITOR" + +/** + * \brief A variable controlling whether the window frame and title bar are interactive when the cursor is hidden + * + * This variable can be set to the following values: + * "0" - The window frame is not interactive when the cursor is hidden (no move, resize, etc) + * "1" - The window frame is interactive when the cursor is hidden + * + * By default SDL will allow interaction with the window frame when the cursor is hidden + */ +#define SDL_HINT_WINDOW_FRAME_USABLE_WHILE_CURSOR_HIDDEN "SDL_WINDOW_FRAME_USABLE_WHILE_CURSOR_HIDDEN" + +/** + * \brief A variable to specify custom icon resource id from RC file on Windows platform + */ +#define SDL_HINT_WINDOWS_INTRESOURCE_ICON "SDL_WINDOWS_INTRESOURCE_ICON" +#define SDL_HINT_WINDOWS_INTRESOURCE_ICON_SMALL "SDL_WINDOWS_INTRESOURCE_ICON_SMALL" + +/** + * \brief A variable controlling whether the windows message loop is processed by SDL + * + * This variable can be set to the following values: + * "0" - The window message loop is not run + * "1" - The window message loop is processed in SDL_PumpEvents() + * + * By default SDL will process the windows message loop + */ +#define SDL_HINT_WINDOWS_ENABLE_MESSAGELOOP "SDL_WINDOWS_ENABLE_MESSAGELOOP" + +/** + * \brief A variable controlling whether grabbing input grabs the keyboard + * + * This variable can be set to the following values: + * "0" - Grab will affect only the mouse + * "1" - Grab will affect mouse and keyboard + * + * By default SDL will not grab the keyboard so system shortcuts still work. + */ +#define SDL_HINT_GRAB_KEYBOARD "SDL_GRAB_KEYBOARD" + +/** + * \brief A variable setting the double click time, in milliseconds. + */ +#define SDL_HINT_MOUSE_DOUBLE_CLICK_TIME "SDL_MOUSE_DOUBLE_CLICK_TIME" + +/** + * \brief A variable setting the double click radius, in pixels. + */ +#define SDL_HINT_MOUSE_DOUBLE_CLICK_RADIUS "SDL_MOUSE_DOUBLE_CLICK_RADIUS" + +/** + * \brief A variable setting the speed scale for mouse motion, in floating point, when the mouse is not in relative mode + */ +#define SDL_HINT_MOUSE_NORMAL_SPEED_SCALE "SDL_MOUSE_NORMAL_SPEED_SCALE" + +/** + * \brief A variable setting the scale for mouse motion, in floating point, when the mouse is in relative mode + */ +#define SDL_HINT_MOUSE_RELATIVE_SPEED_SCALE "SDL_MOUSE_RELATIVE_SPEED_SCALE" + +/** + * \brief A variable controlling whether relative mouse mode is implemented using mouse warping + * + * This variable can be set to the following values: + * "0" - Relative mouse mode uses raw input + * "1" - Relative mouse mode uses mouse warping + * + * By default SDL will use raw input for relative mouse mode + */ +#define SDL_HINT_MOUSE_RELATIVE_MODE_WARP "SDL_MOUSE_RELATIVE_MODE_WARP" + +/** + * \brief Allow mouse click events when clicking to focus an SDL window + * + * This variable can be set to the following values: + * "0" - Ignore mouse clicks that activate a window + * "1" - Generate events for mouse clicks that activate a window + * + * By default SDL will ignore mouse clicks that activate a window + */ +#define SDL_HINT_MOUSE_FOCUS_CLICKTHROUGH "SDL_MOUSE_FOCUS_CLICKTHROUGH" + +/** + * \brief A variable controlling whether touch events should generate synthetic mouse events + * + * This variable can be set to the following values: + * "0" - Touch events will not generate mouse events + * "1" - Touch events will generate mouse events + * + * By default SDL will generate mouse events for touch events + */ +#define SDL_HINT_TOUCH_MOUSE_EVENTS "SDL_TOUCH_MOUSE_EVENTS" + +/** + * \brief A variable controlling whether mouse events should generate synthetic touch events + * + * This variable can be set to the following values: + * "0" - Mouse events will not generate touch events (default for desktop platforms) + * "1" - Mouse events will generate touch events (default for mobile platforms, such as Android and iOS) + */ + +#define SDL_HINT_MOUSE_TOUCH_EVENTS "SDL_MOUSE_TOUCH_EVENTS" + +/** + * \brief Minimize your SDL_Window if it loses key focus when in fullscreen mode. Defaults to true. + * + */ +#define SDL_HINT_VIDEO_MINIMIZE_ON_FOCUS_LOSS "SDL_VIDEO_MINIMIZE_ON_FOCUS_LOSS" + +/** + * \brief A variable controlling whether the idle timer is disabled on iOS. + * + * When an iOS app does not receive touches for some time, the screen is + * dimmed automatically. For games where the accelerometer is the only input + * this is problematic. This functionality can be disabled by setting this + * hint. + * + * As of SDL 2.0.4, SDL_EnableScreenSaver() and SDL_DisableScreenSaver() + * accomplish the same thing on iOS. They should be preferred over this hint. + * + * This variable can be set to the following values: + * "0" - Enable idle timer + * "1" - Disable idle timer + */ +#define SDL_HINT_IDLE_TIMER_DISABLED "SDL_IOS_IDLE_TIMER_DISABLED" + +/** + * \brief A variable controlling which orientations are allowed on iOS/Android. + * + * In some circumstances it is necessary to be able to explicitly control + * which UI orientations are allowed. + * + * This variable is a space delimited list of the following values: + * "LandscapeLeft", "LandscapeRight", "Portrait" "PortraitUpsideDown" + */ +#define SDL_HINT_ORIENTATIONS "SDL_IOS_ORIENTATIONS" + +/** + * \brief A variable controlling whether controllers used with the Apple TV + * generate UI events. + * + * When UI events are generated by controller input, the app will be + * backgrounded when the Apple TV remote's menu button is pressed, and when the + * pause or B buttons on gamepads are pressed. + * + * More information about properly making use of controllers for the Apple TV + * can be found here: + * https://developer.apple.com/tvos/human-interface-guidelines/remote-and-controllers/ + * + * This variable can be set to the following values: + * "0" - Controller input does not generate UI events (the default). + * "1" - Controller input generates UI events. + */ +#define SDL_HINT_APPLE_TV_CONTROLLER_UI_EVENTS "SDL_APPLE_TV_CONTROLLER_UI_EVENTS" + +/** + * \brief A variable controlling whether the Apple TV remote's joystick axes + * will automatically match the rotation of the remote. + * + * This variable can be set to the following values: + * "0" - Remote orientation does not affect joystick axes (the default). + * "1" - Joystick axes are based on the orientation of the remote. + */ +#define SDL_HINT_APPLE_TV_REMOTE_ALLOW_ROTATION "SDL_APPLE_TV_REMOTE_ALLOW_ROTATION" + +/** + * \brief A variable controlling whether the home indicator bar on iPhone X + * should be hidden. + * + * This variable can be set to the following values: + * "0" - The indicator bar is not hidden (default for windowed applications) + * "1" - The indicator bar is hidden and is shown when the screen is touched (useful for movie playback applications) + * "2" - The indicator bar is dim and the first swipe makes it visible and the second swipe performs the "home" action (default for fullscreen applications) + */ +#define SDL_HINT_IOS_HIDE_HOME_INDICATOR "SDL_IOS_HIDE_HOME_INDICATOR" + +/** + * \brief A variable controlling whether the Android / iOS built-in + * accelerometer should be listed as a joystick device. + * + * This variable can be set to the following values: + * "0" - The accelerometer is not listed as a joystick + * "1" - The accelerometer is available as a 3 axis joystick (the default). + */ +#define SDL_HINT_ACCELEROMETER_AS_JOYSTICK "SDL_ACCELEROMETER_AS_JOYSTICK" + +/** + * \brief A variable controlling whether the Android / tvOS remotes + * should be listed as joystick devices, instead of sending keyboard events. + * + * This variable can be set to the following values: + * "0" - Remotes send enter/escape/arrow key events + * "1" - Remotes are available as 2 axis, 2 button joysticks (the default). + */ +#define SDL_HINT_TV_REMOTE_AS_JOYSTICK "SDL_TV_REMOTE_AS_JOYSTICK" + +/** + * \brief A variable that lets you disable the detection and use of Xinput gamepad devices + * + * The variable can be set to the following values: + * "0" - Disable XInput detection (only uses direct input) + * "1" - Enable XInput detection (the default) + */ +#define SDL_HINT_XINPUT_ENABLED "SDL_XINPUT_ENABLED" + +/** + * \brief A variable that causes SDL to use the old axis and button mapping for XInput devices. + * + * This hint is for backwards compatibility only and will be removed in SDL 2.1 + * + * The default value is "0". This hint must be set before SDL_Init() + */ +#define SDL_HINT_XINPUT_USE_OLD_JOYSTICK_MAPPING "SDL_XINPUT_USE_OLD_JOYSTICK_MAPPING" + +/** + * \brief A variable that lets you manually hint extra gamecontroller db entries. + * + * The variable should be newline delimited rows of gamecontroller config data, see SDL_gamecontroller.h + * + * This hint must be set before calling SDL_Init(SDL_INIT_GAMECONTROLLER) + * You can update mappings after the system is initialized with SDL_GameControllerMappingForGUID() and SDL_GameControllerAddMapping() + */ +#define SDL_HINT_GAMECONTROLLERCONFIG "SDL_GAMECONTROLLERCONFIG" + +/** + * \brief A variable that lets you provide a file with extra gamecontroller db entries. + * + * The file should contain lines of gamecontroller config data, see SDL_gamecontroller.h + * + * This hint must be set before calling SDL_Init(SDL_INIT_GAMECONTROLLER) + * You can update mappings after the system is initialized with SDL_GameControllerMappingForGUID() and SDL_GameControllerAddMapping() + */ +#define SDL_HINT_GAMECONTROLLERCONFIG_FILE "SDL_GAMECONTROLLERCONFIG_FILE" + +/** + * \brief A variable containing a list of devices to skip when scanning for game controllers. + * + * The format of the string is a comma separated list of USB VID/PID pairs + * in hexadecimal form, e.g. + * + * 0xAAAA/0xBBBB,0xCCCC/0xDDDD + * + * The variable can also take the form of @file, in which case the named + * file will be loaded and interpreted as the value of the variable. + */ +#define SDL_HINT_GAMECONTROLLER_IGNORE_DEVICES "SDL_GAMECONTROLLER_IGNORE_DEVICES" + +/** + * \brief If set, all devices will be skipped when scanning for game controllers except for the ones listed in this variable. + * + * The format of the string is a comma separated list of USB VID/PID pairs + * in hexadecimal form, e.g. + * + * 0xAAAA/0xBBBB,0xCCCC/0xDDDD + * + * The variable can also take the form of @file, in which case the named + * file will be loaded and interpreted as the value of the variable. + */ +#define SDL_HINT_GAMECONTROLLER_IGNORE_DEVICES_EXCEPT "SDL_GAMECONTROLLER_IGNORE_DEVICES_EXCEPT" + +/** + * \brief A variable that lets you enable joystick (and gamecontroller) events even when your app is in the background. + * + * The variable can be set to the following values: + * "0" - Disable joystick & gamecontroller input events when the + * application is in the background. + * "1" - Enable joystick & gamecontroller input events when the + * application is in the background. + * + * The default value is "0". This hint may be set at any time. + */ +#define SDL_HINT_JOYSTICK_ALLOW_BACKGROUND_EVENTS "SDL_JOYSTICK_ALLOW_BACKGROUND_EVENTS" + +/** + * \brief A variable controlling whether the HIDAPI joystick drivers should be used. + * + * This variable can be set to the following values: + * "0" - HIDAPI drivers are not used + * "1" - HIDAPI drivers are used (the default) + * + * This variable is the default for all drivers, but can be overridden by the hints for specific drivers below. + */ +#define SDL_HINT_JOYSTICK_HIDAPI "SDL_JOYSTICK_HIDAPI" + +/** + * \brief A variable controlling whether the HIDAPI driver for PS4 controllers should be used. + * + * This variable can be set to the following values: + * "0" - HIDAPI driver is not used + * "1" - HIDAPI driver is used + * + * The default is the value of SDL_HINT_JOYSTICK_HIDAPI + */ +#define SDL_HINT_JOYSTICK_HIDAPI_PS4 "SDL_JOYSTICK_HIDAPI_PS4" + +/** + * \brief A variable controlling whether extended input reports should be used for PS4 controllers when using the HIDAPI driver. + * + * This variable can be set to the following values: + * "0" - extended reports are not enabled (the default) + * "1" - extended reports + * + * Extended input reports allow rumble on Bluetooth PS4 controllers, but + * break DirectInput handling for applications that don't use SDL. + * + * Once extended reports are enabled, they can not be disabled without + * power cycling the controller. + */ +#define SDL_HINT_JOYSTICK_HIDAPI_PS4_RUMBLE "SDL_JOYSTICK_HIDAPI_PS4_RUMBLE" + +/** + * \brief A variable controlling whether the HIDAPI driver for Steam Controllers should be used. + * + * This variable can be set to the following values: + * "0" - HIDAPI driver is not used + * "1" - HIDAPI driver is used + * + * The default is the value of SDL_HINT_JOYSTICK_HIDAPI + */ +#define SDL_HINT_JOYSTICK_HIDAPI_STEAM "SDL_JOYSTICK_HIDAPI_STEAM" + +/** + * \brief A variable controlling whether the HIDAPI driver for Nintendo Switch controllers should be used. + * + * This variable can be set to the following values: + * "0" - HIDAPI driver is not used + * "1" - HIDAPI driver is used + * + * The default is the value of SDL_HINT_JOYSTICK_HIDAPI + */ +#define SDL_HINT_JOYSTICK_HIDAPI_SWITCH "SDL_JOYSTICK_HIDAPI_SWITCH" + +/** + * \brief A variable controlling whether the HIDAPI driver for XBox controllers should be used. + * + * This variable can be set to the following values: + * "0" - HIDAPI driver is not used + * "1" - HIDAPI driver is used + * + * The default is the value of SDL_HINT_JOYSTICK_HIDAPI + */ +#define SDL_HINT_JOYSTICK_HIDAPI_XBOX "SDL_JOYSTICK_HIDAPI_XBOX" + +/** + * \brief A variable that controls whether Steam Controllers should be exposed using the SDL joystick and game controller APIs + * + * The variable can be set to the following values: + * "0" - Do not scan for Steam Controllers + * "1" - Scan for Steam Controllers (the default) + * + * The default value is "1". This hint must be set before initializing the joystick subsystem. + */ +#define SDL_HINT_ENABLE_STEAM_CONTROLLERS "SDL_ENABLE_STEAM_CONTROLLERS" + + +/** + * \brief If set to "0" then never set the top most bit on a SDL Window, even if the video mode expects it. + * This is a debugging aid for developers and not expected to be used by end users. The default is "1" + * + * This variable can be set to the following values: + * "0" - don't allow topmost + * "1" - allow topmost + */ +#define SDL_HINT_ALLOW_TOPMOST "SDL_ALLOW_TOPMOST" + +/** + * \brief A variable that controls the timer resolution, in milliseconds. + * + * The higher resolution the timer, the more frequently the CPU services + * timer interrupts, and the more precise delays are, but this takes up + * power and CPU time. This hint is only used on Windows 7 and earlier. + * + * See this blog post for more information: + * http://randomascii.wordpress.com/2013/07/08/windows-timer-resolution-megawatts-wasted/ + * + * If this variable is set to "0", the system timer resolution is not set. + * + * The default value is "1". This hint may be set at any time. + */ +#define SDL_HINT_TIMER_RESOLUTION "SDL_TIMER_RESOLUTION" + + +/** + * \brief A variable describing the content orientation on QtWayland-based platforms. + * + * On QtWayland platforms, windows are rotated client-side to allow for custom + * transitions. In order to correctly position overlays (e.g. volume bar) and + * gestures (e.g. events view, close/minimize gestures), the system needs to + * know in which orientation the application is currently drawing its contents. + * + * This does not cause the window to be rotated or resized, the application + * needs to take care of drawing the content in the right orientation (the + * framebuffer is always in portrait mode). + * + * This variable can be one of the following values: + * "primary" (default), "portrait", "landscape", "inverted-portrait", "inverted-landscape" + */ +#define SDL_HINT_QTWAYLAND_CONTENT_ORIENTATION "SDL_QTWAYLAND_CONTENT_ORIENTATION" + +/** + * \brief Flags to set on QtWayland windows to integrate with the native window manager. + * + * On QtWayland platforms, this hint controls the flags to set on the windows. + * For example, on Sailfish OS "OverridesSystemGestures" disables swipe gestures. + * + * This variable is a space-separated list of the following values (empty = no flags): + * "OverridesSystemGestures", "StaysOnTop", "BypassWindowManager" + */ +#define SDL_HINT_QTWAYLAND_WINDOW_FLAGS "SDL_QTWAYLAND_WINDOW_FLAGS" + +/** +* \brief A string specifying SDL's threads stack size in bytes or "0" for the backend's default size +* +* Use this hint in case you need to set SDL's threads stack size to other than the default. +* This is specially useful if you build SDL against a non glibc libc library (such as musl) which +* provides a relatively small default thread stack size (a few kilobytes versus the default 8MB glibc uses). +* Support for this hint is currently available only in the pthread, Windows, and PSP backend. +* +* Instead of this hint, in 2.0.9 and later, you can use +* SDL_CreateThreadWithStackSize(). This hint only works with the classic +* SDL_CreateThread(). +*/ +#define SDL_HINT_THREAD_STACK_SIZE "SDL_THREAD_STACK_SIZE" + +/** + * \brief If set to 1, then do not allow high-DPI windows. ("Retina" on Mac and iOS) + */ +#define SDL_HINT_VIDEO_HIGHDPI_DISABLED "SDL_VIDEO_HIGHDPI_DISABLED" + +/** + * \brief A variable that determines whether ctrl+click should generate a right-click event on Mac + * + * If present, holding ctrl while left clicking will generate a right click + * event when on Mac. + */ +#define SDL_HINT_MAC_CTRL_CLICK_EMULATE_RIGHT_CLICK "SDL_MAC_CTRL_CLICK_EMULATE_RIGHT_CLICK" + +/** +* \brief A variable specifying which shader compiler to preload when using the Chrome ANGLE binaries +* +* SDL has EGL and OpenGL ES2 support on Windows via the ANGLE project. It +* can use two different sets of binaries, those compiled by the user from source +* or those provided by the Chrome browser. In the later case, these binaries require +* that SDL loads a DLL providing the shader compiler. +* +* This variable can be set to the following values: +* "d3dcompiler_46.dll" - default, best for Vista or later. +* "d3dcompiler_43.dll" - for XP support. +* "none" - do not load any library, useful if you compiled ANGLE from source and included the compiler in your binaries. +* +*/ +#define SDL_HINT_VIDEO_WIN_D3DCOMPILER "SDL_VIDEO_WIN_D3DCOMPILER" + +/** +* \brief A variable that is the address of another SDL_Window* (as a hex string formatted with "%p"). +* +* If this hint is set before SDL_CreateWindowFrom() and the SDL_Window* it is set to has +* SDL_WINDOW_OPENGL set (and running on WGL only, currently), then two things will occur on the newly +* created SDL_Window: +* +* 1. Its pixel format will be set to the same pixel format as this SDL_Window. This is +* needed for example when sharing an OpenGL context across multiple windows. +* +* 2. The flag SDL_WINDOW_OPENGL will be set on the new window so it can be used for +* OpenGL rendering. +* +* This variable can be set to the following values: +* The address (as a string "%p") of the SDL_Window* that new windows created with SDL_CreateWindowFrom() should +* share a pixel format with. +*/ +#define SDL_HINT_VIDEO_WINDOW_SHARE_PIXEL_FORMAT "SDL_VIDEO_WINDOW_SHARE_PIXEL_FORMAT" + +/** + * \brief A URL to a WinRT app's privacy policy + * + * All network-enabled WinRT apps must make a privacy policy available to its + * users. On Windows 8, 8.1, and RT, Microsoft mandates that this policy be + * be available in the Windows Settings charm, as accessed from within the app. + * SDL provides code to add a URL-based link there, which can point to the app's + * privacy policy. + * + * To setup a URL to an app's privacy policy, set SDL_HINT_WINRT_PRIVACY_POLICY_URL + * before calling any SDL_Init() functions. The contents of the hint should + * be a valid URL. For example, "http://www.example.com". + * + * The default value is "", which will prevent SDL from adding a privacy policy + * link to the Settings charm. This hint should only be set during app init. + * + * The label text of an app's "Privacy Policy" link may be customized via another + * hint, SDL_HINT_WINRT_PRIVACY_POLICY_LABEL. + * + * Please note that on Windows Phone, Microsoft does not provide standard UI + * for displaying a privacy policy link, and as such, SDL_HINT_WINRT_PRIVACY_POLICY_URL + * will not get used on that platform. Network-enabled phone apps should display + * their privacy policy through some other, in-app means. + */ +#define SDL_HINT_WINRT_PRIVACY_POLICY_URL "SDL_WINRT_PRIVACY_POLICY_URL" + +/** \brief Label text for a WinRT app's privacy policy link + * + * Network-enabled WinRT apps must include a privacy policy. On Windows 8, 8.1, and RT, + * Microsoft mandates that this policy be available via the Windows Settings charm. + * SDL provides code to add a link there, with its label text being set via the + * optional hint, SDL_HINT_WINRT_PRIVACY_POLICY_LABEL. + * + * Please note that a privacy policy's contents are not set via this hint. A separate + * hint, SDL_HINT_WINRT_PRIVACY_POLICY_URL, is used to link to the actual text of the + * policy. + * + * The contents of this hint should be encoded as a UTF8 string. + * + * The default value is "Privacy Policy". This hint should only be set during app + * initialization, preferably before any calls to SDL_Init(). + * + * For additional information on linking to a privacy policy, see the documentation for + * SDL_HINT_WINRT_PRIVACY_POLICY_URL. + */ +#define SDL_HINT_WINRT_PRIVACY_POLICY_LABEL "SDL_WINRT_PRIVACY_POLICY_LABEL" + +/** \brief Allows back-button-press events on Windows Phone to be marked as handled + * + * Windows Phone devices typically feature a Back button. When pressed, + * the OS will emit back-button-press events, which apps are expected to + * handle in an appropriate manner. If apps do not explicitly mark these + * events as 'Handled', then the OS will invoke its default behavior for + * unhandled back-button-press events, which on Windows Phone 8 and 8.1 is to + * terminate the app (and attempt to switch to the previous app, or to the + * device's home screen). + * + * Setting the SDL_HINT_WINRT_HANDLE_BACK_BUTTON hint to "1" will cause SDL + * to mark back-button-press events as Handled, if and when one is sent to + * the app. + * + * Internally, Windows Phone sends back button events as parameters to + * special back-button-press callback functions. Apps that need to respond + * to back-button-press events are expected to register one or more + * callback functions for such, shortly after being launched (during the + * app's initialization phase). After the back button is pressed, the OS + * will invoke these callbacks. If the app's callback(s) do not explicitly + * mark the event as handled by the time they return, or if the app never + * registers one of these callback, the OS will consider the event + * un-handled, and it will apply its default back button behavior (terminate + * the app). + * + * SDL registers its own back-button-press callback with the Windows Phone + * OS. This callback will emit a pair of SDL key-press events (SDL_KEYDOWN + * and SDL_KEYUP), each with a scancode of SDL_SCANCODE_AC_BACK, after which + * it will check the contents of the hint, SDL_HINT_WINRT_HANDLE_BACK_BUTTON. + * If the hint's value is set to "1", the back button event's Handled + * property will get set to 'true'. If the hint's value is set to something + * else, or if it is unset, SDL will leave the event's Handled property + * alone. (By default, the OS sets this property to 'false', to note.) + * + * SDL apps can either set SDL_HINT_WINRT_HANDLE_BACK_BUTTON well before a + * back button is pressed, or can set it in direct-response to a back button + * being pressed. + * + * In order to get notified when a back button is pressed, SDL apps should + * register a callback function with SDL_AddEventWatch(), and have it listen + * for SDL_KEYDOWN events that have a scancode of SDL_SCANCODE_AC_BACK. + * (Alternatively, SDL_KEYUP events can be listened-for. Listening for + * either event type is suitable.) Any value of SDL_HINT_WINRT_HANDLE_BACK_BUTTON + * set by such a callback, will be applied to the OS' current + * back-button-press event. + * + * More details on back button behavior in Windows Phone apps can be found + * at the following page, on Microsoft's developer site: + * http://msdn.microsoft.com/en-us/library/windowsphone/develop/jj247550(v=vs.105).aspx + */ +#define SDL_HINT_WINRT_HANDLE_BACK_BUTTON "SDL_WINRT_HANDLE_BACK_BUTTON" + +/** + * \brief A variable that dictates policy for fullscreen Spaces on Mac OS X. + * + * This hint only applies to Mac OS X. + * + * The variable can be set to the following values: + * "0" - Disable Spaces support (FULLSCREEN_DESKTOP won't use them and + * SDL_WINDOW_RESIZABLE windows won't offer the "fullscreen" + * button on their titlebars). + * "1" - Enable Spaces support (FULLSCREEN_DESKTOP will use them and + * SDL_WINDOW_RESIZABLE windows will offer the "fullscreen" + * button on their titlebars). + * + * The default value is "1". Spaces are disabled regardless of this hint if + * the OS isn't at least Mac OS X Lion (10.7). This hint must be set before + * any windows are created. + */ +#define SDL_HINT_VIDEO_MAC_FULLSCREEN_SPACES "SDL_VIDEO_MAC_FULLSCREEN_SPACES" + +/** +* \brief When set don't force the SDL app to become a foreground process +* +* This hint only applies to Mac OS X. +* +*/ +#define SDL_HINT_MAC_BACKGROUND_APP "SDL_MAC_BACKGROUND_APP" + +/** + * \brief Android APK expansion main file version. Should be a string number like "1", "2" etc. + * + * Must be set together with SDL_HINT_ANDROID_APK_EXPANSION_PATCH_FILE_VERSION. + * + * If both hints were set then SDL_RWFromFile() will look into expansion files + * after a given relative path was not found in the internal storage and assets. + * + * By default this hint is not set and the APK expansion files are not searched. + */ +#define SDL_HINT_ANDROID_APK_EXPANSION_MAIN_FILE_VERSION "SDL_ANDROID_APK_EXPANSION_MAIN_FILE_VERSION" + +/** + * \brief Android APK expansion patch file version. Should be a string number like "1", "2" etc. + * + * Must be set together with SDL_HINT_ANDROID_APK_EXPANSION_MAIN_FILE_VERSION. + * + * If both hints were set then SDL_RWFromFile() will look into expansion files + * after a given relative path was not found in the internal storage and assets. + * + * By default this hint is not set and the APK expansion files are not searched. + */ +#define SDL_HINT_ANDROID_APK_EXPANSION_PATCH_FILE_VERSION "SDL_ANDROID_APK_EXPANSION_PATCH_FILE_VERSION" + +/** + * \brief A variable to control whether certain IMEs should handle text editing internally instead of sending SDL_TEXTEDITING events. + * + * The variable can be set to the following values: + * "0" - SDL_TEXTEDITING events are sent, and it is the application's + * responsibility to render the text from these events and + * differentiate it somehow from committed text. (default) + * "1" - If supported by the IME then SDL_TEXTEDITING events are not sent, + * and text that is being composed will be rendered in its own UI. + */ +#define SDL_HINT_IME_INTERNAL_EDITING "SDL_IME_INTERNAL_EDITING" + +/** + * \brief A variable to control whether we trap the Android back button to handle it manually. + * This is necessary for the right mouse button to work on some Android devices, or + * to be able to trap the back button for use in your code reliably. If set to true, + * the back button will show up as an SDL_KEYDOWN / SDL_KEYUP pair with a keycode of + * SDL_SCANCODE_AC_BACK. + * + * The variable can be set to the following values: + * "0" - Back button will be handled as usual for system. (default) + * "1" - Back button will be trapped, allowing you to handle the key press + * manually. (This will also let right mouse click work on systems + * where the right mouse button functions as back.) + * + * The value of this hint is used at runtime, so it can be changed at any time. + */ +#define SDL_HINT_ANDROID_TRAP_BACK_BUTTON "SDL_ANDROID_TRAP_BACK_BUTTON" + +/** + * \brief A variable to control whether the event loop will block itself when the app is paused. + * + * The variable can be set to the following values: + * "0" - Non blocking. + * "1" - Blocking. (default) + * + * The value should be set before SDL is initialized. + */ +#define SDL_HINT_ANDROID_BLOCK_ON_PAUSE "SDL_ANDROID_BLOCK_ON_PAUSE" + + /** + * \brief A variable to control whether the return key on the soft keyboard + * should hide the soft keyboard on Android and iOS. + * + * The variable can be set to the following values: + * "0" - The return key will be handled as a key event. This is the behaviour of SDL <= 2.0.3. (default) + * "1" - The return key will hide the keyboard. + * + * The value of this hint is used at runtime, so it can be changed at any time. + */ +#define SDL_HINT_RETURN_KEY_HIDES_IME "SDL_RETURN_KEY_HIDES_IME" + +/** + * \brief override the binding element for keyboard inputs for Emscripten builds + * + * This hint only applies to the emscripten platform + * + * The variable can be one of + * "#window" - The javascript window object (this is the default) + * "#document" - The javascript document object + * "#screen" - the javascript window.screen object + * "#canvas" - the WebGL canvas element + * any other string without a leading # sign applies to the element on the page with that ID. + */ +#define SDL_HINT_EMSCRIPTEN_KEYBOARD_ELEMENT "SDL_EMSCRIPTEN_KEYBOARD_ELEMENT" + +/** + * \brief Tell SDL not to catch the SIGINT or SIGTERM signals. + * + * This hint only applies to Unix-like platforms. + * + * The variable can be set to the following values: + * "0" - SDL will install a SIGINT and SIGTERM handler, and when it + * catches a signal, convert it into an SDL_QUIT event. + * "1" - SDL will not install a signal handler at all. + */ +#define SDL_HINT_NO_SIGNAL_HANDLERS "SDL_NO_SIGNAL_HANDLERS" + +/** + * \brief Tell SDL not to generate window-close events for Alt+F4 on Windows. + * + * The variable can be set to the following values: + * "0" - SDL will generate a window-close event when it sees Alt+F4. + * "1" - SDL will only do normal key handling for Alt+F4. + */ +#define SDL_HINT_WINDOWS_NO_CLOSE_ON_ALT_F4 "SDL_WINDOWS_NO_CLOSE_ON_ALT_F4" + +/** + * \brief Prevent SDL from using version 4 of the bitmap header when saving BMPs. + * + * The bitmap header version 4 is required for proper alpha channel support and + * SDL will use it when required. Should this not be desired, this hint can + * force the use of the 40 byte header version which is supported everywhere. + * + * The variable can be set to the following values: + * "0" - Surfaces with a colorkey or an alpha channel are saved to a + * 32-bit BMP file with an alpha mask. SDL will use the bitmap + * header version 4 and set the alpha mask accordingly. + * "1" - Surfaces with a colorkey or an alpha channel are saved to a + * 32-bit BMP file without an alpha mask. The alpha channel data + * will be in the file, but applications are going to ignore it. + * + * The default value is "0". + */ +#define SDL_HINT_BMP_SAVE_LEGACY_FORMAT "SDL_BMP_SAVE_LEGACY_FORMAT" + +/** + * \brief Tell SDL not to name threads on Windows with the 0x406D1388 Exception. + * The 0x406D1388 Exception is a trick used to inform Visual Studio of a + * thread's name, but it tends to cause problems with other debuggers, + * and the .NET runtime. Note that SDL 2.0.6 and later will still use + * the (safer) SetThreadDescription API, introduced in the Windows 10 + * Creators Update, if available. + * + * The variable can be set to the following values: + * "0" - SDL will raise the 0x406D1388 Exception to name threads. + * This is the default behavior of SDL <= 2.0.4. + * "1" - SDL will not raise this exception, and threads will be unnamed. (default) + * This is necessary with .NET languages or debuggers that aren't Visual Studio. + */ +#define SDL_HINT_WINDOWS_DISABLE_THREAD_NAMING "SDL_WINDOWS_DISABLE_THREAD_NAMING" + +/** + * \brief Tell SDL which Dispmanx layer to use on a Raspberry PI + * + * Also known as Z-order. The variable can take a negative or positive value. + * The default is 10000. + */ +#define SDL_HINT_RPI_VIDEO_LAYER "SDL_RPI_VIDEO_LAYER" + +/** + * \brief Tell the video driver that we only want a double buffer. + * + * By default, most lowlevel 2D APIs will use a triple buffer scheme that + * wastes no CPU time on waiting for vsync after issuing a flip, but + * introduces a frame of latency. On the other hand, using a double buffer + * scheme instead is recommended for cases where low latency is an important + * factor because we save a whole frame of latency. + * We do so by waiting for vsync immediately after issuing a flip, usually just + * after eglSwapBuffers call in the backend's *_SwapWindow function. + * + * Since it's driver-specific, it's only supported where possible and + * implemented. Currently supported the following drivers: + * - KMSDRM (kmsdrm) + * - Raspberry Pi (raspberrypi) + */ +#define SDL_HINT_VIDEO_DOUBLE_BUFFER "SDL_VIDEO_DOUBLE_BUFFER" + +/** + * \brief A variable controlling what driver to use for OpenGL ES contexts. + * + * On some platforms, currently Windows and X11, OpenGL drivers may support + * creating contexts with an OpenGL ES profile. By default SDL uses these + * profiles, when available, otherwise it attempts to load an OpenGL ES + * library, e.g. that provided by the ANGLE project. This variable controls + * whether SDL follows this default behaviour or will always load an + * OpenGL ES library. + * + * Circumstances where this is useful include + * - Testing an app with a particular OpenGL ES implementation, e.g ANGLE, + * or emulator, e.g. those from ARM, Imagination or Qualcomm. + * - Resolving OpenGL ES function addresses at link time by linking with + * the OpenGL ES library instead of querying them at run time with + * SDL_GL_GetProcAddress(). + * + * Caution: for an application to work with the default behaviour across + * different OpenGL drivers it must query the OpenGL ES function + * addresses at run time using SDL_GL_GetProcAddress(). + * + * This variable is ignored on most platforms because OpenGL ES is native + * or not supported. + * + * This variable can be set to the following values: + * "0" - Use ES profile of OpenGL, if available. (Default when not set.) + * "1" - Load OpenGL ES library using the default library names. + * + */ +#define SDL_HINT_OPENGL_ES_DRIVER "SDL_OPENGL_ES_DRIVER" + +/** + * \brief A variable controlling speed/quality tradeoff of audio resampling. + * + * If available, SDL can use libsamplerate ( http://www.mega-nerd.com/SRC/ ) + * to handle audio resampling. There are different resampling modes available + * that produce different levels of quality, using more CPU. + * + * If this hint isn't specified to a valid setting, or libsamplerate isn't + * available, SDL will use the default, internal resampling algorithm. + * + * Note that this is currently only applicable to resampling audio that is + * being written to a device for playback or audio being read from a device + * for capture. SDL_AudioCVT always uses the default resampler (although this + * might change for SDL 2.1). + * + * This hint is currently only checked at audio subsystem initialization. + * + * This variable can be set to the following values: + * + * "0" or "default" - Use SDL's internal resampling (Default when not set - low quality, fast) + * "1" or "fast" - Use fast, slightly higher quality resampling, if available + * "2" or "medium" - Use medium quality resampling, if available + * "3" or "best" - Use high quality resampling, if available + */ +#define SDL_HINT_AUDIO_RESAMPLING_MODE "SDL_AUDIO_RESAMPLING_MODE" + +/** + * \brief A variable controlling the audio category on iOS and Mac OS X + * + * This variable can be set to the following values: + * + * "ambient" - Use the AVAudioSessionCategoryAmbient audio category, will be muted by the phone mute switch (default) + * "playback" - Use the AVAudioSessionCategoryPlayback category + * + * For more information, see Apple's documentation: + * https://developer.apple.com/library/content/documentation/Audio/Conceptual/AudioSessionProgrammingGuide/AudioSessionCategoriesandModes/AudioSessionCategoriesandModes.html + */ +#define SDL_HINT_AUDIO_CATEGORY "SDL_AUDIO_CATEGORY" + +/** + * \brief A variable controlling whether the 2D render API is compatible or efficient. + * + * This variable can be set to the following values: + * + * "0" - Don't use batching to make rendering more efficient. + * "1" - Use batching, but might cause problems if app makes its own direct OpenGL calls. + * + * Up to SDL 2.0.9, the render API would draw immediately when requested. Now + * it batches up draw requests and sends them all to the GPU only when forced + * to (during SDL_RenderPresent, when changing render targets, by updating a + * texture that the batch needs, etc). This is significantly more efficient, + * but it can cause problems for apps that expect to render on top of the + * render API's output. As such, SDL will disable batching if a specific + * render backend is requested (since this might indicate that the app is + * planning to use the underlying graphics API directly). This hint can + * be used to explicitly request batching in this instance. It is a contract + * that you will either never use the underlying graphics API directly, or + * if you do, you will call SDL_RenderFlush() before you do so any current + * batch goes to the GPU before your work begins. Not following this contract + * will result in undefined behavior. + */ +#define SDL_HINT_RENDER_BATCHING "SDL_RENDER_BATCHING" + + +/** + * \brief A variable controlling whether SDL logs all events pushed onto its internal queue. + * + * This variable can be set to the following values: + * + * "0" - Don't log any events (default) + * "1" - Log all events except mouse and finger motion, which are pretty spammy. + * "2" - Log all events. + * + * This is generally meant to be used to debug SDL itself, but can be useful + * for application developers that need better visibility into what is going + * on in the event queue. Logged events are sent through SDL_Log(), which + * means by default they appear on stdout on most platforms or maybe + * OutputDebugString() on Windows, and can be funneled by the app with + * SDL_LogSetOutputFunction(), etc. + * + * This hint can be toggled on and off at runtime, if you only need to log + * events for a small subset of program execution. + */ +#define SDL_HINT_EVENT_LOGGING "SDL_EVENT_LOGGING" + + + +/** + * \brief Controls how the size of the RIFF chunk affects the loading of a WAVE file. + * + * The size of the RIFF chunk (which includes all the sub-chunks of the WAVE + * file) is not always reliable. In case the size is wrong, it's possible to + * just ignore it and step through the chunks until a fixed limit is reached. + * + * Note that files that have trailing data unrelated to the WAVE file or + * corrupt files may slow down the loading process without a reliable boundary. + * By default, SDL stops after 10000 chunks to prevent wasting time. Use the + * environment variable SDL_WAVE_CHUNK_LIMIT to adjust this value. + * + * This variable can be set to the following values: + * + * "force" - Always use the RIFF chunk size as a boundary for the chunk search + * "ignorezero" - Like "force", but a zero size searches up to 4 GiB (default) + * "ignore" - Ignore the RIFF chunk size and always search up to 4 GiB + * "maximum" - Search for chunks until the end of file (not recommended) + */ +#define SDL_HINT_WAVE_RIFF_CHUNK_SIZE "SDL_WAVE_RIFF_CHUNK_SIZE" + +/** + * \brief Controls how a truncated WAVE file is handled. + * + * A WAVE file is considered truncated if any of the chunks are incomplete or + * the data chunk size is not a multiple of the block size. By default, SDL + * decodes until the first incomplete block, as most applications seem to do. + * + * This variable can be set to the following values: + * + * "verystrict" - Raise an error if the file is truncated + * "strict" - Like "verystrict", but the size of the RIFF chunk is ignored + * "dropframe" - Decode until the first incomplete sample frame + * "dropblock" - Decode until the first incomplete block (default) + */ +#define SDL_HINT_WAVE_TRUNCATION "SDL_WAVE_TRUNCATION" + +/** + * \brief Controls how the fact chunk affects the loading of a WAVE file. + * + * The fact chunk stores information about the number of samples of a WAVE + * file. The Standards Update from Microsoft notes that this value can be used + * to 'determine the length of the data in seconds'. This is especially useful + * for compressed formats (for which this is a mandatory chunk) if they produce + * multiple sample frames per block and truncating the block is not allowed. + * The fact chunk can exactly specify how many sample frames there should be + * in this case. + * + * Unfortunately, most application seem to ignore the fact chunk and so SDL + * ignores it by default as well. + * + * This variable can be set to the following values: + * + * "truncate" - Use the number of samples to truncate the wave data if + * the fact chunk is present and valid + * "strict" - Like "truncate", but raise an error if the fact chunk + * is invalid, not present for non-PCM formats, or if the + * data chunk doesn't have that many samples + * "ignorezero" - Like "truncate", but ignore fact chunk if the number of + * samples is zero + * "ignore" - Ignore fact chunk entirely (default) + */ +#define SDL_HINT_WAVE_FACT_CHUNK "SDL_WAVE_FACT_CHUNK" + +/** + * \brief An enumeration of hint priorities + */ +typedef enum +{ + SDL_HINT_DEFAULT, + SDL_HINT_NORMAL, + SDL_HINT_OVERRIDE +} SDL_HintPriority; + + +/** + * \brief Set a hint with a specific priority + * + * The priority controls the behavior when setting a hint that already + * has a value. Hints will replace existing hints of their priority and + * lower. Environment variables are considered to have override priority. + * + * \return SDL_TRUE if the hint was set, SDL_FALSE otherwise + */ +extern DECLSPEC SDL_bool SDLCALL SDL_SetHintWithPriority(const char *name, + const char *value, + SDL_HintPriority priority); + +/** + * \brief Set a hint with normal priority + * + * \return SDL_TRUE if the hint was set, SDL_FALSE otherwise + */ +extern DECLSPEC SDL_bool SDLCALL SDL_SetHint(const char *name, + const char *value); + +/** + * \brief Get a hint + * + * \return The string value of a hint variable. + */ +extern DECLSPEC const char * SDLCALL SDL_GetHint(const char *name); + +/** + * \brief Get a hint + * + * \return The boolean value of a hint variable. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_GetHintBoolean(const char *name, SDL_bool default_value); + +/** + * \brief type definition of the hint callback function. + */ +typedef void (SDLCALL *SDL_HintCallback)(void *userdata, const char *name, const char *oldValue, const char *newValue); + +/** + * \brief Add a function to watch a particular hint + * + * \param name The hint to watch + * \param callback The function to call when the hint value changes + * \param userdata A pointer to pass to the callback function + */ +extern DECLSPEC void SDLCALL SDL_AddHintCallback(const char *name, + SDL_HintCallback callback, + void *userdata); + +/** + * \brief Remove a function watching a particular hint + * + * \param name The hint being watched + * \param callback The function being called when the hint value changes + * \param userdata A pointer being passed to the callback function + */ +extern DECLSPEC void SDLCALL SDL_DelHintCallback(const char *name, + SDL_HintCallback callback, + void *userdata); + +/** + * \brief Clear all hints + * + * This function is called during SDL_Quit() to free stored hints. + */ +extern DECLSPEC void SDLCALL SDL_ClearHints(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_hints_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_joystick.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_joystick.h new file mode 100644 index 0000000..3a4c5d1 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_joystick.h @@ -0,0 +1,408 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_joystick.h + * + * Include file for SDL joystick event handling + * + * The term "device_index" identifies currently plugged in joystick devices between 0 and SDL_NumJoysticks(), with the exact joystick + * behind a device_index changing as joysticks are plugged and unplugged. + * + * The term "instance_id" is the current instantiation of a joystick device in the system, if the joystick is removed and then re-inserted + * then it will get a new instance_id, instance_id's are monotonically increasing identifiers of a joystick plugged in. + * + * The term JoystickGUID is a stable 128-bit identifier for a joystick device that does not change over time, it identifies class of + * the device (a X360 wired controller for example). This identifier is platform dependent. + * + * + */ + +#ifndef SDL_joystick_h_ +#define SDL_joystick_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \file SDL_joystick.h + * + * In order to use these functions, SDL_Init() must have been called + * with the ::SDL_INIT_JOYSTICK flag. This causes SDL to scan the system + * for joysticks, and load appropriate drivers. + * + * If you would like to receive joystick updates while the application + * is in the background, you should set the following hint before calling + * SDL_Init(): SDL_HINT_JOYSTICK_ALLOW_BACKGROUND_EVENTS + */ + +/** + * The joystick structure used to identify an SDL joystick + */ +struct _SDL_Joystick; +typedef struct _SDL_Joystick SDL_Joystick; + +/* A structure that encodes the stable unique id for a joystick device */ +typedef struct { + Uint8 data[16]; +} SDL_JoystickGUID; + +/** + * This is a unique ID for a joystick for the time it is connected to the system, + * and is never reused for the lifetime of the application. If the joystick is + * disconnected and reconnected, it will get a new ID. + * + * The ID value starts at 0 and increments from there. The value -1 is an invalid ID. + */ +typedef Sint32 SDL_JoystickID; + +typedef enum +{ + SDL_JOYSTICK_TYPE_UNKNOWN, + SDL_JOYSTICK_TYPE_GAMECONTROLLER, + SDL_JOYSTICK_TYPE_WHEEL, + SDL_JOYSTICK_TYPE_ARCADE_STICK, + SDL_JOYSTICK_TYPE_FLIGHT_STICK, + SDL_JOYSTICK_TYPE_DANCE_PAD, + SDL_JOYSTICK_TYPE_GUITAR, + SDL_JOYSTICK_TYPE_DRUM_KIT, + SDL_JOYSTICK_TYPE_ARCADE_PAD, + SDL_JOYSTICK_TYPE_THROTTLE +} SDL_JoystickType; + +typedef enum +{ + SDL_JOYSTICK_POWER_UNKNOWN = -1, + SDL_JOYSTICK_POWER_EMPTY, /* <= 5% */ + SDL_JOYSTICK_POWER_LOW, /* <= 20% */ + SDL_JOYSTICK_POWER_MEDIUM, /* <= 70% */ + SDL_JOYSTICK_POWER_FULL, /* <= 100% */ + SDL_JOYSTICK_POWER_WIRED, + SDL_JOYSTICK_POWER_MAX +} SDL_JoystickPowerLevel; + +/* Function prototypes */ + +/** + * Locking for multi-threaded access to the joystick API + * + * If you are using the joystick API or handling events from multiple threads + * you should use these locking functions to protect access to the joysticks. + * + * In particular, you are guaranteed that the joystick list won't change, so + * the API functions that take a joystick index will be valid, and joystick + * and game controller events will not be delivered. + */ +extern DECLSPEC void SDLCALL SDL_LockJoysticks(void); +extern DECLSPEC void SDLCALL SDL_UnlockJoysticks(void); + +/** + * Count the number of joysticks attached to the system right now + */ +extern DECLSPEC int SDLCALL SDL_NumJoysticks(void); + +/** + * Get the implementation dependent name of a joystick. + * This can be called before any joysticks are opened. + * If no name can be found, this function returns NULL. + */ +extern DECLSPEC const char *SDLCALL SDL_JoystickNameForIndex(int device_index); + +/** + * Get the player index of a joystick, or -1 if it's not available + * This can be called before any joysticks are opened. + */ +extern DECLSPEC int SDLCALL SDL_JoystickGetDevicePlayerIndex(int device_index); + +/** + * Return the GUID for the joystick at this index + * This can be called before any joysticks are opened. + */ +extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetDeviceGUID(int device_index); + +/** + * Get the USB vendor ID of a joystick, if available. + * This can be called before any joysticks are opened. + * If the vendor ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetDeviceVendor(int device_index); + +/** + * Get the USB product ID of a joystick, if available. + * This can be called before any joysticks are opened. + * If the product ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetDeviceProduct(int device_index); + +/** + * Get the product version of a joystick, if available. + * This can be called before any joysticks are opened. + * If the product version isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetDeviceProductVersion(int device_index); + +/** + * Get the type of a joystick, if available. + * This can be called before any joysticks are opened. + */ +extern DECLSPEC SDL_JoystickType SDLCALL SDL_JoystickGetDeviceType(int device_index); + +/** + * Get the instance ID of a joystick. + * This can be called before any joysticks are opened. + * If the index is out of range, this function will return -1. + */ +extern DECLSPEC SDL_JoystickID SDLCALL SDL_JoystickGetDeviceInstanceID(int device_index); + +/** + * Open a joystick for use. + * The index passed as an argument refers to the N'th joystick on the system. + * This index is not the value which will identify this joystick in future + * joystick events. The joystick's instance id (::SDL_JoystickID) will be used + * there instead. + * + * \return A joystick identifier, or NULL if an error occurred. + */ +extern DECLSPEC SDL_Joystick *SDLCALL SDL_JoystickOpen(int device_index); + +/** + * Return the SDL_Joystick associated with an instance id. + */ +extern DECLSPEC SDL_Joystick *SDLCALL SDL_JoystickFromInstanceID(SDL_JoystickID joyid); + +/** + * Return the name for this currently opened joystick. + * If no name can be found, this function returns NULL. + */ +extern DECLSPEC const char *SDLCALL SDL_JoystickName(SDL_Joystick * joystick); + +/** + * Get the player index of an opened joystick, or -1 if it's not available + * + * For XInput controllers this returns the XInput user index. + */ +extern DECLSPEC int SDLCALL SDL_JoystickGetPlayerIndex(SDL_Joystick * joystick); + +/** + * Return the GUID for this opened joystick + */ +extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUID(SDL_Joystick * joystick); + +/** + * Get the USB vendor ID of an opened joystick, if available. + * If the vendor ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetVendor(SDL_Joystick * joystick); + +/** + * Get the USB product ID of an opened joystick, if available. + * If the product ID isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetProduct(SDL_Joystick * joystick); + +/** + * Get the product version of an opened joystick, if available. + * If the product version isn't available this function returns 0. + */ +extern DECLSPEC Uint16 SDLCALL SDL_JoystickGetProductVersion(SDL_Joystick * joystick); + +/** + * Get the type of an opened joystick. + */ +extern DECLSPEC SDL_JoystickType SDLCALL SDL_JoystickGetType(SDL_Joystick * joystick); + +/** + * Return a string representation for this guid. pszGUID must point to at least 33 bytes + * (32 for the string plus a NULL terminator). + */ +extern DECLSPEC void SDLCALL SDL_JoystickGetGUIDString(SDL_JoystickGUID guid, char *pszGUID, int cbGUID); + +/** + * Convert a string into a joystick guid + */ +extern DECLSPEC SDL_JoystickGUID SDLCALL SDL_JoystickGetGUIDFromString(const char *pchGUID); + +/** + * Returns SDL_TRUE if the joystick has been opened and currently connected, or SDL_FALSE if it has not. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_JoystickGetAttached(SDL_Joystick * joystick); + +/** + * Get the instance ID of an opened joystick or -1 if the joystick is invalid. + */ +extern DECLSPEC SDL_JoystickID SDLCALL SDL_JoystickInstanceID(SDL_Joystick * joystick); + +/** + * Get the number of general axis controls on a joystick. + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumAxes(SDL_Joystick * joystick); + +/** + * Get the number of trackballs on a joystick. + * + * Joystick trackballs have only relative motion events associated + * with them and their state cannot be polled. + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumBalls(SDL_Joystick * joystick); + +/** + * Get the number of POV hats on a joystick. + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumHats(SDL_Joystick * joystick); + +/** + * Get the number of buttons on a joystick. + */ +extern DECLSPEC int SDLCALL SDL_JoystickNumButtons(SDL_Joystick * joystick); + +/** + * Update the current state of the open joysticks. + * + * This is called automatically by the event loop if any joystick + * events are enabled. + */ +extern DECLSPEC void SDLCALL SDL_JoystickUpdate(void); + +/** + * Enable/disable joystick event polling. + * + * If joystick events are disabled, you must call SDL_JoystickUpdate() + * yourself and check the state of the joystick when you want joystick + * information. + * + * The state can be one of ::SDL_QUERY, ::SDL_ENABLE or ::SDL_IGNORE. + */ +extern DECLSPEC int SDLCALL SDL_JoystickEventState(int state); + +#define SDL_JOYSTICK_AXIS_MAX 32767 +#define SDL_JOYSTICK_AXIS_MIN -32768 +/** + * Get the current state of an axis control on a joystick. + * + * The state is a value ranging from -32768 to 32767. + * + * The axis indices start at index 0. + */ +extern DECLSPEC Sint16 SDLCALL SDL_JoystickGetAxis(SDL_Joystick * joystick, + int axis); + +/** + * Get the initial state of an axis control on a joystick. + * + * The state is a value ranging from -32768 to 32767. + * + * The axis indices start at index 0. + * + * \return SDL_TRUE if this axis has any initial value, or SDL_FALSE if not. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_JoystickGetAxisInitialState(SDL_Joystick * joystick, + int axis, Sint16 *state); + +/** + * \name Hat positions + */ +/* @{ */ +#define SDL_HAT_CENTERED 0x00 +#define SDL_HAT_UP 0x01 +#define SDL_HAT_RIGHT 0x02 +#define SDL_HAT_DOWN 0x04 +#define SDL_HAT_LEFT 0x08 +#define SDL_HAT_RIGHTUP (SDL_HAT_RIGHT|SDL_HAT_UP) +#define SDL_HAT_RIGHTDOWN (SDL_HAT_RIGHT|SDL_HAT_DOWN) +#define SDL_HAT_LEFTUP (SDL_HAT_LEFT|SDL_HAT_UP) +#define SDL_HAT_LEFTDOWN (SDL_HAT_LEFT|SDL_HAT_DOWN) +/* @} */ + +/** + * Get the current state of a POV hat on a joystick. + * + * The hat indices start at index 0. + * + * \return The return value is one of the following positions: + * - ::SDL_HAT_CENTERED + * - ::SDL_HAT_UP + * - ::SDL_HAT_RIGHT + * - ::SDL_HAT_DOWN + * - ::SDL_HAT_LEFT + * - ::SDL_HAT_RIGHTUP + * - ::SDL_HAT_RIGHTDOWN + * - ::SDL_HAT_LEFTUP + * - ::SDL_HAT_LEFTDOWN + */ +extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetHat(SDL_Joystick * joystick, + int hat); + +/** + * Get the ball axis change since the last poll. + * + * \return 0, or -1 if you passed it invalid parameters. + * + * The ball indices start at index 0. + */ +extern DECLSPEC int SDLCALL SDL_JoystickGetBall(SDL_Joystick * joystick, + int ball, int *dx, int *dy); + +/** + * Get the current state of a button on a joystick. + * + * The button indices start at index 0. + */ +extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetButton(SDL_Joystick * joystick, + int button); + +/** + * Trigger a rumble effect + * Each call to this function cancels any previous rumble effect, and calling it with 0 intensity stops any rumbling. + * + * \param joystick The joystick to vibrate + * \param low_frequency_rumble The intensity of the low frequency (left) rumble motor, from 0 to 0xFFFF + * \param high_frequency_rumble The intensity of the high frequency (right) rumble motor, from 0 to 0xFFFF + * \param duration_ms The duration of the rumble effect, in milliseconds + * + * \return 0, or -1 if rumble isn't supported on this joystick + */ +extern DECLSPEC int SDLCALL SDL_JoystickRumble(SDL_Joystick * joystick, Uint16 low_frequency_rumble, Uint16 high_frequency_rumble, Uint32 duration_ms); + +/** + * Close a joystick previously opened with SDL_JoystickOpen(). + */ +extern DECLSPEC void SDLCALL SDL_JoystickClose(SDL_Joystick * joystick); + +/** + * Return the battery level of this joystick + */ +extern DECLSPEC SDL_JoystickPowerLevel SDLCALL SDL_JoystickCurrentPowerLevel(SDL_Joystick * joystick); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_joystick_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keyboard.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keyboard.h new file mode 100644 index 0000000..4b2a055 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keyboard.h @@ -0,0 +1,217 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_keyboard.h + * + * Include file for SDL keyboard event handling + */ + +#ifndef SDL_keyboard_h_ +#define SDL_keyboard_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_keycode.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief The SDL keysym structure, used in key events. + * + * \note If you are looking for translated character input, see the ::SDL_TEXTINPUT event. + */ +typedef struct SDL_Keysym +{ + SDL_Scancode scancode; /**< SDL physical key code - see ::SDL_Scancode for details */ + SDL_Keycode sym; /**< SDL virtual key code - see ::SDL_Keycode for details */ + Uint16 mod; /**< current key modifiers */ + Uint32 unused; +} SDL_Keysym; + +/* Function prototypes */ + +/** + * \brief Get the window which currently has keyboard focus. + */ +extern DECLSPEC SDL_Window * SDLCALL SDL_GetKeyboardFocus(void); + +/** + * \brief Get a snapshot of the current state of the keyboard. + * + * \param numkeys if non-NULL, receives the length of the returned array. + * + * \return An array of key states. Indexes into this array are obtained by using ::SDL_Scancode values. + * + * \b Example: + * \code + * const Uint8 *state = SDL_GetKeyboardState(NULL); + * if ( state[SDL_SCANCODE_RETURN] ) { + * printf(" is pressed.\n"); + * } + * \endcode + */ +extern DECLSPEC const Uint8 *SDLCALL SDL_GetKeyboardState(int *numkeys); + +/** + * \brief Get the current key modifier state for the keyboard. + */ +extern DECLSPEC SDL_Keymod SDLCALL SDL_GetModState(void); + +/** + * \brief Set the current key modifier state for the keyboard. + * + * \note This does not change the keyboard state, only the key modifier flags. + */ +extern DECLSPEC void SDLCALL SDL_SetModState(SDL_Keymod modstate); + +/** + * \brief Get the key code corresponding to the given scancode according + * to the current keyboard layout. + * + * See ::SDL_Keycode for details. + * + * \sa SDL_GetKeyName() + */ +extern DECLSPEC SDL_Keycode SDLCALL SDL_GetKeyFromScancode(SDL_Scancode scancode); + +/** + * \brief Get the scancode corresponding to the given key code according to the + * current keyboard layout. + * + * See ::SDL_Scancode for details. + * + * \sa SDL_GetScancodeName() + */ +extern DECLSPEC SDL_Scancode SDLCALL SDL_GetScancodeFromKey(SDL_Keycode key); + +/** + * \brief Get a human-readable name for a scancode. + * + * \return A pointer to the name for the scancode. + * If the scancode doesn't have a name, this function returns + * an empty string (""). + * + * \sa SDL_Scancode + */ +extern DECLSPEC const char *SDLCALL SDL_GetScancodeName(SDL_Scancode scancode); + +/** + * \brief Get a scancode from a human-readable name + * + * \return scancode, or SDL_SCANCODE_UNKNOWN if the name wasn't recognized + * + * \sa SDL_Scancode + */ +extern DECLSPEC SDL_Scancode SDLCALL SDL_GetScancodeFromName(const char *name); + +/** + * \brief Get a human-readable name for a key. + * + * \return A pointer to a UTF-8 string that stays valid at least until the next + * call to this function. If you need it around any longer, you must + * copy it. If the key doesn't have a name, this function returns an + * empty string (""). + * + * \sa SDL_Keycode + */ +extern DECLSPEC const char *SDLCALL SDL_GetKeyName(SDL_Keycode key); + +/** + * \brief Get a key code from a human-readable name + * + * \return key code, or SDLK_UNKNOWN if the name wasn't recognized + * + * \sa SDL_Keycode + */ +extern DECLSPEC SDL_Keycode SDLCALL SDL_GetKeyFromName(const char *name); + +/** + * \brief Start accepting Unicode text input events. + * This function will show the on-screen keyboard if supported. + * + * \sa SDL_StopTextInput() + * \sa SDL_SetTextInputRect() + * \sa SDL_HasScreenKeyboardSupport() + */ +extern DECLSPEC void SDLCALL SDL_StartTextInput(void); + +/** + * \brief Return whether or not Unicode text input events are enabled. + * + * \sa SDL_StartTextInput() + * \sa SDL_StopTextInput() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsTextInputActive(void); + +/** + * \brief Stop receiving any text input events. + * This function will hide the on-screen keyboard if supported. + * + * \sa SDL_StartTextInput() + * \sa SDL_HasScreenKeyboardSupport() + */ +extern DECLSPEC void SDLCALL SDL_StopTextInput(void); + +/** + * \brief Set the rectangle used to type Unicode text inputs. + * This is used as a hint for IME and on-screen keyboard placement. + * + * \sa SDL_StartTextInput() + */ +extern DECLSPEC void SDLCALL SDL_SetTextInputRect(SDL_Rect *rect); + +/** + * \brief Returns whether the platform has some screen keyboard support. + * + * \return SDL_TRUE if some keyboard support is available else SDL_FALSE. + * + * \note Not all screen keyboard functions are supported on all platforms. + * + * \sa SDL_IsScreenKeyboardShown() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasScreenKeyboardSupport(void); + +/** + * \brief Returns whether the screen keyboard is shown for given window. + * + * \param window The window for which screen keyboard should be queried. + * + * \return SDL_TRUE if screen keyboard is shown else SDL_FALSE. + * + * \sa SDL_HasScreenKeyboardSupport() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsScreenKeyboardShown(SDL_Window *window); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_keyboard_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keycode.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keycode.h new file mode 100644 index 0000000..3bceb41 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_keycode.h @@ -0,0 +1,349 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_keycode.h + * + * Defines constants which identify keyboard keys and modifiers. + */ + +#ifndef SDL_keycode_h_ +#define SDL_keycode_h_ + +#include "SDL_stdinc.h" +#include "SDL_scancode.h" + +/** + * \brief The SDL virtual key representation. + * + * Values of this type are used to represent keyboard keys using the current + * layout of the keyboard. These values include Unicode values representing + * the unmodified character that would be generated by pressing the key, or + * an SDLK_* constant for those keys that do not generate characters. + * + * A special exception is the number keys at the top of the keyboard which + * always map to SDLK_0...SDLK_9, regardless of layout. + */ +typedef Sint32 SDL_Keycode; + +#define SDLK_SCANCODE_MASK (1<<30) +#define SDL_SCANCODE_TO_KEYCODE(X) (X | SDLK_SCANCODE_MASK) + +enum +{ + SDLK_UNKNOWN = 0, + + SDLK_RETURN = '\r', + SDLK_ESCAPE = '\033', + SDLK_BACKSPACE = '\b', + SDLK_TAB = '\t', + SDLK_SPACE = ' ', + SDLK_EXCLAIM = '!', + SDLK_QUOTEDBL = '"', + SDLK_HASH = '#', + SDLK_PERCENT = '%', + SDLK_DOLLAR = '$', + SDLK_AMPERSAND = '&', + SDLK_QUOTE = '\'', + SDLK_LEFTPAREN = '(', + SDLK_RIGHTPAREN = ')', + SDLK_ASTERISK = '*', + SDLK_PLUS = '+', + SDLK_COMMA = ',', + SDLK_MINUS = '-', + SDLK_PERIOD = '.', + SDLK_SLASH = '/', + SDLK_0 = '0', + SDLK_1 = '1', + SDLK_2 = '2', + SDLK_3 = '3', + SDLK_4 = '4', + SDLK_5 = '5', + SDLK_6 = '6', + SDLK_7 = '7', + SDLK_8 = '8', + SDLK_9 = '9', + SDLK_COLON = ':', + SDLK_SEMICOLON = ';', + SDLK_LESS = '<', + SDLK_EQUALS = '=', + SDLK_GREATER = '>', + SDLK_QUESTION = '?', + SDLK_AT = '@', + /* + Skip uppercase letters + */ + SDLK_LEFTBRACKET = '[', + SDLK_BACKSLASH = '\\', + SDLK_RIGHTBRACKET = ']', + SDLK_CARET = '^', + SDLK_UNDERSCORE = '_', + SDLK_BACKQUOTE = '`', + SDLK_a = 'a', + SDLK_b = 'b', + SDLK_c = 'c', + SDLK_d = 'd', + SDLK_e = 'e', + SDLK_f = 'f', + SDLK_g = 'g', + SDLK_h = 'h', + SDLK_i = 'i', + SDLK_j = 'j', + SDLK_k = 'k', + SDLK_l = 'l', + SDLK_m = 'm', + SDLK_n = 'n', + SDLK_o = 'o', + SDLK_p = 'p', + SDLK_q = 'q', + SDLK_r = 'r', + SDLK_s = 's', + SDLK_t = 't', + SDLK_u = 'u', + SDLK_v = 'v', + SDLK_w = 'w', + SDLK_x = 'x', + SDLK_y = 'y', + SDLK_z = 'z', + + SDLK_CAPSLOCK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CAPSLOCK), + + SDLK_F1 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F1), + SDLK_F2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F2), + SDLK_F3 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F3), + SDLK_F4 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F4), + SDLK_F5 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F5), + SDLK_F6 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F6), + SDLK_F7 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F7), + SDLK_F8 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F8), + SDLK_F9 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F9), + SDLK_F10 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F10), + SDLK_F11 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F11), + SDLK_F12 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F12), + + SDLK_PRINTSCREEN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PRINTSCREEN), + SDLK_SCROLLLOCK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SCROLLLOCK), + SDLK_PAUSE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAUSE), + SDLK_INSERT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_INSERT), + SDLK_HOME = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_HOME), + SDLK_PAGEUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAGEUP), + SDLK_DELETE = '\177', + SDLK_END = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_END), + SDLK_PAGEDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAGEDOWN), + SDLK_RIGHT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RIGHT), + SDLK_LEFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LEFT), + SDLK_DOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DOWN), + SDLK_UP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UP), + + SDLK_NUMLOCKCLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_NUMLOCKCLEAR), + SDLK_KP_DIVIDE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DIVIDE), + SDLK_KP_MULTIPLY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MULTIPLY), + SDLK_KP_MINUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MINUS), + SDLK_KP_PLUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUS), + SDLK_KP_ENTER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_ENTER), + SDLK_KP_1 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_1), + SDLK_KP_2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_2), + SDLK_KP_3 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_3), + SDLK_KP_4 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_4), + SDLK_KP_5 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_5), + SDLK_KP_6 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_6), + SDLK_KP_7 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_7), + SDLK_KP_8 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_8), + SDLK_KP_9 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_9), + SDLK_KP_0 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_0), + SDLK_KP_PERIOD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERIOD), + + SDLK_APPLICATION = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APPLICATION), + SDLK_POWER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_POWER), + SDLK_KP_EQUALS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALS), + SDLK_F13 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F13), + SDLK_F14 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F14), + SDLK_F15 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F15), + SDLK_F16 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F16), + SDLK_F17 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F17), + SDLK_F18 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F18), + SDLK_F19 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F19), + SDLK_F20 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F20), + SDLK_F21 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F21), + SDLK_F22 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F22), + SDLK_F23 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F23), + SDLK_F24 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F24), + SDLK_EXECUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EXECUTE), + SDLK_HELP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_HELP), + SDLK_MENU = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MENU), + SDLK_SELECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SELECT), + SDLK_STOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_STOP), + SDLK_AGAIN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AGAIN), + SDLK_UNDO = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UNDO), + SDLK_CUT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CUT), + SDLK_COPY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_COPY), + SDLK_PASTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PASTE), + SDLK_FIND = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_FIND), + SDLK_MUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MUTE), + SDLK_VOLUMEUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEUP), + SDLK_VOLUMEDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEDOWN), + SDLK_KP_COMMA = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COMMA), + SDLK_KP_EQUALSAS400 = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALSAS400), + + SDLK_ALTERASE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_ALTERASE), + SDLK_SYSREQ = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SYSREQ), + SDLK_CANCEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CANCEL), + SDLK_CLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CLEAR), + SDLK_PRIOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PRIOR), + SDLK_RETURN2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RETURN2), + SDLK_SEPARATOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SEPARATOR), + SDLK_OUT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_OUT), + SDLK_OPER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_OPER), + SDLK_CLEARAGAIN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CLEARAGAIN), + SDLK_CRSEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CRSEL), + SDLK_EXSEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EXSEL), + + SDLK_KP_00 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_00), + SDLK_KP_000 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_000), + SDLK_THOUSANDSSEPARATOR = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_THOUSANDSSEPARATOR), + SDLK_DECIMALSEPARATOR = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DECIMALSEPARATOR), + SDLK_CURRENCYUNIT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYUNIT), + SDLK_CURRENCYSUBUNIT = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYSUBUNIT), + SDLK_KP_LEFTPAREN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTPAREN), + SDLK_KP_RIGHTPAREN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTPAREN), + SDLK_KP_LEFTBRACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTBRACE), + SDLK_KP_RIGHTBRACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTBRACE), + SDLK_KP_TAB = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_TAB), + SDLK_KP_BACKSPACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BACKSPACE), + SDLK_KP_A = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_A), + SDLK_KP_B = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_B), + SDLK_KP_C = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_C), + SDLK_KP_D = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_D), + SDLK_KP_E = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_E), + SDLK_KP_F = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_F), + SDLK_KP_XOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_XOR), + SDLK_KP_POWER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_POWER), + SDLK_KP_PERCENT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERCENT), + SDLK_KP_LESS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LESS), + SDLK_KP_GREATER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_GREATER), + SDLK_KP_AMPERSAND = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AMPERSAND), + SDLK_KP_DBLAMPERSAND = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLAMPERSAND), + SDLK_KP_VERTICALBAR = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_VERTICALBAR), + SDLK_KP_DBLVERTICALBAR = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLVERTICALBAR), + SDLK_KP_COLON = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COLON), + SDLK_KP_HASH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_HASH), + SDLK_KP_SPACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_SPACE), + SDLK_KP_AT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AT), + SDLK_KP_EXCLAM = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EXCLAM), + SDLK_KP_MEMSTORE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSTORE), + SDLK_KP_MEMRECALL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMRECALL), + SDLK_KP_MEMCLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMCLEAR), + SDLK_KP_MEMADD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMADD), + SDLK_KP_MEMSUBTRACT = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSUBTRACT), + SDLK_KP_MEMMULTIPLY = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMMULTIPLY), + SDLK_KP_MEMDIVIDE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMDIVIDE), + SDLK_KP_PLUSMINUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUSMINUS), + SDLK_KP_CLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEAR), + SDLK_KP_CLEARENTRY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEARENTRY), + SDLK_KP_BINARY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BINARY), + SDLK_KP_OCTAL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_OCTAL), + SDLK_KP_DECIMAL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DECIMAL), + SDLK_KP_HEXADECIMAL = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_HEXADECIMAL), + + SDLK_LCTRL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LCTRL), + SDLK_LSHIFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LSHIFT), + SDLK_LALT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LALT), + SDLK_LGUI = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LGUI), + SDLK_RCTRL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RCTRL), + SDLK_RSHIFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RSHIFT), + SDLK_RALT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RALT), + SDLK_RGUI = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RGUI), + + SDLK_MODE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MODE), + + SDLK_AUDIONEXT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIONEXT), + SDLK_AUDIOPREV = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOPREV), + SDLK_AUDIOSTOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOSTOP), + SDLK_AUDIOPLAY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOPLAY), + SDLK_AUDIOMUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOMUTE), + SDLK_MEDIASELECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MEDIASELECT), + SDLK_WWW = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_WWW), + SDLK_MAIL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MAIL), + SDLK_CALCULATOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CALCULATOR), + SDLK_COMPUTER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_COMPUTER), + SDLK_AC_SEARCH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_SEARCH), + SDLK_AC_HOME = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_HOME), + SDLK_AC_BACK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_BACK), + SDLK_AC_FORWARD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_FORWARD), + SDLK_AC_STOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_STOP), + SDLK_AC_REFRESH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_REFRESH), + SDLK_AC_BOOKMARKS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_BOOKMARKS), + + SDLK_BRIGHTNESSDOWN = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_BRIGHTNESSDOWN), + SDLK_BRIGHTNESSUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_BRIGHTNESSUP), + SDLK_DISPLAYSWITCH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DISPLAYSWITCH), + SDLK_KBDILLUMTOGGLE = + SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMTOGGLE), + SDLK_KBDILLUMDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMDOWN), + SDLK_KBDILLUMUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMUP), + SDLK_EJECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EJECT), + SDLK_SLEEP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SLEEP), + SDLK_APP1 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APP1), + SDLK_APP2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APP2), + + SDLK_AUDIOREWIND = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOREWIND), + SDLK_AUDIOFASTFORWARD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOFASTFORWARD) +}; + +/** + * \brief Enumeration of valid key mods (possibly OR'd together). + */ +typedef enum +{ + KMOD_NONE = 0x0000, + KMOD_LSHIFT = 0x0001, + KMOD_RSHIFT = 0x0002, + KMOD_LCTRL = 0x0040, + KMOD_RCTRL = 0x0080, + KMOD_LALT = 0x0100, + KMOD_RALT = 0x0200, + KMOD_LGUI = 0x0400, + KMOD_RGUI = 0x0800, + KMOD_NUM = 0x1000, + KMOD_CAPS = 0x2000, + KMOD_MODE = 0x4000, + KMOD_RESERVED = 0x8000 +} SDL_Keymod; + +#define KMOD_CTRL (KMOD_LCTRL|KMOD_RCTRL) +#define KMOD_SHIFT (KMOD_LSHIFT|KMOD_RSHIFT) +#define KMOD_ALT (KMOD_LALT|KMOD_RALT) +#define KMOD_GUI (KMOD_LGUI|KMOD_RGUI) + +#endif /* SDL_keycode_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_loadso.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_loadso.h new file mode 100644 index 0000000..793ba53 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_loadso.h @@ -0,0 +1,81 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_loadso.h + * + * System dependent library loading routines + * + * Some things to keep in mind: + * \li These functions only work on C function names. Other languages may + * have name mangling and intrinsic language support that varies from + * compiler to compiler. + * \li Make sure you declare your function pointers with the same calling + * convention as the actual library function. Your code will crash + * mysteriously if you do not do this. + * \li Avoid namespace collisions. If you load a symbol from the library, + * it is not defined whether or not it goes into the global symbol + * namespace for the application. If it does and it conflicts with + * symbols in your code or other shared libraries, you will not get + * the results you expect. :) + */ + +#ifndef SDL_loadso_h_ +#define SDL_loadso_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * This function dynamically loads a shared object and returns a pointer + * to the object handle (or NULL if there was an error). + * The 'sofile' parameter is a system dependent name of the object file. + */ +extern DECLSPEC void *SDLCALL SDL_LoadObject(const char *sofile); + +/** + * Given an object handle, this function looks up the address of the + * named function in the shared object and returns it. This address + * is no longer valid after calling SDL_UnloadObject(). + */ +extern DECLSPEC void *SDLCALL SDL_LoadFunction(void *handle, + const char *name); + +/** + * Unload a shared object from memory. + */ +extern DECLSPEC void SDLCALL SDL_UnloadObject(void *handle); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_loadso_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_log.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_log.h new file mode 100644 index 0000000..40f768d --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_log.h @@ -0,0 +1,211 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_log.h + * + * Simple log messages with categories and priorities. + * + * By default logs are quiet, but if you're debugging SDL you might want: + * + * SDL_LogSetAllPriority(SDL_LOG_PRIORITY_WARN); + * + * Here's where the messages go on different platforms: + * Windows: debug output stream + * Android: log output + * Others: standard error output (stderr) + */ + +#ifndef SDL_log_h_ +#define SDL_log_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/** + * \brief The maximum size of a log message + * + * Messages longer than the maximum size will be truncated + */ +#define SDL_MAX_LOG_MESSAGE 4096 + +/** + * \brief The predefined log categories + * + * By default the application category is enabled at the INFO level, + * the assert category is enabled at the WARN level, test is enabled + * at the VERBOSE level and all other categories are enabled at the + * CRITICAL level. + */ +enum +{ + SDL_LOG_CATEGORY_APPLICATION, + SDL_LOG_CATEGORY_ERROR, + SDL_LOG_CATEGORY_ASSERT, + SDL_LOG_CATEGORY_SYSTEM, + SDL_LOG_CATEGORY_AUDIO, + SDL_LOG_CATEGORY_VIDEO, + SDL_LOG_CATEGORY_RENDER, + SDL_LOG_CATEGORY_INPUT, + SDL_LOG_CATEGORY_TEST, + + /* Reserved for future SDL library use */ + SDL_LOG_CATEGORY_RESERVED1, + SDL_LOG_CATEGORY_RESERVED2, + SDL_LOG_CATEGORY_RESERVED3, + SDL_LOG_CATEGORY_RESERVED4, + SDL_LOG_CATEGORY_RESERVED5, + SDL_LOG_CATEGORY_RESERVED6, + SDL_LOG_CATEGORY_RESERVED7, + SDL_LOG_CATEGORY_RESERVED8, + SDL_LOG_CATEGORY_RESERVED9, + SDL_LOG_CATEGORY_RESERVED10, + + /* Beyond this point is reserved for application use, e.g. + enum { + MYAPP_CATEGORY_AWESOME1 = SDL_LOG_CATEGORY_CUSTOM, + MYAPP_CATEGORY_AWESOME2, + MYAPP_CATEGORY_AWESOME3, + ... + }; + */ + SDL_LOG_CATEGORY_CUSTOM +}; + +/** + * \brief The predefined log priorities + */ +typedef enum +{ + SDL_LOG_PRIORITY_VERBOSE = 1, + SDL_LOG_PRIORITY_DEBUG, + SDL_LOG_PRIORITY_INFO, + SDL_LOG_PRIORITY_WARN, + SDL_LOG_PRIORITY_ERROR, + SDL_LOG_PRIORITY_CRITICAL, + SDL_NUM_LOG_PRIORITIES +} SDL_LogPriority; + + +/** + * \brief Set the priority of all log categories + */ +extern DECLSPEC void SDLCALL SDL_LogSetAllPriority(SDL_LogPriority priority); + +/** + * \brief Set the priority of a particular log category + */ +extern DECLSPEC void SDLCALL SDL_LogSetPriority(int category, + SDL_LogPriority priority); + +/** + * \brief Get the priority of a particular log category + */ +extern DECLSPEC SDL_LogPriority SDLCALL SDL_LogGetPriority(int category); + +/** + * \brief Reset all priorities to default. + * + * \note This is called in SDL_Quit(). + */ +extern DECLSPEC void SDLCALL SDL_LogResetPriorities(void); + +/** + * \brief Log a message with SDL_LOG_CATEGORY_APPLICATION and SDL_LOG_PRIORITY_INFO + */ +extern DECLSPEC void SDLCALL SDL_Log(SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(1); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_VERBOSE + */ +extern DECLSPEC void SDLCALL SDL_LogVerbose(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_DEBUG + */ +extern DECLSPEC void SDLCALL SDL_LogDebug(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_INFO + */ +extern DECLSPEC void SDLCALL SDL_LogInfo(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_WARN + */ +extern DECLSPEC void SDLCALL SDL_LogWarn(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_ERROR + */ +extern DECLSPEC void SDLCALL SDL_LogError(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with SDL_LOG_PRIORITY_CRITICAL + */ +extern DECLSPEC void SDLCALL SDL_LogCritical(int category, SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Log a message with the specified category and priority. + */ +extern DECLSPEC void SDLCALL SDL_LogMessage(int category, + SDL_LogPriority priority, + SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(3); + +/** + * \brief Log a message with the specified category and priority. + */ +extern DECLSPEC void SDLCALL SDL_LogMessageV(int category, + SDL_LogPriority priority, + const char *fmt, va_list ap); + +/** + * \brief The prototype for the log output function + */ +typedef void (SDLCALL *SDL_LogOutputFunction)(void *userdata, int category, SDL_LogPriority priority, const char *message); + +/** + * \brief Get the current log output function. + */ +extern DECLSPEC void SDLCALL SDL_LogGetOutputFunction(SDL_LogOutputFunction *callback, void **userdata); + +/** + * \brief This function allows you to replace the default log output + * function with one of your own. + */ +extern DECLSPEC void SDLCALL SDL_LogSetOutputFunction(SDL_LogOutputFunction callback, void *userdata); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_log_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_main.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_main.h new file mode 100644 index 0000000..623f2d0 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_main.h @@ -0,0 +1,180 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_main_h_ +#define SDL_main_h_ + +#include "SDL_stdinc.h" + +/** + * \file SDL_main.h + * + * Redefine main() on some platforms so that it is called by SDL. + */ + +#ifndef SDL_MAIN_HANDLED +#if defined(__WIN32__) +/* On Windows SDL provides WinMain(), which parses the command line and passes + the arguments to your main function. + + If you provide your own WinMain(), you may define SDL_MAIN_HANDLED + */ +#define SDL_MAIN_AVAILABLE + +#elif defined(__WINRT__) +/* On WinRT, SDL provides a main function that initializes CoreApplication, + creating an instance of IFrameworkView in the process. + + Please note that #include'ing SDL_main.h is not enough to get a main() + function working. In non-XAML apps, the file, + src/main/winrt/SDL_WinRT_main_NonXAML.cpp, or a copy of it, must be compiled + into the app itself. In XAML apps, the function, SDL_WinRTRunApp must be + called, with a pointer to the Direct3D-hosted XAML control passed in. +*/ +#define SDL_MAIN_NEEDED + +#elif defined(__IPHONEOS__) +/* On iOS SDL provides a main function that creates an application delegate + and starts the iOS application run loop. + + If you link with SDL dynamically on iOS, the main function can't be in a + shared library, so you need to link with libSDLmain.a, which includes a + stub main function that calls into the shared library to start execution. + + See src/video/uikit/SDL_uikitappdelegate.m for more details. + */ +#define SDL_MAIN_NEEDED + +#elif defined(__ANDROID__) +/* On Android SDL provides a Java class in SDLActivity.java that is the + main activity entry point. + + See docs/README-android.md for more details on extending that class. + */ +#define SDL_MAIN_NEEDED + +/* We need to export SDL_main so it can be launched from Java */ +#define SDLMAIN_DECLSPEC DECLSPEC + +#elif defined(__NACL__) +/* On NACL we use ppapi_simple to set up the application helper code, + then wait for the first PSE_INSTANCE_DIDCHANGEVIEW event before + starting the user main function. + All user code is run in a separate thread by ppapi_simple, thus + allowing for blocking io to take place via nacl_io +*/ +#define SDL_MAIN_NEEDED + +#endif +#endif /* SDL_MAIN_HANDLED */ + +#ifndef SDLMAIN_DECLSPEC +#define SDLMAIN_DECLSPEC +#endif + +/** + * \file SDL_main.h + * + * The application's main() function must be called with C linkage, + * and should be declared like this: + * \code + * #ifdef __cplusplus + * extern "C" + * #endif + * int main(int argc, char *argv[]) + * { + * } + * \endcode + */ + +#if defined(SDL_MAIN_NEEDED) || defined(SDL_MAIN_AVAILABLE) +#define main SDL_main +#endif + +#include "begin_code.h" +#ifdef __cplusplus +extern "C" { +#endif + +/** + * The prototype for the application's main() function + */ +typedef int (*SDL_main_func)(int argc, char *argv[]); +extern SDLMAIN_DECLSPEC int SDL_main(int argc, char *argv[]); + + +/** + * This is called by the real SDL main function to let the rest of the + * library know that initialization was done properly. + * + * Calling this yourself without knowing what you're doing can cause + * crashes and hard to diagnose problems with your application. + */ +extern DECLSPEC void SDLCALL SDL_SetMainReady(void); + +#ifdef __WIN32__ + +/** + * This can be called to set the application class at startup + */ +extern DECLSPEC int SDLCALL SDL_RegisterApp(char *name, Uint32 style, void *hInst); +extern DECLSPEC void SDLCALL SDL_UnregisterApp(void); + +#endif /* __WIN32__ */ + + +#ifdef __WINRT__ + +/** + * \brief Initializes and launches an SDL/WinRT application. + * + * \param mainFunction The SDL app's C-style main(). + * \param reserved Reserved for future use; should be NULL + * \return 0 on success, -1 on failure. On failure, use SDL_GetError to retrieve more + * information on the failure. + */ +extern DECLSPEC int SDLCALL SDL_WinRTRunApp(SDL_main_func mainFunction, void * reserved); + +#endif /* __WINRT__ */ + +#if defined(__IPHONEOS__) + +/** + * \brief Initializes and launches an SDL application. + * + * \param argc The argc parameter from the application's main() function + * \param argv The argv parameter from the application's main() function + * \param mainFunction The SDL app's C-style main(). + * \return the return value from mainFunction + */ +extern DECLSPEC int SDLCALL SDL_UIKitRunApp(int argc, char *argv[], SDL_main_func mainFunction); + +#endif /* __IPHONEOS__ */ + + +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_main_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_messagebox.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_messagebox.h new file mode 100644 index 0000000..e34b554 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_messagebox.h @@ -0,0 +1,144 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_messagebox_h_ +#define SDL_messagebox_h_ + +#include "SDL_stdinc.h" +#include "SDL_video.h" /* For SDL_Window */ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief SDL_MessageBox flags. If supported will display warning icon, etc. + */ +typedef enum +{ + SDL_MESSAGEBOX_ERROR = 0x00000010, /**< error dialog */ + SDL_MESSAGEBOX_WARNING = 0x00000020, /**< warning dialog */ + SDL_MESSAGEBOX_INFORMATION = 0x00000040 /**< informational dialog */ +} SDL_MessageBoxFlags; + +/** + * \brief Flags for SDL_MessageBoxButtonData. + */ +typedef enum +{ + SDL_MESSAGEBOX_BUTTON_RETURNKEY_DEFAULT = 0x00000001, /**< Marks the default button when return is hit */ + SDL_MESSAGEBOX_BUTTON_ESCAPEKEY_DEFAULT = 0x00000002 /**< Marks the default button when escape is hit */ +} SDL_MessageBoxButtonFlags; + +/** + * \brief Individual button data. + */ +typedef struct +{ + Uint32 flags; /**< ::SDL_MessageBoxButtonFlags */ + int buttonid; /**< User defined button id (value returned via SDL_ShowMessageBox) */ + const char * text; /**< The UTF-8 button text */ +} SDL_MessageBoxButtonData; + +/** + * \brief RGB value used in a message box color scheme + */ +typedef struct +{ + Uint8 r, g, b; +} SDL_MessageBoxColor; + +typedef enum +{ + SDL_MESSAGEBOX_COLOR_BACKGROUND, + SDL_MESSAGEBOX_COLOR_TEXT, + SDL_MESSAGEBOX_COLOR_BUTTON_BORDER, + SDL_MESSAGEBOX_COLOR_BUTTON_BACKGROUND, + SDL_MESSAGEBOX_COLOR_BUTTON_SELECTED, + SDL_MESSAGEBOX_COLOR_MAX +} SDL_MessageBoxColorType; + +/** + * \brief A set of colors to use for message box dialogs + */ +typedef struct +{ + SDL_MessageBoxColor colors[SDL_MESSAGEBOX_COLOR_MAX]; +} SDL_MessageBoxColorScheme; + +/** + * \brief MessageBox structure containing title, text, window, etc. + */ +typedef struct +{ + Uint32 flags; /**< ::SDL_MessageBoxFlags */ + SDL_Window *window; /**< Parent window, can be NULL */ + const char *title; /**< UTF-8 title */ + const char *message; /**< UTF-8 message text */ + + int numbuttons; + const SDL_MessageBoxButtonData *buttons; + + const SDL_MessageBoxColorScheme *colorScheme; /**< ::SDL_MessageBoxColorScheme, can be NULL to use system settings */ +} SDL_MessageBoxData; + +/** + * \brief Create a modal message box. + * + * \param messageboxdata The SDL_MessageBoxData structure with title, text, etc. + * \param buttonid The pointer to which user id of hit button should be copied. + * + * \return -1 on error, otherwise 0 and buttonid contains user id of button + * hit or -1 if dialog was closed. + * + * \note This function should be called on the thread that created the parent + * window, or on the main thread if the messagebox has no parent. It will + * block execution of that thread until the user clicks a button or + * closes the messagebox. + */ +extern DECLSPEC int SDLCALL SDL_ShowMessageBox(const SDL_MessageBoxData *messageboxdata, int *buttonid); + +/** + * \brief Create a simple modal message box + * + * \param flags ::SDL_MessageBoxFlags + * \param title UTF-8 title text + * \param message UTF-8 message text + * \param window The parent window, or NULL for no parent + * + * \return 0 on success, -1 on error + * + * \sa SDL_ShowMessageBox + */ +extern DECLSPEC int SDLCALL SDL_ShowSimpleMessageBox(Uint32 flags, const char *title, const char *message, SDL_Window *window); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_messagebox_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mouse.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mouse.h new file mode 100644 index 0000000..277559d --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mouse.h @@ -0,0 +1,302 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_mouse.h + * + * Include file for SDL mouse event handling. + */ + +#ifndef SDL_mouse_h_ +#define SDL_mouse_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +typedef struct SDL_Cursor SDL_Cursor; /**< Implementation dependent */ + +/** + * \brief Cursor types for SDL_CreateSystemCursor(). + */ +typedef enum +{ + SDL_SYSTEM_CURSOR_ARROW, /**< Arrow */ + SDL_SYSTEM_CURSOR_IBEAM, /**< I-beam */ + SDL_SYSTEM_CURSOR_WAIT, /**< Wait */ + SDL_SYSTEM_CURSOR_CROSSHAIR, /**< Crosshair */ + SDL_SYSTEM_CURSOR_WAITARROW, /**< Small wait cursor (or Wait if not available) */ + SDL_SYSTEM_CURSOR_SIZENWSE, /**< Double arrow pointing northwest and southeast */ + SDL_SYSTEM_CURSOR_SIZENESW, /**< Double arrow pointing northeast and southwest */ + SDL_SYSTEM_CURSOR_SIZEWE, /**< Double arrow pointing west and east */ + SDL_SYSTEM_CURSOR_SIZENS, /**< Double arrow pointing north and south */ + SDL_SYSTEM_CURSOR_SIZEALL, /**< Four pointed arrow pointing north, south, east, and west */ + SDL_SYSTEM_CURSOR_NO, /**< Slashed circle or crossbones */ + SDL_SYSTEM_CURSOR_HAND, /**< Hand */ + SDL_NUM_SYSTEM_CURSORS +} SDL_SystemCursor; + +/** + * \brief Scroll direction types for the Scroll event + */ +typedef enum +{ + SDL_MOUSEWHEEL_NORMAL, /**< The scroll direction is normal */ + SDL_MOUSEWHEEL_FLIPPED /**< The scroll direction is flipped / natural */ +} SDL_MouseWheelDirection; + +/* Function prototypes */ + +/** + * \brief Get the window which currently has mouse focus. + */ +extern DECLSPEC SDL_Window * SDLCALL SDL_GetMouseFocus(void); + +/** + * \brief Retrieve the current state of the mouse. + * + * The current button state is returned as a button bitmask, which can + * be tested using the SDL_BUTTON(X) macros, and x and y are set to the + * mouse cursor position relative to the focus window for the currently + * selected mouse. You can pass NULL for either x or y. + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetMouseState(int *x, int *y); + +/** + * \brief Get the current state of the mouse, in relation to the desktop + * + * This works just like SDL_GetMouseState(), but the coordinates will be + * reported relative to the top-left of the desktop. This can be useful if + * you need to track the mouse outside of a specific window and + * SDL_CaptureMouse() doesn't fit your needs. For example, it could be + * useful if you need to track the mouse while dragging a window, where + * coordinates relative to a window might not be in sync at all times. + * + * \note SDL_GetMouseState() returns the mouse position as SDL understands + * it from the last pump of the event queue. This function, however, + * queries the OS for the current mouse position, and as such, might + * be a slightly less efficient function. Unless you know what you're + * doing and have a good reason to use this function, you probably want + * SDL_GetMouseState() instead. + * + * \param x Returns the current X coord, relative to the desktop. Can be NULL. + * \param y Returns the current Y coord, relative to the desktop. Can be NULL. + * \return The current button state as a bitmask, which can be tested using the SDL_BUTTON(X) macros. + * + * \sa SDL_GetMouseState + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetGlobalMouseState(int *x, int *y); + +/** + * \brief Retrieve the relative state of the mouse. + * + * The current button state is returned as a button bitmask, which can + * be tested using the SDL_BUTTON(X) macros, and x and y are set to the + * mouse deltas since the last call to SDL_GetRelativeMouseState(). + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetRelativeMouseState(int *x, int *y); + +/** + * \brief Moves the mouse to the given position within the window. + * + * \param window The window to move the mouse into, or NULL for the current mouse focus + * \param x The x coordinate within the window + * \param y The y coordinate within the window + * + * \note This function generates a mouse motion event + */ +extern DECLSPEC void SDLCALL SDL_WarpMouseInWindow(SDL_Window * window, + int x, int y); + +/** + * \brief Moves the mouse to the given position in global screen space. + * + * \param x The x coordinate + * \param y The y coordinate + * \return 0 on success, -1 on error (usually: unsupported by a platform). + * + * \note This function generates a mouse motion event + */ +extern DECLSPEC int SDLCALL SDL_WarpMouseGlobal(int x, int y); + +/** + * \brief Set relative mouse mode. + * + * \param enabled Whether or not to enable relative mode + * + * \return 0 on success, or -1 if relative mode is not supported. + * + * While the mouse is in relative mode, the cursor is hidden, and the + * driver will try to report continuous motion in the current window. + * Only relative motion events will be delivered, the mouse position + * will not change. + * + * \note This function will flush any pending mouse motion. + * + * \sa SDL_GetRelativeMouseMode() + */ +extern DECLSPEC int SDLCALL SDL_SetRelativeMouseMode(SDL_bool enabled); + +/** + * \brief Capture the mouse, to track input outside an SDL window. + * + * \param enabled Whether or not to enable capturing + * + * Capturing enables your app to obtain mouse events globally, instead of + * just within your window. Not all video targets support this function. + * When capturing is enabled, the current window will get all mouse events, + * but unlike relative mode, no change is made to the cursor and it is + * not restrained to your window. + * + * This function may also deny mouse input to other windows--both those in + * your application and others on the system--so you should use this + * function sparingly, and in small bursts. For example, you might want to + * track the mouse while the user is dragging something, until the user + * releases a mouse button. It is not recommended that you capture the mouse + * for long periods of time, such as the entire time your app is running. + * + * While captured, mouse events still report coordinates relative to the + * current (foreground) window, but those coordinates may be outside the + * bounds of the window (including negative values). Capturing is only + * allowed for the foreground window. If the window loses focus while + * capturing, the capture will be disabled automatically. + * + * While capturing is enabled, the current window will have the + * SDL_WINDOW_MOUSE_CAPTURE flag set. + * + * \return 0 on success, or -1 if not supported. + */ +extern DECLSPEC int SDLCALL SDL_CaptureMouse(SDL_bool enabled); + +/** + * \brief Query whether relative mouse mode is enabled. + * + * \sa SDL_SetRelativeMouseMode() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_GetRelativeMouseMode(void); + +/** + * \brief Create a cursor, using the specified bitmap data and + * mask (in MSB format). + * + * The cursor width must be a multiple of 8 bits. + * + * The cursor is created in black and white according to the following: + *

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/vendor/lite/src/lib/lua52/lopcodes.c b/vendor/lite/src/lib/lua52/lopcodes.c new file mode 100644 index 0000000..4190dc7 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lopcodes.c @@ -0,0 +1,107 @@ +/* +** $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/vendor/lite/src/lib/lua52/lopcodes.h b/vendor/lite/src/lib/lua52/lopcodes.h new file mode 100644 index 0000000..8e2f80a --- /dev/null +++ b/vendor/lite/src/lib/lua52/lopcodes.h @@ -0,0 +1,288 @@ +/* +** $Id: lopcodes.h,v 1.142.1.2 2014/10/20 18:32:09 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/vendor/lite/src/lib/lua52/loslib.c b/vendor/lite/src/lib/lua52/loslib.c new file mode 100644 index 0000000..052ba17 --- /dev/null +++ b/vendor/lite/src/lib/lua52/loslib.c @@ -0,0 +1,323 @@ +/* +** $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/vendor/lite/src/lib/lua52/lparser.c b/vendor/lite/src/lib/lua52/lparser.c new file mode 100644 index 0000000..9e1a9ca --- /dev/null +++ b/vendor/lite/src/lib/lua52/lparser.c @@ -0,0 +1,1638 @@ +/* +** $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/vendor/lite/src/lib/lua52/lparser.h b/vendor/lite/src/lib/lua52/lparser.h new file mode 100644 index 0000000..0346e3c --- /dev/null +++ b/vendor/lite/src/lib/lua52/lparser.h @@ -0,0 +1,119 @@ +/* +** $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/vendor/lite/src/lib/lua52/lstate.c b/vendor/lite/src/lib/lua52/lstate.c new file mode 100644 index 0000000..c7f2672 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lstate.c @@ -0,0 +1,323 @@ +/* +** $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/vendor/lite/src/lib/lua52/lstate.h b/vendor/lite/src/lib/lua52/lstate.h new file mode 100644 index 0000000..daffd9a --- /dev/null +++ b/vendor/lite/src/lib/lua52/lstate.h @@ -0,0 +1,228 @@ +/* +** $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/vendor/lite/src/lib/lua52/lstring.c b/vendor/lite/src/lib/lua52/lstring.c new file mode 100644 index 0000000..af96c89 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lstring.c @@ -0,0 +1,185 @@ +/* +** $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/vendor/lite/src/lib/lua52/lstring.h b/vendor/lite/src/lib/lua52/lstring.h new file mode 100644 index 0000000..260e7f1 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lstring.h @@ -0,0 +1,46 @@ +/* +** $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/vendor/lite/src/lib/lua52/lstrlib.c b/vendor/lite/src/lib/lua52/lstrlib.c new file mode 100644 index 0000000..9261fd2 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lstrlib.c @@ -0,0 +1,1019 @@ +/* +** $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/vendor/lite/src/lib/lua52/ltable.c b/vendor/lite/src/lib/lua52/ltable.c new file mode 100644 index 0000000..5d76f97 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ltable.c @@ -0,0 +1,588 @@ +/* +** $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/vendor/lite/src/lib/lua52/ltable.h b/vendor/lite/src/lib/lua52/ltable.h new file mode 100644 index 0000000..d69449b --- /dev/null +++ b/vendor/lite/src/lib/lua52/ltable.h @@ -0,0 +1,45 @@ +/* +** $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/vendor/lite/src/lib/lua52/ltablib.c b/vendor/lite/src/lib/lua52/ltablib.c new file mode 100644 index 0000000..99764d2 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ltablib.c @@ -0,0 +1,285 @@ +/* +** $Id: ltablib.c,v 1.65.1.2 2014/05/07 16:32:55 roberto Exp $ +** Library for Table Manipulation +** See Copyright Notice in lua.h +*/ + + +#include +#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; + unsigned int 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 = (unsigned int)e - (unsigned int)i; /* number of elements minus 1 */ + if (n > (INT_MAX - 10) || !lua_checkstack(L, ++n)) + 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/vendor/lite/src/lib/lua52/ltm.h b/vendor/lite/src/lib/lua52/ltm.h new file mode 100644 index 0000000..7f89c84 --- /dev/null +++ b/vendor/lite/src/lib/lua52/ltm.h @@ -0,0 +1,57 @@ +/* +** $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/vendor/lite/src/lib/lua52/lua.c_ b/vendor/lite/src/lib/lua52/lua.c_ new file mode 100644 index 0000000..4345e55 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lua.c_ @@ -0,0 +1,497 @@ +/* +** $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/vendor/lite/src/lib/lua52/lua.h b/vendor/lite/src/lib/lua52/lua.h new file mode 100644 index 0000000..ff4a108 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lua.h @@ -0,0 +1,444 @@ +/* +** $Id: lua.h,v 1.285.1.4 2015/02/21 14:04:50 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 "4" + +#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-2015 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-2015 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/vendor/lite/src/lib/lua52/lua.hpp b/vendor/lite/src/lib/lua52/lua.hpp new file mode 100644 index 0000000..ec417f5 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lua.hpp @@ -0,0 +1,9 @@ +// 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/vendor/lite/src/lib/lua52/luac.c_ b/vendor/lite/src/lib/lua52/luac.c_ new file mode 100644 index 0000000..7409706 --- /dev/null +++ b/vendor/lite/src/lib/lua52/luac.c_ @@ -0,0 +1,432 @@ +/* +** $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/vendor/lite/src/lib/lua52/luaconf.h b/vendor/lite/src/lib/lua52/luaconf.h new file mode 100644 index 0000000..1b0ff59 --- /dev/null +++ b/vendor/lite/src/lib/lua52/luaconf.h @@ -0,0 +1,551 @@ +/* +** $Id: luaconf.h,v 1.176.1.2 2013/11/21 17:26:16 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 a 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 from consuming 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/vendor/lite/src/lib/lua52/lualib.h b/vendor/lite/src/lib/lua52/lualib.h new file mode 100644 index 0000000..da82005 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lualib.h @@ -0,0 +1,55 @@ +/* +** $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/vendor/lite/src/lib/lua52/lundump.c b/vendor/lite/src/lib/lua52/lundump.c new file mode 100644 index 0000000..4163cb5 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lundump.c @@ -0,0 +1,258 @@ +/* +** $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/vendor/lite/src/lib/lua52/lundump.h b/vendor/lite/src/lib/lua52/lundump.h new file mode 100644 index 0000000..5255db2 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lundump.h @@ -0,0 +1,28 @@ +/* +** $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/vendor/lite/src/lib/lua52/lvm.c b/vendor/lite/src/lib/lua52/lvm.c new file mode 100644 index 0000000..141b9fd --- /dev/null +++ b/vendor/lite/src/lib/lua52/lvm.c @@ -0,0 +1,867 @@ +/* +** $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/vendor/lite/src/lib/lua52/lvm.h b/vendor/lite/src/lib/lua52/lvm.h new file mode 100644 index 0000000..5380270 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lvm.h @@ -0,0 +1,44 @@ +/* +** $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/vendor/lite/src/lib/lua52/lzio.c b/vendor/lite/src/lib/lua52/lzio.c new file mode 100644 index 0000000..20efea9 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lzio.c @@ -0,0 +1,76 @@ +/* +** $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/vendor/lite/src/lib/lua52/lzio.h b/vendor/lite/src/lib/lua52/lzio.h new file mode 100644 index 0000000..441f747 --- /dev/null +++ b/vendor/lite/src/lib/lua52/lzio.h @@ -0,0 +1,65 @@ +/* +** $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/vendor/lite/src/lib/stb/stb_truetype.c b/vendor/lite/src/lib/stb/stb_truetype.c new file mode 100644 index 0000000..dc22d88 --- /dev/null +++ b/vendor/lite/src/lib/stb/stb_truetype.c @@ -0,0 +1,2 @@ +#define STB_TRUETYPE_IMPLEMENTATION +#include "stb_truetype.h" diff --git a/vendor/lite/src/lib/stb/stb_truetype.h b/vendor/lite/src/lib/stb/stb_truetype.h new file mode 100644 index 0000000..a08e929 --- /dev/null +++ b/vendor/lite/src/lib/stb/stb_truetype.h @@ -0,0 +1,4853 @@ +// stb_truetype.h - v1.19 - public domain +// authored from 2009-2016 by 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) +// render glyphs to one-channel SDF bitmaps (signed-distance field/function) +// +// 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 +// Dougall Johnson: OpenType / Type 2 font handling +// Daniel Ribeiro Maciel: basic GPOS-based kerning +// +// Misc other: +// Ryan Gordon +// Simon Glass +// github:IntellectualKitty +// Imanol Celaya +// Daniel Ribeiro Maciel +// +// Bug/warning reports/fixes: +// "Zer" on mollyrocket Fabian "ryg" Giesen +// Cass Everitt Martins Mozeiko +// stoiko (Haemimont Games) Cap Petschulat +// Brian Hook Omar Cornut +// Walter van Niftrik github:aloucks +// David Gow Peter LaValle +// David Given Sergey Popov +// Ivan-Assen Ivanov Giumo X. Clanjor +// Anthony Pesch Higor Euripedes +// Johan Duparc Thomas Fields +// Hou Qiming Derek Vinyard +// Rob Loach Cort Stratton +// Kenney Phillis Jr. github:oyvindjam +// Brian Costabile github:vassvik +// +// VERSION HISTORY +// +// 1.19 (2018-02-11) GPOS kerning, STBTT_fmod +// 1.18 (2018-01-29) add missing function +// 1.17 (2017-07-23) make more arguments const; doc fix +// 1.16 (2017-07-12) SDF support +// 1.15 (2017-03-03) make more arguments const +// 1.14 (2017-01-16) num-fonts-in-TTC function +// 1.13 (2017-01-02) support OpenType fonts, certain Apple fonts +// 1.12 (2016-10-25) suppress warnings about casting away const with -Wcast-qual +// 1.11 (2016-04-02) fix unused-variable warning +// 1.10 (2016-04-02) user-defined fabs(); rare memory leak; remove duplicate typedef +// 1.09 (2016-01-16) warning fix; avoid crash on outofmem; use allocation userdata properly +// 1.08 (2015-09-13) document stbtt_Rasterize(); fixes for vertical & horizontal edges +// 1.07 (2015-08-01) allow PackFontRanges to accept arrays of sparse codepoints; +// variant PackFontRanges to pack and render in separate phases; +// fix stbtt_GetFontOFfsetForIndex (never worked for non-0 input?); +// fixed an assert() bug in the new rasterizer +// replace assert() with STBTT_assert() in new rasterizer +// +// Full history can be found at the end of this file. +// +// LICENSE +// +// See end of file for license information. +// +// 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. +// +// To make the implementation private to the file that generates the implementation, +// #define STBTT_STATIC +// +// Simple 3D API (don't ship this, but it's fine for tools and quick start) +// stbtt_BakeFontBitmap() -- bake a font to a bitmap for use as texture +// stbtt_GetBakedQuad() -- compute quad to draw for a given char +// +// Improved 3D API (more shippable): +// #include "stb_rect_pack.h" -- optional, but you really want it +// stbtt_PackBegin() +// stbtt_PackSetOversampling() -- for improved quality on small fonts +// stbtt_PackFontRanges() -- pack and renders +// stbtt_PackEnd() +// stbtt_GetPackedQuad() +// +// "Load" a font file from a memory buffer (you have to keep the buffer loaded) +// stbtt_InitFont() +// stbtt_GetFontOffsetForIndex() -- indexing for TTC font collections +// stbtt_GetNumberOfFonts() -- number of fonts 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_GetFontVMetricsOS2() +// stbtt_GetCodepointKernAdvance() +// +// Starting with version 1.06, the rasterizer was replaced with a new, +// faster and generally-more-precise rasterizer. The new rasterizer more +// accurately measures pixel coverage for anti-aliasing, except in the case +// where multiple shapes overlap, in which case it overestimates the AA pixel +// coverage. Thus, anti-aliasing of intersecting shapes may look wrong. If +// this turns out to be a problem, you can re-enable the old rasterizer with +// #define STBTT_RASTERIZER_VERSION 1 +// which will incur about a 15% speed hit. +// +// ADDITIONAL DOCUMENTATION +// +// Immediately after this block comment are a series of sample programs. +// +// After the sample programs is the "header file" section. This section +// includes documentation for each API function. +// +// Some important concepts to understand to use this library: +// +// Codepoint +// Characters are defined by unicode codepoints, e.g. 65 is +// uppercase A, 231 is lowercase c with a cedilla, 0x7e30 is +// the hiragana for "ma". +// +// Glyph +// A visual character shape (every codepoint is rendered as +// some glyph) +// +// Glyph index +// A font-specific integer ID representing a glyph +// +// Baseline +// Glyph shapes are defined relative to a baseline, which is the +// bottom of uppercase characters. Characters extend both above +// and below the baseline. +// +// Current Point +// As you draw text to the screen, you keep track of a "current point" +// which is the origin of each character. The current point's vertical +// position is the baseline. Even "baked fonts" use this model. +// +// Vertical Font Metrics +// The vertical qualities of the font, used to vertically position +// and space the characters. See docs for stbtt_GetFontVMetrics. +// +// Font Size in Pixels or Points +// The preferred interface for specifying font sizes in stb_truetype +// is to specify how tall the font's vertical extent should be in pixels. +// If that sounds good enough, skip the next paragraph. +// +// Most font APIs instead use "points", which are a common typographic +// measurement for describing font size, defined as 72 points per inch. +// stb_truetype provides a point API for compatibility. However, true +// "per inch" conventions don't make much sense on computer displays +// since different monitors have different number of pixels per +// inch. For example, Windows traditionally uses a convention that +// there are 96 pixels per inch, thus making 'inch' measurements have +// nothing to do with inches, and thus effectively defining a point to +// be 1.333 pixels. Additionally, the TrueType font data provides +// an explicit scale factor to scale a given font's glyphs to points, +// but the author has observed that this scale factor is often wrong +// for non-commercial fonts, thus making fonts scaled in points +// according to the TrueType spec incoherently sized in practice. +// +// DETAILED USAGE: +// +// Scale: +// Select how high you want the font to be, in points or pixels. +// Call ScaleForPixelHeight or ScaleForMappingEmToPixels to compute +// a scale factor SF that will be used by all other functions. +// +// Baseline: +// You need to select a y-coordinate that is the baseline of where +// your text will appear. Call GetFontBoundingBox to get the baseline-relative +// bounding box for all characters. SF*-y0 will be the distance in pixels +// that the worst-case character could extend above the baseline, so if +// you want the top edge of characters to appear at the top of the +// screen where y=0, then you would set the baseline to SF*-y0. +// +// Current point: +// Set the current point where the first character will appear. The +// first character could extend left of the current point; this is font +// dependent. You can either choose a current point that is the leftmost +// point and hope, or add some padding, or check the bounding box or +// left-side-bearing of the first character to be displayed and set +// the current point based on that. +// +// Displaying a character: +// Compute the bounding box of the character. It will contain signed values +// relative to . I.e. if it returns x0,y0,x1,y1, +// then the character should be displayed in the rectangle from +// to = 32 && *text < 128) { + stbtt_aligned_quad q; + stbtt_GetBakedQuad(cdata, 512,512, *text-32, &x,&y,&q,1);//1=opengl & d3d10+,0=d3d9 + 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=2; // leave a little padding in case the character extends left + char *text = "Heljo World!"; // intentionally misspelled to show 'lj' brokenness + + 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 render + // a sequence of characters, you really need to render each 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 YOUR CODEBASE +//// +//// The following sections allow you to supply alternate definitions +//// of C library functions used by stb_truetype, e.g. if you don't +//// link with the C runtime library. + +#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]; + + // e.g. #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 + + #ifndef STBTT_sqrt + #include + #define STBTT_sqrt(x) sqrt(x) + #define STBTT_pow(x,y) pow(x,y) + #endif + + #ifndef STBTT_fmod + #include + #define STBTT_fmod(x,y) fmod(x,y) + #endif + + #ifndef STBTT_cos + #include + #define STBTT_cos(x) cos(x) + #define STBTT_acos(x) acos(x) + #endif + + #ifndef STBTT_fabs + #include + #define STBTT_fabs(x) fabs(x) + #endif + + // #define your own functions "STBTT_malloc" / "STBTT_free" to avoid malloc.h + #ifndef STBTT_malloc + #include + #define STBTT_malloc(x,u) ((void)(u),malloc(x)) + #define STBTT_free(x,u) ((void)(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 STBTT_STATIC +#define STBTT_DEF static +#else +#define STBTT_DEF extern +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +// private structure +typedef struct +{ + unsigned char *data; + int cursor; + int size; +} stbtt__buf; + +////////////////////////////////////////////////////////////////////////////// +// +// 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; + +STBTT_DEF 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; + +STBTT_DEF void stbtt_GetBakedQuad(const 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. +// +// The coordinate system used assumes y increases downwards. +// +// Characters will extend both above and below the current position; +// see discussion of "BASELINE" above. +// +// It's inefficient; you might want to c&p it and optimize it. + + + +////////////////////////////////////////////////////////////////////////////// +// +// NEW TEXTURE BAKING API +// +// This provides options for packing multiple fonts into one atlas, not +// perfectly but better than nothing. + +typedef struct +{ + unsigned short x0,y0,x1,y1; // coordinates of bbox in bitmap + float xoff,yoff,xadvance; + float xoff2,yoff2; +} stbtt_packedchar; + +typedef struct stbtt_pack_context stbtt_pack_context; +typedef struct stbtt_fontinfo stbtt_fontinfo; +#ifndef STB_RECT_PACK_VERSION +typedef struct stbrp_rect stbrp_rect; +#endif + +STBTT_DEF int stbtt_PackBegin(stbtt_pack_context *spc, unsigned char *pixels, int width, int height, int stride_in_bytes, int padding, void *alloc_context); +// Initializes a packing context stored in the passed-in stbtt_pack_context. +// Future calls using this context will pack characters into the bitmap passed +// in here: a 1-channel bitmap that is width * height. stride_in_bytes is +// the distance from one row to the next (or 0 to mean they are packed tightly +// together). "padding" is the amount of padding to leave between each +// character (normally you want '1' for bitmaps you'll use as textures with +// bilinear filtering). +// +// Returns 0 on failure, 1 on success. + +STBTT_DEF void stbtt_PackEnd (stbtt_pack_context *spc); +// Cleans up the packing context and frees all memory. + +#define STBTT_POINT_SIZE(x) (-(x)) + +STBTT_DEF int stbtt_PackFontRange(stbtt_pack_context *spc, const unsigned char *fontdata, int font_index, float font_size, + int first_unicode_char_in_range, int num_chars_in_range, stbtt_packedchar *chardata_for_range); +// Creates character bitmaps from the font_index'th font found in fontdata (use +// font_index=0 if you don't know what that is). It creates num_chars_in_range +// bitmaps for characters with unicode values starting at first_unicode_char_in_range +// and increasing. Data for how to render them is stored in chardata_for_range; +// pass these to stbtt_GetPackedQuad to get back renderable quads. +// +// font_size is the full height of the character from ascender to descender, +// as computed by stbtt_ScaleForPixelHeight. To use a point size as computed +// by stbtt_ScaleForMappingEmToPixels, wrap the point size in STBTT_POINT_SIZE() +// and pass that result as 'font_size': +// ..., 20 , ... // font max minus min y is 20 pixels tall +// ..., STBTT_POINT_SIZE(20), ... // 'M' is 20 pixels tall + +typedef struct +{ + float font_size; + int first_unicode_codepoint_in_range; // if non-zero, then the chars are continuous, and this is the first codepoint + int *array_of_unicode_codepoints; // if non-zero, then this is an array of unicode codepoints + int num_chars; + stbtt_packedchar *chardata_for_range; // output + unsigned char h_oversample, v_oversample; // don't set these, they're used internally +} stbtt_pack_range; + +STBTT_DEF int stbtt_PackFontRanges(stbtt_pack_context *spc, const unsigned char *fontdata, int font_index, stbtt_pack_range *ranges, int num_ranges); +// Creates character bitmaps from multiple ranges of characters stored in +// ranges. This will usually create a better-packed bitmap than multiple +// calls to stbtt_PackFontRange. Note that you can call this multiple +// times within a single PackBegin/PackEnd. + +STBTT_DEF void stbtt_PackSetOversampling(stbtt_pack_context *spc, unsigned int h_oversample, unsigned int v_oversample); +// Oversampling a font increases the quality by allowing higher-quality subpixel +// positioning, and is especially valuable at smaller text sizes. +// +// This function sets the amount of oversampling for all following calls to +// stbtt_PackFontRange(s) or stbtt_PackFontRangesGatherRects for a given +// pack context. The default (no oversampling) is achieved by h_oversample=1 +// and v_oversample=1. The total number of pixels required is +// h_oversample*v_oversample larger than the default; for example, 2x2 +// oversampling requires 4x the storage of 1x1. For best results, render +// oversampled textures with bilinear filtering. Look at the readme in +// stb/tests/oversample for information about oversampled fonts +// +// To use with PackFontRangesGather etc., you must set it before calls +// call to PackFontRangesGatherRects. + +STBTT_DEF void stbtt_GetPackedQuad(const stbtt_packedchar *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 align_to_integer); + +STBTT_DEF int stbtt_PackFontRangesGatherRects(stbtt_pack_context *spc, const stbtt_fontinfo *info, stbtt_pack_range *ranges, int num_ranges, stbrp_rect *rects); +STBTT_DEF void stbtt_PackFontRangesPackRects(stbtt_pack_context *spc, stbrp_rect *rects, int num_rects); +STBTT_DEF int stbtt_PackFontRangesRenderIntoRects(stbtt_pack_context *spc, const stbtt_fontinfo *info, stbtt_pack_range *ranges, int num_ranges, stbrp_rect *rects); +// Calling these functions in sequence is roughly equivalent to calling +// stbtt_PackFontRanges(). If you more control over the packing of multiple +// fonts, or if you want to pack custom data into a font texture, take a look +// at the source to of stbtt_PackFontRanges() and create a custom version +// using these functions, e.g. call GatherRects multiple times, +// building up a single array of rects, then call PackRects once, +// then call RenderIntoRects repeatedly. This may result in a +// better packing than calling PackFontRanges multiple times +// (or it may not). + +// this is an opaque structure that you shouldn't mess with which holds +// all the context needed from PackBegin to PackEnd. +struct stbtt_pack_context { + void *user_allocator_context; + void *pack_info; + int width; + int height; + int stride_in_bytes; + int padding; + unsigned int h_oversample, v_oversample; + unsigned char *pixels; + void *nodes; +}; + +////////////////////////////////////////////////////////////////////////////// +// +// FONT LOADING +// +// + +STBTT_DEF int stbtt_GetNumberOfFonts(const unsigned char *data); +// This function will determine the number of fonts in a font file. TrueType +// collection (.ttc) files may contain multiple fonts, while TrueType font +// (.ttf) files only contain one font. The number of fonts can be used for +// indexing with the previous function where the index is between zero and one +// less than the total fonts. If an error occurs, -1 is returned. + +STBTT_DEF int stbtt_GetFontOffsetForIndex(const unsigned char *data, int index); +// Each .ttf/.ttc file may have more than one font. Each font 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. + +// The following structure is defined publically so you can declare one on +// the stack or as a global or etc, but you should treat it as opaque. +struct stbtt_fontinfo +{ + 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,gpos; // 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__buf cff; // cff font data + stbtt__buf charstrings; // the charstring index + stbtt__buf gsubrs; // global charstring subroutines index + stbtt__buf subrs; // private charstring subroutines index + stbtt__buf fontdicts; // array of font dicts + stbtt__buf fdselect; // map from glyph to fontdict +}; + +STBTT_DEF 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 pure +// value data with no additional data structures. Returns 0 on failure. + + +////////////////////////////////////////////////////////////////////////////// +// +// CHARACTER TO GLYPH-INDEX CONVERSIOn + +STBTT_DEF 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 +// + +STBTT_DEF 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. + +STBTT_DEF float stbtt_ScaleForMappingEmToPixels(const stbtt_fontinfo *info, float pixels); +// computes a scale factor to produce a font whose EM size is mapped to +// 'pixels' tall. This is probably what traditional APIs compute, but +// I'm not positive. + +STBTT_DEF 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, so you must multiply by +// the scale factor for a given size + +STBTT_DEF int stbtt_GetFontVMetricsOS2(const stbtt_fontinfo *info, int *typoAscent, int *typoDescent, int *typoLineGap); +// analogous to GetFontVMetrics, but returns the "typographic" values from the OS/2 +// table (specific to MS/Windows TTF files). +// +// Returns 1 on success (table present), 0 on failure. + +STBTT_DEF void stbtt_GetFontBoundingBox(const stbtt_fontinfo *info, int *x0, int *y0, int *x1, int *y1); +// the bounding box around all possible characters + +STBTT_DEF 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 + +STBTT_DEF int stbtt_GetCodepointKernAdvance(const stbtt_fontinfo *info, int ch1, int ch2); +// an additional amount to add to the 'advance' value between ch1 and ch2 + +STBTT_DEF 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 + +STBTT_DEF void stbtt_GetGlyphHMetrics(const stbtt_fontinfo *info, int glyph_index, int *advanceWidth, int *leftSideBearing); +STBTT_DEF int stbtt_GetGlyphKernAdvance(const stbtt_fontinfo *info, int glyph1, int glyph2); +STBTT_DEF 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, + STBTT_vcubic + }; +#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,cx1,cy1; + unsigned char type,padding; + } stbtt_vertex; +#endif + +STBTT_DEF int stbtt_IsGlyphEmpty(const stbtt_fontinfo *info, int glyph_index); +// returns non-zero if nothing is drawn for this glyph + +STBTT_DEF int stbtt_GetCodepointShape(const stbtt_fontinfo *info, int unicode_codepoint, stbtt_vertex **vertices); +STBTT_DEF 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 +// +// The shape is a series of countours. Each one starts with +// a STBTT_moveto, then consists of a series of mixed +// STBTT_lineto and STBTT_curveto segments. A lineto +// draws a line from previous endpoint to its x,y; a curveto +// draws a quadratic bezier from previous endpoint to +// its x,y, using cx,cy as the bezier control point. + +STBTT_DEF void stbtt_FreeShape(const stbtt_fontinfo *info, stbtt_vertex *vertices); +// frees the data allocated above + +////////////////////////////////////////////////////////////////////////////// +// +// BITMAP RENDERING +// + +STBTT_DEF void stbtt_FreeBitmap(unsigned char *bitmap, void *userdata); +// frees the bitmap allocated below + +STBTT_DEF 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 + +STBTT_DEF 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 + +STBTT_DEF 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. + +STBTT_DEF 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 + +STBTT_DEF void stbtt_MakeCodepointBitmapSubpixelPrefilter(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 oversample_x, int oversample_y, float *sub_x, float *sub_y, int codepoint); +// same as stbtt_MakeCodepointBitmapSubpixel, but prefiltering +// is performed (see stbtt_PackSetOversampling) + +STBTT_DEF 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.) + +STBTT_DEF 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) +STBTT_DEF unsigned char *stbtt_GetGlyphBitmap(const stbtt_fontinfo *info, float scale_x, float scale_y, int glyph, int *width, int *height, int *xoff, int *yoff); +STBTT_DEF 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); +STBTT_DEF 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_DEF 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); +STBTT_DEF void stbtt_MakeGlyphBitmapSubpixelPrefilter(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 oversample_x, int oversample_y, float *sub_x, float *sub_y, int glyph); +STBTT_DEF void stbtt_GetGlyphBitmapBox(const stbtt_fontinfo *font, int glyph, float scale_x, float scale_y, int *ix0, int *iy0, int *ix1, int *iy1); +STBTT_DEF 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; + +// rasterize a shape with quadratic beziers into a bitmap +STBTT_DEF void stbtt_Rasterize(stbtt__bitmap *result, // 1-channel bitmap to draw into + float flatness_in_pixels, // allowable error of curve in pixels + stbtt_vertex *vertices, // array of vertices defining shape + int num_verts, // number of vertices in above array + float scale_x, float scale_y, // scale applied to input vertices + float shift_x, float shift_y, // translation applied to input vertices + int x_off, int y_off, // another translation applied to input + int invert, // if non-zero, vertically flip shape + void *userdata); // context for to STBTT_MALLOC + +////////////////////////////////////////////////////////////////////////////// +// +// Signed Distance Function (or Field) rendering + +STBTT_DEF void stbtt_FreeSDF(unsigned char *bitmap, void *userdata); +// frees the SDF bitmap allocated below + +STBTT_DEF unsigned char * stbtt_GetGlyphSDF(const stbtt_fontinfo *info, float scale, int glyph, int padding, unsigned char onedge_value, float pixel_dist_scale, int *width, int *height, int *xoff, int *yoff); +STBTT_DEF unsigned char * stbtt_GetCodepointSDF(const stbtt_fontinfo *info, float scale, int codepoint, int padding, unsigned char onedge_value, float pixel_dist_scale, int *width, int *height, int *xoff, int *yoff); +// These functions compute a discretized SDF field for a single character, suitable for storing +// in a single-channel texture, sampling with bilinear filtering, and testing against +// larger than some threshhold to produce scalable fonts. +// info -- the font +// scale -- controls the size of the resulting SDF bitmap, same as it would be creating a regular bitmap +// glyph/codepoint -- the character to generate the SDF for +// padding -- extra "pixels" around the character which are filled with the distance to the character (not 0), +// which allows effects like bit outlines +// onedge_value -- value 0-255 to test the SDF against to reconstruct the character (i.e. the isocontour of the character) +// pixel_dist_scale -- what value the SDF should increase by when moving one SDF "pixel" away from the edge (on the 0..255 scale) +// if positive, > onedge_value is inside; if negative, < onedge_value is inside +// width,height -- output height & width of the SDF bitmap (including padding) +// xoff,yoff -- output origin of the character +// return value -- a 2D array of bytes 0..255, width*height in size +// +// pixel_dist_scale & onedge_value are a scale & bias that allows you to make +// optimal use of the limited 0..255 for your application, trading off precision +// and special effects. SDF values outside the range 0..255 are clamped to 0..255. +// +// Example: +// scale = stbtt_ScaleForPixelHeight(22) +// padding = 5 +// onedge_value = 180 +// pixel_dist_scale = 180/5.0 = 36.0 +// +// This will create an SDF bitmap in which the character is about 22 pixels +// high but the whole bitmap is about 22+5+5=32 pixels high. To produce a filled +// shape, sample the SDF at each pixel and fill the pixel if the SDF value +// is greater than or equal to 180/255. (You'll actually want to antialias, +// which is beyond the scope of this example.) Additionally, you can compute +// offset outlines (e.g. to stroke the character border inside & outside, +// or only outside). For example, to fill outside the character up to 3 SDF +// pixels, you would compare against (180-36.0*3)/255 = 72/255. The above +// choice of variables maps a range from 5 pixels outside the shape to +// 2 pixels inside the shape to 0..255; this is intended primarily for apply +// outside effects only (the interior range is needed to allow proper +// antialiasing of the font at *smaller* sizes) +// +// The function computes the SDF analytically at each SDF pixel, not by e.g. +// building a higher-res bitmap and approximating it. In theory the quality +// should be as high as possible for an SDF of this size & representation, but +// unclear if this is true in practice (perhaps building a higher-res bitmap +// and computing from that can allow drop-out prevention). +// +// The algorithm has not been optimized at all, so expect it to be slow +// if computing lots of characters or very large sizes. + + + +////////////////////////////////////////////////////////////////////////////// +// +// 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. + + +STBTT_DEF 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 + +STBTT_DEF 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 + +STBTT_DEF 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 + +#ifndef STBTT_MAX_OVERSAMPLE +#define STBTT_MAX_OVERSAMPLE 8 +#endif + +#if STBTT_MAX_OVERSAMPLE > 255 +#error "STBTT_MAX_OVERSAMPLE cannot be > 255" +#endif + +typedef int stbtt__test_oversample_pow2[(STBTT_MAX_OVERSAMPLE & (STBTT_MAX_OVERSAMPLE-1)) == 0 ? 1 : -1]; + +#ifndef STBTT_RASTERIZER_VERSION +#define STBTT_RASTERIZER_VERSION 2 +#endif + +#ifdef _MSC_VER +#define STBTT__NOTUSED(v) (void)(v) +#else +#define STBTT__NOTUSED(v) (void)sizeof(v) +#endif + +////////////////////////////////////////////////////////////////////////// +// +// stbtt__buf helpers to parse data from file +// + +static stbtt_uint8 stbtt__buf_get8(stbtt__buf *b) +{ + if (b->cursor >= b->size) + return 0; + return b->data[b->cursor++]; +} + +static stbtt_uint8 stbtt__buf_peek8(stbtt__buf *b) +{ + if (b->cursor >= b->size) + return 0; + return b->data[b->cursor]; +} + +static void stbtt__buf_seek(stbtt__buf *b, int o) +{ + STBTT_assert(!(o > b->size || o < 0)); + b->cursor = (o > b->size || o < 0) ? b->size : o; +} + +static void stbtt__buf_skip(stbtt__buf *b, int o) +{ + stbtt__buf_seek(b, b->cursor + o); +} + +static stbtt_uint32 stbtt__buf_get(stbtt__buf *b, int n) +{ + stbtt_uint32 v = 0; + int i; + STBTT_assert(n >= 1 && n <= 4); + for (i = 0; i < n; i++) + v = (v << 8) | stbtt__buf_get8(b); + return v; +} + +static stbtt__buf stbtt__new_buf(const void *p, size_t size) +{ + stbtt__buf r; + STBTT_assert(size < 0x40000000); + r.data = (stbtt_uint8*) p; + r.size = (int) size; + r.cursor = 0; + return r; +} + +#define stbtt__buf_get16(b) stbtt__buf_get((b), 2) +#define stbtt__buf_get32(b) stbtt__buf_get((b), 4) + +static stbtt__buf stbtt__buf_range(const stbtt__buf *b, int o, int s) +{ + stbtt__buf r = stbtt__new_buf(NULL, 0); + if (o < 0 || s < 0 || o > b->size || s > b->size - o) return r; + r.data = b->data + o; + r.size = s; + return r; +} + +static stbtt__buf stbtt__cff_get_index(stbtt__buf *b) +{ + int count, start, offsize; + start = b->cursor; + count = stbtt__buf_get16(b); + if (count) { + offsize = stbtt__buf_get8(b); + STBTT_assert(offsize >= 1 && offsize <= 4); + stbtt__buf_skip(b, offsize * count); + stbtt__buf_skip(b, stbtt__buf_get(b, offsize) - 1); + } + return stbtt__buf_range(b, start, b->cursor - start); +} + +static stbtt_uint32 stbtt__cff_int(stbtt__buf *b) +{ + int b0 = stbtt__buf_get8(b); + if (b0 >= 32 && b0 <= 246) return b0 - 139; + else if (b0 >= 247 && b0 <= 250) return (b0 - 247)*256 + stbtt__buf_get8(b) + 108; + else if (b0 >= 251 && b0 <= 254) return -(b0 - 251)*256 - stbtt__buf_get8(b) - 108; + else if (b0 == 28) return stbtt__buf_get16(b); + else if (b0 == 29) return stbtt__buf_get32(b); + STBTT_assert(0); + return 0; +} + +static void stbtt__cff_skip_operand(stbtt__buf *b) { + int v, b0 = stbtt__buf_peek8(b); + STBTT_assert(b0 >= 28); + if (b0 == 30) { + stbtt__buf_skip(b, 1); + while (b->cursor < b->size) { + v = stbtt__buf_get8(b); + if ((v & 0xF) == 0xF || (v >> 4) == 0xF) + break; + } + } else { + stbtt__cff_int(b); + } +} + +static stbtt__buf stbtt__dict_get(stbtt__buf *b, int key) +{ + stbtt__buf_seek(b, 0); + while (b->cursor < b->size) { + int start = b->cursor, end, op; + while (stbtt__buf_peek8(b) >= 28) + stbtt__cff_skip_operand(b); + end = b->cursor; + op = stbtt__buf_get8(b); + if (op == 12) op = stbtt__buf_get8(b) | 0x100; + if (op == key) return stbtt__buf_range(b, start, end-start); + } + return stbtt__buf_range(b, 0, 0); +} + +static void stbtt__dict_get_ints(stbtt__buf *b, int key, int outcount, stbtt_uint32 *out) +{ + int i; + stbtt__buf operands = stbtt__dict_get(b, key); + for (i = 0; i < outcount && operands.cursor < operands.size; i++) + out[i] = stbtt__cff_int(&operands); +} + +static int stbtt__cff_index_count(stbtt__buf *b) +{ + stbtt__buf_seek(b, 0); + return stbtt__buf_get16(b); +} + +static stbtt__buf stbtt__cff_index_get(stbtt__buf b, int i) +{ + int count, offsize, start, end; + stbtt__buf_seek(&b, 0); + count = stbtt__buf_get16(&b); + offsize = stbtt__buf_get8(&b); + STBTT_assert(i >= 0 && i < count); + STBTT_assert(offsize >= 1 && offsize <= 4); + stbtt__buf_skip(&b, i*offsize); + start = stbtt__buf_get(&b, offsize); + end = stbtt__buf_get(&b, offsize); + return stbtt__buf_range(&b, 2+(count+1)*offsize+start, end - start); +} + +////////////////////////////////////////////////////////////////////////// +// +// 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) + +static stbtt_uint16 ttUSHORT(stbtt_uint8 *p) { return p[0]*256 + p[1]; } +static stbtt_int16 ttSHORT(stbtt_uint8 *p) { return p[0]*256 + p[1]; } +static stbtt_uint32 ttULONG(stbtt_uint8 *p) { return (p[0]<<24) + (p[1]<<16) + (p[2]<<8) + p[3]; } +static stbtt_int32 ttLONG(stbtt_uint8 *p) { return (p[0]<<24) + (p[1]<<16) + (p[2]<<8) + p[3]; } + +#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(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 + if (stbtt_tag(font, "true")) return 1; // Apple specification for TrueType fonts + 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; +} + +static int stbtt_GetFontOffsetForIndex_internal(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*4); + } + } + return -1; +} + +static int stbtt_GetNumberOfFonts_internal(unsigned char *font_collection) +{ + // if it's just a font, there's only one valid font + if (stbtt__isfont(font_collection)) + return 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) { + return ttLONG(font_collection+8); + } + } + return 0; +} + +static stbtt__buf stbtt__get_subrs(stbtt__buf cff, stbtt__buf fontdict) +{ + stbtt_uint32 subrsoff = 0, private_loc[2] = { 0, 0 }; + stbtt__buf pdict; + stbtt__dict_get_ints(&fontdict, 18, 2, private_loc); + if (!private_loc[1] || !private_loc[0]) return stbtt__new_buf(NULL, 0); + pdict = stbtt__buf_range(&cff, private_loc[1], private_loc[0]); + stbtt__dict_get_ints(&pdict, 19, 1, &subrsoff); + if (!subrsoff) return stbtt__new_buf(NULL, 0); + stbtt__buf_seek(&cff, private_loc[1]+subrsoff); + return stbtt__cff_get_index(&cff); +} + +static int stbtt_InitFont_internal(stbtt_fontinfo *info, unsigned char *data, int fontstart) +{ + stbtt_uint32 cmap, t; + stbtt_int32 i,numTables; + + info->data = data; + info->fontstart = fontstart; + info->cff = stbtt__new_buf(NULL, 0); + + 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 + info->gpos = stbtt__find_table(data, fontstart, "GPOS"); // not required + + if (!cmap || !info->head || !info->hhea || !info->hmtx) + return 0; + if (info->glyf) { + // required for truetype + if (!info->loca) return 0; + } else { + // initialization for CFF / Type2 fonts (OTF) + stbtt__buf b, topdict, topdictidx; + stbtt_uint32 cstype = 2, charstrings = 0, fdarrayoff = 0, fdselectoff = 0; + stbtt_uint32 cff; + + cff = stbtt__find_table(data, fontstart, "CFF "); + if (!cff) return 0; + + info->fontdicts = stbtt__new_buf(NULL, 0); + info->fdselect = stbtt__new_buf(NULL, 0); + + // @TODO this should use size from table (not 512MB) + info->cff = stbtt__new_buf(data+cff, 512*1024*1024); + b = info->cff; + + // read the header + stbtt__buf_skip(&b, 2); + stbtt__buf_seek(&b, stbtt__buf_get8(&b)); // hdrsize + + // @TODO the name INDEX could list multiple fonts, + // but we just use the first one. + stbtt__cff_get_index(&b); // name INDEX + topdictidx = stbtt__cff_get_index(&b); + topdict = stbtt__cff_index_get(topdictidx, 0); + stbtt__cff_get_index(&b); // string INDEX + info->gsubrs = stbtt__cff_get_index(&b); + + stbtt__dict_get_ints(&topdict, 17, 1, &charstrings); + stbtt__dict_get_ints(&topdict, 0x100 | 6, 1, &cstype); + stbtt__dict_get_ints(&topdict, 0x100 | 36, 1, &fdarrayoff); + stbtt__dict_get_ints(&topdict, 0x100 | 37, 1, &fdselectoff); + info->subrs = stbtt__get_subrs(b, topdict); + + // we only support Type 2 charstrings + if (cstype != 2) return 0; + if (charstrings == 0) return 0; + + if (fdarrayoff) { + // looks like a CID font + if (!fdselectoff) return 0; + stbtt__buf_seek(&b, fdarrayoff); + info->fontdicts = stbtt__cff_get_index(&b); + info->fdselect = stbtt__buf_range(&b, fdselectoff, b.size-fdselectoff); + } + + stbtt__buf_seek(&b, charstrings); + info->charstrings = stbtt__cff_get_index(&b); + } + + 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; + case STBTT_PLATFORM_ID_UNICODE: + // Mac/iOS has these + // all the encodingIDs are unicode, so we don't bother to check it + info->index_map = cmap + ttULONG(data+encoding_record+4); + break; + } + } + if (info->index_map == 0) + return 0; + + info->indexToLocFormat = ttUSHORT(data+info->head + 50); + return 1; +} + +STBTT_DEF 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; + + // 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; + + { + stbtt_uint16 offset, start; + stbtt_uint16 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; + 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; +} + +STBTT_DEF 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_int32 x, stbtt_int32 y, stbtt_int32 cx, stbtt_int32 cy) +{ + v->type = type; + v->x = (stbtt_int16) x; + v->y = (stbtt_int16) y; + v->cx = (stbtt_int16) cx; + v->cy = (stbtt_int16) cy; +} + +static int stbtt__GetGlyfOffset(const stbtt_fontinfo *info, int glyph_index) +{ + int g1,g2; + + STBTT_assert(!info->cff.size); + + 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 +} + +static int stbtt__GetGlyphInfoT2(const stbtt_fontinfo *info, int glyph_index, int *x0, int *y0, int *x1, int *y1); + +STBTT_DEF int stbtt_GetGlyphBox(const stbtt_fontinfo *info, int glyph_index, int *x0, int *y0, int *x1, int *y1) +{ + if (info->cff.size) { + stbtt__GetGlyphInfoT2(info, glyph_index, x0, y0, x1, y1); + } else { + 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; +} + +STBTT_DEF 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); +} + +STBTT_DEF int stbtt_IsGlyphEmpty(const stbtt_fontinfo *info, int glyph_index) +{ + stbtt_int16 numberOfContours; + int g; + if (info->cff.size) + return stbtt__GetGlyphInfoT2(info, glyph_index, NULL, NULL, NULL, NULL) == 0; + g = stbtt__GetGlyfOffset(info, glyph_index); + if (g < 0) return 1; + numberOfContours = ttSHORT(info->data + g); + return numberOfContours == 0; +} + +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; +} + +static int stbtt__GetGlyphShapeTT(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; + 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 = (stbtt_int16) 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 = (stbtt_int16) y; + } + + // now convert them to our format + num_vertices=0; + sx = sy = cx = cy = scx = scy = 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) STBTT_sqrt(mtx[0]*mtx[0] + mtx[1]*mtx[1]); + n = (float) STBTT_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) STBTT_memcpy(tmp, vertices, num_vertices*sizeof(stbtt_vertex)); + STBTT_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; +} + +typedef struct +{ + int bounds; + int started; + float first_x, first_y; + float x, y; + stbtt_int32 min_x, max_x, min_y, max_y; + + stbtt_vertex *pvertices; + int num_vertices; +} stbtt__csctx; + +#define STBTT__CSCTX_INIT(bounds) {bounds,0, 0,0, 0,0, 0,0,0,0, NULL, 0} + +static void stbtt__track_vertex(stbtt__csctx *c, stbtt_int32 x, stbtt_int32 y) +{ + if (x > c->max_x || !c->started) c->max_x = x; + if (y > c->max_y || !c->started) c->max_y = y; + if (x < c->min_x || !c->started) c->min_x = x; + if (y < c->min_y || !c->started) c->min_y = y; + c->started = 1; +} + +static void stbtt__csctx_v(stbtt__csctx *c, stbtt_uint8 type, stbtt_int32 x, stbtt_int32 y, stbtt_int32 cx, stbtt_int32 cy, stbtt_int32 cx1, stbtt_int32 cy1) +{ + if (c->bounds) { + stbtt__track_vertex(c, x, y); + if (type == STBTT_vcubic) { + stbtt__track_vertex(c, cx, cy); + stbtt__track_vertex(c, cx1, cy1); + } + } else { + stbtt_setvertex(&c->pvertices[c->num_vertices], type, x, y, cx, cy); + c->pvertices[c->num_vertices].cx1 = (stbtt_int16) cx1; + c->pvertices[c->num_vertices].cy1 = (stbtt_int16) cy1; + } + c->num_vertices++; +} + +static void stbtt__csctx_close_shape(stbtt__csctx *ctx) +{ + if (ctx->first_x != ctx->x || ctx->first_y != ctx->y) + stbtt__csctx_v(ctx, STBTT_vline, (int)ctx->first_x, (int)ctx->first_y, 0, 0, 0, 0); +} + +static void stbtt__csctx_rmove_to(stbtt__csctx *ctx, float dx, float dy) +{ + stbtt__csctx_close_shape(ctx); + ctx->first_x = ctx->x = ctx->x + dx; + ctx->first_y = ctx->y = ctx->y + dy; + stbtt__csctx_v(ctx, STBTT_vmove, (int)ctx->x, (int)ctx->y, 0, 0, 0, 0); +} + +static void stbtt__csctx_rline_to(stbtt__csctx *ctx, float dx, float dy) +{ + ctx->x += dx; + ctx->y += dy; + stbtt__csctx_v(ctx, STBTT_vline, (int)ctx->x, (int)ctx->y, 0, 0, 0, 0); +} + +static void stbtt__csctx_rccurve_to(stbtt__csctx *ctx, float dx1, float dy1, float dx2, float dy2, float dx3, float dy3) +{ + float cx1 = ctx->x + dx1; + float cy1 = ctx->y + dy1; + float cx2 = cx1 + dx2; + float cy2 = cy1 + dy2; + ctx->x = cx2 + dx3; + ctx->y = cy2 + dy3; + stbtt__csctx_v(ctx, STBTT_vcubic, (int)ctx->x, (int)ctx->y, (int)cx1, (int)cy1, (int)cx2, (int)cy2); +} + +static stbtt__buf stbtt__get_subr(stbtt__buf idx, int n) +{ + int count = stbtt__cff_index_count(&idx); + int bias = 107; + if (count >= 33900) + bias = 32768; + else if (count >= 1240) + bias = 1131; + n += bias; + if (n < 0 || n >= count) + return stbtt__new_buf(NULL, 0); + return stbtt__cff_index_get(idx, n); +} + +static stbtt__buf stbtt__cid_get_glyph_subrs(const stbtt_fontinfo *info, int glyph_index) +{ + stbtt__buf fdselect = info->fdselect; + int nranges, start, end, v, fmt, fdselector = -1, i; + + stbtt__buf_seek(&fdselect, 0); + fmt = stbtt__buf_get8(&fdselect); + if (fmt == 0) { + // untested + stbtt__buf_skip(&fdselect, glyph_index); + fdselector = stbtt__buf_get8(&fdselect); + } else if (fmt == 3) { + nranges = stbtt__buf_get16(&fdselect); + start = stbtt__buf_get16(&fdselect); + for (i = 0; i < nranges; i++) { + v = stbtt__buf_get8(&fdselect); + end = stbtt__buf_get16(&fdselect); + if (glyph_index >= start && glyph_index < end) { + fdselector = v; + break; + } + start = end; + } + } + if (fdselector == -1) stbtt__new_buf(NULL, 0); + return stbtt__get_subrs(info->cff, stbtt__cff_index_get(info->fontdicts, fdselector)); +} + +static int stbtt__run_charstring(const stbtt_fontinfo *info, int glyph_index, stbtt__csctx *c) +{ + int in_header = 1, maskbits = 0, subr_stack_height = 0, sp = 0, v, i, b0; + int has_subrs = 0, clear_stack; + float s[48]; + stbtt__buf subr_stack[10], subrs = info->subrs, b; + float f; + +#define STBTT__CSERR(s) (0) + + // this currently ignores the initial width value, which isn't needed if we have hmtx + b = stbtt__cff_index_get(info->charstrings, glyph_index); + while (b.cursor < b.size) { + i = 0; + clear_stack = 1; + b0 = stbtt__buf_get8(&b); + switch (b0) { + // @TODO implement hinting + case 0x13: // hintmask + case 0x14: // cntrmask + if (in_header) + maskbits += (sp / 2); // implicit "vstem" + in_header = 0; + stbtt__buf_skip(&b, (maskbits + 7) / 8); + break; + + case 0x01: // hstem + case 0x03: // vstem + case 0x12: // hstemhm + case 0x17: // vstemhm + maskbits += (sp / 2); + break; + + case 0x15: // rmoveto + in_header = 0; + if (sp < 2) return STBTT__CSERR("rmoveto stack"); + stbtt__csctx_rmove_to(c, s[sp-2], s[sp-1]); + break; + case 0x04: // vmoveto + in_header = 0; + if (sp < 1) return STBTT__CSERR("vmoveto stack"); + stbtt__csctx_rmove_to(c, 0, s[sp-1]); + break; + case 0x16: // hmoveto + in_header = 0; + if (sp < 1) return STBTT__CSERR("hmoveto stack"); + stbtt__csctx_rmove_to(c, s[sp-1], 0); + break; + + case 0x05: // rlineto + if (sp < 2) return STBTT__CSERR("rlineto stack"); + for (; i + 1 < sp; i += 2) + stbtt__csctx_rline_to(c, s[i], s[i+1]); + break; + + // hlineto/vlineto and vhcurveto/hvcurveto alternate horizontal and vertical + // starting from a different place. + + case 0x07: // vlineto + if (sp < 1) return STBTT__CSERR("vlineto stack"); + goto vlineto; + case 0x06: // hlineto + if (sp < 1) return STBTT__CSERR("hlineto stack"); + for (;;) { + if (i >= sp) break; + stbtt__csctx_rline_to(c, s[i], 0); + i++; + vlineto: + if (i >= sp) break; + stbtt__csctx_rline_to(c, 0, s[i]); + i++; + } + break; + + case 0x1F: // hvcurveto + if (sp < 4) return STBTT__CSERR("hvcurveto stack"); + goto hvcurveto; + case 0x1E: // vhcurveto + if (sp < 4) return STBTT__CSERR("vhcurveto stack"); + for (;;) { + if (i + 3 >= sp) break; + stbtt__csctx_rccurve_to(c, 0, s[i], s[i+1], s[i+2], s[i+3], (sp - i == 5) ? s[i + 4] : 0.0f); + i += 4; + hvcurveto: + if (i + 3 >= sp) break; + stbtt__csctx_rccurve_to(c, s[i], 0, s[i+1], s[i+2], (sp - i == 5) ? s[i+4] : 0.0f, s[i+3]); + i += 4; + } + break; + + case 0x08: // rrcurveto + if (sp < 6) return STBTT__CSERR("rcurveline stack"); + for (; i + 5 < sp; i += 6) + stbtt__csctx_rccurve_to(c, s[i], s[i+1], s[i+2], s[i+3], s[i+4], s[i+5]); + break; + + case 0x18: // rcurveline + if (sp < 8) return STBTT__CSERR("rcurveline stack"); + for (; i + 5 < sp - 2; i += 6) + stbtt__csctx_rccurve_to(c, s[i], s[i+1], s[i+2], s[i+3], s[i+4], s[i+5]); + if (i + 1 >= sp) return STBTT__CSERR("rcurveline stack"); + stbtt__csctx_rline_to(c, s[i], s[i+1]); + break; + + case 0x19: // rlinecurve + if (sp < 8) return STBTT__CSERR("rlinecurve stack"); + for (; i + 1 < sp - 6; i += 2) + stbtt__csctx_rline_to(c, s[i], s[i+1]); + if (i + 5 >= sp) return STBTT__CSERR("rlinecurve stack"); + stbtt__csctx_rccurve_to(c, s[i], s[i+1], s[i+2], s[i+3], s[i+4], s[i+5]); + break; + + case 0x1A: // vvcurveto + case 0x1B: // hhcurveto + if (sp < 4) return STBTT__CSERR("(vv|hh)curveto stack"); + f = 0.0; + if (sp & 1) { f = s[i]; i++; } + for (; i + 3 < sp; i += 4) { + if (b0 == 0x1B) + stbtt__csctx_rccurve_to(c, s[i], f, s[i+1], s[i+2], s[i+3], 0.0); + else + stbtt__csctx_rccurve_to(c, f, s[i], s[i+1], s[i+2], 0.0, s[i+3]); + f = 0.0; + } + break; + + case 0x0A: // callsubr + if (!has_subrs) { + if (info->fdselect.size) + subrs = stbtt__cid_get_glyph_subrs(info, glyph_index); + has_subrs = 1; + } + // fallthrough + case 0x1D: // callgsubr + if (sp < 1) return STBTT__CSERR("call(g|)subr stack"); + v = (int) s[--sp]; + if (subr_stack_height >= 10) return STBTT__CSERR("recursion limit"); + subr_stack[subr_stack_height++] = b; + b = stbtt__get_subr(b0 == 0x0A ? subrs : info->gsubrs, v); + if (b.size == 0) return STBTT__CSERR("subr not found"); + b.cursor = 0; + clear_stack = 0; + break; + + case 0x0B: // return + if (subr_stack_height <= 0) return STBTT__CSERR("return outside subr"); + b = subr_stack[--subr_stack_height]; + clear_stack = 0; + break; + + case 0x0E: // endchar + stbtt__csctx_close_shape(c); + return 1; + + case 0x0C: { // two-byte escape + float dx1, dx2, dx3, dx4, dx5, dx6, dy1, dy2, dy3, dy4, dy5, dy6; + float dx, dy; + int b1 = stbtt__buf_get8(&b); + switch (b1) { + // @TODO These "flex" implementations ignore the flex-depth and resolution, + // and always draw beziers. + case 0x22: // hflex + if (sp < 7) return STBTT__CSERR("hflex stack"); + dx1 = s[0]; + dx2 = s[1]; + dy2 = s[2]; + dx3 = s[3]; + dx4 = s[4]; + dx5 = s[5]; + dx6 = s[6]; + stbtt__csctx_rccurve_to(c, dx1, 0, dx2, dy2, dx3, 0); + stbtt__csctx_rccurve_to(c, dx4, 0, dx5, -dy2, dx6, 0); + break; + + case 0x23: // flex + if (sp < 13) return STBTT__CSERR("flex stack"); + dx1 = s[0]; + dy1 = s[1]; + dx2 = s[2]; + dy2 = s[3]; + dx3 = s[4]; + dy3 = s[5]; + dx4 = s[6]; + dy4 = s[7]; + dx5 = s[8]; + dy5 = s[9]; + dx6 = s[10]; + dy6 = s[11]; + //fd is s[12] + stbtt__csctx_rccurve_to(c, dx1, dy1, dx2, dy2, dx3, dy3); + stbtt__csctx_rccurve_to(c, dx4, dy4, dx5, dy5, dx6, dy6); + break; + + case 0x24: // hflex1 + if (sp < 9) return STBTT__CSERR("hflex1 stack"); + dx1 = s[0]; + dy1 = s[1]; + dx2 = s[2]; + dy2 = s[3]; + dx3 = s[4]; + dx4 = s[5]; + dx5 = s[6]; + dy5 = s[7]; + dx6 = s[8]; + stbtt__csctx_rccurve_to(c, dx1, dy1, dx2, dy2, dx3, 0); + stbtt__csctx_rccurve_to(c, dx4, 0, dx5, dy5, dx6, -(dy1+dy2+dy5)); + break; + + case 0x25: // flex1 + if (sp < 11) return STBTT__CSERR("flex1 stack"); + dx1 = s[0]; + dy1 = s[1]; + dx2 = s[2]; + dy2 = s[3]; + dx3 = s[4]; + dy3 = s[5]; + dx4 = s[6]; + dy4 = s[7]; + dx5 = s[8]; + dy5 = s[9]; + dx6 = dy6 = s[10]; + dx = dx1+dx2+dx3+dx4+dx5; + dy = dy1+dy2+dy3+dy4+dy5; + if (STBTT_fabs(dx) > STBTT_fabs(dy)) + dy6 = -dy; + else + dx6 = -dx; + stbtt__csctx_rccurve_to(c, dx1, dy1, dx2, dy2, dx3, dy3); + stbtt__csctx_rccurve_to(c, dx4, dy4, dx5, dy5, dx6, dy6); + break; + + default: + return STBTT__CSERR("unimplemented"); + } + } break; + + default: + if (b0 != 255 && b0 != 28 && (b0 < 32 || b0 > 254)) + return STBTT__CSERR("reserved operator"); + + // push immediate + if (b0 == 255) { + f = (float)(stbtt_int32)stbtt__buf_get32(&b) / 0x10000; + } else { + stbtt__buf_skip(&b, -1); + f = (float)(stbtt_int16)stbtt__cff_int(&b); + } + if (sp >= 48) return STBTT__CSERR("push stack overflow"); + s[sp++] = f; + clear_stack = 0; + break; + } + if (clear_stack) sp = 0; + } + return STBTT__CSERR("no endchar"); + +#undef STBTT__CSERR +} + +static int stbtt__GetGlyphShapeT2(const stbtt_fontinfo *info, int glyph_index, stbtt_vertex **pvertices) +{ + // runs the charstring twice, once to count and once to output (to avoid realloc) + stbtt__csctx count_ctx = STBTT__CSCTX_INIT(1); + stbtt__csctx output_ctx = STBTT__CSCTX_INIT(0); + if (stbtt__run_charstring(info, glyph_index, &count_ctx)) { + *pvertices = (stbtt_vertex*)STBTT_malloc(count_ctx.num_vertices*sizeof(stbtt_vertex), info->userdata); + output_ctx.pvertices = *pvertices; + if (stbtt__run_charstring(info, glyph_index, &output_ctx)) { + STBTT_assert(output_ctx.num_vertices == count_ctx.num_vertices); + return output_ctx.num_vertices; + } + } + *pvertices = NULL; + return 0; +} + +static int stbtt__GetGlyphInfoT2(const stbtt_fontinfo *info, int glyph_index, int *x0, int *y0, int *x1, int *y1) +{ + stbtt__csctx c = STBTT__CSCTX_INIT(1); + int r = stbtt__run_charstring(info, glyph_index, &c); + if (x0) *x0 = r ? c.min_x : 0; + if (y0) *y0 = r ? c.min_y : 0; + if (x1) *x1 = r ? c.max_x : 0; + if (y1) *y1 = r ? c.max_y : 0; + return r ? c.num_vertices : 0; +} + +STBTT_DEF int stbtt_GetGlyphShape(const stbtt_fontinfo *info, int glyph_index, stbtt_vertex **pvertices) +{ + if (!info->cff.size) + return stbtt__GetGlyphShapeTT(info, glyph_index, pvertices); + else + return stbtt__GetGlyphShapeT2(info, glyph_index, pvertices); +} + +STBTT_DEF 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); + } 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)); + } +} + +static int stbtt__GetGlyphKernInfoAdvance(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; +} + +static stbtt_int32 stbtt__GetCoverageIndex(stbtt_uint8 *coverageTable, int glyph) +{ + stbtt_uint16 coverageFormat = ttUSHORT(coverageTable); + switch(coverageFormat) { + case 1: { + stbtt_uint16 glyphCount = ttUSHORT(coverageTable + 2); + + // Binary search. + stbtt_int32 l=0, r=glyphCount-1, m; + int straw, needle=glyph; + while (l <= r) { + stbtt_uint8 *glyphArray = coverageTable + 4; + stbtt_uint16 glyphID; + m = (l + r) >> 1; + glyphID = ttUSHORT(glyphArray + 2 * m); + straw = glyphID; + if (needle < straw) + r = m - 1; + else if (needle > straw) + l = m + 1; + else { + return m; + } + } + } break; + + case 2: { + stbtt_uint16 rangeCount = ttUSHORT(coverageTable + 2); + stbtt_uint8 *rangeArray = coverageTable + 4; + + // Binary search. + stbtt_int32 l=0, r=rangeCount-1, m; + int strawStart, strawEnd, needle=glyph; + while (l <= r) { + stbtt_uint8 *rangeRecord; + m = (l + r) >> 1; + rangeRecord = rangeArray + 6 * m; + strawStart = ttUSHORT(rangeRecord); + strawEnd = ttUSHORT(rangeRecord + 2); + if (needle < strawStart) + r = m - 1; + else if (needle > strawEnd) + l = m + 1; + else { + stbtt_uint16 startCoverageIndex = ttUSHORT(rangeRecord + 4); + return startCoverageIndex + glyph - strawStart; + } + } + } break; + + default: { + // There are no other cases. + STBTT_assert(0); + } break; + } + + return -1; +} + +static stbtt_int32 stbtt__GetGlyphClass(stbtt_uint8 *classDefTable, int glyph) +{ + stbtt_uint16 classDefFormat = ttUSHORT(classDefTable); + switch(classDefFormat) + { + case 1: { + stbtt_uint16 startGlyphID = ttUSHORT(classDefTable + 2); + stbtt_uint16 glyphCount = ttUSHORT(classDefTable + 4); + stbtt_uint8 *classDef1ValueArray = classDefTable + 6; + + if (glyph >= startGlyphID && glyph < startGlyphID + glyphCount) + return (stbtt_int32)ttUSHORT(classDef1ValueArray + 2 * (glyph - startGlyphID)); + + classDefTable = classDef1ValueArray + 2 * glyphCount; + } break; + + case 2: { + stbtt_uint16 classRangeCount = ttUSHORT(classDefTable + 2); + stbtt_uint8 *classRangeRecords = classDefTable + 4; + + // Binary search. + stbtt_int32 l=0, r=classRangeCount-1, m; + int strawStart, strawEnd, needle=glyph; + while (l <= r) { + stbtt_uint8 *classRangeRecord; + m = (l + r) >> 1; + classRangeRecord = classRangeRecords + 6 * m; + strawStart = ttUSHORT(classRangeRecord); + strawEnd = ttUSHORT(classRangeRecord + 2); + if (needle < strawStart) + r = m - 1; + else if (needle > strawEnd) + l = m + 1; + else + return (stbtt_int32)ttUSHORT(classRangeRecord + 4); + } + + classDefTable = classRangeRecords + 6 * classRangeCount; + } break; + + default: { + // There are no other cases. + STBTT_assert(0); + } break; + } + + return -1; +} + +// Define to STBTT_assert(x) if you want to break on unimplemented formats. +#define STBTT_GPOS_TODO_assert(x) + +static stbtt_int32 stbtt__GetGlyphGPOSInfoAdvance(const stbtt_fontinfo *info, int glyph1, int glyph2) +{ + stbtt_uint16 lookupListOffset; + stbtt_uint8 *lookupList; + stbtt_uint16 lookupCount; + stbtt_uint8 *data; + stbtt_int32 i; + + if (!info->gpos) return 0; + + data = info->data + info->gpos; + + if (ttUSHORT(data+0) != 1) return 0; // Major version 1 + if (ttUSHORT(data+2) != 0) return 0; // Minor version 0 + + lookupListOffset = ttUSHORT(data+8); + lookupList = data + lookupListOffset; + lookupCount = ttUSHORT(lookupList); + + for (i=0; i> 1; + pairValue = pairValueArray + (2 + valueRecordPairSizeInBytes) * m; + secondGlyph = ttUSHORT(pairValue); + straw = secondGlyph; + if (needle < straw) + r = m - 1; + else if (needle > straw) + l = m + 1; + else { + stbtt_int16 xAdvance = ttSHORT(pairValue + 2); + return xAdvance; + } + } + } break; + + case 2: { + stbtt_uint16 valueFormat1 = ttUSHORT(table + 4); + stbtt_uint16 valueFormat2 = ttUSHORT(table + 6); + + stbtt_uint16 classDef1Offset = ttUSHORT(table + 8); + stbtt_uint16 classDef2Offset = ttUSHORT(table + 10); + int glyph1class = stbtt__GetGlyphClass(table + classDef1Offset, glyph1); + int glyph2class = stbtt__GetGlyphClass(table + classDef2Offset, glyph2); + + stbtt_uint16 class1Count = ttUSHORT(table + 12); + stbtt_uint16 class2Count = ttUSHORT(table + 14); + STBTT_assert(glyph1class < class1Count); + STBTT_assert(glyph2class < class2Count); + + // TODO: Support more formats. + STBTT_GPOS_TODO_assert(valueFormat1 == 4); + if (valueFormat1 != 4) return 0; + STBTT_GPOS_TODO_assert(valueFormat2 == 0); + if (valueFormat2 != 0) return 0; + + if (glyph1class >= 0 && glyph1class < class1Count && glyph2class >= 0 && glyph2class < class2Count) { + stbtt_uint8 *class1Records = table + 16; + stbtt_uint8 *class2Records = class1Records + 2 * (glyph1class * class2Count); + stbtt_int16 xAdvance = ttSHORT(class2Records + 2 * glyph2class); + return xAdvance; + } + } break; + + default: { + // There are no other cases. + STBTT_assert(0); + break; + }; + } + } + break; + }; + + default: + // TODO: Implement other stuff. + break; + } + } + + return 0; +} + +STBTT_DEF int stbtt_GetGlyphKernAdvance(const stbtt_fontinfo *info, int g1, int g2) +{ + int xAdvance = 0; + + if (info->gpos) + xAdvance += stbtt__GetGlyphGPOSInfoAdvance(info, g1, g2); + + if (info->kern) + xAdvance += stbtt__GetGlyphKernInfoAdvance(info, g1, g2); + + return xAdvance; +} + +STBTT_DEF int stbtt_GetCodepointKernAdvance(const stbtt_fontinfo *info, int ch1, int ch2) +{ + if (!info->kern && !info->gpos) // 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)); +} + +STBTT_DEF void stbtt_GetCodepointHMetrics(const stbtt_fontinfo *info, int codepoint, int *advanceWidth, int *leftSideBearing) +{ + stbtt_GetGlyphHMetrics(info, stbtt_FindGlyphIndex(info,codepoint), advanceWidth, leftSideBearing); +} + +STBTT_DEF 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); +} + +STBTT_DEF int stbtt_GetFontVMetricsOS2(const stbtt_fontinfo *info, int *typoAscent, int *typoDescent, int *typoLineGap) +{ + int tab = stbtt__find_table(info->data, info->fontstart, "OS/2"); + if (!tab) + return 0; + if (typoAscent ) *typoAscent = ttSHORT(info->data+tab + 68); + if (typoDescent) *typoDescent = ttSHORT(info->data+tab + 70); + if (typoLineGap) *typoLineGap = ttSHORT(info->data+tab + 72); + return 1; +} + +STBTT_DEF void stbtt_GetFontBoundingBox(const stbtt_fontinfo *info, int *x0, int *y0, int *x1, int *y1) +{ + *x0 = ttSHORT(info->data + info->head + 36); + *y0 = ttSHORT(info->data + info->head + 38); + *x1 = ttSHORT(info->data + info->head + 40); + *y1 = ttSHORT(info->data + info->head + 42); +} + +STBTT_DEF 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; +} + +STBTT_DEF float stbtt_ScaleForMappingEmToPixels(const stbtt_fontinfo *info, float pixels) +{ + int unitsPerEm = ttUSHORT(info->data + info->head + 18); + return pixels / unitsPerEm; +} + +STBTT_DEF void stbtt_FreeShape(const stbtt_fontinfo *info, stbtt_vertex *v) +{ + STBTT_free(v, info->userdata); +} + +////////////////////////////////////////////////////////////////////////////// +// +// antialiasing software rasterizer +// + +STBTT_DEF 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=0,y0=0,x1,y1; // =0 suppresses compiler warning + if (!stbtt_GetGlyphBox(font, glyph, &x0,&y0,&x1,&y1)) { + // e.g. space character + if (ix0) *ix0 = 0; + if (iy0) *iy0 = 0; + if (ix1) *ix1 = 0; + if (iy1) *iy1 = 0; + } else { + // 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_ifloor(-y1 * scale_y + shift_y); + if (ix1) *ix1 = STBTT_iceil ( x1 * scale_x + shift_x); + if (iy1) *iy1 = STBTT_iceil (-y0 * scale_y + shift_y); + } +} + +STBTT_DEF 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); +} + +STBTT_DEF 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); +} + +STBTT_DEF 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); +} + +////////////////////////////////////////////////////////////////////////////// +// +// Rasterizer + +typedef struct stbtt__hheap_chunk +{ + struct stbtt__hheap_chunk *next; +} stbtt__hheap_chunk; + +typedef struct stbtt__hheap +{ + struct stbtt__hheap_chunk *head; + void *first_free; + int num_remaining_in_head_chunk; +} stbtt__hheap; + +static void *stbtt__hheap_alloc(stbtt__hheap *hh, size_t size, void *userdata) +{ + if (hh->first_free) { + void *p = hh->first_free; + hh->first_free = * (void **) p; + return p; + } else { + if (hh->num_remaining_in_head_chunk == 0) { + int count = (size < 32 ? 2000 : size < 128 ? 800 : 100); + stbtt__hheap_chunk *c = (stbtt__hheap_chunk *) STBTT_malloc(sizeof(stbtt__hheap_chunk) + size * count, userdata); + if (c == NULL) + return NULL; + c->next = hh->head; + hh->head = c; + hh->num_remaining_in_head_chunk = count; + } + --hh->num_remaining_in_head_chunk; + return (char *) (hh->head) + sizeof(stbtt__hheap_chunk) + size * hh->num_remaining_in_head_chunk; + } +} + +static void stbtt__hheap_free(stbtt__hheap *hh, void *p) +{ + *(void **) p = hh->first_free; + hh->first_free = p; +} + +static void stbtt__hheap_cleanup(stbtt__hheap *hh, void *userdata) +{ + stbtt__hheap_chunk *c = hh->head; + while (c) { + stbtt__hheap_chunk *n = c->next; + STBTT_free(c, userdata); + c = n; + } +} + +typedef struct stbtt__edge { + float x0,y0, x1,y1; + int invert; +} stbtt__edge; + + +typedef struct stbtt__active_edge +{ + struct stbtt__active_edge *next; + #if STBTT_RASTERIZER_VERSION==1 + int x,dx; + float ey; + int direction; + #elif STBTT_RASTERIZER_VERSION==2 + float fx,fdx,fdy; + float direction; + float sy; + float ey; + #else + #error "Unrecognized value of STBTT_RASTERIZER_VERSION" + #endif +} stbtt__active_edge; + +#if STBTT_RASTERIZER_VERSION == 1 +#define STBTT_FIXSHIFT 10 +#define STBTT_FIX (1 << STBTT_FIXSHIFT) +#define STBTT_FIXMASK (STBTT_FIX-1) + +static stbtt__active_edge *stbtt__new_active(stbtt__hheap *hh, stbtt__edge *e, int off_x, float start_point, void *userdata) +{ + stbtt__active_edge *z = (stbtt__active_edge *) stbtt__hheap_alloc(hh, sizeof(*z), userdata); + float dxdy = (e->x1 - e->x0) / (e->y1 - e->y0); + STBTT_assert(z != NULL); + if (!z) return z; + + // round dx down to avoid overshooting + if (dxdy < 0) + z->dx = -STBTT_ifloor(STBTT_FIX * -dxdy); + else + z->dx = STBTT_ifloor(STBTT_FIX * dxdy); + + z->x = STBTT_ifloor(STBTT_FIX * e->x0 + z->dx * (start_point - e->y0)); // use z->dx so when we offset later it's by the same amount + z->x -= off_x * STBTT_FIX; + + z->ey = e->y1; + z->next = 0; + z->direction = e->invert ? 1 : -1; + return z; +} +#elif STBTT_RASTERIZER_VERSION == 2 +static stbtt__active_edge *stbtt__new_active(stbtt__hheap *hh, stbtt__edge *e, int off_x, float start_point, void *userdata) +{ + stbtt__active_edge *z = (stbtt__active_edge *) stbtt__hheap_alloc(hh, sizeof(*z), userdata); + float dxdy = (e->x1 - e->x0) / (e->y1 - e->y0); + STBTT_assert(z != NULL); + //STBTT_assert(e->y0 <= start_point); + if (!z) return z; + z->fdx = dxdy; + z->fdy = dxdy != 0.0f ? (1.0f/dxdy) : 0.0f; + z->fx = e->x0 + dxdy * (start_point - e->y0); + z->fx -= off_x; + z->direction = e->invert ? 1.0f : -1.0f; + z->sy = e->y0; + z->ey = e->y1; + z->next = 0; + return z; +} +#else +#error "Unrecognized value of STBTT_RASTERIZER_VERSION" +#endif + +#if STBTT_RASTERIZER_VERSION == 1 +// 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->direction; + } else { + int x1 = e->x; w += e->direction; + // if we went to zero, we need to draw + if (w == 0) { + int i = x0 >> STBTT_FIXSHIFT; + int j = x1 >> STBTT_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 >> STBTT_FIXSHIFT); + } else { + if (i >= 0) // add antialiasing for x0 + scanline[i] = scanline[i] + (stbtt_uint8) (((STBTT_FIX - (x0 & STBTT_FIXMASK)) * max_weight) >> STBTT_FIXSHIFT); + else + i = -1; // clip + + if (j < len) // add antialiasing for x1 + scanline[j] = scanline[j] + (stbtt_uint8) (((x1 & STBTT_FIXMASK) * max_weight) >> STBTT_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__hheap hh = { 0, 0, 0 }; + 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->direction); + z->direction = 0; + stbtt__hheap_free(&hh, z); + } 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 = stbtt__new_active(&hh, e, off_x, scan_y, userdata); + if (z != NULL) { + // 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; + } + + stbtt__hheap_cleanup(&hh, userdata); + + if (scanline != scanline_data) + STBTT_free(scanline, userdata); +} + +#elif STBTT_RASTERIZER_VERSION == 2 + +// the edge passed in here does not cross the vertical line at x or the vertical line at x+1 +// (i.e. it has already been clipped to those) +static void stbtt__handle_clipped_edge(float *scanline, int x, stbtt__active_edge *e, float x0, float y0, float x1, float y1) +{ + if (y0 == y1) return; + STBTT_assert(y0 < y1); + STBTT_assert(e->sy <= e->ey); + if (y0 > e->ey) return; + if (y1 < e->sy) return; + if (y0 < e->sy) { + x0 += (x1-x0) * (e->sy - y0) / (y1-y0); + y0 = e->sy; + } + if (y1 > e->ey) { + x1 += (x1-x0) * (e->ey - y1) / (y1-y0); + y1 = e->ey; + } + + if (x0 == x) + STBTT_assert(x1 <= x+1); + else if (x0 == x+1) + STBTT_assert(x1 >= x); + else if (x0 <= x) + STBTT_assert(x1 <= x); + else if (x0 >= x+1) + STBTT_assert(x1 >= x+1); + else + STBTT_assert(x1 >= x && x1 <= x+1); + + if (x0 <= x && x1 <= x) + scanline[x] += e->direction * (y1-y0); + else if (x0 >= x+1 && x1 >= x+1) + ; + else { + STBTT_assert(x0 >= x && x0 <= x+1 && x1 >= x && x1 <= x+1); + scanline[x] += e->direction * (y1-y0) * (1-((x0-x)+(x1-x))/2); // coverage = 1 - average x position + } +} + +static void stbtt__fill_active_edges_new(float *scanline, float *scanline_fill, int len, stbtt__active_edge *e, float y_top) +{ + float y_bottom = y_top+1; + + while (e) { + // brute force every pixel + + // compute intersection points with top & bottom + STBTT_assert(e->ey >= y_top); + + if (e->fdx == 0) { + float x0 = e->fx; + if (x0 < len) { + if (x0 >= 0) { + stbtt__handle_clipped_edge(scanline,(int) x0,e, x0,y_top, x0,y_bottom); + stbtt__handle_clipped_edge(scanline_fill-1,(int) x0+1,e, x0,y_top, x0,y_bottom); + } else { + stbtt__handle_clipped_edge(scanline_fill-1,0,e, x0,y_top, x0,y_bottom); + } + } + } else { + float x0 = e->fx; + float dx = e->fdx; + float xb = x0 + dx; + float x_top, x_bottom; + float sy0,sy1; + float dy = e->fdy; + STBTT_assert(e->sy <= y_bottom && e->ey >= y_top); + + // compute endpoints of line segment clipped to this scanline (if the + // line segment starts on this scanline. x0 is the intersection of the + // line with y_top, but that may be off the line segment. + if (e->sy > y_top) { + x_top = x0 + dx * (e->sy - y_top); + sy0 = e->sy; + } else { + x_top = x0; + sy0 = y_top; + } + if (e->ey < y_bottom) { + x_bottom = x0 + dx * (e->ey - y_top); + sy1 = e->ey; + } else { + x_bottom = xb; + sy1 = y_bottom; + } + + if (x_top >= 0 && x_bottom >= 0 && x_top < len && x_bottom < len) { + // from here on, we don't have to range check x values + + if ((int) x_top == (int) x_bottom) { + float height; + // simple case, only spans one pixel + int x = (int) x_top; + height = sy1 - sy0; + STBTT_assert(x >= 0 && x < len); + scanline[x] += e->direction * (1-((x_top - x) + (x_bottom-x))/2) * height; + scanline_fill[x] += e->direction * height; // everything right of this pixel is filled + } else { + int x,x1,x2; + float y_crossing, step, sign, area; + // covers 2+ pixels + if (x_top > x_bottom) { + // flip scanline vertically; signed area is the same + float t; + sy0 = y_bottom - (sy0 - y_top); + sy1 = y_bottom - (sy1 - y_top); + t = sy0, sy0 = sy1, sy1 = t; + t = x_bottom, x_bottom = x_top, x_top = t; + dx = -dx; + dy = -dy; + t = x0, x0 = xb, xb = t; + } + + x1 = (int) x_top; + x2 = (int) x_bottom; + // compute intersection with y axis at x1+1 + y_crossing = (x1+1 - x0) * dy + y_top; + + sign = e->direction; + // area of the rectangle covered from y0..y_crossing + area = sign * (y_crossing-sy0); + // area of the triangle (x_top,y0), (x+1,y0), (x+1,y_crossing) + scanline[x1] += area * (1-((x_top - x1)+(x1+1-x1))/2); + + step = sign * dy; + for (x = x1+1; x < x2; ++x) { + scanline[x] += area + step/2; + area += step; + } + y_crossing += dy * (x2 - (x1+1)); + + STBTT_assert(STBTT_fabs(area) <= 1.01f); + + scanline[x2] += area + sign * (1-((x2-x2)+(x_bottom-x2))/2) * (sy1-y_crossing); + + scanline_fill[x2] += sign * (sy1-sy0); + } + } else { + // if edge goes outside of box we're drawing, we require + // clipping logic. since this does not match the intended use + // of this library, we use a different, very slow brute + // force implementation + int x; + for (x=0; x < len; ++x) { + // cases: + // + // there can be up to two intersections with the pixel. any intersection + // with left or right edges can be handled by splitting into two (or three) + // regions. intersections with top & bottom do not necessitate case-wise logic. + // + // the old way of doing this found the intersections with the left & right edges, + // then used some simple logic to produce up to three segments in sorted order + // from top-to-bottom. however, this had a problem: if an x edge was epsilon + // across the x border, then the corresponding y position might not be distinct + // from the other y segment, and it might ignored as an empty segment. to avoid + // that, we need to explicitly produce segments based on x positions. + + // rename variables to clearly-defined pairs + float y0 = y_top; + float x1 = (float) (x); + float x2 = (float) (x+1); + float x3 = xb; + float y3 = y_bottom; + + // x = e->x + e->dx * (y-y_top) + // (y-y_top) = (x - e->x) / e->dx + // y = (x - e->x) / e->dx + y_top + float y1 = (x - x0) / dx + y_top; + float y2 = (x+1 - x0) / dx + y_top; + + if (x0 < x1 && x3 > x2) { // three segments descending down-right + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x1,y1); + stbtt__handle_clipped_edge(scanline,x,e, x1,y1, x2,y2); + stbtt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else if (x3 < x1 && x0 > x2) { // three segments descending down-left + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x2,y2); + stbtt__handle_clipped_edge(scanline,x,e, x2,y2, x1,y1); + stbtt__handle_clipped_edge(scanline,x,e, x1,y1, x3,y3); + } else if (x0 < x1 && x3 > x1) { // two segments across x, down-right + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x1,y1); + stbtt__handle_clipped_edge(scanline,x,e, x1,y1, x3,y3); + } else if (x3 < x1 && x0 > x1) { // two segments across x, down-left + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x1,y1); + stbtt__handle_clipped_edge(scanline,x,e, x1,y1, x3,y3); + } else if (x0 < x2 && x3 > x2) { // two segments across x+1, down-right + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x2,y2); + stbtt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else if (x3 < x2 && x0 > x2) { // two segments across x+1, down-left + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x2,y2); + stbtt__handle_clipped_edge(scanline,x,e, x2,y2, x3,y3); + } else { // one segment + stbtt__handle_clipped_edge(scanline,x,e, x0,y0, x3,y3); + } + } + } + } + e = e->next; + } +} + +// directly AA rasterize edges w/o supersampling +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__hheap hh = { 0, 0, 0 }; + stbtt__active_edge *active = NULL; + int y,j=0, i; + float scanline_data[129], *scanline, *scanline2; + + STBTT__NOTUSED(vsubsample); + + if (result->w > 64) + scanline = (float *) STBTT_malloc((result->w*2+1) * sizeof(float), userdata); + else + scanline = scanline_data; + + scanline2 = scanline + result->w; + + y = off_y; + e[n].y0 = (float) (off_y + result->h) + 1; + + while (j < result->h) { + // find center of pixel for this scanline + float scan_y_top = y + 0.0f; + float scan_y_bottom = y + 1.0f; + stbtt__active_edge **step = &active; + + STBTT_memset(scanline , 0, result->w*sizeof(scanline[0])); + STBTT_memset(scanline2, 0, (result->w+1)*sizeof(scanline[0])); + + // update all active edges; + // remove all active edges that terminate before the top of this scanline + while (*step) { + stbtt__active_edge * z = *step; + if (z->ey <= scan_y_top) { + *step = z->next; // delete from list + STBTT_assert(z->direction); + z->direction = 0; + stbtt__hheap_free(&hh, z); + } else { + step = &((*step)->next); // advance through list + } + } + + // insert all edges that start before the bottom of this scanline + while (e->y0 <= scan_y_bottom) { + if (e->y0 != e->y1) { + stbtt__active_edge *z = stbtt__new_active(&hh, e, off_x, scan_y_top, userdata); + if (z != NULL) { + STBTT_assert(z->ey >= scan_y_top); + // insert at front + z->next = active; + active = z; + } + } + ++e; + } + + // now process all active edges + if (active) + stbtt__fill_active_edges_new(scanline, scanline2+1, result->w, active, scan_y_top); + + { + float sum = 0; + for (i=0; i < result->w; ++i) { + float k; + int m; + sum += scanline2[i]; + k = scanline[i] + sum; + k = (float) STBTT_fabs(k)*255 + 0.5f; + m = (int) k; + if (m > 255) m = 255; + result->pixels[j*result->stride + i] = (unsigned char) m; + } + } + // advance all the edges + step = &active; + while (*step) { + stbtt__active_edge *z = *step; + z->fx += z->fdx; // advance to position for current scanline + step = &((*step)->next); // advance through list + } + + ++y; + ++j; + } + + stbtt__hheap_cleanup(&hh, userdata); + + if (scanline != scanline_data) + STBTT_free(scanline, userdata); +} +#else +#error "Unrecognized value of STBTT_RASTERIZER_VERSION" +#endif + +#define STBTT__COMPARE(a,b) ((a)->y0 < (b)->y0) + +static void stbtt__sort_edges_ins_sort(stbtt__edge *p, int n) +{ + int i,j; + for (i=1; i < n; ++i) { + stbtt__edge t = p[i], *a = &t; + j = i; + while (j > 0) { + stbtt__edge *b = &p[j-1]; + int c = STBTT__COMPARE(a,b); + if (!c) break; + p[j] = p[j-1]; + --j; + } + if (i != j) + p[j] = t; + } +} + +static void stbtt__sort_edges_quicksort(stbtt__edge *p, int n) +{ + /* threshhold for transitioning to insertion sort */ + while (n > 12) { + stbtt__edge t; + int c01,c12,c,m,i,j; + + /* compute median of three */ + m = n >> 1; + c01 = STBTT__COMPARE(&p[0],&p[m]); + c12 = STBTT__COMPARE(&p[m],&p[n-1]); + /* if 0 >= mid >= end, or 0 < mid < end, then use mid */ + if (c01 != c12) { + /* otherwise, we'll need to swap something else to middle */ + int z; + c = STBTT__COMPARE(&p[0],&p[n-1]); + /* 0>mid && midn => n; 0 0 */ + /* 0n: 0>n => 0; 0 n */ + z = (c == c12) ? 0 : n-1; + t = p[z]; + p[z] = p[m]; + p[m] = t; + } + /* now p[m] is the median-of-three */ + /* swap it to the beginning so it won't move around */ + t = p[0]; + p[0] = p[m]; + p[m] = t; + + /* partition loop */ + i=1; + j=n-1; + for(;;) { + /* handling of equality is crucial here */ + /* for sentinels & efficiency with duplicates */ + for (;;++i) { + if (!STBTT__COMPARE(&p[i], &p[0])) break; + } + for (;;--j) { + if (!STBTT__COMPARE(&p[0], &p[j])) break; + } + /* make sure we haven't crossed */ + if (i >= j) break; + t = p[i]; + p[i] = p[j]; + p[j] = t; + + ++i; + --j; + } + /* recurse on smaller side, iterate on larger */ + if (j < (n-i)) { + stbtt__sort_edges_quicksort(p,j); + p = p+i; + n = n-i; + } else { + stbtt__sort_edges_quicksort(p+i, n-i); + n = j; + } + } +} + +static void stbtt__sort_edges(stbtt__edge *p, int n) +{ + stbtt__sort_edges_quicksort(p, n); + stbtt__sort_edges_ins_sort(p, n); +} + +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; +#if STBTT_RASTERIZER_VERSION == 1 + int vsubsample = result->h < 8 ? 15 : 5; +#elif STBTT_RASTERIZER_VERSION == 2 + int vsubsample = 1; +#else + #error "Unrecognized value of STBTT_RASTERIZER_VERSION" +#endif + // 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 + shift_y) * vsubsample; + e[n].x1 = p[b].x * scale_x + shift_x; + e[n].y1 = (p[b].y * y_scale_inv + shift_y) * vsubsample; + ++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); + stbtt__sort_edges(e, n); + + // 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; +} + +static void stbtt__tesselate_cubic(stbtt__point *points, int *num_points, float x0, float y0, float x1, float y1, float x2, float y2, float x3, float y3, float objspace_flatness_squared, int n) +{ + // @TODO this "flatness" calculation is just made-up nonsense that seems to work well enough + float dx0 = x1-x0; + float dy0 = y1-y0; + float dx1 = x2-x1; + float dy1 = y2-y1; + float dx2 = x3-x2; + float dy2 = y3-y2; + float dx = x3-x0; + float dy = y3-y0; + float longlen = (float) (STBTT_sqrt(dx0*dx0+dy0*dy0)+STBTT_sqrt(dx1*dx1+dy1*dy1)+STBTT_sqrt(dx2*dx2+dy2*dy2)); + float shortlen = (float) STBTT_sqrt(dx*dx+dy*dy); + float flatness_squared = longlen*longlen-shortlen*shortlen; + + if (n > 16) // 65536 segments on one curve better be enough! + return; + + if (flatness_squared > objspace_flatness_squared) { + float x01 = (x0+x1)/2; + float y01 = (y0+y1)/2; + float x12 = (x1+x2)/2; + float y12 = (y1+y2)/2; + float x23 = (x2+x3)/2; + float y23 = (y2+y3)/2; + + float xa = (x01+x12)/2; + float ya = (y01+y12)/2; + float xb = (x12+x23)/2; + float yb = (y12+y23)/2; + + float mx = (xa+xb)/2; + float my = (ya+yb)/2; + + stbtt__tesselate_cubic(points, num_points, x0,y0, x01,y01, xa,ya, mx,my, objspace_flatness_squared,n+1); + stbtt__tesselate_cubic(points, num_points, mx,my, xb,yb, x23,y23, x3,y3, objspace_flatness_squared,n+1); + } else { + stbtt__add_point(points, *num_points,x3,y3); + *num_points = *num_points+1; + } +} + +// returns number of contours +static 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; + case STBTT_vcubic: + stbtt__tesselate_cubic(points, &num_points, x,y, + vertices[i].cx, vertices[i].cy, + vertices[i].cx1, vertices[i].cy1, + 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; +} + +STBTT_DEF 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 = 0; + int *winding_lengths = NULL; + 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); + } +} + +STBTT_DEF void stbtt_FreeBitmap(unsigned char *bitmap, void *userdata) +{ + STBTT_free(bitmap, userdata); +} + +STBTT_DEF 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) { + STBTT_free(vertices, info->userdata); + return NULL; + } + scale_y = scale_x; + } + + stbtt_GetGlyphBitmapBoxSubpixel(info, glyph, scale_x, scale_y, shift_x, shift_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; +} + +STBTT_DEF 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); +} + +STBTT_DEF 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); +} + +STBTT_DEF 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); +} + +STBTT_DEF 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); +} + +STBTT_DEF void stbtt_MakeCodepointBitmapSubpixelPrefilter(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 oversample_x, int oversample_y, float *sub_x, float *sub_y, int codepoint) +{ + stbtt_MakeGlyphBitmapSubpixelPrefilter(info, output, out_w, out_h, out_stride, scale_x, scale_y, shift_x, shift_y, oversample_x, oversample_y, sub_x, sub_y, stbtt_FindGlyphIndex(info,codepoint)); +} + +STBTT_DEF 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)); +} + +STBTT_DEF 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); +} + +STBTT_DEF 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 + +static int stbtt_BakeFontBitmap_internal(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; + f.userdata = NULL; + if (!stbtt_InitFont(&f, data, offset)) + return -1; + 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 + 1; + if (y+gh+1 > bottom_y) + bottom_y = y+gh+1; + } + return bottom_y; +} + +STBTT_DEF void stbtt_GetBakedQuad(const 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; + const stbtt_bakedchar *b = chardata + char_index; + int round_x = STBTT_ifloor((*xpos + b->xoff) + 0.5f); + int round_y = STBTT_ifloor((*ypos + b->yoff) + 0.5f); + + 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; +} + +////////////////////////////////////////////////////////////////////////////// +// +// rectangle packing replacement routines if you don't have stb_rect_pack.h +// + +#ifndef STB_RECT_PACK_VERSION + +typedef int stbrp_coord; + +//////////////////////////////////////////////////////////////////////////////////// +// // +// // +// COMPILER WARNING ?!?!? // +// // +// // +// if you get a compile warning due to these symbols being defined more than // +// once, move #include "stb_rect_pack.h" before #include "stb_truetype.h" // +// // +//////////////////////////////////////////////////////////////////////////////////// + +typedef struct +{ + int width,height; + int x,y,bottom_y; +} stbrp_context; + +typedef struct +{ + unsigned char x; +} stbrp_node; + +struct stbrp_rect +{ + stbrp_coord x,y; + int id,w,h,was_packed; +}; + +static void stbrp_init_target(stbrp_context *con, int pw, int ph, stbrp_node *nodes, int num_nodes) +{ + con->width = pw; + con->height = ph; + con->x = 0; + con->y = 0; + con->bottom_y = 0; + STBTT__NOTUSED(nodes); + STBTT__NOTUSED(num_nodes); +} + +static void stbrp_pack_rects(stbrp_context *con, stbrp_rect *rects, int num_rects) +{ + int i; + for (i=0; i < num_rects; ++i) { + if (con->x + rects[i].w > con->width) { + con->x = 0; + con->y = con->bottom_y; + } + if (con->y + rects[i].h > con->height) + break; + rects[i].x = con->x; + rects[i].y = con->y; + rects[i].was_packed = 1; + con->x += rects[i].w; + if (con->y + rects[i].h > con->bottom_y) + con->bottom_y = con->y + rects[i].h; + } + for ( ; i < num_rects; ++i) + rects[i].was_packed = 0; +} +#endif + +////////////////////////////////////////////////////////////////////////////// +// +// bitmap baking +// +// This is SUPER-AWESOME (tm Ryan Gordon) packing using stb_rect_pack.h. If +// stb_rect_pack.h isn't available, it uses the BakeFontBitmap strategy. + +STBTT_DEF int stbtt_PackBegin(stbtt_pack_context *spc, unsigned char *pixels, int pw, int ph, int stride_in_bytes, int padding, void *alloc_context) +{ + stbrp_context *context = (stbrp_context *) STBTT_malloc(sizeof(*context) ,alloc_context); + int num_nodes = pw - padding; + stbrp_node *nodes = (stbrp_node *) STBTT_malloc(sizeof(*nodes ) * num_nodes,alloc_context); + + if (context == NULL || nodes == NULL) { + if (context != NULL) STBTT_free(context, alloc_context); + if (nodes != NULL) STBTT_free(nodes , alloc_context); + return 0; + } + + spc->user_allocator_context = alloc_context; + spc->width = pw; + spc->height = ph; + spc->pixels = pixels; + spc->pack_info = context; + spc->nodes = nodes; + spc->padding = padding; + spc->stride_in_bytes = stride_in_bytes != 0 ? stride_in_bytes : pw; + spc->h_oversample = 1; + spc->v_oversample = 1; + + stbrp_init_target(context, pw-padding, ph-padding, nodes, num_nodes); + + if (pixels) + STBTT_memset(pixels, 0, pw*ph); // background of 0 around pixels + + return 1; +} + +STBTT_DEF void stbtt_PackEnd (stbtt_pack_context *spc) +{ + STBTT_free(spc->nodes , spc->user_allocator_context); + STBTT_free(spc->pack_info, spc->user_allocator_context); +} + +STBTT_DEF void stbtt_PackSetOversampling(stbtt_pack_context *spc, unsigned int h_oversample, unsigned int v_oversample) +{ + STBTT_assert(h_oversample <= STBTT_MAX_OVERSAMPLE); + STBTT_assert(v_oversample <= STBTT_MAX_OVERSAMPLE); + if (h_oversample <= STBTT_MAX_OVERSAMPLE) + spc->h_oversample = h_oversample; + if (v_oversample <= STBTT_MAX_OVERSAMPLE) + spc->v_oversample = v_oversample; +} + +#define STBTT__OVER_MASK (STBTT_MAX_OVERSAMPLE-1) + +static void stbtt__h_prefilter(unsigned char *pixels, int w, int h, int stride_in_bytes, unsigned int kernel_width) +{ + unsigned char buffer[STBTT_MAX_OVERSAMPLE]; + int safe_w = w - kernel_width; + int j; + STBTT_memset(buffer, 0, STBTT_MAX_OVERSAMPLE); // suppress bogus warning from VS2013 -analyze + for (j=0; j < h; ++j) { + int i; + unsigned int total; + STBTT_memset(buffer, 0, kernel_width); + + total = 0; + + // make kernel_width a constant in common cases so compiler can optimize out the divide + switch (kernel_width) { + case 2: + for (i=0; i <= safe_w; ++i) { + total += pixels[i] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 2); + } + break; + case 3: + for (i=0; i <= safe_w; ++i) { + total += pixels[i] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 3); + } + break; + case 4: + for (i=0; i <= safe_w; ++i) { + total += pixels[i] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 4); + } + break; + case 5: + for (i=0; i <= safe_w; ++i) { + total += pixels[i] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / 5); + } + break; + default: + for (i=0; i <= safe_w; ++i) { + total += pixels[i] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i]; + pixels[i] = (unsigned char) (total / kernel_width); + } + break; + } + + for (; i < w; ++i) { + STBTT_assert(pixels[i] == 0); + total -= buffer[i & STBTT__OVER_MASK]; + pixels[i] = (unsigned char) (total / kernel_width); + } + + pixels += stride_in_bytes; + } +} + +static void stbtt__v_prefilter(unsigned char *pixels, int w, int h, int stride_in_bytes, unsigned int kernel_width) +{ + unsigned char buffer[STBTT_MAX_OVERSAMPLE]; + int safe_h = h - kernel_width; + int j; + STBTT_memset(buffer, 0, STBTT_MAX_OVERSAMPLE); // suppress bogus warning from VS2013 -analyze + for (j=0; j < w; ++j) { + int i; + unsigned int total; + STBTT_memset(buffer, 0, kernel_width); + + total = 0; + + // make kernel_width a constant in common cases so compiler can optimize out the divide + switch (kernel_width) { + case 2: + for (i=0; i <= safe_h; ++i) { + total += pixels[i*stride_in_bytes] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 2); + } + break; + case 3: + for (i=0; i <= safe_h; ++i) { + total += pixels[i*stride_in_bytes] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 3); + } + break; + case 4: + for (i=0; i <= safe_h; ++i) { + total += pixels[i*stride_in_bytes] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 4); + } + break; + case 5: + for (i=0; i <= safe_h; ++i) { + total += pixels[i*stride_in_bytes] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / 5); + } + break; + default: + for (i=0; i <= safe_h; ++i) { + total += pixels[i*stride_in_bytes] - buffer[i & STBTT__OVER_MASK]; + buffer[(i+kernel_width) & STBTT__OVER_MASK] = pixels[i*stride_in_bytes]; + pixels[i*stride_in_bytes] = (unsigned char) (total / kernel_width); + } + break; + } + + for (; i < h; ++i) { + STBTT_assert(pixels[i*stride_in_bytes] == 0); + total -= buffer[i & STBTT__OVER_MASK]; + pixels[i*stride_in_bytes] = (unsigned char) (total / kernel_width); + } + + pixels += 1; + } +} + +static float stbtt__oversample_shift(int oversample) +{ + if (!oversample) + return 0.0f; + + // The prefilter is a box filter of width "oversample", + // which shifts phase by (oversample - 1)/2 pixels in + // oversampled space. We want to shift in the opposite + // direction to counter this. + return (float)-(oversample - 1) / (2.0f * (float)oversample); +} + +// rects array must be big enough to accommodate all characters in the given ranges +STBTT_DEF int stbtt_PackFontRangesGatherRects(stbtt_pack_context *spc, const stbtt_fontinfo *info, stbtt_pack_range *ranges, int num_ranges, stbrp_rect *rects) +{ + int i,j,k; + + k=0; + for (i=0; i < num_ranges; ++i) { + float fh = ranges[i].font_size; + float scale = fh > 0 ? stbtt_ScaleForPixelHeight(info, fh) : stbtt_ScaleForMappingEmToPixels(info, -fh); + ranges[i].h_oversample = (unsigned char) spc->h_oversample; + ranges[i].v_oversample = (unsigned char) spc->v_oversample; + for (j=0; j < ranges[i].num_chars; ++j) { + int x0,y0,x1,y1; + int codepoint = ranges[i].array_of_unicode_codepoints == NULL ? ranges[i].first_unicode_codepoint_in_range + j : ranges[i].array_of_unicode_codepoints[j]; + int glyph = stbtt_FindGlyphIndex(info, codepoint); + stbtt_GetGlyphBitmapBoxSubpixel(info,glyph, + scale * spc->h_oversample, + scale * spc->v_oversample, + 0,0, + &x0,&y0,&x1,&y1); + rects[k].w = (stbrp_coord) (x1-x0 + spc->padding + spc->h_oversample-1); + rects[k].h = (stbrp_coord) (y1-y0 + spc->padding + spc->v_oversample-1); + ++k; + } + } + + return k; +} + +STBTT_DEF void stbtt_MakeGlyphBitmapSubpixelPrefilter(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 prefilter_x, int prefilter_y, float *sub_x, float *sub_y, int glyph) +{ + stbtt_MakeGlyphBitmapSubpixel(info, + output, + out_w - (prefilter_x - 1), + out_h - (prefilter_y - 1), + out_stride, + scale_x, + scale_y, + shift_x, + shift_y, + glyph); + + if (prefilter_x > 1) + stbtt__h_prefilter(output, out_w, out_h, out_stride, prefilter_x); + + if (prefilter_y > 1) + stbtt__v_prefilter(output, out_w, out_h, out_stride, prefilter_y); + + *sub_x = stbtt__oversample_shift(prefilter_x); + *sub_y = stbtt__oversample_shift(prefilter_y); +} + +// rects array must be big enough to accommodate all characters in the given ranges +STBTT_DEF int stbtt_PackFontRangesRenderIntoRects(stbtt_pack_context *spc, const stbtt_fontinfo *info, stbtt_pack_range *ranges, int num_ranges, stbrp_rect *rects) +{ + int i,j,k, return_value = 1; + + // save current values + int old_h_over = spc->h_oversample; + int old_v_over = spc->v_oversample; + + k = 0; + for (i=0; i < num_ranges; ++i) { + float fh = ranges[i].font_size; + float scale = fh > 0 ? stbtt_ScaleForPixelHeight(info, fh) : stbtt_ScaleForMappingEmToPixels(info, -fh); + float recip_h,recip_v,sub_x,sub_y; + spc->h_oversample = ranges[i].h_oversample; + spc->v_oversample = ranges[i].v_oversample; + recip_h = 1.0f / spc->h_oversample; + recip_v = 1.0f / spc->v_oversample; + sub_x = stbtt__oversample_shift(spc->h_oversample); + sub_y = stbtt__oversample_shift(spc->v_oversample); + for (j=0; j < ranges[i].num_chars; ++j) { + stbrp_rect *r = &rects[k]; + if (r->was_packed) { + stbtt_packedchar *bc = &ranges[i].chardata_for_range[j]; + int advance, lsb, x0,y0,x1,y1; + int codepoint = ranges[i].array_of_unicode_codepoints == NULL ? ranges[i].first_unicode_codepoint_in_range + j : ranges[i].array_of_unicode_codepoints[j]; + int glyph = stbtt_FindGlyphIndex(info, codepoint); + stbrp_coord pad = (stbrp_coord) spc->padding; + + // pad on left and top + r->x += pad; + r->y += pad; + r->w -= pad; + r->h -= pad; + stbtt_GetGlyphHMetrics(info, glyph, &advance, &lsb); + stbtt_GetGlyphBitmapBox(info, glyph, + scale * spc->h_oversample, + scale * spc->v_oversample, + &x0,&y0,&x1,&y1); + stbtt_MakeGlyphBitmapSubpixel(info, + spc->pixels + r->x + r->y*spc->stride_in_bytes, + r->w - spc->h_oversample+1, + r->h - spc->v_oversample+1, + spc->stride_in_bytes, + scale * spc->h_oversample, + scale * spc->v_oversample, + 0,0, + glyph); + + if (spc->h_oversample > 1) + stbtt__h_prefilter(spc->pixels + r->x + r->y*spc->stride_in_bytes, + r->w, r->h, spc->stride_in_bytes, + spc->h_oversample); + + if (spc->v_oversample > 1) + stbtt__v_prefilter(spc->pixels + r->x + r->y*spc->stride_in_bytes, + r->w, r->h, spc->stride_in_bytes, + spc->v_oversample); + + bc->x0 = (stbtt_int16) r->x; + bc->y0 = (stbtt_int16) r->y; + bc->x1 = (stbtt_int16) (r->x + r->w); + bc->y1 = (stbtt_int16) (r->y + r->h); + bc->xadvance = scale * advance; + bc->xoff = (float) x0 * recip_h + sub_x; + bc->yoff = (float) y0 * recip_v + sub_y; + bc->xoff2 = (x0 + r->w) * recip_h + sub_x; + bc->yoff2 = (y0 + r->h) * recip_v + sub_y; + } else { + return_value = 0; // if any fail, report failure + } + + ++k; + } + } + + // restore original values + spc->h_oversample = old_h_over; + spc->v_oversample = old_v_over; + + return return_value; +} + +STBTT_DEF void stbtt_PackFontRangesPackRects(stbtt_pack_context *spc, stbrp_rect *rects, int num_rects) +{ + stbrp_pack_rects((stbrp_context *) spc->pack_info, rects, num_rects); +} + +STBTT_DEF int stbtt_PackFontRanges(stbtt_pack_context *spc, const unsigned char *fontdata, int font_index, stbtt_pack_range *ranges, int num_ranges) +{ + stbtt_fontinfo info; + int i,j,n, return_value = 1; + //stbrp_context *context = (stbrp_context *) spc->pack_info; + stbrp_rect *rects; + + // flag all characters as NOT packed + for (i=0; i < num_ranges; ++i) + for (j=0; j < ranges[i].num_chars; ++j) + ranges[i].chardata_for_range[j].x0 = + ranges[i].chardata_for_range[j].y0 = + ranges[i].chardata_for_range[j].x1 = + ranges[i].chardata_for_range[j].y1 = 0; + + n = 0; + for (i=0; i < num_ranges; ++i) + n += ranges[i].num_chars; + + rects = (stbrp_rect *) STBTT_malloc(sizeof(*rects) * n, spc->user_allocator_context); + if (rects == NULL) + return 0; + + info.userdata = spc->user_allocator_context; + stbtt_InitFont(&info, fontdata, stbtt_GetFontOffsetForIndex(fontdata,font_index)); + + n = stbtt_PackFontRangesGatherRects(spc, &info, ranges, num_ranges, rects); + + stbtt_PackFontRangesPackRects(spc, rects, n); + + return_value = stbtt_PackFontRangesRenderIntoRects(spc, &info, ranges, num_ranges, rects); + + STBTT_free(rects, spc->user_allocator_context); + return return_value; +} + +STBTT_DEF int stbtt_PackFontRange(stbtt_pack_context *spc, const unsigned char *fontdata, int font_index, float font_size, + int first_unicode_codepoint_in_range, int num_chars_in_range, stbtt_packedchar *chardata_for_range) +{ + stbtt_pack_range range; + range.first_unicode_codepoint_in_range = first_unicode_codepoint_in_range; + range.array_of_unicode_codepoints = NULL; + range.num_chars = num_chars_in_range; + range.chardata_for_range = chardata_for_range; + range.font_size = font_size; + return stbtt_PackFontRanges(spc, fontdata, font_index, &range, 1); +} + +STBTT_DEF void stbtt_GetPackedQuad(const stbtt_packedchar *chardata, int pw, int ph, int char_index, float *xpos, float *ypos, stbtt_aligned_quad *q, int align_to_integer) +{ + float ipw = 1.0f / pw, iph = 1.0f / ph; + const stbtt_packedchar *b = chardata + char_index; + + if (align_to_integer) { + float x = (float) STBTT_ifloor((*xpos + b->xoff) + 0.5f); + float y = (float) STBTT_ifloor((*ypos + b->yoff) + 0.5f); + q->x0 = x; + q->y0 = y; + q->x1 = x + b->xoff2 - b->xoff; + q->y1 = y + b->yoff2 - b->yoff; + } else { + q->x0 = *xpos + b->xoff; + q->y0 = *ypos + b->yoff; + q->x1 = *xpos + b->xoff2; + q->y1 = *ypos + b->yoff2; + } + + q->s0 = b->x0 * ipw; + q->t0 = b->y0 * iph; + q->s1 = b->x1 * ipw; + q->t1 = b->y1 * iph; + + *xpos += b->xadvance; +} + +////////////////////////////////////////////////////////////////////////////// +// +// sdf computation +// + +#define STBTT_min(a,b) ((a) < (b) ? (a) : (b)) +#define STBTT_max(a,b) ((a) < (b) ? (b) : (a)) + +static int stbtt__ray_intersect_bezier(float orig[2], float ray[2], float q0[2], float q1[2], float q2[2], float hits[2][2]) +{ + float q0perp = q0[1]*ray[0] - q0[0]*ray[1]; + float q1perp = q1[1]*ray[0] - q1[0]*ray[1]; + float q2perp = q2[1]*ray[0] - q2[0]*ray[1]; + float roperp = orig[1]*ray[0] - orig[0]*ray[1]; + + float a = q0perp - 2*q1perp + q2perp; + float b = q1perp - q0perp; + float c = q0perp - roperp; + + float s0 = 0., s1 = 0.; + int num_s = 0; + + if (a != 0.0) { + float discr = b*b - a*c; + if (discr > 0.0) { + float rcpna = -1 / a; + float d = (float) STBTT_sqrt(discr); + s0 = (b+d) * rcpna; + s1 = (b-d) * rcpna; + if (s0 >= 0.0 && s0 <= 1.0) + num_s = 1; + if (d > 0.0 && s1 >= 0.0 && s1 <= 1.0) { + if (num_s == 0) s0 = s1; + ++num_s; + } + } + } else { + // 2*b*s + c = 0 + // s = -c / (2*b) + s0 = c / (-2 * b); + if (s0 >= 0.0 && s0 <= 1.0) + num_s = 1; + } + + if (num_s == 0) + return 0; + else { + float rcp_len2 = 1 / (ray[0]*ray[0] + ray[1]*ray[1]); + float rayn_x = ray[0] * rcp_len2, rayn_y = ray[1] * rcp_len2; + + float q0d = q0[0]*rayn_x + q0[1]*rayn_y; + float q1d = q1[0]*rayn_x + q1[1]*rayn_y; + float q2d = q2[0]*rayn_x + q2[1]*rayn_y; + float rod = orig[0]*rayn_x + orig[1]*rayn_y; + + float q10d = q1d - q0d; + float q20d = q2d - q0d; + float q0rd = q0d - rod; + + hits[0][0] = q0rd + s0*(2.0f - 2.0f*s0)*q10d + s0*s0*q20d; + hits[0][1] = a*s0+b; + + if (num_s > 1) { + hits[1][0] = q0rd + s1*(2.0f - 2.0f*s1)*q10d + s1*s1*q20d; + hits[1][1] = a*s1+b; + return 2; + } else { + return 1; + } + } +} + +static int equal(float *a, float *b) +{ + return (a[0] == b[0] && a[1] == b[1]); +} + +static int stbtt__compute_crossings_x(float x, float y, int nverts, stbtt_vertex *verts) +{ + int i; + float orig[2], ray[2] = { 1, 0 }; + float y_frac; + int winding = 0; + + orig[0] = x; + orig[1] = y; + + // make sure y never passes through a vertex of the shape + y_frac = (float) STBTT_fmod(y, 1.0f); + if (y_frac < 0.01f) + y += 0.01f; + else if (y_frac > 0.99f) + y -= 0.01f; + orig[1] = y; + + // test a ray from (-infinity,y) to (x,y) + for (i=0; i < nverts; ++i) { + if (verts[i].type == STBTT_vline) { + int x0 = (int) verts[i-1].x, y0 = (int) verts[i-1].y; + int x1 = (int) verts[i ].x, y1 = (int) verts[i ].y; + if (y > STBTT_min(y0,y1) && y < STBTT_max(y0,y1) && x > STBTT_min(x0,x1)) { + float x_inter = (y - y0) / (y1 - y0) * (x1-x0) + x0; + if (x_inter < x) + winding += (y0 < y1) ? 1 : -1; + } + } + if (verts[i].type == STBTT_vcurve) { + int x0 = (int) verts[i-1].x , y0 = (int) verts[i-1].y ; + int x1 = (int) verts[i ].cx, y1 = (int) verts[i ].cy; + int x2 = (int) verts[i ].x , y2 = (int) verts[i ].y ; + int ax = STBTT_min(x0,STBTT_min(x1,x2)), ay = STBTT_min(y0,STBTT_min(y1,y2)); + int by = STBTT_max(y0,STBTT_max(y1,y2)); + if (y > ay && y < by && x > ax) { + float q0[2],q1[2],q2[2]; + float hits[2][2]; + q0[0] = (float)x0; + q0[1] = (float)y0; + q1[0] = (float)x1; + q1[1] = (float)y1; + q2[0] = (float)x2; + q2[1] = (float)y2; + if (equal(q0,q1) || equal(q1,q2)) { + x0 = (int)verts[i-1].x; + y0 = (int)verts[i-1].y; + x1 = (int)verts[i ].x; + y1 = (int)verts[i ].y; + if (y > STBTT_min(y0,y1) && y < STBTT_max(y0,y1) && x > STBTT_min(x0,x1)) { + float x_inter = (y - y0) / (y1 - y0) * (x1-x0) + x0; + if (x_inter < x) + winding += (y0 < y1) ? 1 : -1; + } + } else { + int num_hits = stbtt__ray_intersect_bezier(orig, ray, q0, q1, q2, hits); + if (num_hits >= 1) + if (hits[0][0] < 0) + winding += (hits[0][1] < 0 ? -1 : 1); + if (num_hits >= 2) + if (hits[1][0] < 0) + winding += (hits[1][1] < 0 ? -1 : 1); + } + } + } + } + return winding; +} + +static float stbtt__cuberoot( float x ) +{ + if (x<0) + return -(float) STBTT_pow(-x,1.0f/3.0f); + else + return (float) STBTT_pow( x,1.0f/3.0f); +} + +// x^3 + c*x^2 + b*x + a = 0 +static int stbtt__solve_cubic(float a, float b, float c, float* r) +{ + float s = -a / 3; + float p = b - a*a / 3; + float q = a * (2*a*a - 9*b) / 27 + c; + float p3 = p*p*p; + float d = q*q + 4*p3 / 27; + if (d >= 0) { + float z = (float) STBTT_sqrt(d); + float u = (-q + z) / 2; + float v = (-q - z) / 2; + u = stbtt__cuberoot(u); + v = stbtt__cuberoot(v); + r[0] = s + u + v; + return 1; + } else { + float u = (float) STBTT_sqrt(-p/3); + float v = (float) STBTT_acos(-STBTT_sqrt(-27/p3) * q / 2) / 3; // p3 must be negative, since d is negative + float m = (float) STBTT_cos(v); + float n = (float) STBTT_cos(v-3.141592/2)*1.732050808f; + r[0] = s + u * 2 * m; + r[1] = s - u * (m + n); + r[2] = s - u * (m - n); + + //STBTT_assert( STBTT_fabs(((r[0]+a)*r[0]+b)*r[0]+c) < 0.05f); // these asserts may not be safe at all scales, though they're in bezier t parameter units so maybe? + //STBTT_assert( STBTT_fabs(((r[1]+a)*r[1]+b)*r[1]+c) < 0.05f); + //STBTT_assert( STBTT_fabs(((r[2]+a)*r[2]+b)*r[2]+c) < 0.05f); + return 3; + } +} + +STBTT_DEF unsigned char * stbtt_GetGlyphSDF(const stbtt_fontinfo *info, float scale, int glyph, int padding, unsigned char onedge_value, float pixel_dist_scale, int *width, int *height, int *xoff, int *yoff) +{ + float scale_x = scale, scale_y = scale; + int ix0,iy0,ix1,iy1; + int w,h; + unsigned char *data; + + // if one scale is 0, use same scale for both + if (scale_x == 0) scale_x = scale_y; + if (scale_y == 0) { + if (scale_x == 0) return NULL; // if both scales are 0, return NULL + scale_y = scale_x; + } + + stbtt_GetGlyphBitmapBoxSubpixel(info, glyph, scale, scale, 0.0f,0.0f, &ix0,&iy0,&ix1,&iy1); + + // if empty, return NULL + if (ix0 == ix1 || iy0 == iy1) + return NULL; + + ix0 -= padding; + iy0 -= padding; + ix1 += padding; + iy1 += padding; + + w = (ix1 - ix0); + h = (iy1 - iy0); + + if (width ) *width = w; + if (height) *height = h; + if (xoff ) *xoff = ix0; + if (yoff ) *yoff = iy0; + + // invert for y-downwards bitmaps + scale_y = -scale_y; + + { + int x,y,i,j; + float *precompute; + stbtt_vertex *verts; + int num_verts = stbtt_GetGlyphShape(info, glyph, &verts); + data = (unsigned char *) STBTT_malloc(w * h, info->userdata); + precompute = (float *) STBTT_malloc(num_verts * sizeof(float), info->userdata); + + for (i=0,j=num_verts-1; i < num_verts; j=i++) { + if (verts[i].type == STBTT_vline) { + float x0 = verts[i].x*scale_x, y0 = verts[i].y*scale_y; + float x1 = verts[j].x*scale_x, y1 = verts[j].y*scale_y; + float dist = (float) STBTT_sqrt((x1-x0)*(x1-x0) + (y1-y0)*(y1-y0)); + precompute[i] = (dist == 0) ? 0.0f : 1.0f / dist; + } else if (verts[i].type == STBTT_vcurve) { + float x2 = verts[j].x *scale_x, y2 = verts[j].y *scale_y; + float x1 = verts[i].cx*scale_x, y1 = verts[i].cy*scale_y; + float x0 = verts[i].x *scale_x, y0 = verts[i].y *scale_y; + float bx = x0 - 2*x1 + x2, by = y0 - 2*y1 + y2; + float len2 = bx*bx + by*by; + if (len2 != 0.0f) + precompute[i] = 1.0f / (bx*bx + by*by); + else + precompute[i] = 0.0f; + } else + precompute[i] = 0.0f; + } + + for (y=iy0; y < iy1; ++y) { + for (x=ix0; x < ix1; ++x) { + float val; + float min_dist = 999999.0f; + float sx = (float) x + 0.5f; + float sy = (float) y + 0.5f; + float x_gspace = (sx / scale_x); + float y_gspace = (sy / scale_y); + + int winding = stbtt__compute_crossings_x(x_gspace, y_gspace, num_verts, verts); // @OPTIMIZE: this could just be a rasterization, but needs to be line vs. non-tesselated curves so a new path + + for (i=0; i < num_verts; ++i) { + float x0 = verts[i].x*scale_x, y0 = verts[i].y*scale_y; + + // check against every point here rather than inside line/curve primitives -- @TODO: wrong if multiple 'moves' in a row produce a garbage point, and given culling, probably more efficient to do within line/curve + float dist2 = (x0-sx)*(x0-sx) + (y0-sy)*(y0-sy); + if (dist2 < min_dist*min_dist) + min_dist = (float) STBTT_sqrt(dist2); + + if (verts[i].type == STBTT_vline) { + float x1 = verts[i-1].x*scale_x, y1 = verts[i-1].y*scale_y; + + // coarse culling against bbox + //if (sx > STBTT_min(x0,x1)-min_dist && sx < STBTT_max(x0,x1)+min_dist && + // sy > STBTT_min(y0,y1)-min_dist && sy < STBTT_max(y0,y1)+min_dist) + float dist = (float) STBTT_fabs((x1-x0)*(y0-sy) - (y1-y0)*(x0-sx)) * precompute[i]; + STBTT_assert(i != 0); + if (dist < min_dist) { + // check position along line + // x' = x0 + t*(x1-x0), y' = y0 + t*(y1-y0) + // minimize (x'-sx)*(x'-sx)+(y'-sy)*(y'-sy) + float dx = x1-x0, dy = y1-y0; + float px = x0-sx, py = y0-sy; + // minimize (px+t*dx)^2 + (py+t*dy)^2 = px*px + 2*px*dx*t + t^2*dx*dx + py*py + 2*py*dy*t + t^2*dy*dy + // derivative: 2*px*dx + 2*py*dy + (2*dx*dx+2*dy*dy)*t, set to 0 and solve + float t = -(px*dx + py*dy) / (dx*dx + dy*dy); + if (t >= 0.0f && t <= 1.0f) + min_dist = dist; + } + } else if (verts[i].type == STBTT_vcurve) { + float x2 = verts[i-1].x *scale_x, y2 = verts[i-1].y *scale_y; + float x1 = verts[i ].cx*scale_x, y1 = verts[i ].cy*scale_y; + float box_x0 = STBTT_min(STBTT_min(x0,x1),x2); + float box_y0 = STBTT_min(STBTT_min(y0,y1),y2); + float box_x1 = STBTT_max(STBTT_max(x0,x1),x2); + float box_y1 = STBTT_max(STBTT_max(y0,y1),y2); + // coarse culling against bbox to avoid computing cubic unnecessarily + if (sx > box_x0-min_dist && sx < box_x1+min_dist && sy > box_y0-min_dist && sy < box_y1+min_dist) { + int num=0; + float ax = x1-x0, ay = y1-y0; + float bx = x0 - 2*x1 + x2, by = y0 - 2*y1 + y2; + float mx = x0 - sx, my = y0 - sy; + float res[3],px,py,t,it; + float a_inv = precompute[i]; + if (a_inv == 0.0) { // if a_inv is 0, it's 2nd degree so use quadratic formula + float a = 3*(ax*bx + ay*by); + float b = 2*(ax*ax + ay*ay) + (mx*bx+my*by); + float c = mx*ax+my*ay; + if (a == 0.0) { // if a is 0, it's linear + if (b != 0.0) { + res[num++] = -c/b; + } + } else { + float discriminant = b*b - 4*a*c; + if (discriminant < 0) + num = 0; + else { + float root = (float) STBTT_sqrt(discriminant); + res[0] = (-b - root)/(2*a); + res[1] = (-b + root)/(2*a); + num = 2; // don't bother distinguishing 1-solution case, as code below will still work + } + } + } else { + float b = 3*(ax*bx + ay*by) * a_inv; // could precompute this as it doesn't depend on sample point + float c = (2*(ax*ax + ay*ay) + (mx*bx+my*by)) * a_inv; + float d = (mx*ax+my*ay) * a_inv; + num = stbtt__solve_cubic(b, c, d, res); + } + if (num >= 1 && res[0] >= 0.0f && res[0] <= 1.0f) { + t = res[0], it = 1.0f - t; + px = it*it*x0 + 2*t*it*x1 + t*t*x2; + py = it*it*y0 + 2*t*it*y1 + t*t*y2; + dist2 = (px-sx)*(px-sx) + (py-sy)*(py-sy); + if (dist2 < min_dist * min_dist) + min_dist = (float) STBTT_sqrt(dist2); + } + if (num >= 2 && res[1] >= 0.0f && res[1] <= 1.0f) { + t = res[1], it = 1.0f - t; + px = it*it*x0 + 2*t*it*x1 + t*t*x2; + py = it*it*y0 + 2*t*it*y1 + t*t*y2; + dist2 = (px-sx)*(px-sx) + (py-sy)*(py-sy); + if (dist2 < min_dist * min_dist) + min_dist = (float) STBTT_sqrt(dist2); + } + if (num >= 3 && res[2] >= 0.0f && res[2] <= 1.0f) { + t = res[2], it = 1.0f - t; + px = it*it*x0 + 2*t*it*x1 + t*t*x2; + py = it*it*y0 + 2*t*it*y1 + t*t*y2; + dist2 = (px-sx)*(px-sx) + (py-sy)*(py-sy); + if (dist2 < min_dist * min_dist) + min_dist = (float) STBTT_sqrt(dist2); + } + } + } + } + if (winding == 0) + min_dist = -min_dist; // if outside the shape, value is negative + val = onedge_value + pixel_dist_scale * min_dist; + if (val < 0) + val = 0; + else if (val > 255) + val = 255; + data[(y-iy0)*w+(x-ix0)] = (unsigned char) val; + } + } + STBTT_free(precompute, info->userdata); + STBTT_free(verts, info->userdata); + } + return data; +} + +STBTT_DEF unsigned char * stbtt_GetCodepointSDF(const stbtt_fontinfo *info, float scale, int codepoint, int padding, unsigned char onedge_value, float pixel_dist_scale, int *width, int *height, int *xoff, int *yoff) +{ + return stbtt_GetGlyphSDF(info, scale, stbtt_FindGlyphIndex(info, codepoint), padding, onedge_value, pixel_dist_scale, width, height, xoff, yoff); +} + +STBTT_DEF void stbtt_FreeSDF(unsigned char *bitmap, void *userdata) +{ + STBTT_free(bitmap, userdata); +} + +////////////////////////////////////////////////////////////////////////////// +// +// 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(stbtt_uint8 *s1, stbtt_int32 len1, 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; +} + +static int stbtt_CompareUTF8toUTF16_bigendian_internal(char *s1, int len1, char *s2, int len2) +{ + return len1 == stbtt__CompareUTF8toUTF16_bigendian_prefix((stbtt_uint8*) s1, len1, (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 +STBTT_DEF 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); + stbtt_int32 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) { + 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_internal((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_int32) 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; +} + +static int stbtt_FindMatchingFont_internal(unsigned char *font_collection, 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; + } +} + +#if defined(__GNUC__) || defined(__clang__) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wcast-qual" +#endif + +STBTT_DEF int stbtt_BakeFontBitmap(const unsigned char *data, int offset, + float pixel_height, unsigned char *pixels, int pw, int ph, + int first_char, int num_chars, stbtt_bakedchar *chardata) +{ + return stbtt_BakeFontBitmap_internal((unsigned char *) data, offset, pixel_height, pixels, pw, ph, first_char, num_chars, chardata); +} + +STBTT_DEF int stbtt_GetFontOffsetForIndex(const unsigned char *data, int index) +{ + return stbtt_GetFontOffsetForIndex_internal((unsigned char *) data, index); +} + +STBTT_DEF int stbtt_GetNumberOfFonts(const unsigned char *data) +{ + return stbtt_GetNumberOfFonts_internal((unsigned char *) data); +} + +STBTT_DEF int stbtt_InitFont(stbtt_fontinfo *info, const unsigned char *data, int offset) +{ + return stbtt_InitFont_internal(info, (unsigned char *) data, offset); +} + +STBTT_DEF int stbtt_FindMatchingFont(const unsigned char *fontdata, const char *name, int flags) +{ + return stbtt_FindMatchingFont_internal((unsigned char *) fontdata, (char *) name, flags); +} + +STBTT_DEF int stbtt_CompareUTF8toUTF16_bigendian(const char *s1, int len1, const char *s2, int len2) +{ + return stbtt_CompareUTF8toUTF16_bigendian_internal((char *) s1, len1, (char *) s2, len2); +} + +#if defined(__GNUC__) || defined(__clang__) +#pragma GCC diagnostic pop +#endif + +#endif // STB_TRUETYPE_IMPLEMENTATION + + +// FULL VERSION HISTORY +// +// 1.19 (2018-02-11) OpenType GPOS kerning (horizontal only), STBTT_fmod +// 1.18 (2018-01-29) add missing function +// 1.17 (2017-07-23) make more arguments const; doc fix +// 1.16 (2017-07-12) SDF support +// 1.15 (2017-03-03) make more arguments const +// 1.14 (2017-01-16) num-fonts-in-TTC function +// 1.13 (2017-01-02) support OpenType fonts, certain Apple fonts +// 1.12 (2016-10-25) suppress warnings about casting away const with -Wcast-qual +// 1.11 (2016-04-02) fix unused-variable warning +// 1.10 (2016-04-02) allow user-defined fabs() replacement +// fix memory leak if fontsize=0.0 +// fix warning from duplicate typedef +// 1.09 (2016-01-16) warning fix; avoid crash on outofmem; use alloc userdata for PackFontRanges +// 1.08 (2015-09-13) document stbtt_Rasterize(); fixes for vertical & horizontal edges +// 1.07 (2015-08-01) allow PackFontRanges to accept arrays of sparse codepoints; +// allow PackFontRanges to pack and render in separate phases; +// fix stbtt_GetFontOFfsetForIndex (never worked for non-0 input?); +// fixed an assert() bug in the new rasterizer +// replace assert() with STBTT_assert() in new rasterizer +// 1.06 (2015-07-14) performance improvements (~35% faster on x86 and x64 on test machine) +// also more precise AA rasterizer, except if shapes overlap +// remove need for STBTT_sort +// 1.05 (2015-04-15) fix misplaced definitions for STBTT_STATIC +// 1.04 (2015-04-15) typo in example +// 1.03 (2015-04-12) STBTT_STATIC, fix memory leak in new packing, various fixes +// 1.02 (2014-12-10) fix various warnings & compile issues w/ stb_rect_pack, C++ +// 1.01 (2014-12-08) fix subpixel position when oversampling to exactly match +// non-oversampled; STBTT_POINT_SIZE for packed case only +// 1.00 (2014-12-06) add new PackBegin etc. API, w/ support for oversampling +// 0.99 (2014-09-18) fix multiple bugs with subpixel rendering (ryg) +// 0.9 (2014-08-07) support certain mac/iOS fonts without an MS platformID +// 0.8b (2014-07-07) fix a warning +// 0.8 (2014-05-25) fix a few more warnings +// 0.7 (2013-09-25) bugfix: subpixel glyph bug fixed in 0.5 had come back +// 0.6c (2012-07-24) improve documentation +// 0.6b (2012-07-20) fix a few more warnings +// 0.6 (2012-07-17) fix warnings; added stbtt_ScaleForMappingEmToPixels, +// stbtt_GetFontBoundingBox, stbtt_IsGlyphEmpty +// 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 +// + +/* +------------------------------------------------------------------------------ +This software is available under 2 licenses -- choose whichever you prefer. +------------------------------------------------------------------------------ +ALTERNATIVE A - MIT License +Copyright (c) 2017 Sean Barrett +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. +------------------------------------------------------------------------------ +ALTERNATIVE B - Public Domain (www.unlicense.org) +This is free and unencumbered software released into the public domain. +Anyone is free to copy, modify, publish, use, compile, sell, or distribute this +software, either in source code form or as a compiled binary, for any purpose, +commercial or non-commercial, and by any means. +In jurisdictions that recognize copyright laws, the author or authors of this +software dedicate any and all copyright interest in the software to the public +domain. We make this dedication for the benefit of the public at large and to +the detriment of our heirs and successors. We intend this dedication to be an +overt act of relinquishment in perpetuity of all present and future rights to +this software under copyright law. +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 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. +------------------------------------------------------------------------------ +*/ diff --git a/vendor/lite/src/main.c b/vendor/lite/src/main.c new file mode 100644 index 0000000..1c6872f --- /dev/null +++ b/vendor/lite/src/main.c @@ -0,0 +1,145 @@ +#include +#include +#include "api/api.h" +#include "renderer.h" + +#ifdef _WIN32 + #include +#elif __linux__ + #include +#elif __APPLE__ + #include +#endif + + +SDL_Window *window; + + +static double get_scale(void) { + float dpi; + SDL_GetDisplayDPI(0, NULL, &dpi, NULL); +#if _WIN32 + return dpi / 96.0; +#else + return 1.0; +#endif +} + + +static void get_exe_filename(char *buf, int sz) { +#if _WIN32 + int len = GetModuleFileName(NULL, buf, sz - 1); + buf[len] = '\0'; +#elif __linux__ + char path[512]; + sprintf(path, "/proc/%d/exe", getpid()); + int len = readlink(path, buf, sz - 1); + buf[len] = '\0'; +#elif __APPLE__ + unsigned size = sz; + _NSGetExecutablePath(buf, &size); +#else + strcpy(buf, "./lite"); +#endif +} + + +static void init_window_icon(void) { +#ifndef _WIN32 + #include "../icon.inl" + (void) icon_rgba_len; /* unused */ + SDL_Surface *surf = SDL_CreateRGBSurfaceFrom( + icon_rgba, 64, 64, + 32, 64 * 4, + 0x000000ff, + 0x0000ff00, + 0x00ff0000, + 0xff000000); + SDL_SetWindowIcon(window, surf); + SDL_FreeSurface(surf); +#endif +} + + +int main(int argc, char **argv) { +#ifdef _WIN32 + HINSTANCE lib = LoadLibrary("user32.dll"); + int (*SetProcessDPIAware)() = (void*) GetProcAddress(lib, "SetProcessDPIAware"); + SetProcessDPIAware(); +#endif + + SDL_Init(SDL_INIT_VIDEO | SDL_INIT_EVENTS); + SDL_EnableScreenSaver(); + SDL_EventState(SDL_DROPFILE, SDL_ENABLE); + atexit(SDL_Quit); + +#ifdef SDL_HINT_VIDEO_X11_NET_WM_BYPASS_COMPOSITOR /* Available since 2.0.8 */ + SDL_SetHint(SDL_HINT_VIDEO_X11_NET_WM_BYPASS_COMPOSITOR, "0"); +#endif +#if SDL_VERSION_ATLEAST(2, 0, 5) + SDL_SetHint(SDL_HINT_MOUSE_FOCUS_CLICKTHROUGH, "1"); +#endif + + SDL_DisplayMode dm; + SDL_GetCurrentDisplayMode(0, &dm); + + window = SDL_CreateWindow( + "", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, dm.w * 0.8, dm.h * 0.8, + SDL_WINDOW_RESIZABLE | SDL_WINDOW_ALLOW_HIGHDPI | SDL_WINDOW_HIDDEN); + init_window_icon(); + ren_init(window); + + + lua_State *L = luaL_newstate(); + luaL_openlibs(L); + api_load_libs(L); + + + lua_newtable(L); + for (int i = 0; i < argc; i++) { + lua_pushstring(L, argv[i]); + lua_rawseti(L, -2, i + 1); + } + lua_setglobal(L, "ARGS"); + + lua_pushstring(L, "1.11"); + lua_setglobal(L, "VERSION"); + + lua_pushstring(L, SDL_GetPlatform()); + lua_setglobal(L, "PLATFORM"); + + lua_pushnumber(L, get_scale()); + lua_setglobal(L, "SCALE"); + + char exename[2048]; + get_exe_filename(exename, sizeof(exename)); + lua_pushstring(L, exename); + lua_setglobal(L, "EXEFILE"); + + + (void) luaL_dostring(L, + "local core\n" + "xpcall(function()\n" + " SCALE = tonumber(os.getenv(\"LITE_SCALE\")) or SCALE\n" + " PATHSEP = package.config:sub(1, 1)\n" + " EXEDIR = EXEFILE:match(\"^(.+)[/\\\\].*$\")\n" + " package.path = EXEDIR .. '/data/?.lua;' .. package.path\n" + " package.path = EXEDIR .. '/data/?/init.lua;' .. package.path\n" + " core = require('core')\n" + " core.init()\n" + " core.run()\n" + "end, function(err)\n" + " print('Error: ' .. tostring(err))\n" + " print(debug.traceback(nil, 2))\n" + " if core and core.on_error then\n" + " pcall(core.on_error, err)\n" + " end\n" + " os.exit(1)\n" + "end)"); + + + lua_close(L); + SDL_DestroyWindow(window); + + return EXIT_SUCCESS; +} diff --git a/vendor/lite/src/rencache.c b/vendor/lite/src/rencache.c new file mode 100644 index 0000000..5c6de32 --- /dev/null +++ b/vendor/lite/src/rencache.c @@ -0,0 +1,291 @@ +#include +#include "rencache.h" + +/* a cache over the software renderer -- all drawing operations are stored as +** commands when issued. At the end of the frame we write the commands to a grid +** of hash values, take the cells that have changed since the previous frame, +** merge them into dirty rectangles and redraw only those regions */ + +#define CELLS_X 80 +#define CELLS_Y 50 +#define CELL_SIZE 96 +#define COMMAND_BUF_SIZE (1024 * 512) + +enum { FREE_FONT, SET_CLIP, DRAW_TEXT, DRAW_RECT }; + +typedef struct { + int type, size; + RenRect rect; + RenColor color; + RenFont *font; + int tab_width; + char text[0]; +} Command; + + +static unsigned cells_buf1[CELLS_X * CELLS_Y]; +static unsigned cells_buf2[CELLS_X * CELLS_Y]; +static unsigned *cells_prev = cells_buf1; +static unsigned *cells = cells_buf2; +static RenRect rect_buf[CELLS_X * CELLS_Y / 2]; +static char command_buf[COMMAND_BUF_SIZE]; +static int command_buf_idx; +static RenRect screen_rect; +static bool show_debug; + + +static inline int min(int a, int b) { return a < b ? a : b; } +static inline int max(int a, int b) { return a > b ? a : b; } + +/* 32bit fnv-1a hash */ +#define HASH_INITIAL 2166136261 + +static void hash(unsigned *h, const void *data, int size) { + const unsigned char *p = data; + while (size--) { + *h = (*h ^ *p++) * 16777619; + } +} + + +static inline int cell_idx(int x, int y) { + return x + y * CELLS_X; +} + + +static inline bool rects_overlap(RenRect a, RenRect b) { + return b.x + b.width >= a.x && b.x <= a.x + a.width + && b.y + b.height >= a.y && b.y <= a.y + a.height; +} + + +static RenRect intersect_rects(RenRect a, RenRect b) { + int x1 = max(a.x, b.x); + int y1 = max(a.y, b.y); + int x2 = min(a.x + a.width, b.x + b.width); + int y2 = min(a.y + a.height, b.y + b.height); + return (RenRect) { x1, y1, max(0, x2 - x1), max(0, y2 - y1) }; +} + + +static RenRect merge_rects(RenRect a, RenRect b) { + int x1 = min(a.x, b.x); + int y1 = min(a.y, b.y); + int x2 = max(a.x + a.width, b.x + b.width); + int y2 = max(a.y + a.height, b.y + b.height); + return (RenRect) { x1, y1, x2 - x1, y2 - y1 }; +} + + +static Command* push_command(int type, int size) { + Command *cmd = (Command*) (command_buf + command_buf_idx); + int n = command_buf_idx + size; + if (n > COMMAND_BUF_SIZE) { + fprintf(stderr, "Warning: (" __FILE__ "): exhausted command buffer\n"); + return NULL; + } + command_buf_idx = n; + memset(cmd, 0, sizeof(Command)); + cmd->type = type; + cmd->size = size; + return cmd; +} + + +static bool next_command(Command **prev) { + if (*prev == NULL) { + *prev = (Command*) command_buf; + } else { + *prev = (Command*) (((char*) *prev) + (*prev)->size); + } + return *prev != ((Command*) (command_buf + command_buf_idx)); +} + + +void rencache_show_debug(bool enable) { + show_debug = enable; +} + + +void rencache_free_font(RenFont *font) { + Command *cmd = push_command(FREE_FONT, sizeof(Command)); + if (cmd) { cmd->font = font; } +} + + +void rencache_set_clip_rect(RenRect rect) { + Command *cmd = push_command(SET_CLIP, sizeof(Command)); + if (cmd) { cmd->rect = intersect_rects(rect, screen_rect); } +} + + +void rencache_draw_rect(RenRect rect, RenColor color) { + if (!rects_overlap(screen_rect, rect)) { return; } + Command *cmd = push_command(DRAW_RECT, sizeof(Command)); + if (cmd) { + cmd->rect = rect; + cmd->color = color; + } +} + + +int rencache_draw_text(RenFont *font, const char *text, int x, int y, RenColor color) { + RenRect rect; + rect.x = x; + rect.y = y; + rect.width = ren_get_font_width(font, text); + rect.height = ren_get_font_height(font); + + if (rects_overlap(screen_rect, rect)) { + int sz = strlen(text) + 1; + Command *cmd = push_command(DRAW_TEXT, sizeof(Command) + sz); + if (cmd) { + memcpy(cmd->text, text, sz); + cmd->color = color; + cmd->font = font; + cmd->rect = rect; + cmd->tab_width = ren_get_font_tab_width(font); + } + } + + return x + rect.width; +} + + +void rencache_invalidate(void) { + memset(cells_prev, 0xff, sizeof(cells_buf1)); +} + + +void rencache_begin_frame(void) { + /* reset all cells if the screen width/height has changed */ + int w, h; + ren_get_size(&w, &h); + if (screen_rect.width != w || h != screen_rect.height) { + screen_rect.width = w; + screen_rect.height = h; + rencache_invalidate(); + } +} + + +static void update_overlapping_cells(RenRect r, unsigned h) { + int x1 = r.x / CELL_SIZE; + int y1 = r.y / CELL_SIZE; + int x2 = (r.x + r.width) / CELL_SIZE; + int y2 = (r.y + r.height) / CELL_SIZE; + + for (int y = y1; y <= y2; y++) { + for (int x = x1; x <= x2; x++) { + int idx = cell_idx(x, y); + hash(&cells[idx], &h, sizeof(h)); + } + } +} + + +static void push_rect(RenRect r, int *count) { + /* try to merge with existing rectangle */ + for (int i = *count - 1; i >= 0; i--) { + RenRect *rp = &rect_buf[i]; + if (rects_overlap(*rp, r)) { + *rp = merge_rects(*rp, r); + return; + } + } + /* couldn't merge with previous rectangle: push */ + rect_buf[(*count)++] = r; +} + + +void rencache_end_frame(void) { + /* update cells from commands */ + Command *cmd = NULL; + RenRect cr = screen_rect; + while (next_command(&cmd)) { + if (cmd->type == SET_CLIP) { cr = cmd->rect; } + RenRect r = intersect_rects(cmd->rect, cr); + if (r.width == 0 || r.height == 0) { continue; } + unsigned h = HASH_INITIAL; + hash(&h, cmd, cmd->size); + update_overlapping_cells(r, h); + } + + /* push rects for all cells changed from last frame, reset cells */ + int rect_count = 0; + int max_x = screen_rect.width / CELL_SIZE + 1; + int max_y = screen_rect.height / CELL_SIZE + 1; + for (int y = 0; y < max_y; y++) { + for (int x = 0; x < max_x; x++) { + /* compare previous and current cell for change */ + int idx = cell_idx(x, y); + if (cells[idx] != cells_prev[idx]) { + push_rect((RenRect) { x, y, 1, 1 }, &rect_count); + } + cells_prev[idx] = HASH_INITIAL; + } + } + + /* expand rects from cells to pixels */ + for (int i = 0; i < rect_count; i++) { + RenRect *r = &rect_buf[i]; + r->x *= CELL_SIZE; + r->y *= CELL_SIZE; + r->width *= CELL_SIZE; + r->height *= CELL_SIZE; + *r = intersect_rects(*r, screen_rect); + } + + /* redraw updated regions */ + bool has_free_commands = false; + for (int i = 0; i < rect_count; i++) { + /* draw */ + RenRect r = rect_buf[i]; + ren_set_clip_rect(r); + + cmd = NULL; + while (next_command(&cmd)) { + switch (cmd->type) { + case FREE_FONT: + has_free_commands = true; + break; + case SET_CLIP: + ren_set_clip_rect(intersect_rects(cmd->rect, r)); + break; + case DRAW_RECT: + ren_draw_rect(cmd->rect, cmd->color); + break; + case DRAW_TEXT: + ren_set_font_tab_width(cmd->font, cmd->tab_width); + ren_draw_text(cmd->font, cmd->text, cmd->rect.x, cmd->rect.y, cmd->color); + break; + } + } + + if (show_debug) { + RenColor color = { rand(), rand(), rand(), 50 }; + ren_draw_rect(r, color); + } + } + + /* update dirty rects */ + if (rect_count > 0) { + ren_update_rects(rect_buf, rect_count); + } + + /* free fonts */ + if (has_free_commands) { + cmd = NULL; + while (next_command(&cmd)) { + if (cmd->type == FREE_FONT) { + ren_free_font(cmd->font); + } + } + } + + /* swap cell buffer and reset */ + unsigned *tmp = cells; + cells = cells_prev; + cells_prev = tmp; + command_buf_idx = 0; +} diff --git a/vendor/lite/src/rencache.h b/vendor/lite/src/rencache.h new file mode 100644 index 0000000..c5fa80f --- /dev/null +++ b/vendor/lite/src/rencache.h @@ -0,0 +1,16 @@ +#ifndef RENCACHE_H +#define RENCACHE_H + +#include +#include "renderer.h" + +void rencache_show_debug(bool enable); +void rencache_free_font(RenFont *font); +void rencache_set_clip_rect(RenRect rect); +void rencache_draw_rect(RenRect rect, RenColor color); +int rencache_draw_text(RenFont *font, const char *text, int x, int y, RenColor color); +void rencache_invalidate(void); +void rencache_begin_frame(void); +void rencache_end_frame(void); + +#endif diff --git a/vendor/lite/src/renderer.c b/vendor/lite/src/renderer.c new file mode 100644 index 0000000..0751d0b --- /dev/null +++ b/vendor/lite/src/renderer.c @@ -0,0 +1,352 @@ +#include +#include +#include +#include +#include "lib/stb/stb_truetype.h" +#include "renderer.h" + +#define MAX_GLYPHSET 256 + +struct RenImage { + RenColor *pixels; + int width, height; +}; + +typedef struct { + RenImage *image; + stbtt_bakedchar glyphs[256]; +} GlyphSet; + +struct RenFont { + void *data; + stbtt_fontinfo stbfont; + GlyphSet *sets[MAX_GLYPHSET]; + float size; + int height; +}; + + +static SDL_Window *window; +static struct { int left, top, right, bottom; } clip; + + +static void* check_alloc(void *ptr) { + if (!ptr) { + fprintf(stderr, "Fatal error: memory allocation failed\n"); + exit(EXIT_FAILURE); + } + return ptr; +} + + +static const char* utf8_to_codepoint(const char *p, unsigned *dst) { + unsigned res, n; + switch (*p & 0xf0) { + case 0xf0 : res = *p & 0x07; n = 3; break; + case 0xe0 : res = *p & 0x0f; n = 2; break; + case 0xd0 : + case 0xc0 : res = *p & 0x1f; n = 1; break; + default : res = *p; n = 0; break; + } + while (n--) { + res = (res << 6) | (*(++p) & 0x3f); + } + *dst = res; + return p + 1; +} + + +void ren_init(SDL_Window *win) { + assert(win); + window = win; + SDL_Surface *surf = SDL_GetWindowSurface(window); + ren_set_clip_rect( (RenRect) { 0, 0, surf->w, surf->h } ); +} + + +void ren_update_rects(RenRect *rects, int count) { + SDL_UpdateWindowSurfaceRects(window, (SDL_Rect*) rects, count); + static bool initial_frame = true; + if (initial_frame) { + SDL_ShowWindow(window); + initial_frame = false; + } +} + + +void ren_set_clip_rect(RenRect rect) { + clip.left = rect.x; + clip.top = rect.y; + clip.right = rect.x + rect.width; + clip.bottom = rect.y + rect.height; +} + + +void ren_get_size(int *x, int *y) { + SDL_Surface *surf = SDL_GetWindowSurface(window); + *x = surf->w; + *y = surf->h; +} + + +RenImage* ren_new_image(int width, int height) { + assert(width > 0 && height > 0); + RenImage *image = malloc(sizeof(RenImage) + width * height * sizeof(RenColor)); + check_alloc(image); + image->pixels = (void*) (image + 1); + image->width = width; + image->height = height; + return image; +} + + +void ren_free_image(RenImage *image) { + free(image); +} + + +static GlyphSet* load_glyphset(RenFont *font, int idx) { + GlyphSet *set = check_alloc(calloc(1, sizeof(GlyphSet))); + + /* init image */ + int width = 128; + int height = 128; +retry: + set->image = ren_new_image(width, height); + + /* load glyphs */ + float s = + stbtt_ScaleForMappingEmToPixels(&font->stbfont, 1) / + stbtt_ScaleForPixelHeight(&font->stbfont, 1); + int res = stbtt_BakeFontBitmap( + font->data, 0, font->size * s, (void*) set->image->pixels, + width, height, idx * 256, 256, set->glyphs); + + /* retry with a larger image buffer if the buffer wasn't large enough */ + if (res < 0) { + width *= 2; + height *= 2; + ren_free_image(set->image); + goto retry; + } + + /* adjust glyph yoffsets and xadvance */ + int ascent, descent, linegap; + stbtt_GetFontVMetrics(&font->stbfont, &ascent, &descent, &linegap); + float scale = stbtt_ScaleForMappingEmToPixels(&font->stbfont, font->size); + int scaled_ascent = ascent * scale + 0.5; + for (int i = 0; i < 256; i++) { + set->glyphs[i].yoff += scaled_ascent; + set->glyphs[i].xadvance = floor(set->glyphs[i].xadvance); + } + + /* convert 8bit data to 32bit */ + for (int i = width * height - 1; i >= 0; i--) { + uint8_t n = *((uint8_t*) set->image->pixels + i); + set->image->pixels[i] = (RenColor) { .r = 255, .g = 255, .b = 255, .a = n }; + } + + return set; +} + + +static GlyphSet* get_glyphset(RenFont *font, int codepoint) { + int idx = (codepoint >> 8) % MAX_GLYPHSET; + if (!font->sets[idx]) { + font->sets[idx] = load_glyphset(font, idx); + } + return font->sets[idx]; +} + + +RenFont* ren_load_font(const char *filename, float size) { + RenFont *font = NULL; + FILE *fp = NULL; + + /* init font */ + font = check_alloc(calloc(1, sizeof(RenFont))); + font->size = size; + + /* load font into buffer */ + fp = fopen(filename, "rb"); + if (!fp) { return NULL; } + /* get size */ + fseek(fp, 0, SEEK_END); int buf_size = ftell(fp); fseek(fp, 0, SEEK_SET); + /* load */ + font->data = check_alloc(malloc(buf_size)); + int _ = fread(font->data, 1, buf_size, fp); (void) _; + fclose(fp); + fp = NULL; + + /* init stbfont */ + int ok = stbtt_InitFont(&font->stbfont, font->data, 0); + if (!ok) { goto fail; } + + /* get height and scale */ + int ascent, descent, linegap; + stbtt_GetFontVMetrics(&font->stbfont, &ascent, &descent, &linegap); + float scale = stbtt_ScaleForMappingEmToPixels(&font->stbfont, size); + font->height = (ascent - descent + linegap) * scale + 0.5; + + /* make tab and newline glyphs invisible */ + stbtt_bakedchar *g = get_glyphset(font, '\n')->glyphs; + g['\t'].x1 = g['\t'].x0; + g['\n'].x1 = g['\n'].x0; + + return font; + +fail: + if (fp) { fclose(fp); } + if (font) { free(font->data); } + free(font); + return NULL; +} + + +void ren_free_font(RenFont *font) { + for (int i = 0; i < MAX_GLYPHSET; i++) { + GlyphSet *set = font->sets[i]; + if (set) { + ren_free_image(set->image); + free(set); + } + } + free(font->data); + free(font); +} + + +void ren_set_font_tab_width(RenFont *font, int n) { + GlyphSet *set = get_glyphset(font, '\t'); + set->glyphs['\t'].xadvance = n; +} + + +int ren_get_font_tab_width(RenFont *font) { + GlyphSet *set = get_glyphset(font, '\t'); + return set->glyphs['\t'].xadvance; +} + + +int ren_get_font_width(RenFont *font, const char *text) { + int x = 0; + const char *p = text; + unsigned codepoint; + while (*p) { + p = utf8_to_codepoint(p, &codepoint); + GlyphSet *set = get_glyphset(font, codepoint); + stbtt_bakedchar *g = &set->glyphs[codepoint & 0xff]; + x += g->xadvance; + } + return x; +} + + +int ren_get_font_height(RenFont *font) { + return font->height; +} + + +static inline RenColor blend_pixel(RenColor dst, RenColor src) { + int ia = 0xff - src.a; + dst.r = ((src.r * src.a) + (dst.r * ia)) >> 8; + dst.g = ((src.g * src.a) + (dst.g * ia)) >> 8; + dst.b = ((src.b * src.a) + (dst.b * ia)) >> 8; + return dst; +} + + +static inline RenColor blend_pixel2(RenColor dst, RenColor src, RenColor color) { + src.a = (src.a * color.a) >> 8; + int ia = 0xff - src.a; + dst.r = ((src.r * color.r * src.a) >> 16) + ((dst.r * ia) >> 8); + dst.g = ((src.g * color.g * src.a) >> 16) + ((dst.g * ia) >> 8); + dst.b = ((src.b * color.b * src.a) >> 16) + ((dst.b * ia) >> 8); + return dst; +} + + +#define rect_draw_loop(expr) \ + for (int j = y1; j < y2; j++) { \ + for (int i = x1; i < x2; i++) { \ + *d = expr; \ + d++; \ + } \ + d += dr; \ + } + +void ren_draw_rect(RenRect rect, RenColor color) { + if (color.a == 0) { return; } + + int x1 = rect.x < clip.left ? clip.left : rect.x; + int y1 = rect.y < clip.top ? clip.top : rect.y; + int x2 = rect.x + rect.width; + int y2 = rect.y + rect.height; + x2 = x2 > clip.right ? clip.right : x2; + y2 = y2 > clip.bottom ? clip.bottom : y2; + + SDL_Surface *surf = SDL_GetWindowSurface(window); + RenColor *d = (RenColor*) surf->pixels; + d += x1 + y1 * surf->w; + int dr = surf->w - (x2 - x1); + + if (color.a == 0xff) { + rect_draw_loop(color); + } else { + rect_draw_loop(blend_pixel(*d, color)); + } +} + + +void ren_draw_image(RenImage *image, RenRect *sub, int x, int y, RenColor color) { + if (color.a == 0) { return; } + + /* clip */ + int n; + if ((n = clip.left - x) > 0) { sub->width -= n; sub->x += n; x += n; } + if ((n = clip.top - y) > 0) { sub->height -= n; sub->y += n; y += n; } + if ((n = x + sub->width - clip.right ) > 0) { sub->width -= n; } + if ((n = y + sub->height - clip.bottom) > 0) { sub->height -= n; } + + if (sub->width <= 0 || sub->height <= 0) { + return; + } + + /* draw */ + SDL_Surface *surf = SDL_GetWindowSurface(window); + RenColor *s = image->pixels; + RenColor *d = (RenColor*) surf->pixels; + s += sub->x + sub->y * image->width; + d += x + y * surf->w; + int sr = image->width - sub->width; + int dr = surf->w - sub->width; + + for (int j = 0; j < sub->height; j++) { + for (int i = 0; i < sub->width; i++) { + *d = blend_pixel2(*d, *s, color); + d++; + s++; + } + d += dr; + s += sr; + } +} + + +int ren_draw_text(RenFont *font, const char *text, int x, int y, RenColor color) { + RenRect rect; + const char *p = text; + unsigned codepoint; + while (*p) { + p = utf8_to_codepoint(p, &codepoint); + GlyphSet *set = get_glyphset(font, codepoint); + stbtt_bakedchar *g = &set->glyphs[codepoint & 0xff]; + rect.x = g->x0; + rect.y = g->y0; + rect.width = g->x1 - g->x0; + rect.height = g->y1 - g->y0; + ren_draw_image(set->image, &rect, x + g->xoff, y + g->yoff, color); + x += g->xadvance; + } + return x; +} diff --git a/vendor/lite/src/renderer.h b/vendor/lite/src/renderer.h new file mode 100644 index 0000000..69cc1f0 --- /dev/null +++ b/vendor/lite/src/renderer.h @@ -0,0 +1,33 @@ +#ifndef RENDERER_H +#define RENDERER_H + +#include +#include + +typedef struct RenImage RenImage; +typedef struct RenFont RenFont; + +typedef struct { uint8_t b, g, r, a; } RenColor; +typedef struct { int x, y, width, height; } RenRect; + + +void ren_init(SDL_Window *win); +void ren_update_rects(RenRect *rects, int count); +void ren_set_clip_rect(RenRect rect); +void ren_get_size(int *x, int *y); + +RenImage* ren_new_image(int width, int height); +void ren_free_image(RenImage *image); + +RenFont* ren_load_font(const char *filename, float size); +void ren_free_font(RenFont *font); +void ren_set_font_tab_width(RenFont *font, int n); +int ren_get_font_tab_width(RenFont *font); +int ren_get_font_width(RenFont *font, const char *text); +int ren_get_font_height(RenFont *font); + +void ren_draw_rect(RenRect rect, RenColor color); +void ren_draw_image(RenImage *image, RenRect *sub, int x, int y, RenColor color); +int ren_draw_text(RenFont *font, const char *text, int x, int y, RenColor color); + +#endif diff --git a/vendor/lite/winlib/SDL2-2.0.10/BUGS.txt b/vendor/lite/winlib/SDL2-2.0.10/BUGS.txt new file mode 100644 index 0000000..57d953f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/BUGS.txt @@ -0,0 +1,16 @@ + +Bugs are now managed in the SDL bug tracker, here: + + https://bugzilla.libsdl.org/ + +You may report bugs there, and search to see if a given issue has already + been reported, discussed, and maybe even fixed. + + +You may also find help at the SDL forums/mailing list: + + https://discourse.libsdl.org/ + +Bug reports are welcome here, but we really appreciate if you use Bugzilla, as + bugs discussed on the mailing list may be forgotten or missed. + diff --git a/vendor/lite/winlib/SDL2-2.0.10/COPYING.txt b/vendor/lite/winlib/SDL2-2.0.10/COPYING.txt new file mode 100644 index 0000000..1a5e2b6 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/COPYING.txt @@ -0,0 +1,20 @@ + +Simple DirectMedia Layer +Copyright (C) 1997-2019 Sam Lantinga + +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. + diff --git a/vendor/lite/winlib/SDL2-2.0.10/CREDITS.txt b/vendor/lite/winlib/SDL2-2.0.10/CREDITS.txt new file mode 100644 index 0000000..74163e8 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/CREDITS.txt @@ -0,0 +1,53 @@ + +Simple DirectMedia Layer CREDITS +Thanks to everyone who made this possible, including: + +* Cliff Matthews, for giving me a reason to start this project. :) + -- Executor rocks! *grin* + +* Ryan Gordon for helping everybody out and keeping the dream alive. :) + +* Gabriel Jacobo for his work on the Android port and generally helping out all around. + +* Philipp Wiesemann for his attention to detail reviewing the entire SDL code base and proposes patches. + +* Andreas Schiffler for his dedication to unit tests, Visual Studio projects, and managing the Google Summer of Code. + +* Mike Sartain for incorporating SDL into Team Fortress 2 and cheering me on at Valve. + +* Alfred Reynolds for the game controller API and general (in)sanity + +* Jørgen Tjernø for numerous magical Mac OS X fixes. + +* Pierre-Loup Griffais for his deep knowledge of OpenGL drivers. + +* Julian Winter for the SDL 2.0 website. + +* Sheena Smith for many months of great work on the SDL wiki creating the API documentation and style guides. + +* Paul Hunkin for his port of SDL to Android during the Google Summer of Code 2010. + +* Eli Gottlieb for his work on shaped windows during the Google Summer of Code 2010. + +* Jim Grandpre for his work on multi-touch and gesture recognition during + the Google Summer of Code 2010. + +* Edgar "bobbens" Simo for his force feedback API development during the + Google Summer of Code 2008. + +* Aaron Wishnick for his work on audio resampling and pitch shifting during + the Google Summer of Code 2008. + +* Holmes Futrell for his port of SDL to the iPhone and iPod Touch during the + Google Summer of Code 2008. + +* Jon Atkins for SDL_image, SDL_mixer and SDL_net documentation. + +* Everybody at Loki Software, Inc. for their great contributions! + + And a big hand to everyone else who has contributed over the years. + +THANKS! :) + + -- Sam Lantinga + diff --git a/vendor/lite/winlib/SDL2-2.0.10/INSTALL.txt b/vendor/lite/winlib/SDL2-2.0.10/INSTALL.txt new file mode 100644 index 0000000..607dafd --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/INSTALL.txt @@ -0,0 +1,18 @@ + +The 32-bit files are in i686-w64-mingw32 +The 64-bit files are in x86_64-w64-mingw32 + +To install SDL for native development: + make native + +To install SDL for cross-compiling development: + make cross + +Look at the example programs in ./test, and check out online documentation: + http://wiki.libsdl.org/ + +Join the SDL developer mailing list if you want to join the community: + http://www.libsdl.org/mailing-list.php + +That's it! +Sam Lantinga diff --git a/vendor/lite/winlib/SDL2-2.0.10/Makefile b/vendor/lite/winlib/SDL2-2.0.10/Makefile new file mode 100644 index 0000000..9edfd00 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/Makefile @@ -0,0 +1,30 @@ +# +# Makefile for installing the mingw32 version of the SDL library + +CROSS_PATH := /usr/local +ARCHITECTURES := i686-w64-mingw32 x86_64-w64-mingw32 + +all install: + @echo "Type \"make native\" to install 32-bit to /usr" + @echo "Type \"make cross\" to install 32-bit and 64-bit to $(CROSS_PATH)" + +native: + make install-package arch=i686-w64-mingw32 prefix=/usr + +cross: + for arch in $(ARCHITECTURES); do \ + make install-package arch=$$arch prefix=$(CROSS_PATH)/$$arch; \ + done + +install-package: + @if test -d $(arch) && test -d $(prefix); then \ + (cd $(arch) && cp -rv bin include lib share $(prefix)/); \ + sed "s|^prefix=.*|prefix=$(prefix)|" <$(arch)/bin/sdl2-config >$(prefix)/bin/sdl2-config; \ + chmod 755 $(prefix)/bin/sdl2-config; \ + sed "s|^libdir=.*|libdir=\'$(prefix)/lib\'|" <$(arch)/lib/libSDL2.la >$(prefix)/lib/libSDL2.la; \ + sed "s|^libdir=.*|libdir=\'$(prefix)/lib\'|" <$(arch)/lib/libSDL2main.la >$(prefix)/lib/libSDL2main.la; \ + sed "s|^prefix=.*|prefix=$(prefix)|" <$(arch)/lib/pkgconfig/sdl2.pc >$(prefix)/lib/pkgconfig/sdl2.pc; \ + else \ + echo "*** ERROR: $(arch) or $(prefix) does not exist!"; \ + exit 1; \ + fi diff --git a/vendor/lite/winlib/SDL2-2.0.10/README-SDL.txt b/vendor/lite/winlib/SDL2-2.0.10/README-SDL.txt new file mode 100644 index 0000000..2984b14 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/README-SDL.txt @@ -0,0 +1,13 @@ + +Please distribute this file with the SDL runtime environment: + +The Simple DirectMedia Layer (SDL for short) is a cross-platform library +designed to make it easy to write multi-media software, such as games +and emulators. + +The Simple DirectMedia Layer library source code is available from: +https://www.libsdl.org/ + +This library is distributed under the terms of the zlib license: +http://www.zlib.net/zlib_license.html + diff --git a/vendor/lite/winlib/SDL2-2.0.10/README.txt b/vendor/lite/winlib/SDL2-2.0.10/README.txt new file mode 100644 index 0000000..e8630c7 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/README.txt @@ -0,0 +1,21 @@ + + Simple DirectMedia Layer + + (SDL) + + Version 2.0 + +--- +https://www.libsdl.org/ + +Simple DirectMedia Layer is a cross-platform development library designed +to provide low level access to audio, keyboard, mouse, joystick, and graphics +hardware via OpenGL and Direct3D. It is used by video playback software, +emulators, and popular games including Valve's award winning catalog +and many Humble Bundle games. + +More extensive documentation is available in the docs directory, starting +with README.md + +Enjoy! + Sam Lantinga (slouken@libsdl.org) diff --git a/vendor/lite/winlib/SDL2-2.0.10/WhatsNew.txt b/vendor/lite/winlib/SDL2-2.0.10/WhatsNew.txt new file mode 100644 index 0000000..faecf1d --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/WhatsNew.txt @@ -0,0 +1,466 @@ + +This is a list of major changes in SDL's version history. + +--------------------------------------------------------------------------- +2.0.10: +--------------------------------------------------------------------------- + +General: +* The SDL_RW* macros have been turned into functions that are available only in 2.0.10 and onward +* Added SDL_SIMDGetAlignment(), SDL_SIMDAlloc(), and SDL_SIMDFree(), to allocate memory aligned for SIMD operations for the current CPU +* Added SDL_RenderDrawPointF(), SDL_RenderDrawPointsF(), SDL_RenderDrawLineF(), SDL_RenderDrawLinesF(), SDL_RenderDrawRectF(), SDL_RenderDrawRectsF(), SDL_RenderFillRectF(), SDL_RenderFillRectsF(), SDL_RenderCopyF(), SDL_RenderCopyExF(), to allow floating point precision in the SDL rendering API. +* Added SDL_GetTouchDeviceType() to get the type of a touch device, which can be a touch screen or a trackpad in relative or absolute coordinate mode. +* The SDL rendering API now uses batched rendering by default, for improved performance +* Added SDL_RenderFlush() to force batched render commands to execute, if you're going to mix SDL rendering with native rendering +* Added the hint SDL_HINT_RENDER_BATCHING to control whether batching should be used for the rendering API. This defaults to "1" if you don't specify what rendering driver to use when creating the renderer. +* Added the hint SDL_HINT_EVENT_LOGGING to enable logging of SDL events for debugging purposes +* Added the hint SDL_HINT_GAMECONTROLLERCONFIG_FILE to specify a file that will be loaded at joystick initialization with game controller bindings +* Added the hint SDL_HINT_MOUSE_TOUCH_EVENTS to control whether SDL will synthesize touch events from mouse events +* Improved handling of malformed WAVE and BMP files, fixing potential security exploits + +Linux: +* Removed the Mir video driver in favor of Wayland + +iOS / tvOS: +* Added support for Xbox and PS4 wireless controllers in iOS 13 and tvOS 13 +* Added support for text input using Bluetooth keyboards + +Android: +* Added low latency audio using OpenSL ES +* Removed SDL_HINT_ANDROID_SEPARATE_MOUSE_AND_TOUCH (replaced by SDL_HINT_MOUSE_TOUCH_EVENTS and SDL_HINT_TOUCH_MOUSE_EVENTS) + SDL_HINT_ANDROID_SEPARATE_MOUSE_AND_TOUCH=1, should be replaced by setting both previous hints to 0. + SDL_HINT_ANDROID_SEPARATE_MOUSE_AND_TOUCH=0, should be replaced by setting both previous hints to 1. +* Added the hint SDL_HINT_ANDROID_BLOCK_ON_PAUSE to set whether the event loop will block itself when the app is paused. + + +--------------------------------------------------------------------------- +2.0.9: +--------------------------------------------------------------------------- + +General: +* Added a new sensor API, initialized by passing SDL_INIT_SENSOR to SDL_Init(), and defined in SDL_sensor.h +* Added an event SDL_SENSORUPDATE which is sent when a sensor is updated +* Added SDL_GetDisplayOrientation() to return the current display orientation +* Added an event SDL_DISPLAYEVENT which is sent when the display orientation changes +* Added HIDAPI joystick drivers for more consistent support for Xbox, PS4 and Nintendo Switch Pro controller support across platforms. (Thanks to Valve for contributing the PS4 and Nintendo Switch Pro controller support) +* Added support for many other popular game controllers +* Added SDL_JoystickGetDevicePlayerIndex(), SDL_JoystickGetPlayerIndex(), and SDL_GameControllerGetPlayerIndex() to get the player index for a controller. For XInput controllers this returns the XInput index for the controller. +* Added SDL_GameControllerRumble() and SDL_JoystickRumble() which allow simple rumble without using the haptics API +* Added SDL_GameControllerMappingForDeviceIndex() to get the mapping for a controller before it's opened +* Added the hint SDL_HINT_MOUSE_DOUBLE_CLICK_TIME to control the mouse double-click time +* Added the hint SDL_HINT_MOUSE_DOUBLE_CLICK_RADIUS to control the mouse double-click radius, in pixels +* Added SDL_HasColorKey() to return whether a surface has a colorkey active +* Added SDL_HasAVX512F() to return whether the CPU has AVX-512F features +* Added SDL_IsTablet() to return whether the application is running on a tablet +* Added SDL_THREAD_PRIORITY_TIME_CRITICAL for threads that must run at the highest priority + +Mac OS X: +* Fixed black screen at start on Mac OS X Mojave + +Linux: +* Added SDL_LinuxSetThreadPriority() to allow adjusting the thread priority of native threads using RealtimeKit if available. + +iOS: +* Fixed Asian IME input + +Android: +* Updated required Android SDK to API 26, to match Google's new App Store requirements +* Added support for wired USB Xbox, PS4, and Nintendo Switch Pro controllers +* Added support for relative mouse mode on Android 7.0 and newer (except where it's broken, on Chromebooks and when in DeX mode with Samsung Experience 9.0) +* Added support for custom mouse cursors on Android 7.0 and newer +* Added the hint SDL_HINT_ANDROID_TRAP_BACK_BUTTON to control whether the back button will back out of the app (the default) or be passed to the application as SDL_SCANCODE_AC_BACK +* Added SDL_AndroidBackButton() to trigger the Android system back button behavior when handling the back button in the application +* Added SDL_IsChromebook() to return whether the app is running in the Chromebook Android runtime +* Added SDL_IsDeXMode() to return whether the app is running while docked in the Samsung DeX + + +--------------------------------------------------------------------------- +2.0.8: +--------------------------------------------------------------------------- + +General: +* Added SDL_fmod() and SDL_log10() +* Each of the SDL math functions now has the corresponding float version +* Added SDL_SetYUVConversionMode() and SDL_GetYUVConversionMode() to control the formula used when converting to and from YUV colorspace. The options are JPEG, BT.601, and BT.709 + +Windows: +* Implemented WASAPI support on Windows UWP and removed the deprecated XAudio2 implementation +* Added resampling support on WASAPI on Windows 7 and above + +Windows UWP: +* Added SDL_WinRTGetDeviceFamily() to find out what type of device your application is running on + +Mac OS X: +* Added support for the Vulkan SDK for Mac: + https://www.lunarg.com/lunarg-releases-vulkan-sdk-1-0-69-0-for-mac/ +* Added support for OpenGL ES using ANGLE when it's available + +Mac OS X / iOS / tvOS: +* Added a Metal 2D render implementation +* Added SDL_RenderGetMetalLayer() and SDL_RenderGetMetalCommandEncoder() to insert your own drawing into SDL rendering when using the Metal implementation + +iOS: +* Added the hint SDL_HINT_IOS_HIDE_HOME_INDICATOR to control whether the home indicator bar on iPhone X should be hidden. This defaults to dimming the indicator for fullscreen applications and showing the indicator for windowed applications. + +iOS / Android: +* Added the hint SDL_HINT_RETURN_KEY_HIDES_IME to control whether the return key on the software keyboard should hide the keyboard or send a key event (the default) + +Android: +* SDL now supports building with Android Studio and Gradle by default, and the old Ant project is available in android-project-ant +* SDL now requires the API 19 SDK to build, but can still target devices down to API 14 (Android 4.0.1) +* Added SDL_IsAndroidTV() to tell whether the application is running on Android TV + +Android / tvOS: +* Added the hint SDL_HINT_TV_REMOTE_AS_JOYSTICK to control whether TV remotes should be listed as joystick devices (the default) or send keyboard events. + +Linux: +* Added the hint SDL_HINT_VIDEO_X11_NET_WM_BYPASS_COMPOSITOR to control whether the X server should skip the compositor for the SDL application. This defaults to "1" +* Added the hint SDL_HINT_VIDEO_DOUBLE_BUFFER to control whether the Raspberry Pi and KMSDRM video drivers should use double or triple buffering (the default) + + +--------------------------------------------------------------------------- +2.0.7: +--------------------------------------------------------------------------- + +General: +* Added audio stream conversion functions: + SDL_NewAudioStream + SDL_AudioStreamPut + SDL_AudioStreamGet + SDL_AudioStreamAvailable + SDL_AudioStreamFlush + SDL_AudioStreamClear + SDL_FreeAudioStream +* Added functions to query and set the SDL memory allocation functions: + SDL_GetMemoryFunctions() + SDL_SetMemoryFunctions() + SDL_GetNumAllocations() +* Added locking functions for multi-threaded access to the joystick and game controller APIs: + SDL_LockJoysticks() + SDL_UnlockJoysticks() +* The following functions are now thread-safe: + SDL_SetEventFilter() + SDL_GetEventFilter() + SDL_AddEventWatch() + SDL_DelEventWatch() + + +General: +--------------------------------------------------------------------------- +2.0.6: +--------------------------------------------------------------------------- + +General: +* Added cross-platform Vulkan graphics support in SDL_vulkan.h + SDL_Vulkan_LoadLibrary() + SDL_Vulkan_GetVkGetInstanceProcAddr() + SDL_Vulkan_GetInstanceExtensions() + SDL_Vulkan_CreateSurface() + SDL_Vulkan_GetDrawableSize() + SDL_Vulkan_UnloadLibrary() + This is all the platform-specific code you need to bring up Vulkan on all SDL platforms. You can look at an example in test/testvulkan.c +* Added SDL_ComposeCustomBlendMode() to create custom blend modes for 2D rendering +* Added SDL_HasNEON() which returns whether the CPU has NEON instruction support +* Added support for many game controllers, including the Nintendo Switch Pro Controller +* Added support for inverted axes and separate axis directions in game controller mappings +* Added functions to return information about a joystick before it's opened: + SDL_JoystickGetDeviceVendor() + SDL_JoystickGetDeviceProduct() + SDL_JoystickGetDeviceProductVersion() + SDL_JoystickGetDeviceType() + SDL_JoystickGetDeviceInstanceID() +* Added functions to return information about an open joystick: + SDL_JoystickGetVendor() + SDL_JoystickGetProduct() + SDL_JoystickGetProductVersion() + SDL_JoystickGetType() + SDL_JoystickGetAxisInitialState() +* Added functions to return information about an open game controller: + SDL_GameControllerGetVendor() + SDL_GameControllerGetProduct() + SDL_GameControllerGetProductVersion() +* Added SDL_GameControllerNumMappings() and SDL_GameControllerMappingForIndex() to be able to enumerate the built-in game controller mappings +* Added SDL_LoadFile() and SDL_LoadFile_RW() to load a file into memory +* Added SDL_DuplicateSurface() to make a copy of a surface +* Added an experimental JACK audio driver +* Implemented non-power-of-two audio resampling, optionally using libsamplerate to perform the resampling +* Added the hint SDL_HINT_AUDIO_RESAMPLING_MODE to control the quality of resampling +* Added the hint SDL_HINT_RENDER_LOGICAL_SIZE_MODE to control the scaling policy for SDL_RenderSetLogicalSize(): + "0" or "letterbox" - Uses letterbox/sidebars to fit the entire rendering on screen (the default) + "1" or "overscan" - Will zoom the rendering so it fills the entire screen, allowing edges to be drawn offscreen +* Added the hints SDL_HINT_MOUSE_NORMAL_SPEED_SCALE and SDL_HINT_MOUSE_RELATIVE_SPEED_SCALE to scale the mouse speed when being read from raw mouse input +* Added the hint SDL_HINT_TOUCH_MOUSE_EVENTS to control whether SDL will synthesize mouse events from touch events + +Windows: +* The new default audio driver on Windows is WASAPI and supports hot-plugging devices and changing the default audio device +* The old XAudio2 audio driver is deprecated and will be removed in the next release +* Added hints SDL_HINT_WINDOWS_INTRESOURCE_ICON and SDL_HINT_WINDOWS_INTRESOURCE_ICON_SMALL to specify a custom icon resource ID for SDL windows +* The hint SDL_HINT_WINDOWS_DISABLE_THREAD_NAMING is now on by default for compatibility with .NET languages and various Windows debuggers +* Updated the GUID format for game controller mappings, older mappings will be automatically converted on load +* Implemented the SDL_WINDOW_ALWAYS_ON_TOP flag on Windows + +Linux: +* Added an experimental KMS/DRM video driver for embedded development + +iOS: +* Added a hint SDL_HINT_AUDIO_CATEGORY to control the audio category, determining whether the phone mute switch affects the audio + +--------------------------------------------------------------------------- +2.0.5: +--------------------------------------------------------------------------- + +General: +* Implemented audio capture support for some platforms +* Added SDL_DequeueAudio() to retrieve audio when buffer queuing is turned on for audio capture +* Added events for dragging and dropping text +* Added events for dragging and dropping multiple items +* By default the click raising a window will not be delivered to the SDL application. You can set the hint SDL_HINT_MOUSE_FOCUS_CLICKTHROUGH to "1" to allow that click through to the window. +* Saving a surface with an alpha channel as a BMP will use a newer BMP format that supports alpha information. You can set the hint SDL_HINT_BMP_SAVE_LEGACY_FORMAT to "1" to use the old format. +* Added SDL_GetHintBoolean() to get the boolean value of a hint +* Added SDL_RenderSetIntegerScale() to set whether to smoothly scale or use integral multiples of the viewport size when scaling the rendering output +* Added SDL_CreateRGBSurfaceWithFormat() and SDL_CreateRGBSurfaceWithFormatFrom() to create an SDL surface with a specific pixel format +* Added SDL_GetDisplayUsableBounds() which returns the area usable for windows. For example, on Mac OS X, this subtracts the area occupied by the menu bar and dock. +* Added SDL_GetWindowBordersSize() which returns the size of the window's borders around the client area +* Added a window event SDL_WINDOWEVENT_HIT_TEST when a window had a hit test that wasn't SDL_HITTEST_NORMAL (e.g. in the title bar or window frame) +* Added SDL_SetWindowResizable() to change whether a window is resizable +* Added SDL_SetWindowOpacity() and SDL_GetWindowOpacity() to affect the window transparency +* Added SDL_SetWindowModalFor() to set a window as modal for another window +* Added support for AUDIO_U16LSB and AUDIO_U16MSB to SDL_MixAudioFormat() +* Fixed flipped images when reading back from target textures when using the OpenGL renderer +* Fixed texture color modulation with SDL_BLENDMODE_NONE when using the OpenGL renderer +* Fixed bug where the alpha value of colorkeys was ignored when blitting in some cases + +Windows: +* Added a hint SDL_HINT_WINDOWS_DISABLE_THREAD_NAMING to prevent SDL from raising a debugger exception to name threads. This exception can cause problems with .NET applications when running under a debugger. +* The hint SDL_HINT_THREAD_STACK_SIZE is now supported on Windows +* Fixed XBox controller triggers automatically being pulled at startup +* The first icon from the executable is used as the default window icon at runtime +* Fixed SDL log messages being printed twice if SDL was built with C library support +* Reset dead keys when the SDL window loses focus, so dead keys pressed in SDL applications don't affect text input into other applications. + +Mac OS X: +* Fixed selecting the dummy video driver +* The caps lock key now generates a pressed event when pressed and a released event when released, instead of a press/release event pair when pressed. +* Fixed mouse wheel events on Mac OS X 10.12 +* The audio driver has been updated to use AVFoundation for better compatibility with newer versions of Mac OS X + +Linux: +* Added support for the Fcitx IME +* Added a window event SDL_WINDOWEVENT_TAKE_FOCUS when a window manager asks the SDL window whether it wants to take focus. +* Refresh rates are now rounded instead of truncated, e.g. 59.94 Hz is rounded up to 60 Hz instead of 59. +* Added initial support for touchscreens on Raspberry Pi + +OpenBSD: +* SDL_GetBasePath() is now implemented on OpenBSD + +iOS: +* Added support for dynamically loaded objects on iOS 8 and newer + +tvOS: +* Added support for Apple TV +* Added a hint SDL_HINT_APPLE_TV_REMOTE_ALLOW_ROTATION to control whether he Apple TV remote's joystick axes will automatically match the rotation of the remote. + +Android: +* Fixed SDL not resizing window when Android screen resolution changes +* Corrected the joystick Z axis reporting for the accelerometer + +Emscripten (running in a web browser): +* Many bug fixes and improvements + + +--------------------------------------------------------------------------- +2.0.4: +--------------------------------------------------------------------------- + +General: +* Added support for web applications using Emscripten, see docs/README-emscripten.md for more information +* Added support for web applications using Native Client (NaCl), see docs/README-nacl.md for more information +* Added an API to queue audio instead of using the audio callback: + SDL_QueueAudio(), SDL_GetQueuedAudioSize(), SDL_ClearQueuedAudio() +* Added events for audio device hot plug support: + SDL_AUDIODEVICEADDED, SDL_AUDIODEVICEREMOVED +* Added SDL_PointInRect() +* Added SDL_HasAVX2() to detect CPUs with AVX2 support +* Added SDL_SetWindowHitTest() to let apps treat parts of their SDL window like traditional window decorations (drag areas, resize areas) +* Added SDL_GetGrabbedWindow() to get the window that currently has input grab, if any +* Added SDL_RenderIsClipEnabled() to tell whether clipping is currently enabled in a renderer +* Added SDL_CaptureMouse() to capture the mouse to get events while the mouse is not in your window +* Added SDL_WarpMouseGlobal() to warp the mouse cursor in global screen space +* Added SDL_GetGlobalMouseState() to get the current mouse state outside of an SDL window +* Added a direction field to mouse wheel events to tell whether they are flipped (natural) or not +* Added GL_CONTEXT_RELEASE_BEHAVIOR GL attribute (maps to [WGL|GLX]_ARB_context_flush_control extension) +* Added EGL_KHR_create_context support to allow OpenGL ES version selection on some platforms +* Added NV12 and NV21 YUV texture support for OpenGL and OpenGL ES 2.0 renderers +* Added a Vivante video driver that is used on various SoC platforms +* Added an event SDL_RENDER_DEVICE_RESET that is sent from the D3D renderers when the D3D device is lost, and from Android's event loop when the GLES context had to be recreated +* Added a hint SDL_HINT_NO_SIGNAL_HANDLERS to disable SDL's built in signal handling +* Added a hint SDL_HINT_THREAD_STACK_SIZE to set the stack size of SDL's threads +* Added SDL_sqrtf(), SDL_tan(), and SDL_tanf() to the stdlib routines +* Improved support for WAV and BMP files with unusual chunks in them +* Renamed SDL_assert_data to SDL_AssertData and SDL_assert_state to SDL_AssertState +* Added a hint SDL_HINT_WINDOW_FRAME_USABLE_WHILE_CURSOR_HIDDEN to prevent window interaction while cursor is hidden +* Added SDL_GetDisplayDPI() to get the DPI information for a display +* Added SDL_JoystickCurrentPowerLevel() to get the battery level of a joystick +* Added SDL_JoystickFromInstanceID(), as a helper function, to get the SDL_Joystick* that an event is referring to. +* Added SDL_GameControllerFromInstanceID(), as a helper function, to get the SDL_GameController* that an event is referring to. + +Windows: +* Added support for Windows Phone 8.1 and Windows 10/UWP (Universal Windows Platform) +* Timer resolution is now 1 ms by default, adjustable with the SDL_HINT_TIMER_RESOLUTION hint +* SDLmain no longer depends on the C runtime, so you can use the same .lib in both Debug and Release builds +* Added SDL_SetWindowsMessageHook() to set a function to be called for every windows message before TranslateMessage() +* Added a hint SDL_HINT_WINDOWS_ENABLE_MESSAGELOOP to control whether SDL_PumpEvents() processes the Windows message loop +* You can distinguish between real mouse and touch events by looking for SDL_TOUCH_MOUSEID in the mouse event "which" field +* SDL_SysWMinfo now contains the window HDC +* Added support for Unicode command line options +* Prevent beeping when Alt-key combos are pressed +* SDL_SetTextInputRect() re-positions the OS-rendered IME +* Added a hint SDL_HINT_WINDOWS_NO_CLOSE_ON_ALT_F4 to prevent generating SDL_WINDOWEVENT_CLOSE events when Alt-F4 is pressed +* Added a hint SDL_HINT_XINPUT_USE_OLD_JOYSTICK_MAPPING to use the old axis and button mapping for XInput devices (deprecated) + +Mac OS X: +* Implemented drag-and-drop support +* Improved joystick hot-plug detection +* The SDL_WINDOWEVENT_EXPOSED window event is triggered in the appropriate situations +* Fixed relative mouse mode when the application loses/regains focus +* Fixed bugs related to transitioning to and from Spaces-aware fullscreen-desktop mode +* Fixed the refresh rate of display modes +* SDL_SysWMInfo is now ARC-compatible +* Added a hint SDL_HINT_MAC_BACKGROUND_APP to prevent forcing the application to become a foreground process + +Linux: +* Enabled building with Mir and Wayland support by default. +* Added IBus IME support +* Added a hint SDL_HINT_IME_INTERNAL_EDITING to control whether IBus should handle text editing internally instead of sending SDL_TEXTEDITING events +* Added a hint SDL_HINT_VIDEO_X11_NET_WM_PING to allow disabling _NET_WM_PING protocol handling in SDL_CreateWindow() +* Added support for multiple audio devices when using Pulseaudio +* Fixed duplicate mouse events when using relative mouse motion + +iOS: +* Added support for iOS 8 +* The SDL_WINDOW_ALLOW_HIGHDPI window flag now enables high-dpi support, and SDL_GL_GetDrawableSize() or SDL_GetRendererOutputSize() gets the window resolution in pixels +* SDL_GetWindowSize() and display mode sizes are in the "DPI-independent points" / "screen coordinates" coordinate space rather than pixels (matches OS X behavior) +* Added native resolution support for the iPhone 6 Plus +* Added support for MFi game controllers +* Added support for the hint SDL_HINT_ACCELEROMETER_AS_JOYSTICK +* Added sRGB OpenGL ES context support on iOS 7+ +* Added support for SDL_DisableScreenSaver(), SDL_EnableScreenSaver() and the hint SDL_HINT_VIDEO_ALLOW_SCREENSAVER +* SDL_SysWMinfo now contains the OpenGL ES framebuffer and color renderbuffer objects used by the window's active GLES view +* Fixed various rotation and orientation issues +* Fixed memory leaks + +Android: +* Added a hint SDL_HINT_ANDROID_SEPARATE_MOUSE_AND_TOUCH to prevent mouse events from being registered as touch events +* Added hints SDL_HINT_ANDROID_APK_EXPANSION_MAIN_FILE_VERSION and SDL_HINT_ANDROID_APK_EXPANSION_PATCH_FILE_VERSION +* Added support for SDL_DisableScreenSaver(), SDL_EnableScreenSaver() and the hint SDL_HINT_VIDEO_ALLOW_SCREENSAVER +* Added support for SDL_ShowMessageBox() and SDL_ShowSimpleMessageBox() + +Raspberry Pi: +* Added support for the Raspberry Pi 2 + + +--------------------------------------------------------------------------- +2.0.3: +--------------------------------------------------------------------------- + +Mac OS X: +* Fixed creating an OpenGL context by default on Mac OS X 10.6 + + +--------------------------------------------------------------------------- +2.0.2: +--------------------------------------------------------------------------- +General: +* Added SDL_GL_ResetAttributes() to reset OpenGL attributes to default values +* Added an API to load a database of game controller mappings from a file: + SDL_GameControllerAddMappingsFromFile(), SDL_GameControllerAddMappingsFromRW() +* Added game controller mappings for the PS4 and OUYA controllers +* Added SDL_GetDefaultAssertionHandler() and SDL_GetAssertionHandler() +* Added SDL_DetachThread() +* Added SDL_HasAVX() to determine if the CPU has AVX features +* Added SDL_vsscanf(), SDL_acos(), and SDL_asin() to the stdlib routines +* EGL can now create/manage OpenGL and OpenGL ES 1.x/2.x contexts, and share + them using SDL_GL_SHARE_WITH_CURRENT_CONTEXT +* Added a field "clicks" to the mouse button event which records whether the event is a single click, double click, etc. +* The screensaver is now disabled by default, and there is a hint SDL_HINT_VIDEO_ALLOW_SCREENSAVER that can change that behavior. +* Added a hint SDL_HINT_MOUSE_RELATIVE_MODE_WARP to specify whether mouse relative mode should be emulated using mouse warping. +* testgl2 does not need to link with libGL anymore +* Added testgles2 test program to demonstrate working with OpenGL ES 2.0 +* Added controllermap test program to visually map a game controller + +Windows: +* Support for OpenGL ES 2.x contexts using either WGL or EGL (natively via + the driver or emulated through ANGLE) +* Added a hint SDL_HINT_VIDEO_WIN_D3DCOMPILER to specify which D3D shader compiler to use for OpenGL ES 2 support through ANGLE +* Added a hint SDL_HINT_VIDEO_WINDOW_SHARE_PIXEL_FORMAT that is useful when creating multiple windows that should share the same OpenGL context. +* Added an event SDL_RENDER_TARGETS_RESET that is sent when D3D9 render targets are reset after the device has been restored. + +Mac OS X: +* Added a hint SDL_HINT_MAC_CTRL_CLICK_EMULATE_RIGHT_CLICK to control whether Ctrl+click should be treated as a right click on Mac OS X. This is off by default. + +Linux: +* Fixed fullscreen and focused behavior when receiving NotifyGrab events +* Added experimental Wayland and Mir support, disabled by default + +Android: +* Joystick support (minimum SDK version required to build SDL is now 12, + the required runtime version remains at 10, but on such devices joystick + support won't be available). +* Hotplugging support for joysticks +* Added a hint SDL_HINT_ACCELEROMETER_AS_JOYSTICK to control whether the accelerometer should be listed as a 3 axis joystick, which it will by default. + + +--------------------------------------------------------------------------- +2.0.1: +--------------------------------------------------------------------------- + +General: +* Added an API to get common filesystem paths in SDL_filesystem.h: + SDL_GetBasePath(), SDL_GetPrefPath() +* Added an API to do optimized YV12 and IYUV texture updates: + SDL_UpdateYUVTexture() +* Added an API to get the amount of RAM on the system: + SDL_GetSystemRAM() +* Added a macro to perform timestamp comparisons with SDL_GetTicks(): + SDL_TICKS_PASSED() +* Dramatically improved OpenGL ES 2.0 rendering performance +* Added OpenGL attribute SDL_GL_FRAMEBUFFER_SRGB_CAPABLE + +Windows: +* Created a static library configuration for the Visual Studio 2010 project +* Added a hint to create the Direct3D device with support for multi-threading: + SDL_HINT_RENDER_DIRECT3D_THREADSAFE +* Added a function to get the D3D9 adapter index for a display: + SDL_Direct3D9GetAdapterIndex() +* Added a function to get the D3D9 device for a D3D9 renderer: + SDL_RenderGetD3D9Device() +* Fixed building SDL with the mingw32 toolchain (mingw-w64 is preferred) +* Fixed crash when using two XInput controllers at the same time +* Fixed detecting a mixture of XInput and DirectInput controllers +* Fixed clearing a D3D render target larger than the window +* Improved support for format specifiers in SDL_snprintf() + +Mac OS X: +* Added support for retina displays: + Create your window with the SDL_WINDOW_ALLOW_HIGHDPI flag, and then use SDL_GL_GetDrawableSize() to find the actual drawable size. You are responsible for scaling mouse and drawing coordinates appropriately. +* Fixed mouse warping in fullscreen mode +* Right mouse click is emulated by holding the Ctrl key while left clicking + +Linux: +* Fixed float audio support with the PulseAudio driver +* Fixed missing line endpoints in the OpenGL renderer on some drivers +* X11 symbols are no longer defined to avoid collisions when linking statically + +iOS: +* Fixed status bar visibility on iOS 7 +* Flipped the accelerometer Y axis to match expected values + +Android: +IMPORTANT: You MUST get the updated SDLActivity.java to match C code +* Moved EGL initialization to native code +* Fixed the accelerometer axis rotation relative to the device rotation +* Fixed race conditions when handling the EGL context on pause/resume +* Touch devices are available for enumeration immediately after init + +Raspberry Pi: +* Added support for the Raspberry Pi, see README-raspberrypi.txt for details diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-android.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-android.md new file mode 100644 index 0000000..78dcdd4 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-android.md @@ -0,0 +1,435 @@ +Android +================================================================================ + +Matt Styles wrote a tutorial on building SDL for Android with Visual Studio: +http://trederia.blogspot.de/2017/03/building-sdl2-for-android-with-visual.html + +The rest of this README covers the Android gradle style build process. + +If you are using the older ant build process, it is no longer officially +supported, but you can use the "android-project-ant" directory as a template. + + +================================================================================ + Requirements +================================================================================ + +Android SDK (version 26 or later) +https://developer.android.com/sdk/index.html + +Android NDK r15c or later +https://developer.android.com/tools/sdk/ndk/index.html + +Minimum API level supported by SDL: 16 (Android 4.1) + + +================================================================================ + How the port works +================================================================================ + +- Android applications are Java-based, optionally with parts written in C +- As SDL apps are C-based, we use a small Java shim that uses JNI to talk to + the SDL library +- This means that your application C code must be placed inside an Android + Java project, along with some C support code that communicates with Java +- This eventually produces a standard Android .apk package + +The Android Java code implements an "Activity" and can be found in: +android-project/app/src/main/java/org/libsdl/app/SDLActivity.java + +The Java code loads your game code, the SDL shared library, and +dispatches to native functions implemented in the SDL library: +src/core/android/SDL_android.c + + +================================================================================ + Building an app +================================================================================ + +For simple projects you can use the script located at build-scripts/androidbuild.sh + +There's two ways of using it: + + androidbuild.sh com.yourcompany.yourapp < sources.list + androidbuild.sh com.yourcompany.yourapp source1.c source2.c ...sourceN.c + +sources.list should be a text file with a source file name in each line +Filenames should be specified relative to the current directory, for example if +you are in the build-scripts directory and want to create the testgles.c test, you'll +run: + + ./androidbuild.sh org.libsdl.testgles ../test/testgles.c + +One limitation of this script is that all sources provided will be aggregated into +a single directory, thus all your source files should have a unique name. + +Once the project is complete the script will tell you where the debug APK is located. +If you want to create a signed release APK, you can use the project created by this +utility to generate it. + +Finally, a word of caution: re running androidbuild.sh wipes any changes you may have +done in the build directory for the app! + + +For more complex projects, follow these instructions: + +1. Copy the android-project directory wherever you want to keep your projects + and rename it to the name of your project. +2. Move or symlink this SDL directory into the "/app/jni" directory +3. Edit "/app/jni/src/Android.mk" to include your source files + +4a. If you want to use Android Studio, simply open your directory and start building. + +4b. If you want to build manually, run './gradlew installDebug' in the project directory. This compiles the .java, creates an .apk with the native code embedded, and installs it on any connected Android device + +Here's an explanation of the files in the Android project, so you can customize them: + + android-project/app + build.gradle - build info including the application version and SDK + src/main/AndroidManifest.xml - package manifest. Among others, it contains the class name of the main Activity and the package name of the application. + jni/ - directory holding native code + jni/Application.mk - Application JNI settings, including target platform and STL library + jni/Android.mk - Android makefile that can call recursively the Android.mk files in all subdirectories + jni/SDL/ - (symlink to) directory holding the SDL library files + jni/SDL/Android.mk - Android makefile for creating the SDL shared library + jni/src/ - directory holding your C/C++ source + jni/src/Android.mk - Android makefile that you should customize to include your source code and any library references + src/main/assets/ - directory holding asset files for your application + src/main/res/ - directory holding resources for your application + src/main/res/mipmap-* - directories holding icons for different phone hardware + src/main/res/values/strings.xml - strings used in your application, including the application name + src/main/java/org/libsdl/app/SDLActivity.java - the Java class handling the initialization and binding to SDL. Be very careful changing this, as the SDL library relies on this implementation. You should instead subclass this for your application. + + +================================================================================ + Customizing your application name +================================================================================ + +To customize your application name, edit AndroidManifest.xml and replace +"org.libsdl.app" with an identifier for your product package. + +Then create a Java class extending SDLActivity and place it in a directory +under src matching your package, e.g. + + src/com/gamemaker/game/MyGame.java + +Here's an example of a minimal class file: + + --- MyGame.java -------------------------- + package com.gamemaker.game; + + import org.libsdl.app.SDLActivity; + + /** + * A sample wrapper class that just calls SDLActivity + */ + + public class MyGame extends SDLActivity { } + + ------------------------------------------ + +Then replace "SDLActivity" in AndroidManifest.xml with the name of your +class, .e.g. "MyGame" + + +================================================================================ + Customizing your application icon +================================================================================ + +Conceptually changing your icon is just replacing the "ic_launcher.png" files in +the drawable directories under the res directory. There are several directories +for different screen sizes. + + +================================================================================ + Loading assets +================================================================================ + +Any files you put in the "app/src/main/assets" directory of your project +directory will get bundled into the application package and you can load +them using the standard functions in SDL_rwops.h. + +There are also a few Android specific functions that allow you to get other +useful paths for saving and loading data: +* SDL_AndroidGetInternalStoragePath() +* SDL_AndroidGetExternalStorageState() +* SDL_AndroidGetExternalStoragePath() + +See SDL_system.h for more details on these functions. + +The asset packaging system will, by default, compress certain file extensions. +SDL includes two asset file access mechanisms, the preferred one is the so +called "File Descriptor" method, which is faster and doesn't involve the Dalvik +GC, but given this method does not work on compressed assets, there is also the +"Input Stream" method, which is automatically used as a fall back by SDL. You +may want to keep this fact in mind when building your APK, specially when large +files are involved. +For more information on which extensions get compressed by default and how to +disable this behaviour, see for example: + +http://ponystyle.com/blog/2010/03/26/dealing-with-asset-compression-in-android-apps/ + + +================================================================================ + Pause / Resume behaviour +================================================================================ + +If SDL_HINT_ANDROID_BLOCK_ON_PAUSE hint is set (the default), +the event loop will block itself when the app is paused (ie, when the user +returns to the main Android dashboard). Blocking is better in terms of battery +use, and it allows your app to spring back to life instantaneously after resume +(versus polling for a resume message). + +Upon resume, SDL will attempt to restore the GL context automatically. +In modern devices (Android 3.0 and up) this will most likely succeed and your +app can continue to operate as it was. + +However, there's a chance (on older hardware, or on systems under heavy load), +where the GL context can not be restored. In that case you have to listen for +a specific message, (which is not yet implemented!) and restore your textures +manually or quit the app (which is actually the kind of behaviour you'll see +under iOS, if the OS can not restore your GL context it will just kill your app) + + +================================================================================ + Threads and the Java VM +================================================================================ + +For a quick tour on how Linux native threads interoperate with the Java VM, take +a look here: https://developer.android.com/guide/practices/jni.html + +If you want to use threads in your SDL app, it's strongly recommended that you +do so by creating them using SDL functions. This way, the required attach/detach +handling is managed by SDL automagically. If you have threads created by other +means and they make calls to SDL functions, make sure that you call +Android_JNI_SetupThread() before doing anything else otherwise SDL will attach +your thread automatically anyway (when you make an SDL call), but it'll never +detach it. + + +================================================================================ + Using STL +================================================================================ + +You can use STL in your project by creating an Application.mk file in the jni +folder and adding the following line: + + APP_STL := c++_shared + +For more information go here: + https://developer.android.com/ndk/guides/cpp-support + + +================================================================================ + Using the emulator +================================================================================ + +There are some good tips and tricks for getting the most out of the +emulator here: https://developer.android.com/tools/devices/emulator.html + +Especially useful is the info on setting up OpenGL ES 2.0 emulation. + +Notice that this software emulator is incredibly slow and needs a lot of disk space. +Using a real device works better. + + +================================================================================ + Troubleshooting +================================================================================ + +You can see if adb can see any devices with the following command: + + adb devices + +You can see the output of log messages on the default device with: + + adb logcat + +You can push files to the device with: + + adb push local_file remote_path_and_file + +You can push files to the SD Card at /sdcard, for example: + + adb push moose.dat /sdcard/moose.dat + +You can see the files on the SD card with a shell command: + + adb shell ls /sdcard/ + +You can start a command shell on the default device with: + + adb shell + +You can remove the library files of your project (and not the SDL lib files) with: + + ndk-build clean + +You can do a build with the following command: + + ndk-build + +You can see the complete command line that ndk-build is using by passing V=1 on the command line: + + ndk-build V=1 + +If your application crashes in native code, you can use ndk-stack to get a symbolic stack trace: + https://developer.android.com/ndk/guides/ndk-stack + +If you want to go through the process manually, you can use addr2line to convert the +addresses in the stack trace to lines in your code. + +For example, if your crash looks like this: + + I/DEBUG ( 31): signal 11 (SIGSEGV), code 2 (SEGV_ACCERR), fault addr 400085d0 + I/DEBUG ( 31): r0 00000000 r1 00001000 r2 00000003 r3 400085d4 + I/DEBUG ( 31): r4 400085d0 r5 40008000 r6 afd41504 r7 436c6a7c + I/DEBUG ( 31): r8 436c6b30 r9 435c6fb0 10 435c6f9c fp 4168d82c + I/DEBUG ( 31): ip 8346aff0 sp 436c6a60 lr afd1c8ff pc afd1c902 cpsr 60000030 + I/DEBUG ( 31): #00 pc 0001c902 /system/lib/libc.so + I/DEBUG ( 31): #01 pc 0001ccf6 /system/lib/libc.so + I/DEBUG ( 31): #02 pc 000014bc /data/data/org.libsdl.app/lib/libmain.so + I/DEBUG ( 31): #03 pc 00001506 /data/data/org.libsdl.app/lib/libmain.so + +You can see that there's a crash in the C library being called from the main code. +I run addr2line with the debug version of my code: + + arm-eabi-addr2line -C -f -e obj/local/armeabi/libmain.so + +and then paste in the number after "pc" in the call stack, from the line that I care about: +000014bc + +I get output from addr2line showing that it's in the quit function, in testspriteminimal.c, on line 23. + +You can add logging to your code to help show what's happening: + + #include + + __android_log_print(ANDROID_LOG_INFO, "foo", "Something happened! x = %d", x); + +If you need to build without optimization turned on, you can create a file called +"Application.mk" in the jni directory, with the following line in it: + + APP_OPTIM := debug + + +================================================================================ + Memory debugging +================================================================================ + +The best (and slowest) way to debug memory issues on Android is valgrind. +Valgrind has support for Android out of the box, just grab code using: + + svn co svn://svn.valgrind.org/valgrind/trunk valgrind + +... and follow the instructions in the file README.android to build it. + +One thing I needed to do on Mac OS X was change the path to the toolchain, +and add ranlib to the environment variables: +export RANLIB=$NDKROOT/toolchains/arm-linux-androideabi-4.4.3/prebuilt/darwin-x86/bin/arm-linux-androideabi-ranlib + +Once valgrind is built, you can create a wrapper script to launch your +application with it, changing org.libsdl.app to your package identifier: + + --- start_valgrind_app ------------------- + #!/system/bin/sh + export TMPDIR=/data/data/org.libsdl.app + exec /data/local/Inst/bin/valgrind --log-file=/sdcard/valgrind.log --error-limit=no $* + ------------------------------------------ + +Then push it to the device: + + adb push start_valgrind_app /data/local + +and make it executable: + + adb shell chmod 755 /data/local/start_valgrind_app + +and tell Android to use the script to launch your application: + + adb shell setprop wrap.org.libsdl.app "logwrapper /data/local/start_valgrind_app" + +If the setprop command says "could not set property", it's likely that +your package name is too long and you should make it shorter by changing +AndroidManifest.xml and the path to your class file in android-project/src + +You can then launch your application normally and waaaaaaaiiittt for it. +You can monitor the startup process with the logcat command above, and +when it's done (or even while it's running) you can grab the valgrind +output file: + + adb pull /sdcard/valgrind.log + +When you're done instrumenting with valgrind, you can disable the wrapper: + + adb shell setprop wrap.org.libsdl.app "" + + +================================================================================ + Graphics debugging +================================================================================ + +If you are developing on a compatible Tegra-based tablet, NVidia provides +Tegra Graphics Debugger at their website. Because SDL2 dynamically loads EGL +and GLES libraries, you must follow their instructions for installing the +interposer library on a rooted device. The non-rooted instructions are not +compatible with applications that use SDL2 for video. + +The Tegra Graphics Debugger is available from NVidia here: +https://developer.nvidia.com/tegra-graphics-debugger + + +================================================================================ + Why is API level 16 the minimum required? +================================================================================ + +The latest NDK toolchain doesn't support targeting earlier than API level 16. +As of this writing, according to https://developer.android.com/about/dashboards/index.html +about 99% of the Android devices accessing Google Play support API level 16 or +higher (January 2018). + + +================================================================================ + A note regarding the use of the "dirty rectangles" rendering technique +================================================================================ + +If your app uses a variation of the "dirty rectangles" rendering technique, +where you only update a portion of the screen on each frame, you may notice a +variety of visual glitches on Android, that are not present on other platforms. +This is caused by SDL's use of EGL as the support system to handle OpenGL ES/ES2 +contexts, in particular the use of the eglSwapBuffers function. As stated in the +documentation for the function "The contents of ancillary buffers are always +undefined after calling eglSwapBuffers". +Setting the EGL_SWAP_BEHAVIOR attribute of the surface to EGL_BUFFER_PRESERVED +is not possible for SDL as it requires EGL 1.4, available only on the API level +17+, so the only workaround available on this platform is to redraw the entire +screen each frame. + +Reference: http://www.khronos.org/registry/egl/specs/EGLTechNote0001.html + + +================================================================================ + Ending your application +================================================================================ + +Two legitimate ways: + +- return from your main() function. Java side will automatically terminate the +Activity by calling Activity.finish(). + +- Android OS can decide to terminate your application by calling onDestroy() +(see Activity life cycle). Your application will receive a SDL_QUIT event you +can handle to save things and quit. + +Don't call exit() as it stops the activity badly. + +NB: "Back button" can be handled as a SDL_KEYDOWN/UP events, with Keycode +SDLK_AC_BACK, for any purpose. + +================================================================================ + Known issues +================================================================================ + +- The number of buttons reported for each joystick is hardcoded to be 36, which +is the current maximum number of buttons Android can report. + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-cmake.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-cmake.md new file mode 100644 index 0000000..2ce11d7 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-cmake.md @@ -0,0 +1,32 @@ +CMake +================================================================================ +(www.cmake.org) + +SDL's build system was traditionally based on autotools. Over time, this +approach has suffered from several issues across the different supported +platforms. +To solve these problems, a new build system based on CMake is under development. +It works in parallel to the legacy system, so users can experiment with it +without complication. +While still experimental, the build system should be usable on the following +platforms: + +* FreeBSD +* Linux +* VS.NET 2010 +* MinGW and Msys +* OS X with support for XCode + + +================================================================================ +Usage +================================================================================ + +Assuming the source for SDL is located at ~/sdl + + cd ~ + mkdir build + cd build + cmake ../sdl + +This will build the static and dynamic versions of SDL in the ~/build directory. diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-directfb.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-directfb.md new file mode 100644 index 0000000..eeac428 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-directfb.md @@ -0,0 +1,107 @@ +DirectFB +======== + +Supports: + +- Hardware YUV overlays +- OpenGL - software only +- 2D/3D accelerations (depends on directfb driver) +- multiple displays +- windows + +What you need: + +* DirectFB 1.0.1, 1.2.x, 1.3.0 +* Kernel-Framebuffer support: required: vesafb, radeonfb .... +* Mesa 7.0.x - optional for OpenGL + +/etc/directfbrc + +This file should contain the following lines to make +your joystick work and avoid crashes: +------------------------ +disable-module=joystick +disable-module=cle266 +disable-module=cyber5k +no-linux-input-grab +------------------------ + +To disable to use x11 backend when DISPLAY variable is found use + +export SDL_DIRECTFB_X11_CHECK=0 + +To disable the use of linux input devices, i.e. multimice/multikeyboard support, +use + +export SDL_DIRECTFB_LINUX_INPUT=0 + +To use hardware accelerated YUV-overlays for YUV-textures, use: + +export SDL_DIRECTFB_YUV_DIRECT=1 + +This is disabled by default. It will only support one +YUV texture, namely the first. Every other YUV texture will be +rendered in software. + +In addition, you may use (directfb-1.2.x) + +export SDL_DIRECTFB_YUV_UNDERLAY=1 + +to make the YUV texture an underlay. This will make the cursor to +be shown. + +Simple Window Manager +===================== + +The driver has support for a very, very basic window manager you may +want to use when running with "wm=default". Use + +export SDL_DIRECTFB_WM=1 + +to enable basic window borders. In order to have the window title rendered, +you need to have the following font installed: + +/usr/share/fonts/truetype/freefont/FreeSans.ttf + +OpenGL Support +============== + +The following instructions will give you *software* OpenGL. However this +works at least on all directfb supported platforms. + +As of this writing 20100802 you need to pull Mesa from git and do the following: + +------------------------ +git clone git://anongit.freedesktop.org/git/mesa/mesa +cd mesa +git checkout 2c9fdaf7292423c157fc79b5ce43f0f199dd753a +------------------------ + +Edit configs/linux-directfb so that the Directories-section looks like +------------------------ +# Directories +SRC_DIRS = mesa glu +GLU_DIRS = sgi +DRIVER_DIRS = directfb +PROGRAM_DIRS = +------------------------ + +make linux-directfb +make + +echo Installing - please enter sudo pw. + +sudo make install INSTALL_DIR=/usr/local/dfb_GL +cd src/mesa/drivers/directfb +make +sudo make install INSTALL_DIR=/usr/local/dfb_GL +------------------------ + +To run the SDL - testprograms: + +export SDL_VIDEODRIVER=directfb +export LD_LIBRARY_PATH=/usr/local/dfb_GL/lib +export LD_PRELOAD=/usr/local/dfb_GL/libGL.so.7 + +./testgl + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-dynapi.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-dynapi.md new file mode 100644 index 0000000..40b44db --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-dynapi.md @@ -0,0 +1,130 @@ +Dynamic API +================================================================================ +Originally posted by Ryan at: + https://plus.google.com/103391075724026391227/posts/TB8UfnDYu4U + +Background: + +- The Steam Runtime has (at least in theory) a really kick-ass build of SDL2, + but developers are shipping their own SDL2 with individual Steam games. + These games might stop getting updates, but a newer SDL2 might be needed later. + Certainly we'll always be fixing bugs in SDL, even if a new video target isn't + ever needed, and these fixes won't make it to a game shipping its own SDL. +- Even if we replace the SDL2 in those games with a compatible one, that is to + say, edit a developer's Steam depot (yuck!), there are developers that are + statically linking SDL2 that we can't do this for. We can't even force the + dynamic loader to ignore their SDL2 in this case, of course. +- If you don't ship an SDL2 with the game in some form, people that disabled the + Steam Runtime, or just tried to run the game from the command line instead of + Steam might find themselves unable to run the game, due to a missing dependency. +- If you want to ship on non-Steam platforms like GOG or Humble Bundle, or target + generic Linux boxes that may or may not have SDL2 installed, you have to ship + the library or risk a total failure to launch. So now, you might have to have + a non-Steam build plus a Steam build (that is, one with and one without SDL2 + included), which is inconvenient if you could have had one universal build + that works everywhere. +- We like the zlib license, but the biggest complaint from the open source + community about the license change is the static linking. The LGPL forced this + as a legal, not technical issue, but zlib doesn't care. Even those that aren't + concerned about the GNU freedoms found themselves solving the same problems: + swapping in a newer SDL to an older game often times can save the day. + Static linking stops this dead. + +So here's what we did: + +SDL now has, internally, a table of function pointers. So, this is what SDL_Init +now looks like: + + UInt32 SDL_Init(Uint32 flags) + { + return jump_table.SDL_Init(flags); + } + +Except that is all done with a bunch of macro magic so we don't have to maintain +every one of these. + +What is jump_table.SDL_init()? Eventually, that's a function pointer of the real +SDL_Init() that you've been calling all this time. But at startup, it looks more +like this: + + Uint32 SDL_Init_DEFAULT(Uint32 flags) + { + SDL_InitDynamicAPI(); + return jump_table.SDL_Init(flags); + } + +SDL_InitDynamicAPI() fills in jump_table with all the actual SDL function +pointers, which means that this _DEFAULT function never gets called again. +First call to any SDL function sets the whole thing up. + +So you might be asking, what was the value in that? Isn't this what the operating +system's dynamic loader was supposed to do for us? Yes, but now we've got this +level of indirection, we can do things like this: + + export SDL_DYNAMIC_API=/my/actual/libSDL-2.0.so.0 + ./MyGameThatIsStaticallyLinkedToSDL2 + +And now, this game that is statically linked to SDL, can still be overridden +with a newer, or better, SDL. The statically linked one will only be used as +far as calling into the jump table in this case. But in cases where no override +is desired, the statically linked version will provide its own jump table, +and everyone is happy. + +So now: +- Developers can statically link SDL, and users can still replace it. + (We'd still rather you ship a shared library, though!) +- Developers can ship an SDL with their game, Valve can override it for, say, + new features on SteamOS, or distros can override it for their own needs, + but it'll also just work in the default case. +- Developers can ship the same package to everyone (Humble Bundle, GOG, etc), + and it'll do the right thing. +- End users (and Valve) can update a game's SDL in almost any case, + to keep abandoned games running on newer platforms. +- Everyone develops with SDL exactly as they have been doing all along. + Same headers, same ABI. Just get the latest version to enable this magic. + + +A little more about SDL_InitDynamicAPI(): + +Internally, InitAPI does some locking to make sure everything waits until a +single thread initializes everything (although even SDL_CreateThread() goes +through here before spinning a thread, too), and then decides if it should use +an external SDL library. If not, it sets up the jump table using the current +SDL's function pointers (which might be statically linked into a program, or in +a shared library of its own). If so, it loads that library and looks for and +calls a single function: + + SInt32 SDL_DYNAPI_entry(Uint32 version, void *table, Uint32 tablesize); + +That function takes a version number (more on that in a moment), the address of +the jump table, and the size, in bytes, of the table. +Now, we've got policy here: this table's layout never changes; new stuff gets +added to the end. Therefore SDL_DYNAPI_entry() knows that it can provide all +the needed functions if tablesize <= sizeof its own jump table. If tablesize is +bigger (say, SDL 2.0.4 is trying to load SDL 2.0.3), then we know to abort, but +if it's smaller, we know we can provide the entire API that the caller needs. + +The version variable is a failsafe switch. +Right now it's always 1. This number changes when there are major API changes +(so we know if the tablesize might be smaller, or entries in it have changed). +Right now SDL_DYNAPI_entry gives up if the version doesn't match, but it's not +inconceivable to have a small dispatch library that only supplies this one +function and loads different, otherwise-incompatible SDL libraries and has the +right one initialize the jump table based on the version. For something that +must generically catch lots of different versions of SDL over time, like the +Steam Client, this isn't a bad option. + +Finally, I'm sure some people are reading this and thinking, +"I don't want that overhead in my project!" +To which I would point out that the extra function call through the jump table +probably wouldn't even show up in a profile, but lucky you: this can all be +disabled. You can build SDL without this if you absolutely must, but we would +encourage you not to do that. However, on heavily locked down platforms like +iOS, or maybe when debugging, it makes sense to disable it. The way this is +designed in SDL, you just have to change one #define, and the entire system +vaporizes out, and SDL functions exactly like it always did. Most of it is +macro magic, so the system is contained to one C file and a few headers. +However, this is on by default and you have to edit a header file to turn it +off. Our hopes is that if we make it easy to disable, but not too easy, +everyone will ultimately be able to get what they want, but we've gently +nudged everyone towards what we think is the best solution. diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-emscripten.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-emscripten.md new file mode 100644 index 0000000..b535cc6 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-emscripten.md @@ -0,0 +1,35 @@ +Emscripten +================================================================================ + +Build: + + $ mkdir build + $ cd build + $ emconfigure ../configure --host=asmjs-unknown-emscripten --disable-assembly --disable-threads --disable-cpuinfo CFLAGS="-O2" + $ emmake make + +Or with cmake: + + $ mkdir build + $ cd build + $ emcmake cmake .. + $ emmake make + +To build one of the tests: + + $ cd test/ + $ emcc -O2 --js-opts 0 -g4 testdraw2.c -I../include ../build/.libs/libSDL2.a ../build/libSDL2_test.a -o a.html + +Uses GLES2 renderer or software + +Some other SDL2 libraries can be easily built (assuming SDL2 is installed somewhere): + +SDL_mixer (http://www.libsdl.org/projects/SDL_mixer/): + + $ EMCONFIGURE_JS=1 emconfigure ../configure + build as usual... + +SDL_gfx (http://cms.ferzkopp.net/index.php/software/13-sdl-gfx): + + $ EMCONFIGURE_JS=1 emconfigure ../configure --disable-mmx + build as usual... diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-gesture.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-gesture.md new file mode 100644 index 0000000..7e9f95b --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-gesture.md @@ -0,0 +1,71 @@ +Dollar Gestures +=========================================================================== +SDL provides an implementation of the $1 gesture recognition system. This allows for recording, saving, loading, and performing single stroke gestures. + +Gestures can be performed with any number of fingers (the centroid of the fingers must follow the path of the gesture), but the number of fingers must be constant (a finger cannot go down in the middle of a gesture). The path of a gesture is considered the path from the time when the final finger went down, to the first time any finger comes up. + +Dollar gestures are assigned an Id based on a hash function. This is guaranteed to remain constant for a given gesture. There is a (small) chance that two different gestures will be assigned the same ID. In this case, simply re-recording one of the gestures should result in a different ID. + +Recording: +---------- +To begin recording on a touch device call: +SDL_RecordGesture(SDL_TouchID touchId), where touchId is the id of the touch device you wish to record on, or -1 to record on all connected devices. + +Recording terminates as soon as a finger comes up. Recording is acknowledged by an SDL_DOLLARRECORD event. +A SDL_DOLLARRECORD event is a dgesture with the following fields: + +* event.dgesture.touchId - the Id of the touch used to record the gesture. +* event.dgesture.gestureId - the unique id of the recorded gesture. + + +Performing: +----------- +As long as there is a dollar gesture assigned to a touch, every finger-up event will also cause an SDL_DOLLARGESTURE event with the following fields: + +* event.dgesture.touchId - the Id of the touch which performed the gesture. +* event.dgesture.gestureId - the unique id of the closest gesture to the performed stroke. +* event.dgesture.error - the difference between the gesture template and the actual performed gesture. Lower error is a better match. +* event.dgesture.numFingers - the number of fingers used to draw the stroke. + +Most programs will want to define an appropriate error threshold and check to be sure that the error of a gesture is not abnormally high (an indicator that no gesture was performed). + + + +Saving: +------- +To save a template, call SDL_SaveDollarTemplate(gestureId, dst) where gestureId is the id of the gesture you want to save, and dst is an SDL_RWops pointer to the file where the gesture will be stored. + +To save all currently loaded templates, call SDL_SaveAllDollarTemplates(dst) where dst is an SDL_RWops pointer to the file where the gesture will be stored. + +Both functions return the number of gestures successfully saved. + + +Loading: +-------- +To load templates from a file, call SDL_LoadDollarTemplates(touchId,src) where touchId is the id of the touch to load to (or -1 to load to all touch devices), and src is an SDL_RWops pointer to a gesture save file. + +SDL_LoadDollarTemplates returns the number of templates successfully loaded. + + + +=========================================================================== +Multi Gestures +=========================================================================== +SDL provides simple support for pinch/rotate/swipe gestures. +Every time a finger is moved an SDL_MULTIGESTURE event is sent with the following fields: + +* event.mgesture.touchId - the Id of the touch on which the gesture was performed. +* event.mgesture.x - the normalized x coordinate of the gesture. (0..1) +* event.mgesture.y - the normalized y coordinate of the gesture. (0..1) +* event.mgesture.dTheta - the amount that the fingers rotated during this motion. +* event.mgesture.dDist - the amount that the fingers pinched during this motion. +* event.mgesture.numFingers - the number of fingers used in the gesture. + + +=========================================================================== +Notes +=========================================================================== +For a complete example see test/testgesture.c + +Please direct questions/comments to: + jim.tla+sdl_touch@gmail.com diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-hg.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-hg.md new file mode 100644 index 0000000..5f3d259 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-hg.md @@ -0,0 +1,22 @@ +Mercurial +========= + +The latest development version of SDL is available via Mercurial. +Mercurial allows you to get up-to-the-minute fixes and enhancements; +as a developer works on a source tree, you can use "hg" to mirror that +source tree instead of waiting for an official release. Please look +at the Mercurial website ( https://www.mercurial-scm.org/ ) for more +information on using hg, where you can also download software for +Mac OS X, Windows, and Unix systems. + + hg clone http://hg.libsdl.org/SDL + +If you are building SDL via configure, you will need to run autogen.sh +before running configure. + +There is a web interface to the subversion repository at: + http://hg.libsdl.org/SDL/ + +There is an RSS feed available at that URL, for those that want to +track commits in real time. + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-ios.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-ios.md new file mode 100644 index 0000000..bf34fe4 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-ios.md @@ -0,0 +1,284 @@ +iOS +====== + +============================================================================== +Building the Simple DirectMedia Layer for iOS 5.1+ +============================================================================== + +Requirements: Mac OS X 10.8 or later and the iOS 7+ SDK. + +Instructions: + +1. Open SDL.xcodeproj (located in Xcode-iOS/SDL) in Xcode. +2. Select your desired target, and hit build. + +There are three build targets: +- libSDL.a: + Build SDL as a statically linked library +- testsdl: + Build a test program (there are known test failures which are fine) +- Template: + Package a project template together with the SDL for iPhone static libraries and copies of the SDL headers. The template includes proper references to the SDL library and headers, skeleton code for a basic SDL program, and placeholder graphics for the application icon and startup screen. + + +============================================================================== +Build SDL for iOS from the command line +============================================================================== + +1. cd (PATH WHERE THE SDL CODE IS)/build-scripts +2. ./iosbuild.sh + +If everything goes fine, you should see a build/ios directory, inside there's +two directories "lib" and "include". +"include" contains a copy of the SDL headers that you'll need for your project, +make sure to configure XCode to look for headers there. +"lib" contains find two files, libSDL2.a and libSDL2main.a, you have to add both +to your XCode project. These libraries contain three architectures in them, +armv6 for legacy devices, armv7, and i386 (for the simulator). +By default, iosbuild.sh will autodetect the SDK version you have installed using +xcodebuild -showsdks, and build for iOS >= 3.0, you can override this behaviour +by setting the MIN_OS_VERSION variable, ie: + +MIN_OS_VERSION=4.2 ./iosbuild.sh + +============================================================================== +Using the Simple DirectMedia Layer for iOS +============================================================================== + +FIXME: This needs to be updated for the latest methods + +Here is the easiest method: +1. Build the SDL library (libSDL2.a) and the iPhone SDL Application template. +2. Install the iPhone SDL Application template by copying it to one of Xcode's template directories. I recommend creating a directory called "SDL" in "/Developer/Platforms/iOS.platform/Developer/Library/Xcode/Project Templates/" and placing it there. +3. Start a new project using the template. The project should be immediately ready for use with SDL. + +Here is a more manual method: +1. Create a new iOS view based application. +2. Build the SDL static library (libSDL2.a) for iOS and include them in your project. Xcode will ignore the library that is not currently of the correct architecture, hence your app will work both on iOS and in the iOS Simulator. +3. Include the SDL header files in your project. +4. Remove the ApplicationDelegate.h and ApplicationDelegate.m files -- SDL for iOS provides its own UIApplicationDelegate. Remove MainWindow.xib -- SDL for iOS produces its user interface programmatically. +5. Delete the contents of main.m and program your app as a regular SDL program instead. You may replace main.m with your own main.c, but you must tell Xcode not to use the project prefix file, as it includes Objective-C code. + +============================================================================== +Notes -- Retina / High-DPI and window sizes +============================================================================== + +Window and display mode sizes in SDL are in "screen coordinates" (or "points", +in Apple's terminology) rather than in pixels. On iOS this means that a window +created on an iPhone 6 will have a size in screen coordinates of 375 x 667, +rather than a size in pixels of 750 x 1334. All iOS apps are expected to +size their content based on screen coordinates / points rather than pixels, +as this allows different iOS devices to have different pixel densities +(Retina versus non-Retina screens, etc.) without apps caring too much. + +By default SDL will not use the full pixel density of the screen on +Retina/high-dpi capable devices. Use the SDL_WINDOW_ALLOW_HIGHDPI flag when +creating your window to enable high-dpi support. + +When high-dpi support is enabled, SDL_GetWindowSize() and display mode sizes +will still be in "screen coordinates" rather than pixels, but the window will +have a much greater pixel density when the device supports it, and the +SDL_GL_GetDrawableSize() or SDL_GetRendererOutputSize() functions (depending on +whether raw OpenGL or the SDL_Render API is used) can be queried to determine +the size in pixels of the drawable screen framebuffer. + +Some OpenGL ES functions such as glViewport expect sizes in pixels rather than +sizes in screen coordinates. When doing 2D rendering with OpenGL ES, an +orthographic projection matrix using the size in screen coordinates +(SDL_GetWindowSize()) can be used in order to display content at the same scale +no matter whether a Retina device is used or not. + +============================================================================== +Notes -- Application events +============================================================================== + +On iOS the application goes through a fixed life cycle and you will get +notifications of state changes via application events. When these events +are delivered you must handle them in an event callback because the OS may +not give you any processing time after the events are delivered. + +e.g. + + int HandleAppEvents(void *userdata, SDL_Event *event) + { + switch (event->type) + { + case SDL_APP_TERMINATING: + /* Terminate the app. + Shut everything down before returning from this function. + */ + return 0; + case SDL_APP_LOWMEMORY: + /* You will get this when your app is paused and iOS wants more memory. + Release as much memory as possible. + */ + return 0; + case SDL_APP_WILLENTERBACKGROUND: + /* Prepare your app to go into the background. Stop loops, etc. + This gets called when the user hits the home button, or gets a call. + */ + return 0; + case SDL_APP_DIDENTERBACKGROUND: + /* This will get called if the user accepted whatever sent your app to the background. + If the user got a phone call and canceled it, you'll instead get an SDL_APP_DIDENTERFOREGROUND event and restart your loops. + When you get this, you have 5 seconds to save all your state or the app will be terminated. + Your app is NOT active at this point. + */ + return 0; + case SDL_APP_WILLENTERFOREGROUND: + /* This call happens when your app is coming back to the foreground. + Restore all your state here. + */ + return 0; + case SDL_APP_DIDENTERFOREGROUND: + /* Restart your loops here. + Your app is interactive and getting CPU again. + */ + return 0; + default: + /* No special processing, add it to the event queue */ + return 1; + } + } + + int main(int argc, char *argv[]) + { + SDL_SetEventFilter(HandleAppEvents, NULL); + + ... run your main loop + + return 0; + } + + +============================================================================== +Notes -- Accelerometer as Joystick +============================================================================== + +SDL for iPhone supports polling the built in accelerometer as a joystick device. For an example on how to do this, see the accelerometer.c in the demos directory. + +The main thing to note when using the accelerometer with SDL is that while the iPhone natively reports accelerometer as floating point values in units of g-force, SDL_JoystickGetAxis() reports joystick values as signed integers. Hence, in order to convert between the two, some clamping and scaling is necessary on the part of the iPhone SDL joystick driver. To convert SDL_JoystickGetAxis() reported values BACK to units of g-force, simply multiply the values by SDL_IPHONE_MAX_GFORCE / 0x7FFF. + +============================================================================== +Notes -- OpenGL ES +============================================================================== + +Your SDL application for iOS uses OpenGL ES for video by default. + +OpenGL ES for iOS supports several display pixel formats, such as RGBA8 and RGB565, which provide a 32 bit and 16 bit color buffer respectively. By default, the implementation uses RGB565, but you may use RGBA8 by setting each color component to 8 bits in SDL_GL_SetAttribute(). + +If your application doesn't use OpenGL's depth buffer, you may find significant performance improvement by setting SDL_GL_DEPTH_SIZE to 0. + +Finally, if your application completely redraws the screen each frame, you may find significant performance improvement by setting the attribute SDL_GL_RETAINED_BACKING to 0. + +OpenGL ES on iOS doesn't use the traditional system-framebuffer setup provided in other operating systems. Special care must be taken because of this: + +- The drawable Renderbuffer must be bound to the GL_RENDERBUFFER binding point when SDL_GL_SwapWindow() is called. +- The drawable Framebuffer Object must be bound while rendering to the screen and when SDL_GL_SwapWindow() is called. +- If multisample antialiasing (MSAA) is used and glReadPixels is used on the screen, the drawable framebuffer must be resolved to the MSAA resolve framebuffer (via glBlitFramebuffer or glResolveMultisampleFramebufferAPPLE), and the MSAA resolve framebuffer must be bound to the GL_READ_FRAMEBUFFER binding point, before glReadPixels is called. + +The above objects can be obtained via SDL_GetWindowWMInfo() (in SDL_syswm.h). + +============================================================================== +Notes -- Keyboard +============================================================================== + +The SDL keyboard API has been extended to support on-screen keyboards: + +void SDL_StartTextInput() + -- enables text events and reveals the onscreen keyboard. + +void SDL_StopTextInput() + -- disables text events and hides the onscreen keyboard. + +SDL_bool SDL_IsTextInputActive() + -- returns whether or not text events are enabled (and the onscreen keyboard is visible) + + +============================================================================== +Notes -- Reading and Writing files +============================================================================== + +Each application installed on iPhone resides in a sandbox which includes its own Application Home directory. Your application may not access files outside this directory. + +Once your application is installed its directory tree looks like: + + MySDLApp Home/ + MySDLApp.app + Documents/ + Library/ + Preferences/ + tmp/ + +When your SDL based iPhone application starts up, it sets the working directory to the main bundle (MySDLApp Home/MySDLApp.app), where your application resources are stored. You cannot write to this directory. Instead, I advise you to write document files to "../Documents/" and preferences to "../Library/Preferences". + +More information on this subject is available here: +http://developer.apple.com/library/ios/#documentation/iPhone/Conceptual/iPhoneOSProgrammingGuide/Introduction/Introduction.html + +============================================================================== +Notes -- iPhone SDL limitations +============================================================================== + +Windows: + Full-size, single window applications only. You cannot create multi-window SDL applications for iPhone OS. The application window will fill the display, though you have the option of turning on or off the menu-bar (pass SDL_CreateWindow() the flag SDL_WINDOW_BORDERLESS). + +Textures: + The optimal texture formats on iOS are SDL_PIXELFORMAT_ABGR8888, SDL_PIXELFORMAT_ABGR8888, SDL_PIXELFORMAT_BGR888, and SDL_PIXELFORMAT_RGB24 pixel formats. + +Loading Shared Objects: + This is disabled by default since it seems to break the terms of the iOS SDK agreement for iOS versions prior to iOS 8. It can be re-enabled in SDL_config_iphoneos.h. + +============================================================================== +Game Center +============================================================================== + +Game Center integration might require that you break up your main loop in order to yield control back to the system. In other words, instead of running an endless main loop, you run each frame in a callback function, using: + + int SDL_iPhoneSetAnimationCallback(SDL_Window * window, int interval, void (*callback)(void*), void *callbackParam); + +This will set up the given function to be called back on the animation callback, and then you have to return from main() to let the Cocoa event loop run. + +e.g. + + extern "C" + void ShowFrame(void*) + { + ... do event handling, frame logic and rendering ... + } + + int main(int argc, char *argv[]) + { + ... initialize game ... + + #if __IPHONEOS__ + // Initialize the Game Center for scoring and matchmaking + InitGameCenter(); + + // Set up the game to run in the window animation callback on iOS + // so that Game Center and so forth works correctly. + SDL_iPhoneSetAnimationCallback(window, 1, ShowFrame, NULL); + #else + while ( running ) { + ShowFrame(0); + DelayFrame(); + } + #endif + return 0; + } + +============================================================================== +Deploying to older versions of iOS +============================================================================== + +SDL supports deploying to older versions of iOS than are supported by the latest version of Xcode, all the way back to iOS 6.1 + +In order to do that you need to download an older version of Xcode: +https://developer.apple.com/download/more/?name=Xcode + +Open the package contents of the older Xcode and your newer version of Xcode and copy over the folders in Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/DeviceSupport + +Then open the file Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/SDKSettings.plist and add the versions of iOS you want to deploy to the key Root/DefaultProperties/DEPLOYMENT_TARGET_SUGGESTED_VALUES + +Open your project and set your deployment target to the desired version of iOS + +Finally, remove GameController from the list of frameworks linked by your application and edit the build settings for "Other Linker Flags" and add -weak_framework GameController diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-linux.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-linux.md new file mode 100644 index 0000000..10f80b9 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-linux.md @@ -0,0 +1,87 @@ +Linux +================================================================================ + +By default SDL will only link against glibc, the rest of the features will be +enabled dynamically at runtime depending on the available features on the target +system. So, for example if you built SDL with Xinerama support and the target +system does not have the Xinerama libraries installed, it will be disabled +at runtime, and you won't get a missing library error, at least with the +default configuration parameters. + + +================================================================================ +Build Dependencies +================================================================================ + +Ubuntu 13.04, all available features enabled: + +sudo apt-get install build-essential mercurial make cmake autoconf automake \ +libtool libasound2-dev libpulse-dev libaudio-dev libx11-dev libxext-dev \ +libxrandr-dev libxcursor-dev libxi-dev libxinerama-dev libxxf86vm-dev \ +libxss-dev libgl1-mesa-dev libesd0-dev libdbus-1-dev libudev-dev \ +libgles1-mesa-dev libgles2-mesa-dev libegl1-mesa-dev libibus-1.0-dev \ +fcitx-libs-dev libsamplerate0-dev libsndio-dev + +Ubuntu 16.04+ can also add "libwayland-dev libxkbcommon-dev wayland-protocols" +to that command line for Wayland support. + +NOTES: +- This includes all the audio targets except arts, because Ubuntu pulled the + artsc0-dev package, but in theory SDL still supports it. +- libsamplerate0-dev lets SDL optionally link to libresamplerate at runtime + for higher-quality audio resampling. SDL will work without it if the library + is missing, so it's safe to build in support even if the end user doesn't + have this library installed. +- DirectFB isn't included because the configure script (currently) fails to find + it at all. You can do "sudo apt-get install libdirectfb-dev" and fix the + configure script to include DirectFB support. Send patches. :) + + +================================================================================ +Joystick does not work +================================================================================ + +If you compiled or are using a version of SDL with udev support (and you should!) +there's a few issues that may cause SDL to fail to detect your joystick. To +debug this, start by installing the evtest utility. On Ubuntu/Debian: + + sudo apt-get install evtest + +Then run: + + sudo evtest + +You'll hopefully see your joystick listed along with a name like "/dev/input/eventXX" +Now run: + + cat /dev/input/event/XX + +If you get a permission error, you need to set a udev rule to change the mode of +your device (see below) + +Also, try: + + sudo udevadm info --query=all --name=input/eventXX + +If you see a line stating ID_INPUT_JOYSTICK=1, great, if you don't see it, +you need to set up an udev rule to force this variable. + +A combined rule for the Saitek Pro Flight Rudder Pedals to fix both issues looks +like: + + SUBSYSTEM=="input", ATTRS{idProduct}=="0763", ATTRS{idVendor}=="06a3", MODE="0666", ENV{ID_INPUT_JOYSTICK}="1" + SUBSYSTEM=="input", ATTRS{idProduct}=="0764", ATTRS{idVendor}=="06a3", MODE="0666", ENV{ID_INPUT_JOYSTICK}="1" + +You can set up similar rules for your device by changing the values listed in +idProduct and idVendor. To obtain these values, try: + + sudo udevadm info -a --name=input/eventXX | grep idVendor + sudo udevadm info -a --name=input/eventXX | grep idProduct + +If multiple values come up for each of these, the one you want is the first one of each. + +On other systems which ship with an older udev (such as CentOS), you may need +to set up a rule such as: + + SUBSYSTEM=="input", ENV{ID_CLASS}=="joystick", ENV{ID_INPUT_JOYSTICK}="1" + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-macosx.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-macosx.md new file mode 100644 index 0000000..ee4f669 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-macosx.md @@ -0,0 +1,240 @@ +Mac OS X +============================================================================== + +These instructions are for people using Apple's Mac OS X (pronounced +"ten"). + +From the developer's point of view, OS X is a sort of hybrid Mac and +Unix system, and you have the option of using either traditional +command line tools or Apple's IDE Xcode. + +Command Line Build +================== + +To build SDL using the command line, use the standard configure and make +process: + + ./configure + make + sudo make install + +You can also build SDL as a Universal library (a single binary for both +32-bit and 64-bit Intel architectures), on Mac OS X 10.7 and newer, by using +the gcc-fat.sh script in build-scripts: + + mkdir mybuild + cd mybuild + CC=$PWD/../build-scripts/gcc-fat.sh CXX=$PWD/../build-scripts/g++-fat.sh ../configure + make + sudo make install + +This script builds SDL with 10.5 ABI compatibility on i386 and 10.6 +ABI compatibility on x86_64 architectures. For best compatibility you +should compile your application the same way. + +Please note that building SDL requires at least Xcode 4.6 and the 10.7 SDK +(even if you target back to 10.5 systems). PowerPC support for Mac OS X has +been officially dropped as of SDL 2.0.2. + +To use the library once it's built, you essential have two possibilities: +use the traditional autoconf/automake/make method, or use Xcode. + +============================================================================== +Caveats for using SDL with Mac OS X +============================================================================== + +Some things you have to be aware of when using SDL on Mac OS X: + +- If you register your own NSApplicationDelegate (using [NSApp setDelegate:]), + SDL will not register its own. This means that SDL will not terminate using + SDL_Quit if it receives a termination request, it will terminate like a + normal app, and it will not send a SDL_DROPFILE when you request to open a + file with the app. To solve these issues, put the following code in your + NSApplicationDelegate implementation: + + + - (NSApplicationTerminateReply)applicationShouldTerminate:(NSApplication *)sender + { + if (SDL_GetEventState(SDL_QUIT) == SDL_ENABLE) { + SDL_Event event; + event.type = SDL_QUIT; + SDL_PushEvent(&event); + } + + return NSTerminateCancel; + } + + - (BOOL)application:(NSApplication *)theApplication openFile:(NSString *)filename + { + if (SDL_GetEventState(SDL_DROPFILE) == SDL_ENABLE) { + SDL_Event event; + event.type = SDL_DROPFILE; + event.drop.file = SDL_strdup([filename UTF8String]); + return (SDL_PushEvent(&event) > 0); + } + + return NO; + } + +============================================================================== +Using the Simple DirectMedia Layer with a traditional Makefile +============================================================================== + +An existing autoconf/automake build system for your SDL app has good chances +to work almost unchanged on OS X. However, to produce a "real" Mac OS X binary +that you can distribute to users, you need to put the generated binary into a +so called "bundle", which basically is a fancy folder with a name like +"MyCoolGame.app". + +To get this build automatically, add something like the following rule to +your Makefile.am: + + bundle_contents = APP_NAME.app/Contents + APP_NAME_bundle: EXE_NAME + mkdir -p $(bundle_contents)/MacOS + mkdir -p $(bundle_contents)/Resources + echo "APPL????" > $(bundle_contents)/PkgInfo + $(INSTALL_PROGRAM) $< $(bundle_contents)/MacOS/ + +You should replace EXE_NAME with the name of the executable. APP_NAME is what +will be visible to the user in the Finder. Usually it will be the same +as EXE_NAME but capitalized. E.g. if EXE_NAME is "testgame" then APP_NAME +usually is "TestGame". You might also want to use `@PACKAGE@` to use the package +name as specified in your configure.ac file. + +If your project builds more than one application, you will have to do a bit +more. For each of your target applications, you need a separate rule. + +If you want the created bundles to be installed, you may want to add this +rule to your Makefile.am: + + install-exec-hook: APP_NAME_bundle + rm -rf $(DESTDIR)$(prefix)/Applications/APP_NAME.app + mkdir -p $(DESTDIR)$(prefix)/Applications/ + cp -r $< /$(DESTDIR)$(prefix)Applications/ + +This rule takes the Bundle created by the rule from step 3 and installs them +into "$(DESTDIR)$(prefix)/Applications/". + +Again, if you want to install multiple applications, you will have to augment +the make rule accordingly. + + +But beware! That is only part of the story! With the above, you end up with +a bare bone .app bundle, which is double clickable from the Finder. But +there are some more things you should do before shipping your product... + +1) The bundle right now probably is dynamically linked against SDL. That + means that when you copy it to another computer, *it will not run*, + unless you also install SDL on that other computer. A good solution + for this dilemma is to static link against SDL. On OS X, you can + achieve that by linking against the libraries listed by + + sdl-config --static-libs + + instead of those listed by + + sdl-config --libs + + Depending on how exactly SDL is integrated into your build systems, the + way to achieve that varies, so I won't describe it here in detail + +2) Add an 'Info.plist' to your application. That is a special XML file which + contains some meta-information about your application (like some copyright + information, the version of your app, the name of an optional icon file, + and other things). Part of that information is displayed by the Finder + when you click on the .app, or if you look at the "Get Info" window. + More information about Info.plist files can be found on Apple's homepage. + + +As a final remark, let me add that I use some of the techniques (and some +variations of them) in Exult and ScummVM; both are available in source on +the net, so feel free to take a peek at them for inspiration! + + +============================================================================== +Using the Simple DirectMedia Layer with Xcode +============================================================================== + +These instructions are for using Apple's Xcode IDE to build SDL applications. + +- First steps + +The first thing to do is to unpack the Xcode.tar.gz archive in the +top level SDL directory (where the Xcode.tar.gz archive resides). +Because Stuffit Expander will unpack the archive into a subdirectory, +you should unpack the archive manually from the command line: + + cd [path_to_SDL_source] + tar zxf Xcode.tar.gz + +This will create a new folder called Xcode, which you can browse +normally from the Finder. + +- Building the Framework + +The SDL Library is packaged as a framework bundle, an organized +relocatable folder hierarchy of executable code, interface headers, +and additional resources. For practical purposes, you can think of a +framework as a more user and system-friendly shared library, whose library +file behaves more or less like a standard UNIX shared library. + +To build the framework, simply open the framework project and build it. +By default, the framework bundle "SDL.framework" is installed in +/Library/Frameworks. Therefore, the testers and project stationary expect +it to be located there. However, it will function the same in any of the +following locations: + + ~/Library/Frameworks + /Local/Library/Frameworks + /System/Library/Frameworks + +- Build Options + There are two "Build Styles" (See the "Targets" tab) for SDL. + "Deployment" should be used if you aren't tweaking the SDL library. + "Development" should be used to debug SDL apps or the library itself. + +- Building the Testers + Open the SDLTest project and build away! + +- Using the Project Stationary + Copy the stationary to the indicated folders to access it from + the "New Project" and "Add target" menus. What could be easier? + +- Setting up a new project by hand + Some of you won't want to use the Stationary so I'll give some tips: + * Create a new "Cocoa Application" + * Add src/main/macosx/SDLMain.m , .h and .nib to your project + * Remove "main.c" from your project + * Remove "MainMenu.nib" from your project + * Add "$(HOME)/Library/Frameworks/SDL.framework/Headers" to include path + * Add "$(HOME)/Library/Frameworks" to the frameworks search path + * Add "-framework SDL -framework Foundation -framework AppKit" to "OTHER_LDFLAGS" + * Set the "Main Nib File" under "Application Settings" to "SDLMain.nib" + * Add your files + * Clean and build + +- Building from command line + Use pbxbuild in the same directory as your .pbproj file + +- Running your app + You can send command line args to your app by either invoking it from + the command line (in *.app/Contents/MacOS) or by entering them in the + "Executables" panel of the target settings. + +- Implementation Notes + Some things that may be of interest about how it all works... + * Working directory + As defined in the SDL_main.m file, the working directory of your SDL app + is by default set to its parent. You may wish to change this to better + suit your needs. + * You have a Cocoa App! + Your SDL app is essentially a Cocoa application. When your app + starts up and the libraries finish loading, a Cocoa procedure is called, + which sets up the working directory and calls your main() method. + You are free to modify your Cocoa app with generally no consequence + to SDL. You cannot, however, easily change the SDL window itself. + Functionality may be added in the future to help this. + + +Known bugs are listed in the file "BUGS.txt". diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-nacl.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-nacl.md new file mode 100644 index 0000000..53ada33 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-nacl.md @@ -0,0 +1,103 @@ +Native Client +================================================================================ + +Requirements: + +* Native Client SDK (https://developer.chrome.com/native-client), + (tested with Pepper version 33 or higher). + +The SDL backend for Chrome's Native Client has been tested only with the PNaCl +toolchain, which generates binaries designed to run on ARM and x86_32/64 +platforms. This does not mean it won't work with the other toolchains! + +================================================================================ +Building SDL for NaCl +================================================================================ + +Set up the right environment variables (see naclbuild.sh), then configure SDL with: + + configure --host=pnacl --prefix some/install/destination + +Then "make". + +As an example of how to create a deployable app a Makefile project is provided +in test/nacl/Makefile, which includes some monkey patching of the common.mk file +provided by NaCl, without which linking properly to SDL won't work (the search +path can't be modified externally, so the linker won't find SDL's binaries unless +you dump them into the SDK path, which is inconvenient). +Also provided in test/nacl is the required support file, such as index.html, +manifest.json, etc. +SDL apps for NaCl run on a worker thread using the ppapi_simple infrastructure. +This allows for blocking calls on all the relevant systems (OpenGL ES, filesystem), +hiding the asynchronous nature of the browser behind the scenes...which is not the +same as making it disappear! + + +================================================================================ +Running tests +================================================================================ + +Due to the nature of NaCl programs, building and running SDL tests is not as +straightforward as one would hope. The script naclbuild.sh in build-scripts +automates the process and should serve as a guide for users of SDL trying to build +their own applications. + +Basic usage: + + ./naclbuild.sh path/to/pepper/toolchain (i.e. ~/naclsdk/pepper_35) + +This will build testgles2.c by default. + +If you want to build a different test, for example testrendercopyex.c: + + SOURCES=~/sdl/SDL/test/testrendercopyex.c ./naclbuild.sh ~/naclsdk/pepper_35 + +Once the build finishes, you have to serve the contents with a web server (the +script will give you instructions on how to do that with Python). + +================================================================================ +RWops and nacl_io +================================================================================ + +SDL_RWops work transparently with nacl_io. Two functions control the mount points: + + int mount(const char* source, const char* target, + const char* filesystemtype, + unsigned long mountflags, const void *data); + int umount(const char *target); + + For convenience, SDL will by default mount an httpfs tree at / before calling +the app's main function. Such setting can be overridden by calling: + + umount("/"); + +And then mounting a different filesystem at / + +It's important to consider that the asynchronous nature of file operations on a +browser is hidden from the application, effectively providing the developer with +a set of blocking file operations just like you get in a regular desktop +environment, which eases the job of porting to Native Client, but also introduces +a set of challenges of its own, in particular when big file sizes and slow +connections are involved. + +For more information on how nacl_io and mount points work, see: + + https://developer.chrome.com/native-client/devguide/coding/nacl_io + https://src.chromium.org/chrome/trunk/src/native_client_sdk/src/libraries/nacl_io/nacl_io.h + +To be able to save into the directory "/save/" (like backup of game) : + + mount("", "/save", "html5fs", 0, "type=PERSISTENT"); + +And add to manifest.json : + + "permissions": [ + "unlimitedStorage" + ] + +================================================================================ +TODO - Known Issues +================================================================================ +* Testing of all systems with a real application (something other than SDL's tests) +* Key events don't seem to work properly + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-pandora.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-pandora.md new file mode 100644 index 0000000..a027763 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-pandora.md @@ -0,0 +1,17 @@ +Pandora +===================================================================== + +( http://openpandora.org/ ) +- A pandora specific video driver was written to allow SDL 2.0 with OpenGL ES +support to work on the pandora under the framebuffer. This driver do not have +input support for now, so if you use it you will have to add your own control code. +The video driver name is "pandora" so if you have problem running it from +the framebuffer, try to set the following variable before starting your application : +"export SDL_VIDEODRIVER=pandora" + +- OpenGL ES support was added to the x11 driver, so it's working like the normal +x11 driver one with OpenGLX support, with SDL input event's etc.. + + +David Carré (Cpasjuste) +cpasjuste@gmail.com diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-platforms.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-platforms.md new file mode 100644 index 0000000..711557d --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-platforms.md @@ -0,0 +1,8 @@ +Platforms +========= + +We maintain the list of supported platforms on our wiki now, and how to +build and install SDL for those platforms: + + https://wiki.libsdl.org/Installation + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-porting.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-porting.md new file mode 100644 index 0000000..de30592 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-porting.md @@ -0,0 +1,68 @@ +Porting +======= + +* Porting To A New Platform + + The first thing you have to do when porting to a new platform, is look at +include/SDL_platform.h and create an entry there for your operating system. +The standard format is "__PLATFORM__", where PLATFORM is the name of the OS. +Ideally SDL_platform.h will be able to auto-detect the system it's building +on based on C preprocessor symbols. + +There are two basic ways of building SDL at the moment: + +1. The "UNIX" way: ./configure; make; make install + + If you have a GNUish system, then you might try this. Edit configure.ac, + take a look at the large section labelled: + + "Set up the configuration based on the host platform!" + + Add a section for your platform, and then re-run autogen.sh and build! + +2. Using an IDE: + + If you're using an IDE or other non-configure build system, you'll probably + want to create a custom SDL_config.h for your platform. Edit SDL_config.h, + add a section for your platform, and create a custom SDL_config_{platform}.h, + based on SDL_config_minimal.h and SDL_config.h.in + + Add the top level include directory to the header search path, and then add + the following sources to the project: + + src/*.c + src/atomic/*.c + src/audio/*.c + src/cpuinfo/*.c + src/events/*.c + src/file/*.c + src/haptic/*.c + src/joystick/*.c + src/power/*.c + src/render/*.c + src/render/software/*.c + src/stdlib/*.c + src/thread/*.c + src/timer/*.c + src/video/*.c + src/audio/disk/*.c + src/audio/dummy/*.c + src/filesystem/dummy/*.c + src/video/dummy/*.c + src/haptic/dummy/*.c + src/joystick/dummy/*.c + src/main/dummy/*.c + src/thread/generic/*.c + src/timer/dummy/*.c + src/loadso/dummy/*.c + + +Once you have a working library without any drivers, you can go back to each +of the major subsystems and start implementing drivers for your platform. + +If you have any questions, don't hesitate to ask on the SDL mailing list: + http://www.libsdl.org/mailing-list.php + +Enjoy! + Sam Lantinga (slouken@libsdl.org) + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-psp.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-psp.md new file mode 100644 index 0000000..e891136 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-psp.md @@ -0,0 +1,19 @@ +PSP +====== +SDL port for the Sony PSP contributed by + Captian Lex + +Credit to + Marcus R.Brown,Jim Paris,Matthew H for the original SDL 1.2 for PSP + Geecko for his PSP GU lib "Glib2d" + +Building +-------- +To build for the PSP, make sure psp-config is in the path and run: + make -f Makefile.psp + + + +To Do +------ +PSP Screen Keyboard diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-raspberrypi.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-raspberrypi.md new file mode 100644 index 0000000..5e23ad5 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-raspberrypi.md @@ -0,0 +1,188 @@ +Raspberry Pi +================================================================================ + +Requirements: + +Raspbian (other Linux distros may work as well). + +================================================================================ + Features +================================================================================ + +* Works without X11 +* Hardware accelerated OpenGL ES 2.x +* Sound via ALSA +* Input (mouse/keyboard/joystick) via EVDEV +* Hotplugging of input devices via UDEV + + +================================================================================ + Raspbian Build Dependencies +================================================================================ + +sudo apt-get install libudev-dev libasound2-dev libdbus-1-dev + +You also need the VideoCore binary stuff that ships in /opt/vc for EGL and +OpenGL ES 2.x, it usually comes pre-installed, but in any case: + +sudo apt-get install libraspberrypi0 libraspberrypi-bin libraspberrypi-dev + + +================================================================================ + NEON +================================================================================ + +If your Pi has NEON support, make sure you add -mfpu=neon to your CFLAGS so +that SDL will select some otherwise-disabled highly-optimized code. The +original Pi units don't have NEON, the Pi2 probably does, and the Pi3 +definitely does. + +================================================================================ + Cross compiling from x86 Linux +================================================================================ + +To cross compile SDL for Raspbian from your desktop machine, you'll need a +Raspbian system root and the cross compilation tools. We'll assume these tools +will be placed in /opt/rpi-tools + + sudo git clone --depth 1 https://github.com/raspberrypi/tools /opt/rpi-tools + +You'll also need a Raspbian binary image. +Get it from: http://downloads.raspberrypi.org/raspbian_latest +After unzipping, you'll get file with a name like: "-wheezy-raspbian.img" +Let's assume the sysroot will be built in /opt/rpi-sysroot. + + export SYSROOT=/opt/rpi-sysroot + sudo kpartx -a -v .img + sudo mount -o loop /dev/mapper/loop0p2 /mnt + sudo cp -r /mnt $SYSROOT + sudo apt-get install qemu binfmt-support qemu-user-static + sudo cp /usr/bin/qemu-arm-static $SYSROOT/usr/bin + sudo mount --bind /dev $SYSROOT/dev + sudo mount --bind /proc $SYSROOT/proc + sudo mount --bind /sys $SYSROOT/sys + +Now, before chrooting into the ARM sysroot, you'll need to apply a workaround, +edit $SYSROOT/etc/ld.so.preload and comment out all lines in it. + + sudo chroot $SYSROOT + apt-get install libudev-dev libasound2-dev libdbus-1-dev libraspberrypi0 libraspberrypi-bin libraspberrypi-dev libx11-dev libxext-dev libxrandr-dev libxcursor-dev libxi-dev libxinerama-dev libxxf86vm-dev libxss-dev + exit + sudo umount $SYSROOT/dev + sudo umount $SYSROOT/proc + sudo umount $SYSROOT/sys + sudo umount /mnt + +There's one more fix required, as the libdl.so symlink uses an absolute path +which doesn't quite work in our setup. + + sudo rm -rf $SYSROOT/usr/lib/arm-linux-gnueabihf/libdl.so + sudo ln -s ../../../lib/arm-linux-gnueabihf/libdl.so.2 $SYSROOT/usr/lib/arm-linux-gnueabihf/libdl.so + +The final step is compiling SDL itself. + + export CC="/opt/rpi-tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf-gcc --sysroot=$SYSROOT -I$SYSROOT/opt/vc/include -I$SYSROOT/usr/include -I$SYSROOT/opt/vc/include/interface/vcos/pthreads -I$SYSROOT/opt/vc/include/interface/vmcs_host/linux" + cd + mkdir -p build;cd build + LDFLAGS="-L$SYSROOT/opt/vc/lib" ../configure --with-sysroot=$SYSROOT --host=arm-raspberry-linux-gnueabihf --prefix=$PWD/rpi-sdl2-installed --disable-pulseaudio --disable-esd + make + make install + +To be able to deploy this to /usr/local in the Raspbian system you need to fix up a few paths: + + perl -w -pi -e "s#$PWD/rpi-sdl2-installed#/usr/local#g;" ./rpi-sdl2-installed/lib/libSDL2.la ./rpi-sdl2-installed/lib/pkgconfig/sdl2.pc ./rpi-sdl2-installed/bin/sdl2-config + +================================================================================ + Apps don't work or poor video/audio performance +================================================================================ + +If you get sound problems, buffer underruns, etc, run "sudo rpi-update" to +update the RPi's firmware. Note that doing so will fix these problems, but it +will also render the CMA - Dynamic Memory Split functionality useless. + +Also, by default the Raspbian distro configures the GPU RAM at 64MB, this is too +low in general, specially if a 1080p TV is hooked up. + +See here how to configure this setting: http://elinux.org/RPiconfig + +Using a fixed gpu_mem=128 is the best option (specially if you updated the +firmware, using CMA probably won't work, at least it's the current case). + +================================================================================ + No input +================================================================================ + +Make sure you belong to the "input" group. + + sudo usermod -aG input `whoami` + +================================================================================ + No HDMI Audio +================================================================================ + +If you notice that ALSA works but there's no audio over HDMI, try adding: + + hdmi_drive=2 + +to your config.txt file and reboot. + +Reference: http://www.raspberrypi.org/phpBB3/viewtopic.php?t=5062 + +================================================================================ + Text Input API support +================================================================================ + +The Text Input API is supported, with translation of scan codes done via the +kernel symbol tables. For this to work, SDL needs access to a valid console. +If you notice there's no SDL_TEXTINPUT message being emitted, double check that +your app has read access to one of the following: + +* /proc/self/fd/0 +* /dev/tty +* /dev/tty[0...6] +* /dev/vc/0 +* /dev/console + +This is usually not a problem if you run from the physical terminal (as opposed +to running from a pseudo terminal, such as via SSH). If running from a PTS, a +quick workaround is to run your app as root or add yourself to the tty group, +then re-login to the system. + + sudo usermod -aG tty `whoami` + +The keyboard layout used by SDL is the same as the one the kernel uses. +To configure the layout on Raspbian: + + sudo dpkg-reconfigure keyboard-configuration + +To configure the locale, which controls which keys are interpreted as letters, +this determining the CAPS LOCK behavior: + + sudo dpkg-reconfigure locales + +================================================================================ + OpenGL problems +================================================================================ + +If you have desktop OpenGL headers installed at build time in your RPi or cross +compilation environment, support for it will be built in. However, the chipset +does not actually have support for it, which causes issues in certain SDL apps +since the presence of OpenGL support supersedes the ES/ES2 variants. +The workaround is to disable OpenGL at configuration time: + + ./configure --disable-video-opengl + +Or if the application uses the Render functions, you can use the SDL_RENDER_DRIVER +environment variable: + + export SDL_RENDER_DRIVER=opengles2 + +================================================================================ + Notes +================================================================================ + +* When launching apps remotely (via SSH), SDL can prevent local keystrokes from + leaking into the console only if it has root privileges. Launching apps locally + does not suffer from this issue. + + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-touch.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-touch.md new file mode 100644 index 0000000..09188b8 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-touch.md @@ -0,0 +1,86 @@ +Touch +=========================================================================== +System Specific Notes +=========================================================================== +Linux: +The linux touch system is currently based off event streams, and proc/bus/devices. The active user must be given permissions to read /dev/input/TOUCHDEVICE, where TOUCHDEVICE is the event stream for your device. Currently only Wacom tablets are supported. If you have an unsupported tablet contact me at jim.tla+sdl_touch@gmail.com and I will help you get support for it. + +Mac: +The Mac and iPhone APIs are pretty. If your touch device supports them then you'll be fine. If it doesn't, then there isn't much we can do. + +iPhone: +Works out of box. + +Windows: +Unfortunately there is no windows support as of yet. Support for Windows 7 is planned, but we currently have no way to test. If you have a Windows 7 WM_TOUCH supported device, and are willing to help test please contact me at jim.tla+sdl_touch@gmail.com + +=========================================================================== +Events +=========================================================================== +SDL_FINGERDOWN: +Sent when a finger (or stylus) is placed on a touch device. +Fields: +* event.tfinger.touchId - the Id of the touch device. +* event.tfinger.fingerId - the Id of the finger which just went down. +* event.tfinger.x - the x coordinate of the touch (0..1) +* event.tfinger.y - the y coordinate of the touch (0..1) +* event.tfinger.pressure - the pressure of the touch (0..1) + +SDL_FINGERMOTION: +Sent when a finger (or stylus) is moved on the touch device. +Fields: +Same as SDL_FINGERDOWN but with additional: +* event.tfinger.dx - change in x coordinate during this motion event. +* event.tfinger.dy - change in y coordinate during this motion event. + +SDL_FINGERUP: +Sent when a finger (or stylus) is lifted from the touch device. +Fields: +Same as SDL_FINGERDOWN. + + +=========================================================================== +Functions +=========================================================================== +SDL provides the ability to access the underlying SDL_Finger structures. +These structures should _never_ be modified. + +The following functions are included from SDL_touch.h + +To get a SDL_TouchID call SDL_GetTouchDevice(int index). +This returns a SDL_TouchID. +IMPORTANT: If the touch has been removed, or there is no touch with the given index, SDL_GetTouchDevice() will return 0. Be sure to check for this! + +The number of touch devices can be queried with SDL_GetNumTouchDevices(). + +A SDL_TouchID may be used to get pointers to SDL_Finger. + +SDL_GetNumTouchFingers(touchID) may be used to get the number of fingers currently down on the device. + +The most common reason to access SDL_Finger is to query the fingers outside the event. In most cases accessing the fingers is using the event. This would be accomplished by code like the following: + + float x = event.tfinger.x; + float y = event.tfinger.y; + + + +To get a SDL_Finger, call SDL_GetTouchFinger(SDL_TouchID touchID, int index), where touchID is a SDL_TouchID, and index is the requested finger. +This returns a SDL_Finger *, or NULL if the finger does not exist, or has been removed. +A SDL_Finger is guaranteed to be persistent for the duration of a touch, but it will be de-allocated as soon as the finger is removed. This occurs when the SDL_FINGERUP event is _added_ to the event queue, and thus _before_ the SDL_FINGERUP event is polled. +As a result, be very careful to check for NULL return values. + +A SDL_Finger has the following fields: +* x, y: + The current coordinates of the touch. +* pressure: + The pressure of the touch. + + +=========================================================================== +Notes +=========================================================================== +For a complete example see test/testgesture.c + +Please direct questions/comments to: + jim.tla+sdl_touch@gmail.com + (original author, API was changed since) diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-wince.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-wince.md new file mode 100644 index 0000000..d5fb64f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-wince.md @@ -0,0 +1,10 @@ +WinCE +===== + +Windows CE is no longer supported by SDL. + +We have left the CE support in SDL 1.2 for those that must have it, and we +have support for Windows Phone 8 and WinRT in SDL2, as of SDL 2.0.3. + +--ryan. + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-windows.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-windows.md new file mode 100644 index 0000000..71f968e --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-windows.md @@ -0,0 +1,45 @@ +Windows +================================================================================ + +================================================================================ +OpenGL ES 2.x support +================================================================================ + +SDL has support for OpenGL ES 2.x under Windows via two alternative +implementations. +The most straightforward method consists in running your app in a system with +a graphic card paired with a relatively recent (as of November of 2013) driver +which supports the WGL_EXT_create_context_es2_profile extension. Vendors known +to ship said extension on Windows currently include nVidia and Intel. + +The other method involves using the ANGLE library (https://code.google.com/p/angleproject/) +If an OpenGL ES 2.x context is requested and no WGL_EXT_create_context_es2_profile +extension is found, SDL will try to load the libEGL.dll library provided by +ANGLE. +To obtain the ANGLE binaries, you can either compile from source from +https://chromium.googlesource.com/angle/angle or copy the relevant binaries from +a recent Chrome/Chromium install for Windows. The files you need are: + + * libEGL.dll + * libGLESv2.dll + * d3dcompiler_46.dll (supports Windows Vista or later, better shader compiler) + or... + * d3dcompiler_43.dll (supports Windows XP or later) + +If you compile ANGLE from source, you can configure it so it does not need the +d3dcompiler_* DLL at all (for details on this, see their documentation). +However, by default SDL will try to preload the d3dcompiler_46.dll to +comply with ANGLE's requirements. If you wish SDL to preload d3dcompiler_43.dll (to +support Windows XP) or to skip this step at all, you can use the +SDL_HINT_VIDEO_WIN_D3DCOMPILER hint (see SDL_hints.h for more details). + +Known Bugs: + + * SDL_GL_SetSwapInterval is currently a no op when using ANGLE. It appears + that there's a bug in the library which prevents the window contents from + refreshing if this is set to anything other than the default value. + +Vulkan Surface Support +============== + +Support for creating Vulkan surfaces is configured on by default. To disable it change the value of `SDL_VIDEO_VULKAN` to 0 in `SDL_config_windows.h`. You must install the [Vulkan SDK](https://www.lunarg.com/vulkan-sdk/) in order to use Vulkan graphics in your application. diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README-winrt.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README-winrt.md new file mode 100644 index 0000000..73ef372 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README-winrt.md @@ -0,0 +1,547 @@ +WinRT +===== + +This port allows SDL applications to run on Microsoft's platforms that require +use of "Windows Runtime", aka. "WinRT", APIs. Microsoft may, in some cases, +refer to them as either "Windows Store", or for Windows 10, "UWP" apps. + +Some of the operating systems that include WinRT, are: + +* Windows 10, via its Universal Windows Platform (UWP) APIs +* Windows 8.x +* Windows RT 8.x (aka. Windows 8.x for ARM processors) +* Windows Phone 8.x + + +Requirements +------------ + +* Microsoft Visual C++ (aka Visual Studio), either 2017, 2015, 2013, or 2012 + - Free, "Community" or "Express" editions may be used, so long as they + include support for either "Windows Store" or "Windows Phone" apps. + "Express" versions marked as supporting "Windows Desktop" development + typically do not include support for creating WinRT apps, to note. + (The "Community" editions of Visual C++ do, however, support both + desktop/Win32 and WinRT development). + - Visual Studio 2017 can be used, however it is recommended that you install + the Visual C++ 2015 build tools. These build tools can be installed + using VS 2017's installer. Be sure to also install the workload for + "Universal Windows Platform development", its optional component, the + "C++ Universal Windows Platform tools", and for UWP / Windows 10 + development, the "Windows 10 SDK (10.0.10240.0)". Please note that + targeting UWP / Windows 10 apps from development machine(s) running + earlier versions of Windows, such as Windows 7, is not always supported + by Visual Studio, and you may get error(s) when attempting to do so. + - Visual C++ 2012 can only build apps that target versions 8.0 of Windows, + or Windows Phone. 8.0-targeted apps will run on devices running 8.1 + editions of Windows, however they will not be able to take advantage of + 8.1-specific features. + - Visual C++ 2013 cannot create app projects that target Windows 8.0. + Visual C++ 2013 Update 4, can create app projects for Windows Phone 8.0, + Windows Phone 8.1, and Windows 8.1, but not Windows 8.0. An optional + Visual Studio add-in, "Tools for Maintaining Store apps for Windows 8", + allows Visual C++ 2013 to load and build Windows 8.0 projects that were + created with Visual C++ 2012, so long as Visual C++ 2012 is installed + on the same machine. More details on targeting different versions of + Windows can found at the following web pages: + - [Develop apps by using Visual Studio 2013](http://msdn.microsoft.com/en-us/library/windows/apps/br211384.aspx) + - [To add the Tools for Maintaining Store apps for Windows 8](http://msdn.microsoft.com/en-us/library/windows/apps/dn263114.aspx#AddMaintenanceTools) +* A valid Microsoft account - This requirement is not imposed by SDL, but + rather by Microsoft's Visual C++ toolchain. This is required to launch or + debug apps. + + +Status +------ + +Here is a rough list of what works, and what doesn't: + +* What works: + * compilation via Visual C++ 2012 through 2015 + * compile-time platform detection for SDL programs. The C/C++ #define, + `__WINRT__`, will be set to 1 (by SDL) when compiling for WinRT. + * GPU-accelerated 2D rendering, via SDL_Renderer. + * OpenGL ES 2, via the ANGLE library (included separately from SDL) + * software rendering, via either SDL_Surface (optionally in conjunction with + SDL_GetWindowSurface() and SDL_UpdateWindowSurface()) or via the + SDL_Renderer APIs + * threads + * timers (via SDL_GetTicks(), SDL_AddTimer(), SDL_GetPerformanceCounter(), + SDL_GetPerformanceFrequency(), etc.) + * file I/O via SDL_RWops + * mouse input (unsupported on Windows Phone) + * audio, via SDL's WASAPI backend (if you want to record, your app must + have "Microphone" capabilities enabled in its manifest, and the user must + not have blocked access. Otherwise, capture devices will fail to work, + presenting as a device disconnect shortly after opening it.) + * .DLL file loading. Libraries *MUST* be packaged inside applications. Loading + anything outside of the app is not supported. + * system path retrieval via SDL's filesystem APIs + * game controllers. Support is provided via the SDL_Joystick and + SDL_GameController APIs, and is backed by Microsoft's XInput API. Please + note, however, that Windows limits game-controller support in UWP apps to, + "Xbox compatible controllers" (many controllers that work in Win32 apps, + do not work in UWP, due to restrictions in UWP itself.) + * multi-touch input + * app events. SDL_APP_WILLENTER* and SDL_APP_DIDENTER* events get sent out as + appropriate. + * window events + * using Direct3D 11.x APIs outside of SDL. Non-XAML / Direct3D-only apps can + choose to render content directly via Direct3D, using SDL to manage the + internal WinRT window, as well as input and audio. (Use + SDL_GetWindowWMInfo() to get the WinRT 'CoreWindow', and pass it into + IDXGIFactory2::CreateSwapChainForCoreWindow() as appropriate.) + +* What partially works: + * keyboard input. Most of WinRT's documented virtual keys are supported, as + well as many keys with documented hardware scancodes. Converting + SDL_Scancodes to or from SDL_Keycodes may not work, due to missing APIs + (MapVirtualKey()) in Microsoft's Windows Store / UWP APIs. + * SDLmain. WinRT uses a different signature for each app's main() function. + SDL-based apps that use this port must compile in SDL_winrt_main_NonXAML.cpp + (in `SDL\src\main\winrt\`) directly in order for their C-style main() + functions to be called. + +* What doesn't work: + * compilation with anything other than Visual C++ + * programmatically-created custom cursors. These don't appear to be supported + by WinRT. Different OS-provided cursors can, however, be created via + SDL_CreateSystemCursor() (unsupported on Windows Phone) + * SDL_WarpMouseInWindow() or SDL_WarpMouseGlobal(). This are not currently + supported by WinRT itself. + * joysticks and game controllers that either are not supported by + Microsoft's XInput API, or are not supported within UWP apps (many + controllers that work in Win32, do not work in UWP, due to restrictions in + UWP itself). + * turning off VSync when rendering on Windows Phone. Attempts to turn VSync + off on Windows Phone result either in Direct3D not drawing anything, or it + forcing VSync back on. As such, SDL_RENDERER_PRESENTVSYNC will always get + turned-on on Windows Phone. This limitation is not present in non-Phone + WinRT (such as Windows 8.x), where turning off VSync appears to work. + * probably anything else that's not listed as supported + + + +Upgrade Notes +------------- + +#### SDL_GetPrefPath() usage when upgrading WinRT apps from SDL 2.0.3 + +SDL 2.0.4 fixes two bugs found in the WinRT version of SDL_GetPrefPath(). +The fixes may affect older, SDL 2.0.3-based apps' save data. Please note +that these changes only apply to SDL-based WinRT apps, and not to apps for +any other platform. + +1. SDL_GetPrefPath() would return an invalid path, one in which the path's + directory had not been created. Attempts to create files there + (via fopen(), for example), would fail, unless that directory was + explicitly created beforehand. + +2. SDL_GetPrefPath(), for non-WinPhone-based apps, would return a path inside + a WinRT 'Roaming' folder, the contents of which get automatically + synchronized across multiple devices. This process can occur while an + application runs, and can cause existing save-data to be overwritten + at unexpected times, with data from other devices. (Windows Phone apps + written with SDL 2.0.3 did not utilize a Roaming folder, due to API + restrictions in Windows Phone 8.0). + + +SDL_GetPrefPath(), starting with SDL 2.0.4, addresses these by: + +1. making sure that SDL_GetPrefPath() returns a directory in which data + can be written to immediately, without first needing to create directories. + +2. basing SDL_GetPrefPath() off of a different, non-Roaming folder, the + contents of which do not automatically get synchronized across devices + (and which require less work to use safely, in terms of data integrity). + +Apps that wish to get their Roaming folder's path can do so either by using +SDL_WinRTGetFSPathUTF8(), SDL_WinRTGetFSPathUNICODE() (which returns a +UCS-2/wide-char string), or directly through the WinRT class, +Windows.Storage.ApplicationData. + + + +Setup, High-Level Steps +----------------------- + +The steps for setting up a project for an SDL/WinRT app looks like the +following, at a high-level: + +1. create a new Visual C++ project using Microsoft's template for a, + "Direct3D App". +2. remove most of the files from the project. +3. make your app's project directly reference SDL/WinRT's own Visual C++ + project file, via use of Visual C++'s "References" dialog. This will setup + the linker, and will copy SDL's .dll files to your app's final output. +4. adjust your app's build settings, at minimum, telling it where to find SDL's + header files. +5. add files that contains a WinRT-appropriate main function, along with some + data to make sure mouse-cursor-hiding (via SDL_ShowCursor(SDL_DISABLE) calls) + work properly. +6. add SDL-specific app code. +7. build and run your app. + + +Setup, Detailed Steps +--------------------- + +### 1. Create a new project ### + +Create a new project using one of Visual C++'s templates for a plain, non-XAML, +"Direct3D App" (XAML support for SDL/WinRT is not yet ready for use). If you +don't see one of these templates, in Visual C++'s 'New Project' dialog, try +using the textbox titled, 'Search Installed Templates' to look for one. + + +### 2. Remove unneeded files from the project ### + +In the new project, delete any file that has one of the following extensions: + +- .cpp +- .h +- .hlsl + +When you are done, you should be left with a few files, each of which will be a +necessary part of your app's project. These files will consist of: + +- an .appxmanifest file, which contains metadata on your WinRT app. This is + similar to an Info.plist file on iOS, or an AndroidManifest.xml on Android. +- a few .png files, one of which is a splash screen (displayed when your app + launches), others are app icons. +- a .pfx file, used for code signing purposes. + + +### 3. Add references to SDL's project files ### + +SDL/WinRT can be built in multiple variations, spanning across three different +CPU architectures (x86, x64, and ARM) and two different configurations +(Debug and Release). WinRT and Visual C++ do not currently provide a means +for combining multiple variations of one library into a single file. +Furthermore, it does not provide an easy means for copying pre-built .dll files +into your app's final output (via Post-Build steps, for example). It does, +however, provide a system whereby an app can reference the MSVC projects of +libraries such that, when the app is built: + +1. each library gets built for the appropriate CPU architecture(s) and WinRT + platform(s). +2. each library's output, such as .dll files, get copied to the app's build + output. + +To set this up for SDL/WinRT, you'll need to run through the following steps: + +1. open up the Solution Explorer inside Visual C++ (under the "View" menu, then + "Solution Explorer") +2. right click on your app's solution. +3. navigate to "Add", then to "Existing Project..." +4. find SDL/WinRT's Visual C++ project file and open it. Different project + files exist for different WinRT platforms. All of them are in SDL's + source distribution, in the following directories: + * `VisualC-WinRT/UWP_VS2015/` - for Windows 10 / UWP apps + * `VisualC-WinRT/WinPhone81_VS2013/` - for Windows Phone 8.1 apps + * `VisualC-WinRT/WinRT80_VS2012/` - for Windows 8.0 apps + * `VisualC-WinRT/WinRT81_VS2013/` - for Windows 8.1 apps +5. once the project has been added, right-click on your app's project and + select, "References..." +6. click on the button titled, "Add New Reference..." +7. check the box next to SDL +8. click OK to close the dialog +9. SDL will now show up in the list of references. Click OK to close that + dialog. + +Your project is now linked to SDL's project, insofar that when the app is +built, SDL will be built as well, with its build output getting included with +your app. + + +### 4. Adjust Your App's Build Settings ### + +Some build settings need to be changed in your app's project. This guide will +outline the following: + +- making sure that the compiler knows where to find SDL's header files +- **Optional for C++, but NECESSARY for compiling C code:** telling the + compiler not to use Microsoft's C++ extensions for WinRT development. +- **Optional:** telling the compiler not generate errors due to missing + precompiled header files. + +To change these settings: + +1. right-click on the project +2. choose "Properties" +3. in the drop-down box next to "Configuration", choose, "All Configurations" +4. in the drop-down box next to "Platform", choose, "All Platforms" +5. in the left-hand list, expand the "C/C++" section +6. select "General" +7. edit the "Additional Include Directories" setting, and add a path to SDL's + "include" directory +8. **Optional: to enable compilation of C code:** change the setting for + "Consume Windows Runtime Extension" from "Yes (/ZW)" to "No". If you're + working with a completely C++ based project, this step can usually be + omitted. +9. **Optional: to disable precompiled headers (which can produce + 'stdafx.h'-related build errors, if setup incorrectly:** in the left-hand + list, select "Precompiled Headers", then change the setting for "Precompiled + Header" from "Use (/Yu)" to "Not Using Precompiled Headers". +10. close the dialog, saving settings, by clicking the "OK" button + + +### 5. Add a WinRT-appropriate main function, and a blank-cursor image, to the app. ### + +A few files should be included directly in your app's MSVC project, specifically: +1. a WinRT-appropriate main function (which is different than main() functions on + other platforms) +2. a Win32-style cursor resource, used by SDL_ShowCursor() to hide the mouse cursor + (if and when the app needs to do so). *If this cursor resource is not + included, mouse-position reporting may fail if and when the cursor is + hidden, due to possible bugs/design-oddities in Windows itself.* + +To include these files for C/C++ projects: + +1. right-click on your project (again, in Visual C++'s Solution Explorer), + navigate to "Add", then choose "Existing Item...". +2. navigate to the directory containing SDL's source code, then into its + subdirectory, 'src/main/winrt/'. Select, then add, the following files: + - `SDL_winrt_main_NonXAML.cpp` + - `SDL2-WinRTResources.rc` + - `SDL2-WinRTResource_BlankCursor.cur` +3. right-click on the file `SDL_winrt_main_NonXAML.cpp` (as listed in your + project), then click on "Properties...". +4. in the drop-down box next to "Configuration", choose, "All Configurations" +5. in the drop-down box next to "Platform", choose, "All Platforms" +6. in the left-hand list, click on "C/C++" +7. change the setting for "Consume Windows Runtime Extension" to "Yes (/ZW)". +8. click the OK button. This will close the dialog. + +**NOTE: C++/CX compilation is currently required in at least one file of your +app's project. This is to make sure that Visual C++'s linker builds a 'Windows +Metadata' file (.winmd) for your app. Not doing so can lead to build errors.** + +For non-C++ projects, you will need to call SDL_WinRTRunApp from your language's +main function, and generate SDL2-WinRTResources.res manually by using `rc` via +the Developer Command Prompt and including it as a within the +first block in your Visual Studio project file. + +### 6. Add app code and assets ### + +At this point, you can add in SDL-specific source code. Be sure to include a +C-style main function (ie: `int main(int argc, char *argv[])`). From there you +should be able to create a single `SDL_Window` (WinRT apps can only have one +window, at present), as well as an `SDL_Renderer`. Direct3D will be used to +draw content. Events are received via SDL's usual event functions +(`SDL_PollEvent`, etc.) If you have a set of existing source files and assets, +you can start adding them to the project now. If not, or if you would like to +make sure that you're setup correctly, some short and simple sample code is +provided below. + + +#### 6.A. ... when creating a new app #### + +If you are creating a new app (rather than porting an existing SDL-based app), +or if you would just like a simple app to test SDL/WinRT with before trying to +get existing code working, some working SDL/WinRT code is provided below. To +set this up: + +1. right click on your app's project +2. select Add, then New Item. An "Add New Item" dialog will show up. +3. from the left-hand list, choose "Visual C++" +4. from the middle/main list, choose "C++ File (.cpp)" +5. near the bottom of the dialog, next to "Name:", type in a name for your +source file, such as, "main.cpp". +6. click on the Add button. This will close the dialog, add the new file to +your project, and open the file in Visual C++'s text editor. +7. Copy and paste the following code into the new file, then save it. + + + #include + + int main(int argc, char **argv) + { + SDL_DisplayMode mode; + SDL_Window * window = NULL; + SDL_Renderer * renderer = NULL; + SDL_Event evt; + + if (SDL_Init(SDL_INIT_VIDEO) != 0) { + return 1; + } + + if (SDL_GetCurrentDisplayMode(0, &mode) != 0) { + return 1; + } + + if (SDL_CreateWindowAndRenderer(mode.w, mode.h, SDL_WINDOW_FULLSCREEN, &window, &renderer) != 0) { + return 1; + } + + while (1) { + while (SDL_PollEvent(&evt)) { + } + + SDL_SetRenderDrawColor(renderer, 0, 255, 0, 255); + SDL_RenderClear(renderer); + SDL_RenderPresent(renderer); + } + } + + +#### 6.B. Adding code and assets #### + +If you have existing code and assets that you'd like to add, you should be able +to add them now. The process for adding a set of files is as such. + +1. right click on the app's project +2. select Add, then click on "New Item..." +3. open any source, header, or asset files as appropriate. Support for C and +C++ is available. + +Do note that WinRT only supports a subset of the APIs that are available to +Win32-based apps. Many portions of the Win32 API and the C runtime are not +available. + +A list of unsupported C APIs can be found at + + +General information on using the C runtime in WinRT can be found at + + +A list of supported Win32 APIs for WinRT apps can be found at +. To note, +the list of supported Win32 APIs for Windows Phone 8.0 is different. +That list can be found at + + + +### 7. Build and run your app ### + +Your app project should now be setup, and you should be ready to build your app. +To run it on the local machine, open the Debug menu and choose "Start +Debugging". This will build your app, then run your app full-screen. To switch +out of your app, press the Windows key. Alternatively, you can choose to run +your app in a window. To do this, before building and running your app, find +the drop-down menu in Visual C++'s toolbar that says, "Local Machine". Expand +this by clicking on the arrow on the right side of the list, then click on +Simulator. Once you do that, any time you build and run the app, the app will +launch in window, rather than full-screen. + + +#### 7.A. Running apps on older, ARM-based, "Windows RT" devices #### + +**These instructions do not include Windows Phone, despite Windows Phone +typically running on ARM processors.** They are specifically for devices +that use the "Windows RT" operating system, which was a modified version of +Windows 8.x that ran primarily on ARM-based tablet computers. + +To build and run the app on ARM-based, "Windows RT" devices, you'll need to: + +- install Microsoft's "Remote Debugger" on the device. Visual C++ installs and + debugs ARM-based apps via IP networks. +- change a few options on the development machine, both to make sure it builds + for ARM (rather than x86 or x64), and to make sure it knows how to find the + Windows RT device (on the network). + +Microsoft's Remote Debugger can be found at +. Please note +that separate versions of this debugger exist for different versions of Visual +C++, one each for MSVC 2015, 2013, and 2012. + +To setup Visual C++ to launch your app on an ARM device: + +1. make sure the Remote Debugger is running on your ARM device, and that it's on + the same IP network as your development machine. +2. from Visual C++'s toolbar, find a drop-down menu that says, "Win32". Click + it, then change the value to "ARM". +3. make sure Visual C++ knows the hostname or IP address of the ARM device. To + do this: + 1. open the app project's properties + 2. select "Debugging" + 3. next to "Machine Name", enter the hostname or IP address of the ARM + device + 4. if, and only if, you've turned off authentication in the Remote Debugger, + then change the setting for "Require Authentication" to No + 5. click "OK" +4. build and run the app (from Visual C++). The first time you do this, a + prompt will show up on the ARM device, asking for a Microsoft Account. You + do, unfortunately, need to log in here, and will need to follow the + subsequent registration steps in order to launch the app. After you do so, + if the app didn't already launch, try relaunching it again from within Visual + C++. + + +Troubleshooting +--------------- + +#### Build fails with message, "error LNK2038: mismatch detected for 'vccorlib_lib_should_be_specified_before_msvcrt_lib_to_linker'" + +Try adding the following to your linker flags. In MSVC, this can be done by +right-clicking on the app project, navigating to Configuration Properties -> +Linker -> Command Line, then adding them to the Additional Options +section. + +* For Release builds / MSVC-Configurations, add: + + /nodefaultlib:vccorlib /nodefaultlib:msvcrt vccorlib.lib msvcrt.lib + +* For Debug builds / MSVC-Configurations, add: + + /nodefaultlib:vccorlibd /nodefaultlib:msvcrtd vccorlibd.lib msvcrtd.lib + + +#### Mouse-motion events fail to get sent, or SDL_GetMouseState() fails to return updated values + +This may be caused by a bug in Windows itself, whereby hiding the mouse +cursor can cause mouse-position reporting to fail. + +SDL provides a workaround for this, but it requires that an app links to a +set of Win32-style cursor image-resource files. A copy of suitable resource +files can be found in `src/main/winrt/`. Adding them to an app's Visual C++ +project file should be sufficient to get the app to use them. + + +#### SDL's Visual Studio project file fails to open, with message, "The system can't find the file specified." + +This can be caused for any one of a few reasons, which Visual Studio can +report, but won't always do so in an up-front manner. + +To help determine why this error comes up: + +1. open a copy of Visual Studio without opening a project file. This can be + accomplished via Windows' Start Menu, among other means. +2. show Visual Studio's Output window. This can be done by going to VS' + menu bar, then to View, and then to Output. +3. try opening the SDL project file directly by going to VS' menu bar, then + to File, then to Open, then to Project/Solution. When a File-Open dialog + appears, open the SDL project (such as the one in SDL's source code, in its + directory, VisualC-WinRT/UWP_VS2015/). +4. after attempting to open SDL's Visual Studio project file, additional error + information will be output to the Output window. + +If Visual Studio reports (via its Output window) that the project: + +"could not be loaded because it's missing install components. To fix this launch Visual Studio setup with the following selections: +Microsoft.VisualStudio.ComponentGroup.UWP.VC" + +... then you will need to re-launch Visual Studio's installer, and make sure that +the workflow for "Universal Windows Platform development" is checked, and that its +optional component, "C++ Universal Windows Platform tools" is also checked. While +you are there, if you are planning on targeting UWP / Windows 10, also make sure +that you check the optional component, "Windows 10 SDK (10.0.10240.0)". After +making sure these items are checked as-appropriate, install them. + +Once you install these components, try re-launching Visual Studio, and re-opening +the SDL project file. If you still get the error dialog, try using the Output +window, again, seeing what Visual Studio says about it. + + +#### Game controllers / joysticks aren't working! + +Windows only permits certain game controllers and joysticks to work within +WinRT / UWP apps. Even if a game controller or joystick works in a Win32 +app, that device is not guaranteed to work inside a WinRT / UWP app. + +According to Microsoft, "Xbox compatible controllers" should work inside +UWP apps, potentially with more working in the future. This includes, but +may not be limited to, Microsoft-made Xbox controllers and USB adapters. +(Source: https://social.msdn.microsoft.com/Forums/en-US/9064838b-e8c3-4c18-8a83-19bf0dfe150d/xinput-fails-to-detect-game-controllers?forum=wpdevelop) + + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/README.md b/vendor/lite/winlib/SDL2-2.0.10/docs/README.md new file mode 100644 index 0000000..7e2c151 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/README.md @@ -0,0 +1,63 @@ +Simple DirectMedia Layer {#mainpage} +======================== + + (SDL) + + Version 2.0 + +--- +http://www.libsdl.org/ + +Simple DirectMedia Layer is a cross-platform development library designed +to provide low level access to audio, keyboard, mouse, joystick, and graphics +hardware via OpenGL and Direct3D. It is used by video playback software, +emulators, and popular games including Valve's award winning catalog +and many Humble Bundle games. + +SDL officially supports Windows, Mac OS X, Linux, iOS, and Android. +Support for other platforms may be found in the source code. + +SDL is written in C, works natively with C++, and there are bindings +available for several other languages, including C# and Python. + +This library is distributed under the zlib license, which can be found +in the file "COPYING.txt". + +The best way to learn how to use SDL is to check out the header files in +the "include" subdirectory and the programs in the "test" subdirectory. +The header files and test programs are well commented and always up to date. + +More documentation and FAQs are available online at [the wiki](http://wiki.libsdl.org/) + +- [Android](README-android.md) +- [CMake](README-cmake.md) +- [DirectFB](README-directfb.md) +- [DynAPI](README-dynapi.md) +- [Emscripten](README-emscripten.md) +- [Gesture](README-gesture.md) +- [Mercurial](README-hg.md) +- [iOS](README-ios.md) +- [Linux](README-linux.md) +- [OS X](README-macosx.md) +- [Native Client](README-nacl.md) +- [Pandora](README-pandora.md) +- [Supported Platforms](README-platforms.md) +- [Porting information](README-porting.md) +- [PSP](README-psp.md) +- [Raspberry Pi](README-raspberrypi.md) +- [Touch](README-touch.md) +- [WinCE](README-wince.md) +- [Windows](README-windows.md) +- [WinRT](README-winrt.md) + +If you need help with the library, or just want to discuss SDL related +issues, you can join the [developers mailing list](http://www.libsdl.org/mailing-list.php) + +If you want to report bugs or contribute patches, please submit them to +[bugzilla](https://bugzilla.libsdl.org/) + +Enjoy! + + +Sam Lantinga + diff --git a/vendor/lite/winlib/SDL2-2.0.10/docs/doxyfile b/vendor/lite/winlib/SDL2-2.0.10/docs/doxyfile new file mode 100644 index 0000000..baf1c98 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/docs/doxyfile @@ -0,0 +1,1560 @@ +# Doxyfile 1.5.9 + +# This file describes the settings to be used by the documentation system +# doxygen (www.doxygen.org) for a project +# +# All text after a hash (#) is considered a comment and will be ignored +# The format is: +# TAG = value [value, ...] +# For lists items can also be appended using: +# TAG += value [value, ...] +# Values that contain spaces should be placed between quotes (" ") + +#--------------------------------------------------------------------------- +# Project related configuration options +#--------------------------------------------------------------------------- + +# This tag specifies the encoding used for all characters in the config file +# that follow. The default is UTF-8 which is also the encoding used for all +# text before the first occurrence of this tag. Doxygen uses libiconv (or the +# iconv built into libc) for the transcoding. See +# http://www.gnu.org/software/libiconv for the list of possible encodings. + +DOXYFILE_ENCODING = UTF-8 + +# The PROJECT_NAME tag is a single word (or a sequence of words surrounded +# by quotes) that should identify the project. + +PROJECT_NAME = SDL + +# The PROJECT_NUMBER tag can be used to enter a project or revision number. +# This could be handy for archiving the generated documentation or +# if some version control system is used. + +PROJECT_NUMBER = 2.0 + +# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) +# base path where the generated documentation will be put. +# If a relative path is entered, it will be relative to the location +# where doxygen was started. If left blank the current directory will be used. + +OUTPUT_DIRECTORY = ./output + +# If the CREATE_SUBDIRS tag is set to YES, then doxygen will create +# 4096 sub-directories (in 2 levels) under the output directory of each output +# format and will distribute the generated files over these directories. +# Enabling this option can be useful when feeding doxygen a huge amount of +# source files, where putting all generated files in the same directory would +# otherwise cause performance problems for the file system. + +CREATE_SUBDIRS = YES + +# The OUTPUT_LANGUAGE tag is used to specify the language in which all +# documentation generated by doxygen is written. Doxygen will use this +# information to generate all constant output in the proper language. +# The default language is English, other supported languages are: +# Afrikaans, Arabic, Brazilian, Catalan, Chinese, Chinese-Traditional, +# Croatian, Czech, Danish, Dutch, Esperanto, Farsi, Finnish, French, German, +# Greek, Hungarian, Italian, Japanese, Japanese-en (Japanese with English +# messages), Korean, Korean-en, Lithuanian, Norwegian, Macedonian, Persian, +# Polish, Portuguese, Romanian, Russian, Serbian, Serbian-Cyrilic, Slovak, +# Slovene, Spanish, Swedish, Ukrainian, and Vietnamese. + +OUTPUT_LANGUAGE = English + +# If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will +# include brief member descriptions after the members that are listed in +# the file and class documentation (similar to JavaDoc). +# Set to NO to disable this. + +BRIEF_MEMBER_DESC = YES + +# If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend +# the brief description of a member or function before the detailed description. +# Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the +# brief descriptions will be completely suppressed. + +REPEAT_BRIEF = YES + +# This tag implements a quasi-intelligent brief description abbreviator +# that is used to form the text in various listings. Each string +# in this list, if found as the leading text of the brief description, will be +# stripped from the text and the result after processing the whole list, is +# used as the annotated text. Otherwise, the brief description is used as-is. +# If left blank, the following values are used ("$name" is automatically +# replaced with the name of the entity): "The $name class" "The $name widget" +# "The $name file" "is" "provides" "specifies" "contains" +# "represents" "a" "an" "the" + +ABBREVIATE_BRIEF = "The $name class" \ + "The $name widget" \ + "The $name file" \ + is \ + provides \ + specifies \ + contains \ + represents \ + a \ + an \ + the + +# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then +# Doxygen will generate a detailed section even if there is only a brief +# description. + +ALWAYS_DETAILED_SEC = YES + +# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all +# inherited members of a class in the documentation of that class as if those +# members were ordinary class members. Constructors, destructors and assignment +# operators of the base classes will not be shown. + +INLINE_INHERITED_MEMB = NO + +# If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full +# path before files name in the file list and in the header files. If set +# to NO the shortest path that makes the file name unique will be used. + +FULL_PATH_NAMES = YES + +# If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag +# can be used to strip a user-defined part of the path. Stripping is +# only done if one of the specified strings matches the left-hand part of +# the path. The tag can be used to show relative paths in the file list. +# If left blank the directory from which doxygen is run is used as the +# path to strip. + +STRIP_FROM_PATH = + +# The STRIP_FROM_INC_PATH tag can be used to strip a user-defined part of +# the path mentioned in the documentation of a class, which tells +# the reader which header file to include in order to use a class. +# If left blank only the name of the header file containing the class +# definition is used. Otherwise one should specify the include paths that +# are normally passed to the compiler using the -I flag. + +STRIP_FROM_INC_PATH = + +# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter +# (but less readable) file names. This can be useful is your file systems +# doesn't support long names like on DOS, Mac, or CD-ROM. + +SHORT_NAMES = NO + +# If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen +# will interpret the first line (until the first dot) of a JavaDoc-style +# comment as the brief description. If set to NO, the JavaDoc +# comments will behave just like regular Qt-style comments +# (thus requiring an explicit @brief command for a brief description.) + +JAVADOC_AUTOBRIEF = NO + +# If the QT_AUTOBRIEF tag is set to YES then Doxygen will +# interpret the first line (until the first dot) of a Qt-style +# comment as the brief description. If set to NO, the comments +# will behave just like regular Qt-style comments (thus requiring +# an explicit \brief command for a brief description.) + +QT_AUTOBRIEF = NO + +# The MULTILINE_CPP_IS_BRIEF tag can be set to YES to make Doxygen +# treat a multi-line C++ special comment block (i.e. a block of //! or /// +# comments) as a brief description. This used to be the default behaviour. +# The new default is to treat a multi-line C++ comment block as a detailed +# description. Set this tag to YES if you prefer the old behaviour instead. + +MULTILINE_CPP_IS_BRIEF = NO + +# If the INHERIT_DOCS tag is set to YES (the default) then an undocumented +# member inherits the documentation from any documented member that it +# re-implements. + +INHERIT_DOCS = YES + +# If the SEPARATE_MEMBER_PAGES tag is set to YES, then doxygen will produce +# a new page for each member. If set to NO, the documentation of a member will +# be part of the file/class/namespace that contains it. + +SEPARATE_MEMBER_PAGES = NO + +# The TAB_SIZE tag can be used to set the number of spaces in a tab. +# Doxygen uses this value to replace tabs by spaces in code fragments. + +TAB_SIZE = 8 + +# This tag can be used to specify a number of aliases that acts +# as commands in the documentation. An alias has the form "name=value". +# For example adding "sideeffect=\par Side Effects:\n" will allow you to +# put the command \sideeffect (or @sideeffect) in the documentation, which +# will result in a user-defined paragraph with heading "Side Effects:". +# You can put \n's in the value part of an alias to insert newlines. + +ALIASES = "defined=\"\def\"" \ + "discussion=\"\par Discussion:\n\"" + +# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C +# sources only. Doxygen will then generate output that is more tailored for C. +# For instance, some of the names that are used will be different. The list +# of all members will be omitted, etc. + +OPTIMIZE_OUTPUT_FOR_C = YES + +# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java +# sources only. Doxygen will then generate output that is more tailored for +# Java. For instance, namespaces will be presented as packages, qualified +# scopes will look different, etc. + +OPTIMIZE_OUTPUT_JAVA = NO + +# Set the OPTIMIZE_FOR_FORTRAN tag to YES if your project consists of Fortran +# sources only. Doxygen will then generate output that is more tailored for +# Fortran. + +OPTIMIZE_FOR_FORTRAN = NO + +# Set the OPTIMIZE_OUTPUT_VHDL tag to YES if your project consists of VHDL +# sources. Doxygen will then generate output that is tailored for +# VHDL. + +OPTIMIZE_OUTPUT_VHDL = NO + +# Doxygen selects the parser to use depending on the extension of the files it parses. +# With this tag you can assign which parser to use for a given extension. +# Doxygen has a built-in mapping, but you can override or extend it using this tag. +# The format is ext=language, where ext is a file extension, and language is one of +# the parsers supported by doxygen: IDL, Java, Javascript, C#, C, C++, D, PHP, +# Objective-C, Python, Fortran, VHDL, C, C++. For instance to make doxygen treat +# .inc files as Fortran files (default is PHP), and .f files as C (default is Fortran), +# use: inc=Fortran f=C. Note that for custom extensions you also need to set +# FILE_PATTERNS otherwise the files are not read by doxygen. + +EXTENSION_MAPPING = + +# If you use STL classes (i.e. std::string, std::vector, etc.) but do not want +# to include (a tag file for) the STL sources as input, then you should +# set this tag to YES in order to let doxygen match functions declarations and +# definitions whose arguments contain STL classes (e.g. func(std::string); v.s. +# func(std::string) {}). This also make the inheritance and collaboration +# diagrams that involve STL classes more complete and accurate. + +BUILTIN_STL_SUPPORT = YES + +# If you use Microsoft's C++/CLI language, you should set this option to YES to +# enable parsing support. + +CPP_CLI_SUPPORT = NO + +# Set the SIP_SUPPORT tag to YES if your project consists of sip sources only. +# Doxygen will parse them like normal C++ but will assume all classes use public +# instead of private inheritance when no explicit protection keyword is present. + +SIP_SUPPORT = NO + +# For Microsoft's IDL there are propget and propput attributes to indicate getter +# and setter methods for a property. Setting this option to YES (the default) +# will make doxygen to replace the get and set methods by a property in the +# documentation. This will only work if the methods are indeed getting or +# setting a simple type. If this is not the case, or you want to show the +# methods anyway, you should set this option to NO. + +IDL_PROPERTY_SUPPORT = YES + +# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC +# tag is set to YES, then doxygen will reuse the documentation of the first +# member in the group (if any) for the other members of the group. By default +# all members of a group must be documented explicitly. + +DISTRIBUTE_GROUP_DOC = NO + +# Set the SUBGROUPING tag to YES (the default) to allow class member groups of +# the same type (for instance a group of public functions) to be put as a +# subgroup of that type (e.g. under the Public Functions section). Set it to +# NO to prevent subgrouping. Alternatively, this can be done per class using +# the \nosubgrouping command. + +SUBGROUPING = YES + +# When TYPEDEF_HIDES_STRUCT is enabled, a typedef of a struct, union, or enum +# is documented as struct, union, or enum with the name of the typedef. So +# typedef struct TypeS {} TypeT, will appear in the documentation as a struct +# with name TypeT. When disabled the typedef will appear as a member of a file, +# namespace, or class. And the struct will be named TypeS. This can typically +# be useful for C code in case the coding convention dictates that all compound +# types are typedef'ed and only the typedef is referenced, never the tag name. + +TYPEDEF_HIDES_STRUCT = YES + +# The SYMBOL_CACHE_SIZE determines the size of the internal cache use to +# determine which symbols to keep in memory and which to flush to disk. +# When the cache is full, less often used symbols will be written to disk. +# For small to medium size projects (<1000 input files) the default value is +# probably good enough. For larger projects a too small cache size can cause +# doxygen to be busy swapping symbols to and from disk most of the time +# causing a significant performance penality. +# If the system has enough physical memory increasing the cache will improve the +# performance by keeping more symbols in memory. Note that the value works on +# a logarithmic scale so increasing the size by one will rougly double the +# memory usage. The cache size is given by this formula: +# 2^(16+SYMBOL_CACHE_SIZE). The valid range is 0..9, the default is 0, +# corresponding to a cache size of 2^16 = 65536 symbols + +SYMBOL_CACHE_SIZE = 0 + +#--------------------------------------------------------------------------- +# Build related configuration options +#--------------------------------------------------------------------------- + +# If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in +# documentation are documented, even if no documentation was available. +# Private class members and static file members will be hidden unless +# the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES + +EXTRACT_ALL = YES + +# If the EXTRACT_PRIVATE tag is set to YES all private members of a class +# will be included in the documentation. + +EXTRACT_PRIVATE = YES + +# If the EXTRACT_STATIC tag is set to YES all static members of a file +# will be included in the documentation. + +EXTRACT_STATIC = YES + +# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs) +# defined locally in source files will be included in the documentation. +# If set to NO only classes defined in header files are included. + +EXTRACT_LOCAL_CLASSES = YES + +# This flag is only useful for Objective-C code. When set to YES local +# methods, which are defined in the implementation section but not in +# the interface are included in the documentation. +# If set to NO (the default) only methods in the interface are included. + +EXTRACT_LOCAL_METHODS = YES + +# If this flag is set to YES, the members of anonymous namespaces will be +# extracted and appear in the documentation as a namespace called +# 'anonymous_namespace{file}', where file will be replaced with the base +# name of the file that contains the anonymous namespace. By default +# anonymous namespace are hidden. + +EXTRACT_ANON_NSPACES = YES + +# If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all +# undocumented members of documented classes, files or namespaces. +# If set to NO (the default) these members will be included in the +# various overviews, but no documentation section is generated. +# This option has no effect if EXTRACT_ALL is enabled. + +HIDE_UNDOC_MEMBERS = NO + +# If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all +# undocumented classes that are normally visible in the class hierarchy. +# If set to NO (the default) these classes will be included in the various +# overviews. This option has no effect if EXTRACT_ALL is enabled. + +HIDE_UNDOC_CLASSES = NO + +# If the HIDE_FRIEND_COMPOUNDS tag is set to YES, Doxygen will hide all +# friend (class|struct|union) declarations. +# If set to NO (the default) these declarations will be included in the +# documentation. + +HIDE_FRIEND_COMPOUNDS = NO + +# If the HIDE_IN_BODY_DOCS tag is set to YES, Doxygen will hide any +# documentation blocks found inside the body of a function. +# If set to NO (the default) these blocks will be appended to the +# function's detailed documentation block. + +HIDE_IN_BODY_DOCS = NO + +# The INTERNAL_DOCS tag determines if documentation +# that is typed after a \internal command is included. If the tag is set +# to NO (the default) then the documentation will be excluded. +# Set it to YES to include the internal documentation. + +INTERNAL_DOCS = YES + +# If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate +# file names in lower-case letters. If set to YES upper-case letters are also +# allowed. This is useful if you have classes or files whose names only differ +# in case and if your file system supports case sensitive file names. Windows +# and Mac users are advised to set this option to NO. + +CASE_SENSE_NAMES = NO + +# If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen +# will show members with their full class and namespace scopes in the +# documentation. If set to YES the scope will be hidden. + +HIDE_SCOPE_NAMES = NO + +# If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen +# will put a list of the files that are included by a file in the documentation +# of that file. + +SHOW_INCLUDE_FILES = YES + +# If the INLINE_INFO tag is set to YES (the default) then a tag [inline] +# is inserted in the documentation for inline members. + +INLINE_INFO = YES + +# If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen +# will sort the (detailed) documentation of file and class members +# alphabetically by member name. If set to NO the members will appear in +# declaration order. + +SORT_MEMBER_DOCS = YES + +# If the SORT_BRIEF_DOCS tag is set to YES then doxygen will sort the +# brief documentation of file, namespace and class members alphabetically +# by member name. If set to NO (the default) the members will appear in +# declaration order. + +SORT_BRIEF_DOCS = NO + +# If the SORT_GROUP_NAMES tag is set to YES then doxygen will sort the +# hierarchy of group names into alphabetical order. If set to NO (the default) +# the group names will appear in their defined order. + +SORT_GROUP_NAMES = NO + +# If the SORT_BY_SCOPE_NAME tag is set to YES, the class list will be +# sorted by fully-qualified names, including namespaces. If set to +# NO (the default), the class list will be sorted only by class name, +# not including the namespace part. +# Note: This option is not very useful if HIDE_SCOPE_NAMES is set to YES. +# Note: This option applies only to the class list, not to the +# alphabetical list. + +SORT_BY_SCOPE_NAME = NO + +# The GENERATE_TODOLIST tag can be used to enable (YES) or +# disable (NO) the todo list. This list is created by putting \todo +# commands in the documentation. + +GENERATE_TODOLIST = YES + +# The GENERATE_TESTLIST tag can be used to enable (YES) or +# disable (NO) the test list. This list is created by putting \test +# commands in the documentation. + +GENERATE_TESTLIST = YES + +# The GENERATE_BUGLIST tag can be used to enable (YES) or +# disable (NO) the bug list. This list is created by putting \bug +# commands in the documentation. + +GENERATE_BUGLIST = YES + +# The GENERATE_DEPRECATEDLIST tag can be used to enable (YES) or +# disable (NO) the deprecated list. This list is created by putting +# \deprecated commands in the documentation. + +GENERATE_DEPRECATEDLIST= YES + +# The ENABLED_SECTIONS tag can be used to enable conditional +# documentation sections, marked by \if sectionname ... \endif. + +ENABLED_SECTIONS = + +# The MAX_INITIALIZER_LINES tag determines the maximum number of lines +# the initial value of a variable or define consists of for it to appear in +# the documentation. If the initializer consists of more lines than specified +# here it will be hidden. Use a value of 0 to hide initializers completely. +# The appearance of the initializer of individual variables and defines in the +# documentation can be controlled using \showinitializer or \hideinitializer +# command in the documentation regardless of this setting. + +MAX_INITIALIZER_LINES = 30 + +# If the sources in your project are distributed over multiple directories +# then setting the SHOW_DIRECTORIES tag to YES will show the directory hierarchy +# in the documentation. The default is NO. + +SHOW_DIRECTORIES = YES + +# Set the SHOW_FILES tag to NO to disable the generation of the Files page. +# This will remove the Files entry from the Quick Index and from the +# Folder Tree View (if specified). The default is YES. + +SHOW_FILES = YES + +# Set the SHOW_NAMESPACES tag to NO to disable the generation of the +# Namespaces page. This will remove the Namespaces entry from the Quick Index +# and from the Folder Tree View (if specified). The default is YES. + +SHOW_NAMESPACES = YES + +# The FILE_VERSION_FILTER tag can be used to specify a program or script that +# doxygen should invoke to get the current version for each file (typically from +# the version control system). Doxygen will invoke the program by executing (via +# popen()) the command , where is the value of +# the FILE_VERSION_FILTER tag, and is the name of an input file +# provided by doxygen. Whatever the program writes to standard output +# is used as the file version. See the manual for examples. + +FILE_VERSION_FILTER = + +# The LAYOUT_FILE tag can be used to specify a layout file which will be parsed by +# doxygen. The layout file controls the global structure of the generated output files +# in an output format independent way. The create the layout file that represents +# doxygen's defaults, run doxygen with the -l option. You can optionally specify a +# file name after the option, if omitted DoxygenLayout.xml will be used as the name +# of the layout file. + +LAYOUT_FILE = + +#--------------------------------------------------------------------------- +# configuration options related to warning and progress messages +#--------------------------------------------------------------------------- + +# The QUIET tag can be used to turn on/off the messages that are generated +# by doxygen. Possible values are YES and NO. If left blank NO is used. + +QUIET = NO + +# The WARNINGS tag can be used to turn on/off the warning messages that are +# generated by doxygen. Possible values are YES and NO. If left blank +# NO is used. + +WARNINGS = YES + +# If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings +# for undocumented members. If EXTRACT_ALL is set to YES then this flag will +# automatically be disabled. + +WARN_IF_UNDOCUMENTED = YES + +# If WARN_IF_DOC_ERROR is set to YES, doxygen will generate warnings for +# potential errors in the documentation, such as not documenting some +# parameters in a documented function, or documenting parameters that +# don't exist or using markup commands wrongly. + +WARN_IF_DOC_ERROR = YES + +# This WARN_NO_PARAMDOC option can be abled to get warnings for +# functions that are documented, but have no documentation for their parameters +# or return value. If set to NO (the default) doxygen will only warn about +# wrong or incomplete parameter documentation, but not about the absence of +# documentation. + +WARN_NO_PARAMDOC = YES + +# The WARN_FORMAT tag determines the format of the warning messages that +# doxygen can produce. The string should contain the $file, $line, and $text +# tags, which will be replaced by the file and line number from which the +# warning originated and the warning text. Optionally the format may contain +# $version, which will be replaced by the version of the file (if it could +# be obtained via FILE_VERSION_FILTER) + +WARN_FORMAT = "$file:$line: $text" + +# The WARN_LOGFILE tag can be used to specify a file to which warning +# and error messages should be written. If left blank the output is written +# to stderr. + +WARN_LOGFILE = ./doxygen_warn.txt + +#--------------------------------------------------------------------------- +# configuration options related to the input files +#--------------------------------------------------------------------------- + +# The INPUT tag can be used to specify the files and/or directories that contain +# documented source files. You may enter file names like "myfile.cpp" or +# directories like "/usr/src/myproject". Separate the files or directories +# with spaces. + +INPUT = . ../include + +# This tag can be used to specify the character encoding of the source files +# that doxygen parses. Internally doxygen uses the UTF-8 encoding, which is +# also the default input encoding. Doxygen uses libiconv (or the iconv built +# into libc) for the transcoding. See http://www.gnu.org/software/libiconv for +# the list of possible encodings. + +INPUT_ENCODING = UTF-8 + +# If the value of the INPUT tag contains directories, you can use the +# FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp +# and *.h) to filter out the source-files in the directories. If left +# blank the following patterns are tested: +# *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx +# *.hpp *.h++ *.idl *.odl *.cs *.php *.php3 *.inc *.m *.mm *.py *.f90 + +FILE_PATTERNS = *.c \ + *.cc \ + *.cxx \ + *.cpp \ + *.c++ \ + *.d \ + *.java \ + *.ii \ + *.ixx \ + *.ipp \ + *.i++ \ + *.inl \ + *.h \ + *.hh \ + *.hxx \ + *.hpp \ + *.h++ \ + *.idl \ + *.odl \ + *.cs \ + *.php \ + *.php3 \ + *.inc \ + *.m \ + *.mm \ + *.dox \ + *.py \ + *.f90 \ + *.f \ + *.vhd \ + *.vhdl \ + *.h.in \ + *.h.default \ + *.md + +# The RECURSIVE tag can be used to turn specify whether or not subdirectories +# should be searched for input files as well. Possible values are YES and NO. +# If left blank NO is used. + +RECURSIVE = YES + +# The EXCLUDE tag can be used to specify files and/or directories that should +# excluded from the INPUT source files. This way you can easily exclude a +# subdirectory from a directory tree whose root is specified with the INPUT tag. + +EXCLUDE = ../include/SDL_opengles2_gl2ext.h \ + ../include/SDL_opengles2_gl2platform.h \ + ../include/SDL_opengles2_khrplatform.h \ + ../include/SDL_opengl_glext.h \ + ../include/SDL_opengles2_gl2.h \ + ../include/SDL_opengles2.h \ + ../include/SDL_opengles.h \ + ../include/SDL_opengl.h \ + ../include/SDL_egl.h \ + + +# The EXCLUDE_SYMLINKS tag can be used select whether or not files or +# directories that are symbolic links (a Unix filesystem feature) are excluded +# from the input. + +EXCLUDE_SYMLINKS = NO + +# If the value of the INPUT tag contains directories, you can use the +# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude +# certain files from those directories. Note that the wildcards are matched +# against the file with absolute path, so to exclude all test directories +# for example use the pattern */test/* + +EXCLUDE_PATTERNS = + +# The EXCLUDE_SYMBOLS tag can be used to specify one or more symbol names +# (namespaces, classes, functions, etc.) that should be excluded from the +# output. The symbol name can be a fully qualified name, a word, or if the +# wildcard * is used, a substring. Examples: ANamespace, AClass, +# AClass::ANamespace, ANamespace::*Test + +EXCLUDE_SYMBOLS = + +# The EXAMPLE_PATH tag can be used to specify one or more files or +# directories that contain example code fragments that are included (see +# the \include command). + +EXAMPLE_PATH = + +# If the value of the EXAMPLE_PATH tag contains directories, you can use the +# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp +# and *.h) to filter out the source-files in the directories. If left +# blank all files are included. + +EXAMPLE_PATTERNS = * + +# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be +# searched for input files to be used with the \include or \dontinclude +# commands irrespective of the value of the RECURSIVE tag. +# Possible values are YES and NO. If left blank NO is used. + +EXAMPLE_RECURSIVE = YES + +# The IMAGE_PATH tag can be used to specify one or more files or +# directories that contain image that are included in the documentation (see +# the \image command). + +IMAGE_PATH = + +# The INPUT_FILTER tag can be used to specify a program that doxygen should +# invoke to filter for each input file. Doxygen will invoke the filter program +# by executing (via popen()) the command , where +# is the value of the INPUT_FILTER tag, and is the name of an +# input file. Doxygen will then use the output that the filter program writes +# to standard output. If FILTER_PATTERNS is specified, this tag will be +# ignored. + +INPUT_FILTER = + +# The FILTER_PATTERNS tag can be used to specify filters on a per file pattern +# basis. Doxygen will compare the file name with each pattern and apply the +# filter if there is a match. The filters are a list of the form: +# pattern=filter (like *.cpp=my_cpp_filter). See INPUT_FILTER for further +# info on how filters are used. If FILTER_PATTERNS is empty, INPUT_FILTER +# is applied to all files. + +FILTER_PATTERNS = + +# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using +# INPUT_FILTER) will be used to filter the input files when producing source +# files to browse (i.e. when SOURCE_BROWSER is set to YES). + +FILTER_SOURCE_FILES = NO + +#--------------------------------------------------------------------------- +# configuration options related to source browsing +#--------------------------------------------------------------------------- + +# If the SOURCE_BROWSER tag is set to YES then a list of source files will +# be generated. Documented entities will be cross-referenced with these sources. +# Note: To get rid of all source code in the generated output, make sure also +# VERBATIM_HEADERS is set to NO. + +SOURCE_BROWSER = YES + +# Setting the INLINE_SOURCES tag to YES will include the body +# of functions and classes directly in the documentation. + +INLINE_SOURCES = YES + +# Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct +# doxygen to hide any special comment blocks from generated source code +# fragments. Normal C and C++ comments will always remain visible. + +STRIP_CODE_COMMENTS = NO + +# If the REFERENCED_BY_RELATION tag is set to YES +# then for each documented function all documented +# functions referencing it will be listed. + +REFERENCED_BY_RELATION = YES + +# If the REFERENCES_RELATION tag is set to YES +# then for each documented function all documented entities +# called/used by that function will be listed. + +REFERENCES_RELATION = YES + +# If the REFERENCES_LINK_SOURCE tag is set to YES (the default) +# and SOURCE_BROWSER tag is set to YES, then the hyperlinks from +# functions in REFERENCES_RELATION and REFERENCED_BY_RELATION lists will +# link to the source code. Otherwise they will link to the documentation. + +REFERENCES_LINK_SOURCE = YES + +# If the USE_HTAGS tag is set to YES then the references to source code +# will point to the HTML generated by the htags(1) tool instead of doxygen +# built-in source browser. The htags tool is part of GNU's global source +# tagging system (see http://www.gnu.org/software/global/global.html). You +# will need version 4.8.6 or higher. + +USE_HTAGS = NO + +# If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen +# will generate a verbatim copy of the header file for each class for +# which an include is specified. Set to NO to disable this. + +VERBATIM_HEADERS = YES + +#--------------------------------------------------------------------------- +# configuration options related to the alphabetical class index +#--------------------------------------------------------------------------- + +# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index +# of all compounds will be generated. Enable this if the project +# contains a lot of classes, structs, unions or interfaces. + +ALPHABETICAL_INDEX = YES + +# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then +# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns +# in which this list will be split (can be a number in the range [1..20]) + +COLS_IN_ALPHA_INDEX = 5 + +# In case all classes in a project start with a common prefix, all +# classes will be put under the same header in the alphabetical index. +# The IGNORE_PREFIX tag can be used to specify one or more prefixes that +# should be ignored while generating the index headers. + +IGNORE_PREFIX = SDL_ \ + SDL + +#--------------------------------------------------------------------------- +# configuration options related to the HTML output +#--------------------------------------------------------------------------- + +# If the GENERATE_HTML tag is set to YES (the default) Doxygen will +# generate HTML output. + +GENERATE_HTML = YES + +# The HTML_OUTPUT tag is used to specify where the HTML docs will be put. +# If a relative path is entered the value of OUTPUT_DIRECTORY will be +# put in front of it. If left blank `html' will be used as the default path. + +HTML_OUTPUT = html + +# The HTML_FILE_EXTENSION tag can be used to specify the file extension for +# each generated HTML page (for example: .htm,.php,.asp). If it is left blank +# doxygen will generate files with .html extension. + +HTML_FILE_EXTENSION = .html + +# The HTML_HEADER tag can be used to specify a personal HTML header for +# each generated HTML page. If it is left blank doxygen will generate a +# standard header. + +HTML_HEADER = + +# The HTML_FOOTER tag can be used to specify a personal HTML footer for +# each generated HTML page. If it is left blank doxygen will generate a +# standard footer. + +HTML_FOOTER = + +# The HTML_STYLESHEET tag can be used to specify a user-defined cascading +# style sheet that is used by each HTML page. It can be used to +# fine-tune the look of the HTML output. If the tag is left blank doxygen +# will generate a default style sheet. Note that doxygen will try to copy +# the style sheet file to the HTML output directory, so don't put your own +# stylesheet in the HTML output directory as well, or it will be erased! + +HTML_STYLESHEET = + +# If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes, +# files or namespaces will be aligned in HTML using tables. If set to +# NO a bullet list will be used. + +HTML_ALIGN_MEMBERS = YES + +# If the HTML_DYNAMIC_SECTIONS tag is set to YES then the generated HTML +# documentation will contain sections that can be hidden and shown after the +# page has loaded. For this to work a browser that supports +# JavaScript and DHTML is required (for instance Mozilla 1.0+, Firefox +# Netscape 6.0+, Internet explorer 5.0+, Konqueror, or Safari). + +HTML_DYNAMIC_SECTIONS = YES + +# If the GENERATE_DOCSET tag is set to YES, additional index files +# will be generated that can be used as input for Apple's Xcode 3 +# integrated development environment, introduced with OSX 10.5 (Leopard). +# To create a documentation set, doxygen will generate a Makefile in the +# HTML output directory. Running make will produce the docset in that +# directory and running "make install" will install the docset in +# ~/Library/Developer/Shared/Documentation/DocSets so that Xcode will find +# it at startup. +# See http://developer.apple.com/tools/creatingdocsetswithdoxygen.html for more information. + +GENERATE_DOCSET = NO + +# When GENERATE_DOCSET tag is set to YES, this tag determines the name of the +# feed. A documentation feed provides an umbrella under which multiple +# documentation sets from a single provider (such as a company or product suite) +# can be grouped. + +DOCSET_FEEDNAME = "SDL 2.0 Doxygen" + +# When GENERATE_DOCSET tag is set to YES, this tag specifies a string that +# should uniquely identify the documentation set bundle. This should be a +# reverse domain-name style string, e.g. com.mycompany.MyDocSet. Doxygen +# will append .docset to the name. + +DOCSET_BUNDLE_ID = org.libsdl.sdl20 + +# If the GENERATE_HTMLHELP tag is set to YES, additional index files +# will be generated that can be used as input for tools like the +# Microsoft HTML help workshop to generate a compiled HTML help file (.chm) +# of the generated HTML documentation. + +GENERATE_HTMLHELP = NO + +# If the GENERATE_HTMLHELP tag is set to YES, the CHM_FILE tag can +# be used to specify the file name of the resulting .chm file. You +# can add a path in front of the file if the result should not be +# written to the html output directory. + +CHM_FILE = ./sdl20.chm + +# If the GENERATE_HTMLHELP tag is set to YES, the HHC_LOCATION tag can +# be used to specify the location (absolute path including file name) of +# the HTML help compiler (hhc.exe). If non-empty doxygen will try to run +# the HTML help compiler on the generated index.hhp. + +HHC_LOCATION = + +# If the GENERATE_HTMLHELP tag is set to YES, the GENERATE_CHI flag +# controls if a separate .chi index file is generated (YES) or that +# it should be included in the master .chm file (NO). + +GENERATE_CHI = NO + +# If the GENERATE_HTMLHELP tag is set to YES, the CHM_INDEX_ENCODING +# is used to encode HtmlHelp index (hhk), content (hhc) and project file +# content. + +CHM_INDEX_ENCODING = + +# If the GENERATE_HTMLHELP tag is set to YES, the BINARY_TOC flag +# controls whether a binary table of contents is generated (YES) or a +# normal table of contents (NO) in the .chm file. + +BINARY_TOC = NO + +# The TOC_EXPAND flag can be set to YES to add extra items for group members +# to the contents of the HTML help documentation and to the tree view. + +TOC_EXPAND = YES + +# If the GENERATE_QHP tag is set to YES and both QHP_NAMESPACE and QHP_VIRTUAL_FOLDER +# are set, an additional index file will be generated that can be used as input for +# Qt's qhelpgenerator to generate a Qt Compressed Help (.qch) of the generated +# HTML documentation. + +GENERATE_QHP = NO + +# If the QHG_LOCATION tag is specified, the QCH_FILE tag can +# be used to specify the file name of the resulting .qch file. +# The path specified is relative to the HTML output folder. + +QCH_FILE = + +# The QHP_NAMESPACE tag specifies the namespace to use when generating +# Qt Help Project output. For more information please see +# http://doc.trolltech.com/qthelpproject.html#namespace + +QHP_NAMESPACE = + +# The QHP_VIRTUAL_FOLDER tag specifies the namespace to use when generating +# Qt Help Project output. For more information please see +# http://doc.trolltech.com/qthelpproject.html#virtual-folders + +QHP_VIRTUAL_FOLDER = doc + +# If QHP_CUST_FILTER_NAME is set, it specifies the name of a custom filter to add. +# For more information please see +# http://doc.trolltech.com/qthelpproject.html#custom-filters + +QHP_CUST_FILTER_NAME = + +# The QHP_CUST_FILT_ATTRS tag specifies the list of the attributes of the custom filter to add.For more information please see +# Qt Help Project / Custom Filters. + +QHP_CUST_FILTER_ATTRS = + +# The QHP_SECT_FILTER_ATTRS tag specifies the list of the attributes this project's +# filter section matches. +# Qt Help Project / Filter Attributes. + +QHP_SECT_FILTER_ATTRS = + +# If the GENERATE_QHP tag is set to YES, the QHG_LOCATION tag can +# be used to specify the location of Qt's qhelpgenerator. +# If non-empty doxygen will try to run qhelpgenerator on the generated +# .qhp file. + +QHG_LOCATION = + +# The DISABLE_INDEX tag can be used to turn on/off the condensed index at +# top of each HTML page. The value NO (the default) enables the index and +# the value YES disables it. + +DISABLE_INDEX = NO + +# This tag can be used to set the number of enum values (range [1..20]) +# that doxygen will group on one line in the generated HTML documentation. + +ENUM_VALUES_PER_LINE = 1 + +# The GENERATE_TREEVIEW tag is used to specify whether a tree-like index +# structure should be generated to display hierarchical information. +# If the tag value is set to FRAME, a side panel will be generated +# containing a tree-like index structure (just like the one that +# is generated for HTML Help). For this to work a browser that supports +# JavaScript, DHTML, CSS and frames is required (for instance Mozilla 1.0+, +# Netscape 6.0+, Internet explorer 5.0+, or Konqueror). Windows users are +# probably better off using the HTML help feature. Other possible values +# for this tag are: HIERARCHIES, which will generate the Groups, Directories, +# and Class Hierarchy pages using a tree view instead of an ordered list; +# ALL, which combines the behavior of FRAME and HIERARCHIES; and NONE, which +# disables this behavior completely. For backwards compatibility with previous +# releases of Doxygen, the values YES and NO are equivalent to FRAME and NONE +# respectively. + +GENERATE_TREEVIEW = ALL + +# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be +# used to set the initial width (in pixels) of the frame in which the tree +# is shown. + +TREEVIEW_WIDTH = 250 + +# Use this tag to change the font size of Latex formulas included +# as images in the HTML documentation. The default is 10. Note that +# when you change the font size after a successful doxygen run you need +# to manually remove any form_*.png images from the HTML output directory +# to force them to be regenerated. + +FORMULA_FONTSIZE = 10 + +#--------------------------------------------------------------------------- +# configuration options related to the LaTeX output +#--------------------------------------------------------------------------- + +# If the GENERATE_LATEX tag is set to YES (the default) Doxygen will +# generate Latex output. + +GENERATE_LATEX = NO + +# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put. +# If a relative path is entered the value of OUTPUT_DIRECTORY will be +# put in front of it. If left blank `latex' will be used as the default path. + +LATEX_OUTPUT = latex + +# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be +# invoked. If left blank `latex' will be used as the default command name. + +LATEX_CMD_NAME = latex + +# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to +# generate index for LaTeX. If left blank `makeindex' will be used as the +# default command name. + +MAKEINDEX_CMD_NAME = makeindex + +# If the COMPACT_LATEX tag is set to YES Doxygen generates more compact +# LaTeX documents. This may be useful for small projects and may help to +# save some trees in general. + +COMPACT_LATEX = NO + +# The PAPER_TYPE tag can be used to set the paper type that is used +# by the printer. Possible values are: a4, a4wide, letter, legal and +# executive. If left blank a4wide will be used. + +PAPER_TYPE = a4wide + +# The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX +# packages that should be included in the LaTeX output. + +EXTRA_PACKAGES = + +# The LATEX_HEADER tag can be used to specify a personal LaTeX header for +# the generated latex document. The header should contain everything until +# the first chapter. If it is left blank doxygen will generate a +# standard header. Notice: only use this tag if you know what you are doing! + +LATEX_HEADER = + +# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated +# is prepared for conversion to pdf (using ps2pdf). The pdf file will +# contain links (just like the HTML output) instead of page references +# This makes the output suitable for online browsing using a pdf viewer. + +PDF_HYPERLINKS = YES + +# If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of +# plain latex in the generated Makefile. Set this option to YES to get a +# higher quality PDF documentation. + +USE_PDFLATEX = YES + +# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode. +# command to the generated LaTeX files. This will instruct LaTeX to keep +# running if errors occur, instead of asking the user for help. +# This option is also used when generating formulas in HTML. + +LATEX_BATCHMODE = NO + +# If LATEX_HIDE_INDICES is set to YES then doxygen will not +# include the index chapters (such as File Index, Compound Index, etc.) +# in the output. + +LATEX_HIDE_INDICES = NO + +# If LATEX_SOURCE_CODE is set to YES then doxygen will include +# source code with syntax highlighting in the LaTeX output. +# Note that which sources are shown also depends on other settings +# such as SOURCE_BROWSER. + +LATEX_SOURCE_CODE = NO + +#--------------------------------------------------------------------------- +# configuration options related to the RTF output +#--------------------------------------------------------------------------- + +# If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output +# The RTF output is optimized for Word 97 and may not look very pretty with +# other RTF readers or editors. + +GENERATE_RTF = NO + +# The RTF_OUTPUT tag is used to specify where the RTF docs will be put. +# If a relative path is entered the value of OUTPUT_DIRECTORY will be +# put in front of it. If left blank `rtf' will be used as the default path. + +RTF_OUTPUT = rtf + +# If the COMPACT_RTF tag is set to YES Doxygen generates more compact +# RTF documents. This may be useful for small projects and may help to +# save some trees in general. + +COMPACT_RTF = NO + +# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated +# will contain hyperlink fields. The RTF file will +# contain links (just like the HTML output) instead of page references. +# This makes the output suitable for online browsing using WORD or other +# programs which support those fields. +# Note: wordpad (write) and others do not support links. + +RTF_HYPERLINKS = NO + +# Load stylesheet definitions from file. Syntax is similar to doxygen's +# config file, i.e. a series of assignments. You only have to provide +# replacements, missing definitions are set to their default value. + +RTF_STYLESHEET_FILE = + +# Set optional variables used in the generation of an rtf document. +# Syntax is similar to doxygen's config file. + +RTF_EXTENSIONS_FILE = + +#--------------------------------------------------------------------------- +# configuration options related to the man page output +#--------------------------------------------------------------------------- + +# If the GENERATE_MAN tag is set to YES (the default) Doxygen will +# generate man pages + +GENERATE_MAN = NO + +# The MAN_OUTPUT tag is used to specify where the man pages will be put. +# If a relative path is entered the value of OUTPUT_DIRECTORY will be +# put in front of it. If left blank `man' will be used as the default path. + +MAN_OUTPUT = man + +# The MAN_EXTENSION tag determines the extension that is added to +# the generated man pages (default is the subroutine's section .3) + +MAN_EXTENSION = .3 + +# If the MAN_LINKS tag is set to YES and Doxygen generates man output, +# then it will generate one additional man file for each entity +# documented in the real man page(s). These additional files +# only source the real man page, but without them the man command +# would be unable to find the correct page. The default is NO. + +MAN_LINKS = NO + +#--------------------------------------------------------------------------- +# configuration options related to the XML output +#--------------------------------------------------------------------------- + +# If the GENERATE_XML tag is set to YES Doxygen will +# generate an XML file that captures the structure of +# the code including all documentation. + +GENERATE_XML = NO + +# The XML_OUTPUT tag is used to specify where the XML pages will be put. +# If a relative path is entered the value of OUTPUT_DIRECTORY will be +# put in front of it. If left blank `xml' will be used as the default path. + +XML_OUTPUT = xml + +# The XML_SCHEMA tag can be used to specify an XML schema, +# which can be used by a validating XML parser to check the +# syntax of the XML files. + +XML_SCHEMA = + +# The XML_DTD tag can be used to specify an XML DTD, +# which can be used by a validating XML parser to check the +# syntax of the XML files. + +XML_DTD = + +# If the XML_PROGRAMLISTING tag is set to YES Doxygen will +# dump the program listings (including syntax highlighting +# and cross-referencing information) to the XML output. Note that +# enabling this will significantly increase the size of the XML output. + +XML_PROGRAMLISTING = YES + +#--------------------------------------------------------------------------- +# configuration options for the AutoGen Definitions output +#--------------------------------------------------------------------------- + +# If the GENERATE_AUTOGEN_DEF tag is set to YES Doxygen will +# generate an AutoGen Definitions (see autogen.sf.net) file +# that captures the structure of the code including all +# documentation. Note that this feature is still experimental +# and incomplete at the moment. + +GENERATE_AUTOGEN_DEF = NO + +#--------------------------------------------------------------------------- +# configuration options related to the Perl module output +#--------------------------------------------------------------------------- + +# If the GENERATE_PERLMOD tag is set to YES Doxygen will +# generate a Perl module file that captures the structure of +# the code including all documentation. Note that this +# feature is still experimental and incomplete at the +# moment. + +GENERATE_PERLMOD = NO + +# If the PERLMOD_LATEX tag is set to YES Doxygen will generate +# the necessary Makefile rules, Perl scripts and LaTeX code to be able +# to generate PDF and DVI output from the Perl module output. + +PERLMOD_LATEX = NO + +# If the PERLMOD_PRETTY tag is set to YES the Perl module output will be +# nicely formatted so it can be parsed by a human reader. This is useful +# if you want to understand what is going on. On the other hand, if this +# tag is set to NO the size of the Perl module output will be much smaller +# and Perl will parse it just the same. + +PERLMOD_PRETTY = YES + +# The names of the make variables in the generated doxyrules.make file +# are prefixed with the string contained in PERLMOD_MAKEVAR_PREFIX. +# This is useful so different doxyrules.make files included by the same +# Makefile don't overwrite each other's variables. + +PERLMOD_MAKEVAR_PREFIX = + +#--------------------------------------------------------------------------- +# Configuration options related to the preprocessor +#--------------------------------------------------------------------------- + +# If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will +# evaluate all C-preprocessor directives found in the sources and include +# files. + +ENABLE_PREPROCESSING = YES + +# If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro +# names in the source code. If set to NO (the default) only conditional +# compilation will be performed. Macro expansion can be done in a controlled +# way by setting EXPAND_ONLY_PREDEF to YES. + +MACRO_EXPANSION = YES + +# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES +# then the macro expansion is limited to the macros specified with the +# PREDEFINED and EXPAND_AS_DEFINED tags. + +EXPAND_ONLY_PREDEF = YES + +# If the SEARCH_INCLUDES tag is set to YES (the default) the includes files +# in the INCLUDE_PATH (see below) will be search if a #include is found. + +SEARCH_INCLUDES = YES + +# The INCLUDE_PATH tag can be used to specify one or more directories that +# contain include files that are not input files but should be processed by +# the preprocessor. + +INCLUDE_PATH = + +# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard +# patterns (like *.h and *.hpp) to filter out the header-files in the +# directories. If left blank, the patterns specified with FILE_PATTERNS will +# be used. + +INCLUDE_FILE_PATTERNS = + +# The PREDEFINED tag can be used to specify one or more macro names that +# are defined before the preprocessor is started (similar to the -D option of +# gcc). The argument of the tag is a list of macros of the form: name +# or name=definition (no spaces). If the definition and the = are +# omitted =1 is assumed. To prevent a macro definition from being +# undefined via #undef or recursively expanded use the := operator +# instead of the = operator. + +PREDEFINED = DOXYGEN_SHOULD_IGNORE_THIS=1 \ + DECLSPEC= \ + SDLCALL= \ + _WIN32=1 + +# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then +# this tag can be used to specify a list of macro names that should be expanded. +# The macro definition that is found in the sources will be used. +# Use the PREDEFINED tag if you want to use a different macro definition. + +EXPAND_AS_DEFINED = + +# If the SKIP_FUNCTION_MACROS tag is set to YES (the default) then +# doxygen's preprocessor will remove all function-like macros that are alone +# on a line, have an all uppercase name, and do not end with a semicolon. Such +# function macros are typically used for boiler-plate code, and will confuse +# the parser if not removed. + +SKIP_FUNCTION_MACROS = YES + +#--------------------------------------------------------------------------- +# Configuration::additions related to external references +#--------------------------------------------------------------------------- + +# The TAGFILES option can be used to specify one or more tagfiles. +# Optionally an initial location of the external documentation +# can be added for each tagfile. The format of a tag file without +# this location is as follows: +# TAGFILES = file1 file2 ... +# Adding location for the tag files is done as follows: +# TAGFILES = file1=loc1 "file2 = loc2" ... +# where "loc1" and "loc2" can be relative or absolute paths or +# URLs. If a location is present for each tag, the installdox tool +# does not have to be run to correct the links. +# Note that each tag file must have a unique name +# (where the name does NOT include the path) +# If a tag file is not located in the directory in which doxygen +# is run, you must also specify the path to the tagfile here. + +TAGFILES = + +# When a file name is specified after GENERATE_TAGFILE, doxygen will create +# a tag file that is based on the input files it reads. + +GENERATE_TAGFILE = ./SDL.tag + +# If the ALLEXTERNALS tag is set to YES all external classes will be listed +# in the class index. If set to NO only the inherited external classes +# will be listed. + +ALLEXTERNALS = NO + +# If the EXTERNAL_GROUPS tag is set to YES all external groups will be listed +# in the modules index. If set to NO, only the current project's groups will +# be listed. + +EXTERNAL_GROUPS = YES + +# The PERL_PATH should be the absolute path and name of the perl script +# interpreter (i.e. the result of `which perl'). + +PERL_PATH = c:\Perl\bin\perl.exe + +#--------------------------------------------------------------------------- +# Configuration options related to the dot tool +#--------------------------------------------------------------------------- + +# If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will +# generate a inheritance diagram (in HTML, RTF and LaTeX) for classes with base +# or super classes. Setting the tag to NO turns the diagrams off. Note that +# this option is superseded by the HAVE_DOT option below. This is only a +# fallback. It is recommended to install and use dot, since it yields more +# powerful graphs. + +CLASS_DIAGRAMS = YES + +# You can define message sequence charts within doxygen comments using the \msc +# command. Doxygen will then run the mscgen tool (see +# http://www.mcternan.me.uk/mscgen/) to produce the chart and insert it in the +# documentation. The MSCGEN_PATH tag allows you to specify the directory where +# the mscgen tool resides. If left empty the tool is assumed to be found in the +# default search path. + +MSCGEN_PATH = + +# If set to YES, the inheritance and collaboration graphs will hide +# inheritance and usage relations if the target is undocumented +# or is not a class. + +HIDE_UNDOC_RELATIONS = YES + +# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is +# available from the path. This tool is part of Graphviz, a graph visualization +# toolkit from AT&T and Lucent Bell Labs. The other options in this section +# have no effect if this option is set to NO (the default) + +HAVE_DOT = YES + +# By default doxygen will write a font called FreeSans.ttf to the output +# directory and reference it in all dot files that doxygen generates. This +# font does not include all possible unicode characters however, so when you need +# these (or just want a differently looking font) you can specify the font name +# using DOT_FONTNAME. You need need to make sure dot is able to find the font, +# which can be done by putting it in a standard location or by setting the +# DOTFONTPATH environment variable or by setting DOT_FONTPATH to the directory +# containing the font. + +DOT_FONTNAME = FreeSans + +# The DOT_FONTSIZE tag can be used to set the size of the font of dot graphs. +# The default size is 10pt. + +DOT_FONTSIZE = 10 + +# By default doxygen will tell dot to use the output directory to look for the +# FreeSans.ttf font (which doxygen will put there itself). If you specify a +# different font using DOT_FONTNAME you can set the path where dot +# can find it using this tag. + +DOT_FONTPATH = + +# If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen +# will generate a graph for each documented class showing the direct and +# indirect inheritance relations. Setting this tag to YES will force the +# the CLASS_DIAGRAMS tag to NO. + +CLASS_GRAPH = YES + +# If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen +# will generate a graph for each documented class showing the direct and +# indirect implementation dependencies (inheritance, containment, and +# class references variables) of the class with other documented classes. + +COLLABORATION_GRAPH = YES + +# If the GROUP_GRAPHS and HAVE_DOT tags are set to YES then doxygen +# will generate a graph for groups, showing the direct groups dependencies + +GROUP_GRAPHS = YES + +# If the UML_LOOK tag is set to YES doxygen will generate inheritance and +# collaboration diagrams in a style similar to the OMG's Unified Modeling +# Language. + +UML_LOOK = NO + +# If set to YES, the inheritance and collaboration graphs will show the +# relations between templates and their instances. + +TEMPLATE_RELATIONS = YES + +# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDE_GRAPH, and HAVE_DOT +# tags are set to YES then doxygen will generate a graph for each documented +# file showing the direct and indirect include dependencies of the file with +# other documented files. + +INCLUDE_GRAPH = YES + +# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDED_BY_GRAPH, and +# HAVE_DOT tags are set to YES then doxygen will generate a graph for each +# documented header file showing the documented files that directly or +# indirectly include this file. + +INCLUDED_BY_GRAPH = YES + +# If the CALL_GRAPH and HAVE_DOT options are set to YES then +# doxygen will generate a call dependency graph for every global function +# or class method. Note that enabling this option will significantly increase +# the time of a run. So in most cases it will be better to enable call graphs +# for selected functions only using the \callgraph command. + +CALL_GRAPH = NO + +# If the CALLER_GRAPH and HAVE_DOT tags are set to YES then +# doxygen will generate a caller dependency graph for every global function +# or class method. Note that enabling this option will significantly increase +# the time of a run. So in most cases it will be better to enable caller +# graphs for selected functions only using the \callergraph command. + +CALLER_GRAPH = NO + +# If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen +# will graphical hierarchy of all classes instead of a textual one. + +GRAPHICAL_HIERARCHY = YES + +# If the DIRECTORY_GRAPH, SHOW_DIRECTORIES and HAVE_DOT tags are set to YES +# then doxygen will show the dependencies a directory has on other directories +# in a graphical way. The dependency relations are determined by the #include +# relations between the files in the directories. + +DIRECTORY_GRAPH = YES + +# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images +# generated by dot. Possible values are png, jpg, or gif +# If left blank png will be used. + +DOT_IMAGE_FORMAT = png + +# The tag DOT_PATH can be used to specify the path where the dot tool can be +# found. If left blank, it is assumed the dot tool can be found in the path. + +DOT_PATH = + +# The DOTFILE_DIRS tag can be used to specify one or more directories that +# contain dot files that are included in the documentation (see the +# \dotfile command). + +DOTFILE_DIRS = + +# The DOT_GRAPH_MAX_NODES tag can be used to set the maximum number of +# nodes that will be shown in the graph. If the number of nodes in a graph +# becomes larger than this value, doxygen will truncate the graph, which is +# visualized by representing a node as a red box. Note that doxygen if the +# number of direct children of the root node in a graph is already larger than +# DOT_GRAPH_MAX_NODES then the graph will not be shown at all. Also note +# that the size of a graph can be further restricted by MAX_DOT_GRAPH_DEPTH. + +DOT_GRAPH_MAX_NODES = 60 + +# The MAX_DOT_GRAPH_DEPTH tag can be used to set the maximum depth of the +# graphs generated by dot. A depth value of 3 means that only nodes reachable +# from the root by following a path via at most 3 edges will be shown. Nodes +# that lay further from the root node will be omitted. Note that setting this +# option to 1 or 2 may greatly reduce the computation time needed for large +# code bases. Also note that the size of a graph can be further restricted by +# DOT_GRAPH_MAX_NODES. Using a depth of 0 means no depth restriction. + +MAX_DOT_GRAPH_DEPTH = 2 + +# Set the DOT_TRANSPARENT tag to YES to generate images with a transparent +# background. This is disabled by default, because dot on Windows does not +# seem to support this out of the box. Warning: Depending on the platform used, +# enabling this option may lead to badly anti-aliased labels on the edges of +# a graph (i.e. they become hard to read). + +DOT_TRANSPARENT = NO + +# Set the DOT_MULTI_TARGETS tag to YES allow dot to generate multiple output +# files in one run (i.e. multiple -o and -T options on the command line). This +# makes dot run faster, but since only newer versions of dot (>1.8.10) +# support this, this feature is disabled by default. + +DOT_MULTI_TARGETS = YES + +# If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will +# generate a legend page explaining the meaning of the various boxes and +# arrows in the dot generated graphs. + +GENERATE_LEGEND = YES + +# If the DOT_CLEANUP tag is set to YES (the default) Doxygen will +# remove the intermediate dot files that are used to generate +# the various graphs. + +DOT_CLEANUP = YES + +#--------------------------------------------------------------------------- +# Options related to the search engine +#--------------------------------------------------------------------------- + +# The SEARCHENGINE tag specifies whether or not a search engine should be +# used. If set to NO the values of all tags below this one will be ignored. + +SEARCHENGINE = NO diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/SDL2.dll b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/bin/SDL2.dll new file mode 100755 index 0000000000000000000000000000000000000000..3673be1aba7d2e2ce36eddb13c6fdd525bceb5ac GIT binary patch literal 1156096 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

+ * + * + * + * + * + *
data mask resulting pixel on screen
0 1 White
1 1 Black
0 0 Transparent
1 0 Inverted color if possible, black + * if not.
+ * + * \sa SDL_FreeCursor() + */ +extern DECLSPEC SDL_Cursor *SDLCALL SDL_CreateCursor(const Uint8 * data, + const Uint8 * mask, + int w, int h, int hot_x, + int hot_y); + +/** + * \brief Create a color cursor. + * + * \sa SDL_FreeCursor() + */ +extern DECLSPEC SDL_Cursor *SDLCALL SDL_CreateColorCursor(SDL_Surface *surface, + int hot_x, + int hot_y); + +/** + * \brief Create a system cursor. + * + * \sa SDL_FreeCursor() + */ +extern DECLSPEC SDL_Cursor *SDLCALL SDL_CreateSystemCursor(SDL_SystemCursor id); + +/** + * \brief Set the active cursor. + */ +extern DECLSPEC void SDLCALL SDL_SetCursor(SDL_Cursor * cursor); + +/** + * \brief Return the active cursor. + */ +extern DECLSPEC SDL_Cursor *SDLCALL SDL_GetCursor(void); + +/** + * \brief Return the default cursor. + */ +extern DECLSPEC SDL_Cursor *SDLCALL SDL_GetDefaultCursor(void); + +/** + * \brief Frees a cursor created with SDL_CreateCursor() or similar functions. + * + * \sa SDL_CreateCursor() + * \sa SDL_CreateColorCursor() + * \sa SDL_CreateSystemCursor() + */ +extern DECLSPEC void SDLCALL SDL_FreeCursor(SDL_Cursor * cursor); + +/** + * \brief Toggle whether or not the cursor is shown. + * + * \param toggle 1 to show the cursor, 0 to hide it, -1 to query the current + * state. + * + * \return 1 if the cursor is shown, or 0 if the cursor is hidden. + */ +extern DECLSPEC int SDLCALL SDL_ShowCursor(int toggle); + +/** + * Used as a mask when testing buttons in buttonstate. + * - Button 1: Left mouse button + * - Button 2: Middle mouse button + * - Button 3: Right mouse button + */ +#define SDL_BUTTON(X) (1 << ((X)-1)) +#define SDL_BUTTON_LEFT 1 +#define SDL_BUTTON_MIDDLE 2 +#define SDL_BUTTON_RIGHT 3 +#define SDL_BUTTON_X1 4 +#define SDL_BUTTON_X2 5 +#define SDL_BUTTON_LMASK SDL_BUTTON(SDL_BUTTON_LEFT) +#define SDL_BUTTON_MMASK SDL_BUTTON(SDL_BUTTON_MIDDLE) +#define SDL_BUTTON_RMASK SDL_BUTTON(SDL_BUTTON_RIGHT) +#define SDL_BUTTON_X1MASK SDL_BUTTON(SDL_BUTTON_X1) +#define SDL_BUTTON_X2MASK SDL_BUTTON(SDL_BUTTON_X2) + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_mouse_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mutex.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mutex.h new file mode 100644 index 0000000..970e787 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_mutex.h @@ -0,0 +1,251 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_mutex_h_ +#define SDL_mutex_h_ + +/** + * \file SDL_mutex.h + * + * Functions to provide thread synchronization primitives. + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * Synchronization functions which can time out return this value + * if they time out. + */ +#define SDL_MUTEX_TIMEDOUT 1 + +/** + * This is the timeout value which corresponds to never time out. + */ +#define SDL_MUTEX_MAXWAIT (~(Uint32)0) + + +/** + * \name Mutex functions + */ +/* @{ */ + +/* The SDL mutex structure, defined in SDL_sysmutex.c */ +struct SDL_mutex; +typedef struct SDL_mutex SDL_mutex; + +/** + * Create a mutex, initialized unlocked. + */ +extern DECLSPEC SDL_mutex *SDLCALL SDL_CreateMutex(void); + +/** + * Lock the mutex. + * + * \return 0, or -1 on error. + */ +#define SDL_mutexP(m) SDL_LockMutex(m) +extern DECLSPEC int SDLCALL SDL_LockMutex(SDL_mutex * mutex); + +/** + * Try to lock the mutex + * + * \return 0, SDL_MUTEX_TIMEDOUT, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_TryLockMutex(SDL_mutex * mutex); + +/** + * Unlock the mutex. + * + * \return 0, or -1 on error. + * + * \warning It is an error to unlock a mutex that has not been locked by + * the current thread, and doing so results in undefined behavior. + */ +#define SDL_mutexV(m) SDL_UnlockMutex(m) +extern DECLSPEC int SDLCALL SDL_UnlockMutex(SDL_mutex * mutex); + +/** + * Destroy a mutex. + */ +extern DECLSPEC void SDLCALL SDL_DestroyMutex(SDL_mutex * mutex); + +/* @} *//* Mutex functions */ + + +/** + * \name Semaphore functions + */ +/* @{ */ + +/* The SDL semaphore structure, defined in SDL_syssem.c */ +struct SDL_semaphore; +typedef struct SDL_semaphore SDL_sem; + +/** + * Create a semaphore, initialized with value, returns NULL on failure. + */ +extern DECLSPEC SDL_sem *SDLCALL SDL_CreateSemaphore(Uint32 initial_value); + +/** + * Destroy a semaphore. + */ +extern DECLSPEC void SDLCALL SDL_DestroySemaphore(SDL_sem * sem); + +/** + * This function suspends the calling thread until the semaphore pointed + * to by \c sem has a positive count. It then atomically decreases the + * semaphore count. + */ +extern DECLSPEC int SDLCALL SDL_SemWait(SDL_sem * sem); + +/** + * Non-blocking variant of SDL_SemWait(). + * + * \return 0 if the wait succeeds, ::SDL_MUTEX_TIMEDOUT if the wait would + * block, and -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_SemTryWait(SDL_sem * sem); + +/** + * Variant of SDL_SemWait() with a timeout in milliseconds. + * + * \return 0 if the wait succeeds, ::SDL_MUTEX_TIMEDOUT if the wait does not + * succeed in the allotted time, and -1 on error. + * + * \warning On some platforms this function is implemented by looping with a + * delay of 1 ms, and so should be avoided if possible. + */ +extern DECLSPEC int SDLCALL SDL_SemWaitTimeout(SDL_sem * sem, Uint32 ms); + +/** + * Atomically increases the semaphore's count (not blocking). + * + * \return 0, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_SemPost(SDL_sem * sem); + +/** + * Returns the current count of the semaphore. + */ +extern DECLSPEC Uint32 SDLCALL SDL_SemValue(SDL_sem * sem); + +/* @} *//* Semaphore functions */ + + +/** + * \name Condition variable functions + */ +/* @{ */ + +/* The SDL condition variable structure, defined in SDL_syscond.c */ +struct SDL_cond; +typedef struct SDL_cond SDL_cond; + +/** + * Create a condition variable. + * + * Typical use of condition variables: + * + * Thread A: + * SDL_LockMutex(lock); + * while ( ! condition ) { + * SDL_CondWait(cond, lock); + * } + * SDL_UnlockMutex(lock); + * + * Thread B: + * SDL_LockMutex(lock); + * ... + * condition = true; + * ... + * SDL_CondSignal(cond); + * SDL_UnlockMutex(lock); + * + * There is some discussion whether to signal the condition variable + * with the mutex locked or not. There is some potential performance + * benefit to unlocking first on some platforms, but there are some + * potential race conditions depending on how your code is structured. + * + * In general it's safer to signal the condition variable while the + * mutex is locked. + */ +extern DECLSPEC SDL_cond *SDLCALL SDL_CreateCond(void); + +/** + * Destroy a condition variable. + */ +extern DECLSPEC void SDLCALL SDL_DestroyCond(SDL_cond * cond); + +/** + * Restart one of the threads that are waiting on the condition variable. + * + * \return 0 or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondSignal(SDL_cond * cond); + +/** + * Restart all threads that are waiting on the condition variable. + * + * \return 0 or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondBroadcast(SDL_cond * cond); + +/** + * Wait on the condition variable, unlocking the provided mutex. + * + * \warning The mutex must be locked before entering this function! + * + * The mutex is re-locked once the condition variable is signaled. + * + * \return 0 when it is signaled, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_CondWait(SDL_cond * cond, SDL_mutex * mutex); + +/** + * Waits for at most \c ms milliseconds, and returns 0 if the condition + * variable is signaled, ::SDL_MUTEX_TIMEDOUT if the condition is not + * signaled in the allotted time, and -1 on error. + * + * \warning On some platforms this function is implemented by looping with a + * delay of 1 ms, and so should be avoided if possible. + */ +extern DECLSPEC int SDLCALL SDL_CondWaitTimeout(SDL_cond * cond, + SDL_mutex * mutex, Uint32 ms); + +/* @} *//* Condition variable functions */ + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_mutex_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_name.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_name.h new file mode 100644 index 0000000..690a819 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_name.h @@ -0,0 +1,33 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDLname_h_ +#define SDLname_h_ + +#if defined(__STDC__) || defined(__cplusplus) +#define NeedFunctionPrototypes 1 +#endif + +#define SDL_NAME(X) SDL_##X + +#endif /* SDLname_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl.h new file mode 100644 index 0000000..6685be7 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl.h @@ -0,0 +1,2183 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_opengl.h + * + * This is a simple file to encapsulate the OpenGL API headers. + */ + +/** + * \def NO_SDL_GLEXT + * + * Define this if you have your own version of glext.h and want to disable the + * version included in SDL_opengl.h. + */ + +#ifndef SDL_opengl_h_ +#define SDL_opengl_h_ + +#include "SDL_config.h" + +#ifndef __IPHONEOS__ /* No OpenGL on iOS. */ + +/* + * Mesa 3-D graphics library + * + * Copyright (C) 1999-2006 Brian Paul All Rights Reserved. + * Copyright (C) 2009 VMware, Inc. 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 + * 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. + */ + + +#ifndef __gl_h_ +#define __gl_h_ + +#if defined(USE_MGL_NAMESPACE) +#include "gl_mangle.h" +#endif + + +/********************************************************************** + * Begin system-specific stuff. + */ + +#if defined(_WIN32) && !defined(__WIN32__) && !defined(__CYGWIN__) +#define __WIN32__ +#endif + +#if defined(__WIN32__) && !defined(__CYGWIN__) +# if (defined(_MSC_VER) || defined(__MINGW32__)) && defined(BUILD_GL32) /* tag specify we're building mesa as a DLL */ +# define GLAPI __declspec(dllexport) +# elif (defined(_MSC_VER) || defined(__MINGW32__)) && defined(_DLL) /* tag specifying we're building for DLL runtime support */ +# define GLAPI __declspec(dllimport) +# else /* for use with static link lib build of Win32 edition only */ +# define GLAPI extern +# endif /* _STATIC_MESA support */ +# if defined(__MINGW32__) && defined(GL_NO_STDCALL) || defined(UNDER_CE) /* The generated DLLs by MingW with STDCALL are not compatible with the ones done by Microsoft's compilers */ +# define GLAPIENTRY +# else +# define GLAPIENTRY __stdcall +# endif +#elif defined(__CYGWIN__) && defined(USE_OPENGL32) /* use native windows opengl32 */ +# define GLAPI extern +# define GLAPIENTRY __stdcall +#elif defined(__OS2__) || defined(__EMX__) /* native os/2 opengl */ +# define GLAPI extern +# define GLAPIENTRY _System +# define APIENTRY _System +# if defined(__GNUC__) && !defined(_System) +# define _System +# endif +#elif (defined(__GNUC__) && __GNUC__ >= 4) || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)) +# define GLAPI __attribute__((visibility("default"))) +# define GLAPIENTRY +#endif /* WIN32 && !CYGWIN */ + +/* + * WINDOWS: Include windows.h here to define APIENTRY. + * It is also useful when applications include this file by + * including only glut.h, since glut.h depends on windows.h. + * Applications needing to include windows.h with parms other + * than "WIN32_LEAN_AND_MEAN" may include windows.h before + * glut.h or gl.h. + */ +#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN 1 +#endif +#ifndef NOMINMAX /* don't define min() and max(). */ +#define NOMINMAX +#endif +#include +#endif + +#ifndef GLAPI +#define GLAPI extern +#endif + +#ifndef GLAPIENTRY +#define GLAPIENTRY +#endif + +#ifndef APIENTRY +#define APIENTRY GLAPIENTRY +#endif + +/* "P" suffix to be used for a pointer to a function */ +#ifndef APIENTRYP +#define APIENTRYP APIENTRY * +#endif + +#ifndef GLAPIENTRYP +#define GLAPIENTRYP GLAPIENTRY * +#endif + +#if defined(PRAGMA_EXPORT_SUPPORTED) +#pragma export on +#endif + +/* + * End system-specific stuff. + **********************************************************************/ + + + +#ifdef __cplusplus +extern "C" { +#endif + + + +#define GL_VERSION_1_1 1 +#define GL_VERSION_1_2 1 +#define GL_VERSION_1_3 1 +#define GL_ARB_imaging 1 + + +/* + * Datatypes + */ +typedef unsigned int GLenum; +typedef unsigned char GLboolean; +typedef unsigned int GLbitfield; +typedef void GLvoid; +typedef signed char GLbyte; /* 1-byte signed */ +typedef short GLshort; /* 2-byte signed */ +typedef int GLint; /* 4-byte signed */ +typedef unsigned char GLubyte; /* 1-byte unsigned */ +typedef unsigned short GLushort; /* 2-byte unsigned */ +typedef unsigned int GLuint; /* 4-byte unsigned */ +typedef int GLsizei; /* 4-byte signed */ +typedef float GLfloat; /* single precision float */ +typedef float GLclampf; /* single precision float in [0,1] */ +typedef double GLdouble; /* double precision float */ +typedef double GLclampd; /* double precision float in [0,1] */ + + + +/* + * Constants + */ + +/* Boolean values */ +#define GL_FALSE 0 +#define GL_TRUE 1 + +/* Data types */ +#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 + +/* Primitives */ +#define GL_POINTS 0x0000 +#define GL_LINES 0x0001 +#define GL_LINE_LOOP 0x0002 +#define GL_LINE_STRIP 0x0003 +#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 0x0009 + +/* Vertex Arrays */ +#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_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 + +/* Matrix Mode */ +#define GL_MATRIX_MODE 0x0BA0 +#define GL_MODELVIEW 0x1700 +#define GL_PROJECTION 0x1701 +#define GL_TEXTURE 0x1702 + +/* Points */ +#define GL_POINT_SMOOTH 0x0B10 +#define GL_POINT_SIZE 0x0B11 +#define GL_POINT_SIZE_GRANULARITY 0x0B13 +#define GL_POINT_SIZE_RANGE 0x0B12 + +/* Lines */ +#define GL_LINE_SMOOTH 0x0B20 +#define GL_LINE_STIPPLE 0x0B24 +#define GL_LINE_STIPPLE_PATTERN 0x0B25 +#define GL_LINE_STIPPLE_REPEAT 0x0B26 +#define GL_LINE_WIDTH 0x0B21 +#define GL_LINE_WIDTH_GRANULARITY 0x0B23 +#define GL_LINE_WIDTH_RANGE 0x0B22 + +/* Polygons */ +#define GL_POINT 0x1B00 +#define GL_LINE 0x1B01 +#define GL_FILL 0x1B02 +#define GL_CW 0x0900 +#define GL_CCW 0x0901 +#define GL_FRONT 0x0404 +#define GL_BACK 0x0405 +#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_POLYGON_OFFSET_FACTOR 0x8038 +#define GL_POLYGON_OFFSET_UNITS 0x2A00 +#define GL_POLYGON_OFFSET_POINT 0x2A01 +#define GL_POLYGON_OFFSET_LINE 0x2A02 +#define GL_POLYGON_OFFSET_FILL 0x8037 + +/* Display Lists */ +#define GL_COMPILE 0x1300 +#define GL_COMPILE_AND_EXECUTE 0x1301 +#define GL_LIST_BASE 0x0B32 +#define GL_LIST_INDEX 0x0B33 +#define GL_LIST_MODE 0x0B30 + +/* Depth buffer */ +#define GL_NEVER 0x0200 +#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_DEPTH_TEST 0x0B71 +#define GL_DEPTH_BITS 0x0D56 +#define GL_DEPTH_CLEAR_VALUE 0x0B73 +#define GL_DEPTH_FUNC 0x0B74 +#define GL_DEPTH_RANGE 0x0B70 +#define GL_DEPTH_WRITEMASK 0x0B72 +#define GL_DEPTH_COMPONENT 0x1902 + +/* Lighting */ +#define GL_LIGHTING 0x0B50 +#define GL_LIGHT0 0x4000 +#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_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_AMBIENT 0x1200 +#define GL_DIFFUSE 0x1201 +#define GL_SPECULAR 0x1202 +#define GL_SHININESS 0x1601 +#define GL_EMISSION 0x1600 +#define GL_POSITION 0x1203 +#define GL_SPOT_DIRECTION 0x1204 +#define GL_AMBIENT_AND_DIFFUSE 0x1602 +#define GL_COLOR_INDEXES 0x1603 +#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52 +#define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51 +#define GL_LIGHT_MODEL_AMBIENT 0x0B53 +#define GL_FRONT_AND_BACK 0x0408 +#define GL_SHADE_MODEL 0x0B54 +#define GL_FLAT 0x1D00 +#define GL_SMOOTH 0x1D01 +#define GL_COLOR_MATERIAL 0x0B57 +#define GL_COLOR_MATERIAL_FACE 0x0B55 +#define GL_COLOR_MATERIAL_PARAMETER 0x0B56 +#define GL_NORMALIZE 0x0BA1 + +/* User clipping planes */ +#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 + +/* Accumulation buffer */ +#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_ACCUM_CLEAR_VALUE 0x0B80 +#define GL_ACCUM 0x0100 +#define GL_ADD 0x0104 +#define GL_LOAD 0x0101 +#define GL_MULT 0x0103 +#define GL_RETURN 0x0102 + +/* Alpha testing */ +#define GL_ALPHA_TEST 0x0BC0 +#define GL_ALPHA_TEST_REF 0x0BC2 +#define GL_ALPHA_TEST_FUNC 0x0BC1 + +/* Blending */ +#define GL_BLEND 0x0BE2 +#define GL_BLEND_SRC 0x0BE1 +#define GL_BLEND_DST 0x0BE0 +#define GL_ZERO 0 +#define GL_ONE 1 +#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 + +/* Render Mode */ +#define GL_FEEDBACK 0x1C01 +#define GL_RENDER 0x1C00 +#define GL_SELECT 0x1C02 + +/* Feedback */ +#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_POINT_TOKEN 0x0701 +#define GL_LINE_TOKEN 0x0702 +#define GL_LINE_RESET_TOKEN 0x0707 +#define GL_POLYGON_TOKEN 0x0703 +#define GL_BITMAP_TOKEN 0x0704 +#define GL_DRAW_PIXEL_TOKEN 0x0705 +#define GL_COPY_PIXEL_TOKEN 0x0706 +#define GL_PASS_THROUGH_TOKEN 0x0700 +#define GL_FEEDBACK_BUFFER_POINTER 0x0DF0 +#define GL_FEEDBACK_BUFFER_SIZE 0x0DF1 +#define GL_FEEDBACK_BUFFER_TYPE 0x0DF2 + +/* Selection */ +#define GL_SELECTION_BUFFER_POINTER 0x0DF3 +#define GL_SELECTION_BUFFER_SIZE 0x0DF4 + +/* Fog */ +#define GL_FOG 0x0B60 +#define GL_FOG_MODE 0x0B65 +#define GL_FOG_DENSITY 0x0B62 +#define GL_FOG_COLOR 0x0B66 +#define GL_FOG_INDEX 0x0B61 +#define GL_FOG_START 0x0B63 +#define GL_FOG_END 0x0B64 +#define GL_LINEAR 0x2601 +#define GL_EXP 0x0800 +#define GL_EXP2 0x0801 + +/* Logic Ops */ +#define GL_LOGIC_OP 0x0BF1 +#define GL_INDEX_LOGIC_OP 0x0BF1 +#define GL_COLOR_LOGIC_OP 0x0BF2 +#define GL_LOGIC_OP_MODE 0x0BF0 +#define GL_CLEAR 0x1500 +#define GL_SET 0x150F +#define GL_COPY 0x1503 +#define GL_COPY_INVERTED 0x150C +#define GL_NOOP 0x1505 +#define GL_INVERT 0x150A +#define GL_AND 0x1501 +#define GL_NAND 0x150E +#define GL_OR 0x1507 +#define GL_NOR 0x1508 +#define GL_XOR 0x1506 +#define GL_EQUIV 0x1509 +#define GL_AND_REVERSE 0x1502 +#define GL_AND_INVERTED 0x1504 +#define GL_OR_REVERSE 0x150B +#define GL_OR_INVERTED 0x150D + +/* Stencil */ +#define GL_STENCIL_BITS 0x0D57 +#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_STENCIL_INDEX 0x1901 +#define GL_KEEP 0x1E00 +#define GL_REPLACE 0x1E01 +#define GL_INCR 0x1E02 +#define GL_DECR 0x1E03 + +/* Buffers, Pixel Drawing/Reading */ +#define GL_NONE 0 +#define GL_LEFT 0x0406 +#define GL_RIGHT 0x0407 +/*GL_FRONT 0x0404 */ +/*GL_BACK 0x0405 */ +/*GL_FRONT_AND_BACK 0x0408 */ +#define GL_FRONT_LEFT 0x0400 +#define GL_FRONT_RIGHT 0x0401 +#define GL_BACK_LEFT 0x0402 +#define GL_BACK_RIGHT 0x0403 +#define GL_AUX0 0x0409 +#define GL_AUX1 0x040A +#define GL_AUX2 0x040B +#define GL_AUX3 0x040C +#define GL_COLOR_INDEX 0x1900 +#define GL_RED 0x1903 +#define GL_GREEN 0x1904 +#define GL_BLUE 0x1905 +#define GL_ALPHA 0x1906 +#define GL_LUMINANCE 0x1909 +#define GL_LUMINANCE_ALPHA 0x190A +#define GL_ALPHA_BITS 0x0D55 +#define GL_RED_BITS 0x0D52 +#define GL_GREEN_BITS 0x0D53 +#define GL_BLUE_BITS 0x0D54 +#define GL_INDEX_BITS 0x0D51 +#define GL_SUBPIXEL_BITS 0x0D50 +#define GL_AUX_BUFFERS 0x0C00 +#define GL_READ_BUFFER 0x0C02 +#define GL_DRAW_BUFFER 0x0C01 +#define GL_DOUBLEBUFFER 0x0C32 +#define GL_STEREO 0x0C33 +#define GL_BITMAP 0x1A00 +#define GL_COLOR 0x1800 +#define GL_DEPTH 0x1801 +#define GL_STENCIL 0x1802 +#define GL_DITHER 0x0BD0 +#define GL_RGB 0x1907 +#define GL_RGBA 0x1908 + +/* Implementation limits */ +#define GL_MAX_LIST_NESTING 0x0B31 +#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 + +/* Gets */ +#define GL_ATTRIB_STACK_DEPTH 0x0BB0 +#define GL_CLIENT_ATTRIB_STACK_DEPTH 0x0BB1 +#define GL_COLOR_CLEAR_VALUE 0x0C22 +#define GL_COLOR_WRITEMASK 0x0C23 +#define GL_CURRENT_INDEX 0x0B01 +#define GL_CURRENT_COLOR 0x0B00 +#define GL_CURRENT_NORMAL 0x0B02 +#define GL_CURRENT_RASTER_COLOR 0x0B04 +#define GL_CURRENT_RASTER_DISTANCE 0x0B09 +#define GL_CURRENT_RASTER_INDEX 0x0B05 +#define GL_CURRENT_RASTER_POSITION 0x0B07 +#define GL_CURRENT_RASTER_TEXTURE_COORDS 0x0B06 +#define GL_CURRENT_RASTER_POSITION_VALID 0x0B08 +#define GL_CURRENT_TEXTURE_COORDS 0x0B03 +#define GL_INDEX_CLEAR_VALUE 0x0C20 +#define GL_INDEX_MODE 0x0C30 +#define GL_INDEX_WRITEMASK 0x0C21 +#define GL_MODELVIEW_MATRIX 0x0BA6 +#define GL_MODELVIEW_STACK_DEPTH 0x0BA3 +#define GL_NAME_STACK_DEPTH 0x0D70 +#define GL_PROJECTION_MATRIX 0x0BA7 +#define GL_PROJECTION_STACK_DEPTH 0x0BA4 +#define GL_RENDER_MODE 0x0C40 +#define GL_RGBA_MODE 0x0C31 +#define GL_TEXTURE_MATRIX 0x0BA8 +#define GL_TEXTURE_STACK_DEPTH 0x0BA5 +#define GL_VIEWPORT 0x0BA2 + +/* Evaluators */ +#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_COEFF 0x0A00 +#define GL_ORDER 0x0A01 +#define GL_DOMAIN 0x0A02 + +/* Hints */ +#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_DONT_CARE 0x1100 +#define GL_FASTEST 0x1101 +#define GL_NICEST 0x1102 + +/* Scissor box */ +#define GL_SCISSOR_BOX 0x0C10 +#define GL_SCISSOR_TEST 0x0C11 + +/* Pixel Mode / Transfer */ +#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_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_PIXEL_MAP_S_TO_S_SIZE 0x0CB1 +#define GL_PIXEL_MAP_I_TO_I_SIZE 0x0CB0 +#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_PIXEL_MAP_S_TO_S 0x0C71 +#define GL_PIXEL_MAP_I_TO_I 0x0C70 +#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_PACK_ALIGNMENT 0x0D05 +#define GL_PACK_LSB_FIRST 0x0D01 +#define GL_PACK_ROW_LENGTH 0x0D02 +#define GL_PACK_SKIP_PIXELS 0x0D04 +#define GL_PACK_SKIP_ROWS 0x0D03 +#define GL_PACK_SWAP_BYTES 0x0D00 +#define GL_UNPACK_ALIGNMENT 0x0CF5 +#define GL_UNPACK_LSB_FIRST 0x0CF1 +#define GL_UNPACK_ROW_LENGTH 0x0CF2 +#define GL_UNPACK_SKIP_PIXELS 0x0CF4 +#define GL_UNPACK_SKIP_ROWS 0x0CF3 +#define GL_UNPACK_SWAP_BYTES 0x0CF0 +#define GL_ZOOM_X 0x0D16 +#define GL_ZOOM_Y 0x0D17 + +/* Texture mapping */ +#define GL_TEXTURE_ENV 0x2300 +#define GL_TEXTURE_ENV_MODE 0x2200 +#define GL_TEXTURE_1D 0x0DE0 +#define GL_TEXTURE_2D 0x0DE1 +#define GL_TEXTURE_WRAP_S 0x2802 +#define GL_TEXTURE_WRAP_T 0x2803 +#define GL_TEXTURE_MAG_FILTER 0x2800 +#define GL_TEXTURE_MIN_FILTER 0x2801 +#define GL_TEXTURE_ENV_COLOR 0x2201 +#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_TEXTURE_GEN_MODE 0x2500 +#define GL_TEXTURE_BORDER_COLOR 0x1004 +#define GL_TEXTURE_WIDTH 0x1000 +#define GL_TEXTURE_HEIGHT 0x1001 +#define GL_TEXTURE_BORDER 0x1005 +#define GL_TEXTURE_COMPONENTS 0x1003 +#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_NEAREST_MIPMAP_NEAREST 0x2700 +#define GL_NEAREST_MIPMAP_LINEAR 0x2702 +#define GL_LINEAR_MIPMAP_NEAREST 0x2701 +#define GL_LINEAR_MIPMAP_LINEAR 0x2703 +#define GL_OBJECT_LINEAR 0x2401 +#define GL_OBJECT_PLANE 0x2501 +#define GL_EYE_LINEAR 0x2400 +#define GL_EYE_PLANE 0x2502 +#define GL_SPHERE_MAP 0x2402 +#define GL_DECAL 0x2101 +#define GL_MODULATE 0x2100 +#define GL_NEAREST 0x2600 +#define GL_REPEAT 0x2901 +#define GL_CLAMP 0x2900 +#define GL_S 0x2000 +#define GL_T 0x2001 +#define GL_R 0x2002 +#define GL_Q 0x2003 + +/* Utility */ +#define GL_VENDOR 0x1F00 +#define GL_RENDERER 0x1F01 +#define GL_VERSION 0x1F02 +#define GL_EXTENSIONS 0x1F03 + +/* Errors */ +#define GL_NO_ERROR 0 +#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 + +/* glPush/PopAttrib bits */ +#define GL_CURRENT_BIT 0x00000001 +#define GL_POINT_BIT 0x00000002 +#define GL_LINE_BIT 0x00000004 +#define GL_POLYGON_BIT 0x00000008 +#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_BUFFER_BIT 0x00000200 +#define GL_STENCIL_BUFFER_BIT 0x00000400 +#define GL_VIEWPORT_BIT 0x00000800 +#define GL_TRANSFORM_BIT 0x00001000 +#define GL_ENABLE_BIT 0x00002000 +#define GL_COLOR_BUFFER_BIT 0x00004000 +#define GL_HINT_BIT 0x00008000 +#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 + + +/* OpenGL 1.1 */ +#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_TEXTURE_INTERNAL_FORMAT 0x1003 +#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_R3_G3_B2 0x2A10 +#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_CLIENT_PIXEL_STORE_BIT 0x00000001 +#define GL_CLIENT_VERTEX_ARRAY_BIT 0x00000002 +#define GL_ALL_CLIENT_ATTRIB_BITS 0xFFFFFFFF +#define GL_CLIENT_ALL_ATTRIB_BITS 0xFFFFFFFF + + + +/* + * Miscellaneous + */ + +GLAPI void GLAPIENTRY glClearIndex( GLfloat c ); + +GLAPI void GLAPIENTRY glClearColor( GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha ); + +GLAPI void GLAPIENTRY glClear( GLbitfield mask ); + +GLAPI void GLAPIENTRY glIndexMask( GLuint mask ); + +GLAPI void GLAPIENTRY glColorMask( GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha ); + +GLAPI void GLAPIENTRY glAlphaFunc( GLenum func, GLclampf ref ); + +GLAPI void GLAPIENTRY glBlendFunc( GLenum sfactor, GLenum dfactor ); + +GLAPI void GLAPIENTRY glLogicOp( GLenum opcode ); + +GLAPI void GLAPIENTRY glCullFace( GLenum mode ); + +GLAPI void GLAPIENTRY glFrontFace( GLenum mode ); + +GLAPI void GLAPIENTRY glPointSize( GLfloat size ); + +GLAPI void GLAPIENTRY glLineWidth( GLfloat width ); + +GLAPI void GLAPIENTRY glLineStipple( GLint factor, GLushort pattern ); + +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 glGetPolygonStipple( GLubyte *mask ); + +GLAPI void GLAPIENTRY glEdgeFlag( GLboolean flag ); + +GLAPI void GLAPIENTRY glEdgeFlagv( const GLboolean *flag ); + +GLAPI void GLAPIENTRY glScissor( GLint x, GLint y, GLsizei width, GLsizei height); + +GLAPI void GLAPIENTRY glClipPlane( GLenum plane, const GLdouble *equation ); + +GLAPI void GLAPIENTRY glGetClipPlane( GLenum plane, GLdouble *equation ); + +GLAPI void GLAPIENTRY glDrawBuffer( GLenum mode ); + +GLAPI void GLAPIENTRY glReadBuffer( GLenum mode ); + +GLAPI void GLAPIENTRY glEnable( GLenum cap ); + +GLAPI void GLAPIENTRY glDisable( GLenum cap ); + +GLAPI GLboolean GLAPIENTRY glIsEnabled( GLenum cap ); + + +GLAPI void GLAPIENTRY glEnableClientState( GLenum cap ); /* 1.1 */ + +GLAPI void GLAPIENTRY glDisableClientState( GLenum cap ); /* 1.1 */ + + +GLAPI void GLAPIENTRY glGetBooleanv( GLenum pname, GLboolean *params ); + +GLAPI void GLAPIENTRY glGetDoublev( GLenum pname, GLdouble *params ); + +GLAPI void GLAPIENTRY glGetFloatv( GLenum pname, GLfloat *params ); + +GLAPI void GLAPIENTRY glGetIntegerv( GLenum pname, GLint *params ); + + +GLAPI void GLAPIENTRY glPushAttrib( GLbitfield mask ); + +GLAPI void GLAPIENTRY glPopAttrib( void ); + + +GLAPI void GLAPIENTRY glPushClientAttrib( GLbitfield mask ); /* 1.1 */ + +GLAPI void GLAPIENTRY glPopClientAttrib( void ); /* 1.1 */ + + +GLAPI GLint GLAPIENTRY glRenderMode( GLenum mode ); + +GLAPI GLenum GLAPIENTRY glGetError( void ); + +GLAPI const GLubyte * GLAPIENTRY glGetString( GLenum name ); + +GLAPI void GLAPIENTRY glFinish( void ); + +GLAPI void GLAPIENTRY glFlush( void ); + +GLAPI void GLAPIENTRY glHint( GLenum target, GLenum mode ); + + +/* + * Depth Buffer + */ + +GLAPI void GLAPIENTRY glClearDepth( GLclampd depth ); + +GLAPI void GLAPIENTRY glDepthFunc( GLenum func ); + +GLAPI void GLAPIENTRY glDepthMask( GLboolean flag ); + +GLAPI void GLAPIENTRY glDepthRange( GLclampd near_val, GLclampd far_val ); + + +/* + * Accumulation Buffer + */ + +GLAPI void GLAPIENTRY glClearAccum( GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha ); + +GLAPI void GLAPIENTRY glAccum( GLenum op, GLfloat value ); + + +/* + * Transformation + */ + +GLAPI void GLAPIENTRY glMatrixMode( GLenum mode ); + +GLAPI void GLAPIENTRY glOrtho( GLdouble left, GLdouble right, + GLdouble bottom, GLdouble top, + GLdouble near_val, GLdouble far_val ); + +GLAPI void GLAPIENTRY glFrustum( GLdouble left, GLdouble right, + GLdouble bottom, GLdouble top, + GLdouble near_val, GLdouble far_val ); + +GLAPI void GLAPIENTRY glViewport( GLint x, GLint y, + GLsizei width, GLsizei height ); + +GLAPI void GLAPIENTRY glPushMatrix( void ); + +GLAPI void GLAPIENTRY glPopMatrix( void ); + +GLAPI void GLAPIENTRY glLoadIdentity( void ); + +GLAPI void GLAPIENTRY glLoadMatrixd( const GLdouble *m ); +GLAPI void GLAPIENTRY glLoadMatrixf( const GLfloat *m ); + +GLAPI void GLAPIENTRY glMultMatrixd( const GLdouble *m ); +GLAPI void GLAPIENTRY glMultMatrixf( const GLfloat *m ); + +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 glTranslated( GLdouble x, GLdouble y, GLdouble z ); +GLAPI void GLAPIENTRY glTranslatef( GLfloat x, GLfloat y, GLfloat z ); + + +/* + * Display Lists + */ + +GLAPI GLboolean GLAPIENTRY glIsList( GLuint list ); + +GLAPI void GLAPIENTRY glDeleteLists( GLuint list, GLsizei range ); + +GLAPI GLuint GLAPIENTRY glGenLists( GLsizei range ); + +GLAPI void GLAPIENTRY glNewList( GLuint list, GLenum mode ); + +GLAPI void GLAPIENTRY glEndList( void ); + +GLAPI void GLAPIENTRY glCallList( GLuint list ); + +GLAPI void GLAPIENTRY glCallLists( GLsizei n, GLenum type, + const GLvoid *lists ); + +GLAPI void GLAPIENTRY glListBase( GLuint base ); + + +/* + * Drawing Functions + */ + +GLAPI void GLAPIENTRY glBegin( GLenum mode ); + +GLAPI void GLAPIENTRY glEnd( void ); + + +GLAPI void GLAPIENTRY glVertex2d( GLdouble x, GLdouble y ); +GLAPI void GLAPIENTRY glVertex2f( GLfloat x, GLfloat y ); +GLAPI void GLAPIENTRY glVertex2i( GLint x, GLint y ); +GLAPI void GLAPIENTRY glVertex2s( GLshort x, GLshort y ); + +GLAPI void GLAPIENTRY glVertex3d( GLdouble x, GLdouble y, GLdouble z ); +GLAPI void GLAPIENTRY glVertex3f( GLfloat x, GLfloat y, GLfloat z ); +GLAPI void GLAPIENTRY glVertex3i( GLint x, GLint y, GLint z ); +GLAPI void GLAPIENTRY glVertex3s( GLshort x, GLshort y, GLshort z ); + +GLAPI void GLAPIENTRY glVertex4d( GLdouble x, GLdouble y, GLdouble z, GLdouble w ); +GLAPI void GLAPIENTRY glVertex4f( GLfloat x, GLfloat y, GLfloat z, GLfloat w ); +GLAPI void GLAPIENTRY glVertex4i( GLint x, GLint y, GLint z, GLint w ); +GLAPI void GLAPIENTRY glVertex4s( GLshort x, GLshort y, GLshort z, GLshort w ); + +GLAPI void GLAPIENTRY glVertex2dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glVertex2fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glVertex2iv( const GLint *v ); +GLAPI void GLAPIENTRY glVertex2sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glVertex3dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glVertex3fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glVertex3iv( const GLint *v ); +GLAPI void GLAPIENTRY glVertex3sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glVertex4dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glVertex4fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glVertex4iv( const GLint *v ); +GLAPI void GLAPIENTRY glVertex4sv( const GLshort *v ); + + +GLAPI void GLAPIENTRY glNormal3b( GLbyte nx, GLbyte ny, GLbyte nz ); +GLAPI void GLAPIENTRY glNormal3d( GLdouble nx, GLdouble ny, GLdouble nz ); +GLAPI void GLAPIENTRY glNormal3f( GLfloat nx, GLfloat ny, GLfloat nz ); +GLAPI void GLAPIENTRY glNormal3i( GLint nx, GLint ny, GLint nz ); +GLAPI void GLAPIENTRY glNormal3s( GLshort nx, GLshort ny, GLshort nz ); + +GLAPI void GLAPIENTRY glNormal3bv( const GLbyte *v ); +GLAPI void GLAPIENTRY glNormal3dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glNormal3fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glNormal3iv( const GLint *v ); +GLAPI void GLAPIENTRY glNormal3sv( const GLshort *v ); + + +GLAPI void GLAPIENTRY glIndexd( GLdouble c ); +GLAPI void GLAPIENTRY glIndexf( GLfloat c ); +GLAPI void GLAPIENTRY glIndexi( GLint c ); +GLAPI void GLAPIENTRY glIndexs( GLshort c ); +GLAPI void GLAPIENTRY glIndexub( GLubyte c ); /* 1.1 */ + +GLAPI void GLAPIENTRY glIndexdv( const GLdouble *c ); +GLAPI void GLAPIENTRY glIndexfv( const GLfloat *c ); +GLAPI void GLAPIENTRY glIndexiv( const GLint *c ); +GLAPI void GLAPIENTRY glIndexsv( const GLshort *c ); +GLAPI void GLAPIENTRY glIndexubv( const GLubyte *c ); /* 1.1 */ + +GLAPI void GLAPIENTRY glColor3b( GLbyte red, GLbyte green, GLbyte blue ); +GLAPI void GLAPIENTRY glColor3d( GLdouble red, GLdouble green, GLdouble blue ); +GLAPI void GLAPIENTRY glColor3f( GLfloat red, GLfloat green, GLfloat blue ); +GLAPI void GLAPIENTRY glColor3i( GLint red, GLint green, GLint blue ); +GLAPI void GLAPIENTRY glColor3s( GLshort red, GLshort green, GLshort blue ); +GLAPI void GLAPIENTRY glColor3ub( GLubyte red, GLubyte green, GLubyte blue ); +GLAPI void GLAPIENTRY glColor3ui( GLuint red, GLuint green, GLuint blue ); +GLAPI void GLAPIENTRY glColor3us( GLushort red, GLushort green, GLushort blue ); + +GLAPI void GLAPIENTRY glColor4b( GLbyte red, GLbyte green, + GLbyte blue, GLbyte alpha ); +GLAPI void GLAPIENTRY glColor4d( GLdouble red, GLdouble green, + GLdouble blue, GLdouble alpha ); +GLAPI void GLAPIENTRY glColor4f( GLfloat red, GLfloat green, + GLfloat blue, GLfloat alpha ); +GLAPI void GLAPIENTRY glColor4i( GLint red, GLint green, + GLint blue, GLint alpha ); +GLAPI void GLAPIENTRY glColor4s( GLshort red, GLshort green, + GLshort blue, GLshort alpha ); +GLAPI void GLAPIENTRY glColor4ub( GLubyte red, GLubyte green, + GLubyte blue, GLubyte alpha ); +GLAPI void GLAPIENTRY glColor4ui( GLuint red, GLuint green, + GLuint blue, GLuint alpha ); +GLAPI void GLAPIENTRY glColor4us( GLushort red, GLushort green, + GLushort blue, GLushort alpha ); + + +GLAPI void GLAPIENTRY glColor3bv( const GLbyte *v ); +GLAPI void GLAPIENTRY glColor3dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glColor3fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glColor3iv( const GLint *v ); +GLAPI void GLAPIENTRY glColor3sv( const GLshort *v ); +GLAPI void GLAPIENTRY glColor3ubv( const GLubyte *v ); +GLAPI void GLAPIENTRY glColor3uiv( const GLuint *v ); +GLAPI void GLAPIENTRY glColor3usv( const GLushort *v ); + +GLAPI void GLAPIENTRY glColor4bv( const GLbyte *v ); +GLAPI void GLAPIENTRY glColor4dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glColor4fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glColor4iv( const GLint *v ); +GLAPI void GLAPIENTRY glColor4sv( const GLshort *v ); +GLAPI void GLAPIENTRY glColor4ubv( const GLubyte *v ); +GLAPI void GLAPIENTRY glColor4uiv( const GLuint *v ); +GLAPI void GLAPIENTRY glColor4usv( const GLushort *v ); + + +GLAPI void GLAPIENTRY glTexCoord1d( GLdouble s ); +GLAPI void GLAPIENTRY glTexCoord1f( GLfloat s ); +GLAPI void GLAPIENTRY glTexCoord1i( GLint s ); +GLAPI void GLAPIENTRY glTexCoord1s( GLshort s ); + +GLAPI void GLAPIENTRY glTexCoord2d( GLdouble s, GLdouble t ); +GLAPI void GLAPIENTRY glTexCoord2f( GLfloat s, GLfloat t ); +GLAPI void GLAPIENTRY glTexCoord2i( GLint s, GLint t ); +GLAPI void GLAPIENTRY glTexCoord2s( GLshort s, GLshort t ); + +GLAPI void GLAPIENTRY glTexCoord3d( GLdouble s, GLdouble t, GLdouble r ); +GLAPI void GLAPIENTRY glTexCoord3f( GLfloat s, GLfloat t, GLfloat r ); +GLAPI void GLAPIENTRY glTexCoord3i( GLint s, GLint t, GLint r ); +GLAPI void GLAPIENTRY glTexCoord3s( GLshort s, GLshort t, GLshort r ); + +GLAPI void GLAPIENTRY glTexCoord4d( GLdouble s, GLdouble t, GLdouble r, GLdouble q ); +GLAPI void GLAPIENTRY glTexCoord4f( GLfloat s, GLfloat t, GLfloat r, GLfloat q ); +GLAPI void GLAPIENTRY glTexCoord4i( GLint s, GLint t, GLint r, GLint q ); +GLAPI void GLAPIENTRY glTexCoord4s( GLshort s, GLshort t, GLshort r, GLshort q ); + +GLAPI void GLAPIENTRY glTexCoord1dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glTexCoord1fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glTexCoord1iv( const GLint *v ); +GLAPI void GLAPIENTRY glTexCoord1sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glTexCoord2dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glTexCoord2fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glTexCoord2iv( const GLint *v ); +GLAPI void GLAPIENTRY glTexCoord2sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glTexCoord3dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glTexCoord3fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glTexCoord3iv( const GLint *v ); +GLAPI void GLAPIENTRY glTexCoord3sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glTexCoord4dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glTexCoord4fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glTexCoord4iv( const GLint *v ); +GLAPI void GLAPIENTRY glTexCoord4sv( const GLshort *v ); + + +GLAPI void GLAPIENTRY glRasterPos2d( GLdouble x, GLdouble y ); +GLAPI void GLAPIENTRY glRasterPos2f( GLfloat x, GLfloat y ); +GLAPI void GLAPIENTRY glRasterPos2i( GLint x, GLint y ); +GLAPI void GLAPIENTRY glRasterPos2s( GLshort x, GLshort y ); + +GLAPI void GLAPIENTRY glRasterPos3d( GLdouble x, GLdouble y, GLdouble z ); +GLAPI void GLAPIENTRY glRasterPos3f( GLfloat x, GLfloat y, GLfloat z ); +GLAPI void GLAPIENTRY glRasterPos3i( GLint x, GLint y, GLint z ); +GLAPI void GLAPIENTRY glRasterPos3s( GLshort x, GLshort y, GLshort z ); + +GLAPI void GLAPIENTRY glRasterPos4d( GLdouble x, GLdouble y, GLdouble z, GLdouble w ); +GLAPI void GLAPIENTRY glRasterPos4f( GLfloat x, GLfloat y, GLfloat z, GLfloat w ); +GLAPI void GLAPIENTRY glRasterPos4i( GLint x, GLint y, GLint z, GLint w ); +GLAPI void GLAPIENTRY glRasterPos4s( GLshort x, GLshort y, GLshort z, GLshort w ); + +GLAPI void GLAPIENTRY glRasterPos2dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glRasterPos2fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glRasterPos2iv( const GLint *v ); +GLAPI void GLAPIENTRY glRasterPos2sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glRasterPos3dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glRasterPos3fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glRasterPos3iv( const GLint *v ); +GLAPI void GLAPIENTRY glRasterPos3sv( const GLshort *v ); + +GLAPI void GLAPIENTRY glRasterPos4dv( const GLdouble *v ); +GLAPI void GLAPIENTRY glRasterPos4fv( const GLfloat *v ); +GLAPI void GLAPIENTRY glRasterPos4iv( const GLint *v ); +GLAPI void GLAPIENTRY glRasterPos4sv( const GLshort *v ); + + +GLAPI void GLAPIENTRY glRectd( GLdouble x1, GLdouble y1, GLdouble x2, GLdouble y2 ); +GLAPI void GLAPIENTRY glRectf( GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2 ); +GLAPI void GLAPIENTRY glRecti( GLint x1, GLint y1, GLint x2, GLint y2 ); +GLAPI void GLAPIENTRY glRects( GLshort x1, GLshort y1, GLshort x2, GLshort y2 ); + + +GLAPI void GLAPIENTRY glRectdv( const GLdouble *v1, const GLdouble *v2 ); +GLAPI void GLAPIENTRY glRectfv( const GLfloat *v1, const GLfloat *v2 ); +GLAPI void GLAPIENTRY glRectiv( const GLint *v1, const GLint *v2 ); +GLAPI void GLAPIENTRY glRectsv( const GLshort *v1, const GLshort *v2 ); + + +/* + * Vertex Arrays (1.1) + */ + +GLAPI void GLAPIENTRY glVertexPointer( GLint size, GLenum type, + GLsizei stride, const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glNormalPointer( GLenum type, GLsizei stride, + const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glColorPointer( GLint size, GLenum type, + GLsizei stride, const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glIndexPointer( GLenum type, GLsizei stride, + const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glTexCoordPointer( GLint size, GLenum type, + GLsizei stride, const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glEdgeFlagPointer( GLsizei stride, const GLvoid *ptr ); + +GLAPI void GLAPIENTRY glGetPointerv( GLenum pname, GLvoid **params ); + +GLAPI void GLAPIENTRY glArrayElement( GLint i ); + +GLAPI void GLAPIENTRY glDrawArrays( GLenum mode, GLint first, GLsizei count ); + +GLAPI void GLAPIENTRY glDrawElements( GLenum mode, GLsizei count, + GLenum type, const GLvoid *indices ); + +GLAPI void GLAPIENTRY glInterleavedArrays( GLenum format, GLsizei stride, + const GLvoid *pointer ); + +/* + * Lighting + */ + +GLAPI void GLAPIENTRY glShadeModel( GLenum mode ); + +GLAPI void GLAPIENTRY glLightf( GLenum light, GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glLighti( GLenum light, GLenum pname, GLint param ); +GLAPI void GLAPIENTRY glLightfv( GLenum light, GLenum pname, + const GLfloat *params ); +GLAPI void GLAPIENTRY glLightiv( GLenum light, GLenum pname, + const 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 glLightModelf( GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glLightModeli( GLenum pname, GLint param ); +GLAPI void GLAPIENTRY glLightModelfv( GLenum pname, const GLfloat *params ); +GLAPI void GLAPIENTRY glLightModeliv( GLenum pname, const GLint *params ); + +GLAPI void GLAPIENTRY glMaterialf( GLenum face, GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glMateriali( GLenum face, GLenum pname, GLint param ); +GLAPI void GLAPIENTRY glMaterialfv( GLenum face, GLenum pname, const GLfloat *params ); +GLAPI void GLAPIENTRY glMaterialiv( GLenum face, GLenum pname, const GLint *params ); + +GLAPI void GLAPIENTRY glGetMaterialfv( GLenum face, GLenum pname, GLfloat *params ); +GLAPI void GLAPIENTRY glGetMaterialiv( GLenum face, GLenum pname, GLint *params ); + +GLAPI void GLAPIENTRY glColorMaterial( GLenum face, GLenum mode ); + + +/* + * Raster functions + */ + +GLAPI void GLAPIENTRY glPixelZoom( GLfloat xfactor, GLfloat yfactor ); + +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 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 glGetPixelMapfv( GLenum map, GLfloat *values ); +GLAPI void GLAPIENTRY glGetPixelMapuiv( GLenum map, GLuint *values ); +GLAPI void GLAPIENTRY glGetPixelMapusv( GLenum map, GLushort *values ); + +GLAPI void GLAPIENTRY glBitmap( GLsizei width, GLsizei height, + GLfloat xorig, GLfloat yorig, + GLfloat xmove, GLfloat ymove, + const GLubyte *bitmap ); + +GLAPI void GLAPIENTRY glReadPixels( GLint x, GLint y, + GLsizei width, GLsizei height, + GLenum format, GLenum type, + GLvoid *pixels ); + +GLAPI void GLAPIENTRY glDrawPixels( GLsizei width, GLsizei height, + GLenum format, GLenum type, + const GLvoid *pixels ); + +GLAPI void GLAPIENTRY glCopyPixels( GLint x, GLint y, + GLsizei width, GLsizei height, + GLenum type ); + +/* + * Stenciling + */ + +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 glClearStencil( GLint s ); + + + +/* + * Texture mapping + */ + +GLAPI void GLAPIENTRY glTexGend( GLenum coord, GLenum pname, GLdouble param ); +GLAPI void GLAPIENTRY glTexGenf( GLenum coord, GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glTexGeni( GLenum coord, GLenum pname, GLint param ); + +GLAPI void GLAPIENTRY glTexGendv( GLenum coord, GLenum pname, const GLdouble *params ); +GLAPI void GLAPIENTRY glTexGenfv( GLenum coord, GLenum pname, const GLfloat *params ); +GLAPI void GLAPIENTRY glTexGeniv( GLenum coord, GLenum pname, const 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 glTexEnvf( GLenum target, GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glTexEnvi( GLenum target, GLenum pname, GLint param ); + +GLAPI void GLAPIENTRY glTexEnvfv( GLenum target, GLenum pname, const GLfloat *params ); +GLAPI void GLAPIENTRY glTexEnviv( GLenum target, GLenum pname, const GLint *params ); + +GLAPI void GLAPIENTRY glGetTexEnvfv( GLenum target, GLenum pname, GLfloat *params ); +GLAPI void GLAPIENTRY glGetTexEnviv( GLenum target, GLenum pname, GLint *params ); + + +GLAPI void GLAPIENTRY glTexParameterf( GLenum target, GLenum pname, GLfloat param ); +GLAPI void GLAPIENTRY glTexParameteri( GLenum target, GLenum pname, GLint param ); + +GLAPI void GLAPIENTRY glTexParameterfv( GLenum target, GLenum pname, + const GLfloat *params ); +GLAPI void GLAPIENTRY glTexParameteriv( GLenum target, GLenum pname, + const 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 glGetTexLevelParameterfv( GLenum target, GLint level, + GLenum pname, GLfloat *params ); +GLAPI void GLAPIENTRY glGetTexLevelParameteriv( GLenum target, GLint level, + GLenum pname, 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 glGetTexImage( GLenum target, GLint level, + GLenum format, GLenum type, + GLvoid *pixels ); + + +/* 1.1 functions */ + +GLAPI void GLAPIENTRY glGenTextures( GLsizei n, GLuint *textures ); + +GLAPI void GLAPIENTRY glDeleteTextures( GLsizei n, const GLuint *textures); + +GLAPI void GLAPIENTRY glBindTexture( GLenum target, GLuint texture ); + +GLAPI void GLAPIENTRY glPrioritizeTextures( GLsizei n, + const GLuint *textures, + const GLclampf *priorities ); + +GLAPI GLboolean GLAPIENTRY glAreTexturesResident( GLsizei n, + const GLuint *textures, + GLboolean *residences ); + +GLAPI GLboolean GLAPIENTRY glIsTexture( GLuint texture ); + + +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 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 ); + + +/* + * Evaluators + */ + +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 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 glEvalCoord1d( GLdouble u ); +GLAPI void GLAPIENTRY glEvalCoord1f( GLfloat u ); + +GLAPI void GLAPIENTRY glEvalCoord1dv( const GLdouble *u ); +GLAPI void GLAPIENTRY glEvalCoord1fv( const GLfloat *u ); + +GLAPI void GLAPIENTRY glEvalCoord2d( GLdouble u, GLdouble v ); +GLAPI void GLAPIENTRY glEvalCoord2f( GLfloat u, GLfloat v ); + +GLAPI void GLAPIENTRY glEvalCoord2dv( const GLdouble *u ); +GLAPI void GLAPIENTRY glEvalCoord2fv( const GLfloat *u ); + +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 glEvalPoint1( GLint i ); + +GLAPI void GLAPIENTRY glEvalPoint2( GLint i, GLint j ); + +GLAPI void GLAPIENTRY glEvalMesh1( GLenum mode, GLint i1, GLint i2 ); + +GLAPI void GLAPIENTRY glEvalMesh2( GLenum mode, GLint i1, GLint i2, GLint j1, GLint j2 ); + + +/* + * Fog + */ + +GLAPI void GLAPIENTRY glFogf( GLenum pname, GLfloat param ); + +GLAPI void GLAPIENTRY glFogi( GLenum pname, GLint param ); + +GLAPI void GLAPIENTRY glFogfv( GLenum pname, const GLfloat *params ); + +GLAPI void GLAPIENTRY glFogiv( GLenum pname, const GLint *params ); + + +/* + * Selection and Feedback + */ + +GLAPI void GLAPIENTRY glFeedbackBuffer( GLsizei size, GLenum type, GLfloat *buffer ); + +GLAPI void GLAPIENTRY glPassThrough( GLfloat token ); + +GLAPI void GLAPIENTRY glSelectBuffer( GLsizei size, GLuint *buffer ); + +GLAPI void GLAPIENTRY glInitNames( void ); + +GLAPI void GLAPIENTRY glLoadName( GLuint name ); + +GLAPI void GLAPIENTRY glPushName( GLuint name ); + +GLAPI void GLAPIENTRY glPopName( void ); + + + +/* + * OpenGL 1.2 + */ + +#define GL_RESCALE_NORMAL 0x803A +#define GL_CLAMP_TO_EDGE 0x812F +#define GL_MAX_ELEMENTS_VERTICES 0x80E8 +#define GL_MAX_ELEMENTS_INDICES 0x80E9 +#define GL_BGR 0x80E0 +#define GL_BGRA 0x80E1 +#define GL_UNSIGNED_BYTE_3_3_2 0x8032 +#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 0x8033 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV 0x8365 +#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 +#define GL_UNSIGNED_SHORT_1_5_5_5_REV 0x8366 +#define GL_UNSIGNED_INT_8_8_8_8 0x8035 +#define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367 +#define GL_UNSIGNED_INT_10_10_10_2 0x8036 +#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368 +#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 +#define GL_SINGLE_COLOR 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR 0x81FA +#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_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_ALIASED_POINT_SIZE_RANGE 0x846D +#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E +#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_TEXTURE_BINDING_3D 0x806A + +GLAPI void GLAPIENTRY glDrawRangeElements( GLenum mode, GLuint start, + GLuint end, GLsizei count, GLenum type, const GLvoid *indices ); + +GLAPI void GLAPIENTRY glTexImage3D( GLenum target, GLint level, + GLint internalFormat, + GLsizei width, GLsizei height, + GLsizei depth, GLint border, + GLenum format, GLenum type, + const GLvoid *pixels ); + +GLAPI void GLAPIENTRY glTexSubImage3D( GLenum target, GLint level, + GLint xoffset, GLint yoffset, + GLint zoffset, GLsizei width, + GLsizei height, GLsizei depth, + GLenum format, + GLenum type, const GLvoid *pixels); + +GLAPI void GLAPIENTRY glCopyTexSubImage3D( GLenum target, GLint level, + GLint xoffset, GLint yoffset, + GLint zoffset, GLint x, + GLint y, GLsizei width, + GLsizei height ); + +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const GLvoid *indices); +typedef void (APIENTRYP PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid *pixels); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); + + +/* + * GL_ARB_imaging + */ + +#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_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_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_CONSTANT_BORDER 0x8151 +#define GL_REPLICATE_BORDER 0x8153 +#define GL_CONVOLUTION_BORDER_COLOR 0x8154 +#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_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_BLEND_EQUATION 0x8009 +#define GL_MIN 0x8007 +#define GL_MAX 0x8008 +#define GL_FUNC_ADD 0x8006 +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B +#define GL_BLEND_COLOR 0x8005 + + +GLAPI void GLAPIENTRY glColorTable( GLenum target, GLenum internalformat, + GLsizei width, GLenum format, + GLenum type, const GLvoid *table ); + +GLAPI void GLAPIENTRY glColorSubTable( GLenum target, + GLsizei start, GLsizei count, + GLenum format, GLenum type, + const GLvoid *data ); + +GLAPI void GLAPIENTRY glColorTableParameteriv(GLenum target, GLenum pname, + const GLint *params); + +GLAPI void GLAPIENTRY glColorTableParameterfv(GLenum target, GLenum pname, + const GLfloat *params); + +GLAPI void GLAPIENTRY glCopyColorSubTable( GLenum target, GLsizei start, + GLint x, GLint y, GLsizei width ); + +GLAPI void GLAPIENTRY glCopyColorTable( GLenum target, GLenum internalformat, + GLint x, GLint y, GLsizei width ); + +GLAPI void GLAPIENTRY glGetColorTable( GLenum target, GLenum format, + GLenum type, GLvoid *table ); + +GLAPI void GLAPIENTRY glGetColorTableParameterfv( GLenum target, GLenum pname, + GLfloat *params ); + +GLAPI void GLAPIENTRY glGetColorTableParameteriv( GLenum target, GLenum pname, + GLint *params ); + +GLAPI void GLAPIENTRY glBlendEquation( GLenum mode ); + +GLAPI void GLAPIENTRY glBlendColor( GLclampf red, GLclampf green, + GLclampf blue, GLclampf alpha ); + +GLAPI void GLAPIENTRY glHistogram( GLenum target, GLsizei width, + GLenum internalformat, GLboolean sink ); + +GLAPI void GLAPIENTRY glResetHistogram( GLenum target ); + +GLAPI void GLAPIENTRY glGetHistogram( GLenum target, GLboolean reset, + GLenum format, GLenum type, + GLvoid *values ); + +GLAPI void GLAPIENTRY glGetHistogramParameterfv( GLenum target, GLenum pname, + GLfloat *params ); + +GLAPI void GLAPIENTRY glGetHistogramParameteriv( GLenum target, GLenum pname, + GLint *params ); + +GLAPI void GLAPIENTRY glMinmax( GLenum target, GLenum internalformat, + GLboolean sink ); + +GLAPI void GLAPIENTRY glResetMinmax( GLenum target ); + +GLAPI void GLAPIENTRY glGetMinmax( GLenum target, GLboolean reset, + GLenum format, GLenum types, + GLvoid *values ); + +GLAPI void GLAPIENTRY glGetMinmaxParameterfv( GLenum target, GLenum pname, + GLfloat *params ); + +GLAPI void GLAPIENTRY glGetMinmaxParameteriv( GLenum target, GLenum pname, + GLint *params ); + +GLAPI void GLAPIENTRY glConvolutionFilter1D( GLenum target, + GLenum internalformat, GLsizei width, GLenum format, GLenum type, + const GLvoid *image ); + +GLAPI void GLAPIENTRY glConvolutionFilter2D( GLenum target, + GLenum internalformat, GLsizei width, GLsizei height, GLenum format, + GLenum type, const GLvoid *image ); + +GLAPI void GLAPIENTRY glConvolutionParameterf( GLenum target, GLenum pname, + GLfloat params ); + +GLAPI void GLAPIENTRY glConvolutionParameterfv( GLenum target, GLenum pname, + const GLfloat *params ); + +GLAPI void GLAPIENTRY glConvolutionParameteri( GLenum target, GLenum pname, + GLint params ); + +GLAPI void GLAPIENTRY glConvolutionParameteriv( GLenum target, GLenum pname, + const GLint *params ); + +GLAPI void GLAPIENTRY glCopyConvolutionFilter1D( GLenum target, + GLenum internalformat, GLint x, GLint y, GLsizei width ); + +GLAPI void GLAPIENTRY glCopyConvolutionFilter2D( GLenum target, + GLenum internalformat, GLint x, GLint y, GLsizei width, + GLsizei height); + +GLAPI void GLAPIENTRY glGetConvolutionFilter( GLenum target, GLenum format, + GLenum type, GLvoid *image ); + +GLAPI void GLAPIENTRY glGetConvolutionParameterfv( GLenum target, GLenum pname, + GLfloat *params ); + +GLAPI void GLAPIENTRY glGetConvolutionParameteriv( GLenum target, GLenum pname, + GLint *params ); + +GLAPI void GLAPIENTRY glSeparableFilter2D( GLenum target, + GLenum internalformat, GLsizei width, GLsizei height, GLenum format, + GLenum type, const GLvoid *row, const GLvoid *column ); + +GLAPI void GLAPIENTRY glGetSeparableFilter( GLenum target, GLenum format, + GLenum type, GLvoid *row, GLvoid *column, GLvoid *span ); + + + + +/* + * OpenGL 1.3 + */ + +/* multitexture */ +#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 +/* texture_cube_map */ +#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 +/* texture_compression */ +#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_TEXTURE_COMPRESSED_IMAGE_SIZE 0x86A0 +#define GL_TEXTURE_COMPRESSED 0x86A1 +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 +/* multisample */ +#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_MULTISAMPLE_BIT 0x20000000 +/* transpose_matrix */ +#define GL_TRANSPOSE_MODELVIEW_MATRIX 0x84E3 +#define GL_TRANSPOSE_PROJECTION_MATRIX 0x84E4 +#define GL_TRANSPOSE_TEXTURE_MATRIX 0x84E5 +#define GL_TRANSPOSE_COLOR_MATRIX 0x84E6 +/* texture_env_combine */ +#define GL_COMBINE 0x8570 +#define GL_COMBINE_RGB 0x8571 +#define GL_COMBINE_ALPHA 0x8572 +#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_RGB_SCALE 0x8573 +#define GL_ADD_SIGNED 0x8574 +#define GL_INTERPOLATE 0x8575 +#define GL_SUBTRACT 0x84E7 +#define GL_CONSTANT 0x8576 +#define GL_PRIMARY_COLOR 0x8577 +#define GL_PREVIOUS 0x8578 +/* texture_env_dot3 */ +#define GL_DOT3_RGB 0x86AE +#define GL_DOT3_RGBA 0x86AF +/* texture_border_clamp */ +#define GL_CLAMP_TO_BORDER 0x812D + +GLAPI void GLAPIENTRY glActiveTexture( GLenum texture ); + +GLAPI void GLAPIENTRY glClientActiveTexture( GLenum texture ); + +GLAPI void GLAPIENTRY glCompressedTexImage1D( GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glCompressedTexImage2D( GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glCompressedTexImage3D( GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glCompressedTexSubImage1D( GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glCompressedTexSubImage2D( GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glCompressedTexSubImage3D( GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid *data ); + +GLAPI void GLAPIENTRY glGetCompressedTexImage( GLenum target, GLint lod, GLvoid *img ); + +GLAPI void GLAPIENTRY glMultiTexCoord1d( GLenum target, GLdouble s ); + +GLAPI void GLAPIENTRY glMultiTexCoord1dv( GLenum target, const GLdouble *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord1f( GLenum target, GLfloat s ); + +GLAPI void GLAPIENTRY glMultiTexCoord1fv( GLenum target, const GLfloat *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord1i( GLenum target, GLint s ); + +GLAPI void GLAPIENTRY glMultiTexCoord1iv( GLenum target, const GLint *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord1s( GLenum target, GLshort s ); + +GLAPI void GLAPIENTRY glMultiTexCoord1sv( GLenum target, const GLshort *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord2d( GLenum target, GLdouble s, GLdouble t ); + +GLAPI void GLAPIENTRY glMultiTexCoord2dv( GLenum target, const GLdouble *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord2f( GLenum target, GLfloat s, GLfloat t ); + +GLAPI void GLAPIENTRY glMultiTexCoord2fv( GLenum target, const GLfloat *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord2i( GLenum target, GLint s, GLint t ); + +GLAPI void GLAPIENTRY glMultiTexCoord2iv( GLenum target, const GLint *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord2s( GLenum target, GLshort s, GLshort t ); + +GLAPI void GLAPIENTRY glMultiTexCoord2sv( GLenum target, const GLshort *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord3d( GLenum target, GLdouble s, GLdouble t, GLdouble r ); + +GLAPI void GLAPIENTRY glMultiTexCoord3dv( GLenum target, const GLdouble *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord3f( GLenum target, GLfloat s, GLfloat t, GLfloat r ); + +GLAPI void GLAPIENTRY glMultiTexCoord3fv( GLenum target, const GLfloat *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord3i( GLenum target, GLint s, GLint t, GLint r ); + +GLAPI void GLAPIENTRY glMultiTexCoord3iv( GLenum target, const GLint *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord3s( GLenum target, GLshort s, GLshort t, GLshort r ); + +GLAPI void GLAPIENTRY glMultiTexCoord3sv( GLenum target, const GLshort *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord4d( GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q ); + +GLAPI void GLAPIENTRY glMultiTexCoord4dv( GLenum target, const GLdouble *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord4f( GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q ); + +GLAPI void GLAPIENTRY glMultiTexCoord4fv( GLenum target, const GLfloat *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord4i( GLenum target, GLint s, GLint t, GLint r, GLint q ); + +GLAPI void GLAPIENTRY glMultiTexCoord4iv( GLenum target, const GLint *v ); + +GLAPI void GLAPIENTRY glMultiTexCoord4s( GLenum target, GLshort s, GLshort t, GLshort r, GLshort q ); + +GLAPI void GLAPIENTRY glMultiTexCoord4sv( GLenum target, const GLshort *v ); + + +GLAPI void GLAPIENTRY glLoadTransposeMatrixd( const GLdouble m[16] ); + +GLAPI void GLAPIENTRY glLoadTransposeMatrixf( const GLfloat m[16] ); + +GLAPI void GLAPIENTRY glMultTransposeMatrixd( const GLdouble m[16] ); + +GLAPI void GLAPIENTRY glMultTransposeMatrixf( const GLfloat m[16] ); + +GLAPI void GLAPIENTRY glSampleCoverage( GLclampf value, GLboolean invert ); + + +typedef void (APIENTRYP PFNGLACTIVETEXTUREPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const GLvoid *data); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint level, GLvoid *img); + + + +/* + * GL_ARB_multitexture (ARB extension 1 and OpenGL 1.2.1) + */ +#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 + +GLAPI void GLAPIENTRY glActiveTextureARB(GLenum texture); +GLAPI void GLAPIENTRY glClientActiveTextureARB(GLenum texture); +GLAPI void GLAPIENTRY glMultiTexCoord1dARB(GLenum target, GLdouble s); +GLAPI void GLAPIENTRY glMultiTexCoord1dvARB(GLenum target, const GLdouble *v); +GLAPI void GLAPIENTRY glMultiTexCoord1fARB(GLenum target, GLfloat s); +GLAPI void GLAPIENTRY glMultiTexCoord1fvARB(GLenum target, const GLfloat *v); +GLAPI void GLAPIENTRY glMultiTexCoord1iARB(GLenum target, GLint s); +GLAPI void GLAPIENTRY glMultiTexCoord1ivARB(GLenum target, const GLint *v); +GLAPI void GLAPIENTRY glMultiTexCoord1sARB(GLenum target, GLshort s); +GLAPI void GLAPIENTRY glMultiTexCoord1svARB(GLenum target, const GLshort *v); +GLAPI void GLAPIENTRY glMultiTexCoord2dARB(GLenum target, GLdouble s, GLdouble t); +GLAPI void GLAPIENTRY glMultiTexCoord2dvARB(GLenum target, const GLdouble *v); +GLAPI void GLAPIENTRY glMultiTexCoord2fARB(GLenum target, GLfloat s, GLfloat t); +GLAPI void GLAPIENTRY glMultiTexCoord2fvARB(GLenum target, const GLfloat *v); +GLAPI void GLAPIENTRY glMultiTexCoord2iARB(GLenum target, GLint s, GLint t); +GLAPI void GLAPIENTRY glMultiTexCoord2ivARB(GLenum target, const GLint *v); +GLAPI void GLAPIENTRY glMultiTexCoord2sARB(GLenum target, GLshort s, GLshort t); +GLAPI void GLAPIENTRY glMultiTexCoord2svARB(GLenum target, const GLshort *v); +GLAPI void GLAPIENTRY glMultiTexCoord3dARB(GLenum target, GLdouble s, GLdouble t, GLdouble r); +GLAPI void GLAPIENTRY glMultiTexCoord3dvARB(GLenum target, const GLdouble *v); +GLAPI void GLAPIENTRY glMultiTexCoord3fARB(GLenum target, GLfloat s, GLfloat t, GLfloat r); +GLAPI void GLAPIENTRY glMultiTexCoord3fvARB(GLenum target, const GLfloat *v); +GLAPI void GLAPIENTRY glMultiTexCoord3iARB(GLenum target, GLint s, GLint t, GLint r); +GLAPI void GLAPIENTRY glMultiTexCoord3ivARB(GLenum target, const GLint *v); +GLAPI void GLAPIENTRY glMultiTexCoord3sARB(GLenum target, GLshort s, GLshort t, GLshort r); +GLAPI void GLAPIENTRY glMultiTexCoord3svARB(GLenum target, const GLshort *v); +GLAPI void GLAPIENTRY glMultiTexCoord4dARB(GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI void GLAPIENTRY glMultiTexCoord4dvARB(GLenum target, const GLdouble *v); +GLAPI void GLAPIENTRY glMultiTexCoord4fARB(GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI void GLAPIENTRY glMultiTexCoord4fvARB(GLenum target, const GLfloat *v); +GLAPI void GLAPIENTRY glMultiTexCoord4iARB(GLenum target, GLint s, GLint t, GLint r, GLint q); +GLAPI void GLAPIENTRY glMultiTexCoord4ivARB(GLenum target, const GLint *v); +GLAPI void GLAPIENTRY glMultiTexCoord4sARB(GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI void GLAPIENTRY glMultiTexCoord4svARB(GLenum target, const GLshort *v); + +typedef void (APIENTRYP PFNGLACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); + +#endif /* GL_ARB_multitexture */ + + + +/* + * Define this token if you want "old-style" header file behaviour (extensions + * defined in gl.h). Otherwise, extensions will be included from glext.h. + */ +#if !defined(NO_SDL_GLEXT) && !defined(GL_GLEXT_LEGACY) +#include "SDL_opengl_glext.h" +#endif /* GL_GLEXT_LEGACY */ + + + +/* + * ???. GL_MESA_packed_depth_stencil + * XXX obsolete + */ +#ifndef GL_MESA_packed_depth_stencil +#define GL_MESA_packed_depth_stencil 1 + +#define GL_DEPTH_STENCIL_MESA 0x8750 +#define GL_UNSIGNED_INT_24_8_MESA 0x8751 +#define GL_UNSIGNED_INT_8_24_REV_MESA 0x8752 +#define GL_UNSIGNED_SHORT_15_1_MESA 0x8753 +#define GL_UNSIGNED_SHORT_1_15_REV_MESA 0x8754 + +#endif /* GL_MESA_packed_depth_stencil */ + + +#ifndef GL_ATI_blend_equation_separate +#define GL_ATI_blend_equation_separate 1 + +#define GL_ALPHA_BLEND_EQUATION_ATI 0x883D + +GLAPI void GLAPIENTRY glBlendEquationSeparateATI( GLenum modeRGB, GLenum modeA ); +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEATIPROC) (GLenum modeRGB, GLenum modeA); + +#endif /* GL_ATI_blend_equation_separate */ + + +/* GL_OES_EGL_image */ +#ifndef GL_OES_EGL_image +typedef void* GLeglImageOES; +#endif + +#ifndef GL_OES_EGL_image +#define GL_OES_EGL_image 1 +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glEGLImageTargetTexture2DOES (GLenum target, GLeglImageOES image); +GLAPI void APIENTRY glEGLImageTargetRenderbufferStorageOES (GLenum target, GLeglImageOES image); +#endif +typedef void (APIENTRYP PFNGLEGLIMAGETARGETTEXTURE2DOESPROC) (GLenum target, GLeglImageOES image); +typedef void (APIENTRYP PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC) (GLenum target, GLeglImageOES image); +#endif + + +/** + ** NOTE!!!!! If you add new functions to this file, or update + ** glext.h be sure to regenerate the gl_mangle.h file. See comments + ** in that file for details. + **/ + + + +/********************************************************************** + * Begin system-specific stuff + */ +#if defined(PRAGMA_EXPORT_SUPPORTED) +#pragma export off +#endif + +/* + * End system-specific stuff + **********************************************************************/ + + +#ifdef __cplusplus +} +#endif + +#endif /* __gl_h_ */ + +#endif /* !__IPHONEOS__ */ + +#endif /* SDL_opengl_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl_glext.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl_glext.h new file mode 100644 index 0000000..cd3869f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengl_glext.h @@ -0,0 +1,11177 @@ +#ifndef __glext_h_ +#define __glext_h_ 1 + +#ifdef __cplusplus +extern "C" { +#endif + +/* +** Copyright (c) 2013-2014 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. +*/ +/* +** This header is generated from the Khronos OpenGL / OpenGL ES XML +** API Registry. The current version of the Registry, generator scripts +** used to make the header, and the header can be found at +** http://www.opengl.org/registry/ +** +** Khronos $Revision: 26745 $ on $Date: 2014-05-21 03:12:26 -0700 (Wed, 21 May 2014) $ +*/ + +#if defined(_WIN32) && !defined(APIENTRY) && !defined(__CYGWIN__) && !defined(__SCITECH_SNAP__) +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN 1 +#endif +#include +#endif + +#ifndef APIENTRY +#define APIENTRY +#endif +#ifndef APIENTRYP +#define APIENTRYP APIENTRY * +#endif +#ifndef GLAPI +#define GLAPI extern +#endif + +#define GL_GLEXT_VERSION 20140521 + +/* Generated C header for: + * API: gl + * Profile: compatibility + * Versions considered: .* + * Versions emitted: 1\.[2-9]|[234]\.[0-9] + * Default extensions included: gl + * Additional extensions included: _nomatch_^ + * Extensions removed: _nomatch_^ + */ + +#ifndef GL_VERSION_1_2 +#define GL_VERSION_1_2 1 +#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_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_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_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_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_ALIASED_LINE_WIDTH_RANGE 0x846E +#define GL_RESCALE_NORMAL 0x803A +#define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8 +#define GL_SINGLE_COLOR 0x81F9 +#define GL_SEPARATE_SPECULAR_COLOR 0x81FA +#define GL_ALIASED_POINT_SIZE_RANGE 0x846D +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices); +typedef void (APIENTRYP PFNGLTEXIMAGE3DPROC) (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE3DPROC) (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 (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawRangeElements (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices); +GLAPI void APIENTRY glTexImage3D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glCopyTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#endif +#endif /* GL_VERSION_1_2 */ + +#ifndef GL_VERSION_1_3 +#define GL_VERSION_1_3 1 +#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_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_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_COMPRESSED_RGB 0x84ED +#define GL_COMPRESSED_RGBA 0x84EE +#define GL_TEXTURE_COMPRESSION_HINT 0x84EF +#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_CLAMP_TO_BORDER 0x812D +#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_MULTISAMPLE_BIT 0x20000000 +#define GL_NORMAL_MAP 0x8511 +#define GL_REFLECTION_MAP 0x8512 +#define GL_COMPRESSED_ALPHA 0x84E9 +#define GL_COMPRESSED_LUMINANCE 0x84EA +#define GL_COMPRESSED_LUMINANCE_ALPHA 0x84EB +#define GL_COMPRESSED_INTENSITY 0x84EC +#define GL_COMBINE 0x8570 +#define GL_COMBINE_RGB 0x8571 +#define GL_COMBINE_ALPHA 0x8572 +#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_RGB_SCALE 0x8573 +#define GL_ADD_SIGNED 0x8574 +#define GL_INTERPOLATE 0x8575 +#define GL_SUBTRACT 0x84E7 +#define GL_CONSTANT 0x8576 +#define GL_PRIMARY_COLOR 0x8577 +#define GL_PREVIOUS 0x8578 +#define GL_DOT3_RGB 0x86AE +#define GL_DOT3_RGBA 0x86AF +typedef void (APIENTRYP PFNGLACTIVETEXTUREPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEPROC) (GLfloat value, GLboolean invert); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE3DPROC) (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 (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEPROC) (GLenum target, GLint level, void *img); +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DPROC) (GLenum target, GLdouble s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FPROC) (GLenum target, GLfloat s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IPROC) (GLenum target, GLint s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SPROC) (GLenum target, GLshort s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IPROC) (GLenum target, GLint s, GLint t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SPROC) (GLenum target, GLshort s, GLshort t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXFPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXDPROC) (const GLdouble *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXFPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDPROC) (const GLdouble *m); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveTexture (GLenum texture); +GLAPI void APIENTRY glSampleCoverage (GLfloat value, GLboolean invert); +GLAPI void APIENTRY glCompressedTexImage3D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexImage2D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexImage1D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage3D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage1D (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glGetCompressedTexImage (GLenum target, GLint level, void *img); +GLAPI void APIENTRY glClientActiveTexture (GLenum texture); +GLAPI void APIENTRY glMultiTexCoord1d (GLenum target, GLdouble s); +GLAPI void APIENTRY glMultiTexCoord1dv (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord1f (GLenum target, GLfloat s); +GLAPI void APIENTRY glMultiTexCoord1fv (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord1i (GLenum target, GLint s); +GLAPI void APIENTRY glMultiTexCoord1iv (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord1s (GLenum target, GLshort s); +GLAPI void APIENTRY glMultiTexCoord1sv (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord2d (GLenum target, GLdouble s, GLdouble t); +GLAPI void APIENTRY glMultiTexCoord2dv (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord2f (GLenum target, GLfloat s, GLfloat t); +GLAPI void APIENTRY glMultiTexCoord2fv (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord2i (GLenum target, GLint s, GLint t); +GLAPI void APIENTRY glMultiTexCoord2iv (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord2s (GLenum target, GLshort s, GLshort t); +GLAPI void APIENTRY glMultiTexCoord2sv (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord3d (GLenum target, GLdouble s, GLdouble t, GLdouble r); +GLAPI void APIENTRY glMultiTexCoord3dv (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord3f (GLenum target, GLfloat s, GLfloat t, GLfloat r); +GLAPI void APIENTRY glMultiTexCoord3fv (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord3i (GLenum target, GLint s, GLint t, GLint r); +GLAPI void APIENTRY glMultiTexCoord3iv (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord3s (GLenum target, GLshort s, GLshort t, GLshort r); +GLAPI void APIENTRY glMultiTexCoord3sv (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord4d (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI void APIENTRY glMultiTexCoord4dv (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord4f (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI void APIENTRY glMultiTexCoord4fv (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord4i (GLenum target, GLint s, GLint t, GLint r, GLint q); +GLAPI void APIENTRY glMultiTexCoord4iv (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord4s (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI void APIENTRY glMultiTexCoord4sv (GLenum target, const GLshort *v); +GLAPI void APIENTRY glLoadTransposeMatrixf (const GLfloat *m); +GLAPI void APIENTRY glLoadTransposeMatrixd (const GLdouble *m); +GLAPI void APIENTRY glMultTransposeMatrixf (const GLfloat *m); +GLAPI void APIENTRY glMultTransposeMatrixd (const GLdouble *m); +#endif +#endif /* GL_VERSION_1_3 */ + +#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_FADE_THRESHOLD_SIZE 0x8128 +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_DEPTH_COMPONENT24 0x81A6 +#define GL_DEPTH_COMPONENT32 0x81A7 +#define GL_MIRRORED_REPEAT 0x8370 +#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD +#define GL_TEXTURE_LOD_BIAS 0x8501 +#define GL_INCR_WRAP 0x8507 +#define GL_DECR_WRAP 0x8508 +#define GL_TEXTURE_DEPTH_SIZE 0x884A +#define GL_TEXTURE_COMPARE_MODE 0x884C +#define GL_TEXTURE_COMPARE_FUNC 0x884D +#define GL_POINT_SIZE_MIN 0x8126 +#define GL_POINT_SIZE_MAX 0x8127 +#define GL_POINT_DISTANCE_ATTENUATION 0x8129 +#define GL_GENERATE_MIPMAP 0x8191 +#define GL_GENERATE_MIPMAP_HINT 0x8192 +#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_TEXTURE_FILTER_CONTROL 0x8500 +#define GL_DEPTH_TEXTURE_MODE 0x884B +#define GL_COMPARE_R_TO_TEXTURE 0x884E +#define GL_FUNC_ADD 0x8006 +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B +#define GL_MIN 0x8007 +#define GL_MAX 0x8008 +#define GL_CONSTANT_COLOR 0x8001 +#define GL_ONE_MINUS_CONSTANT_COLOR 0x8002 +#define GL_CONSTANT_ALPHA 0x8003 +#define GL_ONE_MINUS_CONSTANT_ALPHA 0x8004 +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei drawcount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSPROC) (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIVPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLFOGCOORDFPROC) (GLfloat coord); +typedef void (APIENTRYP PFNGLFOGCOORDFVPROC) (const GLfloat *coord); +typedef void (APIENTRYP PFNGLFOGCOORDDPROC) (GLdouble coord); +typedef void (APIENTRYP PFNGLFOGCOORDDVPROC) (const GLdouble *coord); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTERPROC) (GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BVPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IPROC) (GLint red, GLint green, GLint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SVPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBVPROC) (const GLubyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIVPROC) (const GLuint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USVPROC) (const GLushort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTERPROC) (GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLWINDOWPOS2DPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLBLENDCOLORPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +typedef void (APIENTRYP PFNGLBLENDEQUATIONPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparate (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +GLAPI void APIENTRY glMultiDrawArrays (GLenum mode, const GLint *first, const GLsizei *count, GLsizei drawcount); +GLAPI void APIENTRY glMultiDrawElements (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount); +GLAPI void APIENTRY glPointParameterf (GLenum pname, GLfloat param); +GLAPI void APIENTRY glPointParameterfv (GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glPointParameteri (GLenum pname, GLint param); +GLAPI void APIENTRY glPointParameteriv (GLenum pname, const GLint *params); +GLAPI void APIENTRY glFogCoordf (GLfloat coord); +GLAPI void APIENTRY glFogCoordfv (const GLfloat *coord); +GLAPI void APIENTRY glFogCoordd (GLdouble coord); +GLAPI void APIENTRY glFogCoorddv (const GLdouble *coord); +GLAPI void APIENTRY glFogCoordPointer (GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glSecondaryColor3b (GLbyte red, GLbyte green, GLbyte blue); +GLAPI void APIENTRY glSecondaryColor3bv (const GLbyte *v); +GLAPI void APIENTRY glSecondaryColor3d (GLdouble red, GLdouble green, GLdouble blue); +GLAPI void APIENTRY glSecondaryColor3dv (const GLdouble *v); +GLAPI void APIENTRY glSecondaryColor3f (GLfloat red, GLfloat green, GLfloat blue); +GLAPI void APIENTRY glSecondaryColor3fv (const GLfloat *v); +GLAPI void APIENTRY glSecondaryColor3i (GLint red, GLint green, GLint blue); +GLAPI void APIENTRY glSecondaryColor3iv (const GLint *v); +GLAPI void APIENTRY glSecondaryColor3s (GLshort red, GLshort green, GLshort blue); +GLAPI void APIENTRY glSecondaryColor3sv (const GLshort *v); +GLAPI void APIENTRY glSecondaryColor3ub (GLubyte red, GLubyte green, GLubyte blue); +GLAPI void APIENTRY glSecondaryColor3ubv (const GLubyte *v); +GLAPI void APIENTRY glSecondaryColor3ui (GLuint red, GLuint green, GLuint blue); +GLAPI void APIENTRY glSecondaryColor3uiv (const GLuint *v); +GLAPI void APIENTRY glSecondaryColor3us (GLushort red, GLushort green, GLushort blue); +GLAPI void APIENTRY glSecondaryColor3usv (const GLushort *v); +GLAPI void APIENTRY glSecondaryColorPointer (GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glWindowPos2d (GLdouble x, GLdouble y); +GLAPI void APIENTRY glWindowPos2dv (const GLdouble *v); +GLAPI void APIENTRY glWindowPos2f (GLfloat x, GLfloat y); +GLAPI void APIENTRY glWindowPos2fv (const GLfloat *v); +GLAPI void APIENTRY glWindowPos2i (GLint x, GLint y); +GLAPI void APIENTRY glWindowPos2iv (const GLint *v); +GLAPI void APIENTRY glWindowPos2s (GLshort x, GLshort y); +GLAPI void APIENTRY glWindowPos2sv (const GLshort *v); +GLAPI void APIENTRY glWindowPos3d (GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glWindowPos3dv (const GLdouble *v); +GLAPI void APIENTRY glWindowPos3f (GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glWindowPos3fv (const GLfloat *v); +GLAPI void APIENTRY glWindowPos3i (GLint x, GLint y, GLint z); +GLAPI void APIENTRY glWindowPos3iv (const GLint *v); +GLAPI void APIENTRY glWindowPos3s (GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glWindowPos3sv (const GLshort *v); +GLAPI void APIENTRY glBlendColor (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +GLAPI void APIENTRY glBlendEquation (GLenum mode); +#endif +#endif /* GL_VERSION_1_4 */ + +#ifndef GL_VERSION_1_5 +#define GL_VERSION_1_5 1 +#include +#ifdef __MACOSX__ +typedef long GLsizeiptr; +typedef long GLintptr; +#else +typedef ptrdiff_t GLsizeiptr; +typedef ptrdiff_t GLintptr; +#endif +#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_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 +#define GL_SRC1_ALPHA 0x8589 +#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_FOG_COORD_SRC 0x8450 +#define GL_FOG_COORD 0x8451 +#define GL_CURRENT_FOG_COORD 0x8453 +#define GL_FOG_COORD_ARRAY_TYPE 0x8454 +#define GL_FOG_COORD_ARRAY_STRIDE 0x8455 +#define GL_FOG_COORD_ARRAY_POINTER 0x8456 +#define GL_FOG_COORD_ARRAY 0x8457 +#define GL_FOG_COORD_ARRAY_BUFFER_BINDING 0x889D +#define GL_SRC0_RGB 0x8580 +#define GL_SRC1_RGB 0x8581 +#define GL_SRC2_RGB 0x8582 +#define GL_SRC0_ALPHA 0x8588 +#define GL_SRC2_ALPHA 0x858A +typedef void (APIENTRYP PFNGLGENQUERIESPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEQUERIESPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISQUERYPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINQUERYPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLENDQUERYPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETQUERYIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTIVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUIVPROC) (GLuint id, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLBINDBUFFERPROC) (GLenum target, GLuint buffer); +typedef void (APIENTRYP PFNGLDELETEBUFFERSPROC) (GLsizei n, const GLuint *buffers); +typedef void (APIENTRYP PFNGLGENBUFFERSPROC) (GLsizei n, GLuint *buffers); +typedef GLboolean (APIENTRYP PFNGLISBUFFERPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLBUFFERDATAPROC) (GLenum target, GLsizeiptr size, const void *data, GLenum usage); +typedef void (APIENTRYP PFNGLBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, const void *data); +typedef void (APIENTRYP PFNGLGETBUFFERSUBDATAPROC) (GLenum target, GLintptr offset, GLsizeiptr size, void *data); +typedef void *(APIENTRYP PFNGLMAPBUFFERPROC) (GLenum target, GLenum access); +typedef GLboolean (APIENTRYP PFNGLUNMAPBUFFERPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETBUFFERPOINTERVPROC) (GLenum target, GLenum pname, void **params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenQueries (GLsizei n, GLuint *ids); +GLAPI void APIENTRY glDeleteQueries (GLsizei n, const GLuint *ids); +GLAPI GLboolean APIENTRY glIsQuery (GLuint id); +GLAPI void APIENTRY glBeginQuery (GLenum target, GLuint id); +GLAPI void APIENTRY glEndQuery (GLenum target); +GLAPI void APIENTRY glGetQueryiv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetQueryObjectiv (GLuint id, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetQueryObjectuiv (GLuint id, GLenum pname, GLuint *params); +GLAPI void APIENTRY glBindBuffer (GLenum target, GLuint buffer); +GLAPI void APIENTRY glDeleteBuffers (GLsizei n, const GLuint *buffers); +GLAPI void APIENTRY glGenBuffers (GLsizei n, GLuint *buffers); +GLAPI GLboolean APIENTRY glIsBuffer (GLuint buffer); +GLAPI void APIENTRY glBufferData (GLenum target, GLsizeiptr size, const void *data, GLenum usage); +GLAPI void APIENTRY glBufferSubData (GLenum target, GLintptr offset, GLsizeiptr size, const void *data); +GLAPI void APIENTRY glGetBufferSubData (GLenum target, GLintptr offset, GLsizeiptr size, void *data); +GLAPI void *APIENTRY glMapBuffer (GLenum target, GLenum access); +GLAPI GLboolean APIENTRY glUnmapBuffer (GLenum target); +GLAPI void APIENTRY glGetBufferParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetBufferPointerv (GLenum target, GLenum pname, void **params); +#endif +#endif /* GL_VERSION_1_5 */ + +#ifndef GL_VERSION_2_0 +#define GL_VERSION_2_0 1 +typedef char GLchar; +#define GL_BLEND_EQUATION_RGB 0x8009 +#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_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_MAX_VERTEX_ATTRIBS 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A +#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 +#define GL_VERTEX_PROGRAM_TWO_SIDE 0x8643 +#define GL_POINT_SPRITE 0x8861 +#define GL_COORD_REPLACE 0x8862 +#define GL_MAX_TEXTURE_COORDS 0x8871 +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEPROC) (GLenum modeRGB, GLenum modeAlpha); +typedef void (APIENTRYP PFNGLDRAWBUFFERSPROC) (GLsizei n, const GLenum *bufs); +typedef void (APIENTRYP PFNGLSTENCILOPSEPARATEPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +typedef void (APIENTRYP PFNGLSTENCILFUNCSEPARATEPROC) (GLenum face, GLenum func, GLint ref, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILMASKSEPARATEPROC) (GLenum face, GLuint mask); +typedef void (APIENTRYP PFNGLATTACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (APIENTRYP PFNGLBINDATTRIBLOCATIONPROC) (GLuint program, GLuint index, const GLchar *name); +typedef void (APIENTRYP PFNGLCOMPILESHADERPROC) (GLuint shader); +typedef GLuint (APIENTRYP PFNGLCREATEPROGRAMPROC) (void); +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROC) (GLenum type); +typedef void (APIENTRYP PFNGLDELETEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLDELETESHADERPROC) (GLuint shader); +typedef void (APIENTRYP PFNGLDETACHSHADERPROC) (GLuint program, GLuint shader); +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBARRAYPROC) (GLuint index); +typedef void (APIENTRYP PFNGLENABLEVERTEXATTRIBARRAYPROC) (GLuint index); +typedef void (APIENTRYP PFNGLGETACTIVEATTRIBPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLGETATTACHEDSHADERSPROC) (GLuint program, GLsizei maxCount, GLsizei *count, GLuint *shaders); +typedef GLint (APIENTRYP PFNGLGETATTRIBLOCATIONPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGETPROGRAMIVPROC) (GLuint program, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMINFOLOGPROC) (GLuint program, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +typedef void (APIENTRYP PFNGLGETSHADERIVPROC) (GLuint shader, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSHADERINFOLOGPROC) (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +typedef void (APIENTRYP PFNGLGETSHADERSOURCEPROC) (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *source); +typedef GLint (APIENTRYP PFNGLGETUNIFORMLOCATIONPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGETUNIFORMFVPROC) (GLuint program, GLint location, GLfloat *params); +typedef void (APIENTRYP PFNGLGETUNIFORMIVPROC) (GLuint program, GLint location, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVPROC) (GLuint index, GLenum pname, void **pointer); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMPROC) (GLuint program); +typedef GLboolean (APIENTRYP PFNGLISSHADERPROC) (GLuint shader); +typedef void (APIENTRYP PFNGLLINKPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLSHADERSOURCEPROC) (GLuint shader, GLsizei count, const GLchar *const*string, const GLint *length); +typedef void (APIENTRYP PFNGLUSEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLUNIFORM1FPROC) (GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLUNIFORM2FPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLUNIFORM3FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLUNIFORM4FPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLUNIFORM1IPROC) (GLint location, GLint v0); +typedef void (APIENTRYP PFNGLUNIFORM2IPROC) (GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLUNIFORM3IPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLUNIFORM4IPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLUNIFORM1FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM2FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM3FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM4FVPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM1IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM2IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM3IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM4IVPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMPROC) (GLuint program); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NBVPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NIVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NSVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUSVPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4BVPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4USVPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationSeparate (GLenum modeRGB, GLenum modeAlpha); +GLAPI void APIENTRY glDrawBuffers (GLsizei n, const GLenum *bufs); +GLAPI void APIENTRY glStencilOpSeparate (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +GLAPI void APIENTRY glStencilFuncSeparate (GLenum face, GLenum func, GLint ref, GLuint mask); +GLAPI void APIENTRY glStencilMaskSeparate (GLenum face, GLuint mask); +GLAPI void APIENTRY glAttachShader (GLuint program, GLuint shader); +GLAPI void APIENTRY glBindAttribLocation (GLuint program, GLuint index, const GLchar *name); +GLAPI void APIENTRY glCompileShader (GLuint shader); +GLAPI GLuint APIENTRY glCreateProgram (void); +GLAPI GLuint APIENTRY glCreateShader (GLenum type); +GLAPI void APIENTRY glDeleteProgram (GLuint program); +GLAPI void APIENTRY glDeleteShader (GLuint shader); +GLAPI void APIENTRY glDetachShader (GLuint program, GLuint shader); +GLAPI void APIENTRY glDisableVertexAttribArray (GLuint index); +GLAPI void APIENTRY glEnableVertexAttribArray (GLuint index); +GLAPI void APIENTRY glGetActiveAttrib (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +GLAPI void APIENTRY glGetActiveUniform (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLint *size, GLenum *type, GLchar *name); +GLAPI void APIENTRY glGetAttachedShaders (GLuint program, GLsizei maxCount, GLsizei *count, GLuint *shaders); +GLAPI GLint APIENTRY glGetAttribLocation (GLuint program, const GLchar *name); +GLAPI void APIENTRY glGetProgramiv (GLuint program, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetProgramInfoLog (GLuint program, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +GLAPI void APIENTRY glGetShaderiv (GLuint shader, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetShaderInfoLog (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +GLAPI void APIENTRY glGetShaderSource (GLuint shader, GLsizei bufSize, GLsizei *length, GLchar *source); +GLAPI GLint APIENTRY glGetUniformLocation (GLuint program, const GLchar *name); +GLAPI void APIENTRY glGetUniformfv (GLuint program, GLint location, GLfloat *params); +GLAPI void APIENTRY glGetUniformiv (GLuint program, GLint location, GLint *params); +GLAPI void APIENTRY glGetVertexAttribdv (GLuint index, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glGetVertexAttribfv (GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVertexAttribiv (GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribPointerv (GLuint index, GLenum pname, void **pointer); +GLAPI GLboolean APIENTRY glIsProgram (GLuint program); +GLAPI GLboolean APIENTRY glIsShader (GLuint shader); +GLAPI void APIENTRY glLinkProgram (GLuint program); +GLAPI void APIENTRY glShaderSource (GLuint shader, GLsizei count, const GLchar *const*string, const GLint *length); +GLAPI void APIENTRY glUseProgram (GLuint program); +GLAPI void APIENTRY glUniform1f (GLint location, GLfloat v0); +GLAPI void APIENTRY glUniform2f (GLint location, GLfloat v0, GLfloat v1); +GLAPI void APIENTRY glUniform3f (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +GLAPI void APIENTRY glUniform4f (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +GLAPI void APIENTRY glUniform1i (GLint location, GLint v0); +GLAPI void APIENTRY glUniform2i (GLint location, GLint v0, GLint v1); +GLAPI void APIENTRY glUniform3i (GLint location, GLint v0, GLint v1, GLint v2); +GLAPI void APIENTRY glUniform4i (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +GLAPI void APIENTRY glUniform1fv (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform2fv (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform3fv (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform4fv (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform1iv (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform2iv (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform3iv (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform4iv (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniformMatrix2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glValidateProgram (GLuint program); +GLAPI void APIENTRY glVertexAttrib1d (GLuint index, GLdouble x); +GLAPI void APIENTRY glVertexAttrib1dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib1f (GLuint index, GLfloat x); +GLAPI void APIENTRY glVertexAttrib1fv (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib1s (GLuint index, GLshort x); +GLAPI void APIENTRY glVertexAttrib1sv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib2d (GLuint index, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexAttrib2dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib2f (GLuint index, GLfloat x, GLfloat y); +GLAPI void APIENTRY glVertexAttrib2fv (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib2s (GLuint index, GLshort x, GLshort y); +GLAPI void APIENTRY glVertexAttrib2sv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib3d (GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexAttrib3dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib3f (GLuint index, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glVertexAttrib3fv (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib3s (GLuint index, GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glVertexAttrib3sv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4Nbv (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttrib4Niv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttrib4Nsv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4Nub (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +GLAPI void APIENTRY glVertexAttrib4Nubv (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttrib4Nuiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttrib4Nusv (GLuint index, const GLushort *v); +GLAPI void APIENTRY glVertexAttrib4bv (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttrib4d (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexAttrib4dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib4f (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glVertexAttrib4fv (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib4iv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttrib4s (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void APIENTRY glVertexAttrib4sv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4ubv (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttrib4uiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttrib4usv (GLuint index, const GLushort *v); +GLAPI void APIENTRY glVertexAttribPointer (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void *pointer); +#endif +#endif /* GL_VERSION_2_0 */ + +#ifndef GL_VERSION_2_1 +#define GL_VERSION_2_1 1 +#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_COMPRESSED_SRGB 0x8C48 +#define GL_COMPRESSED_SRGB_ALPHA 0x8C49 +#define GL_CURRENT_RASTER_SECONDARY_COLOR 0x845F +#define GL_SLUMINANCE_ALPHA 0x8C44 +#define GL_SLUMINANCE8_ALPHA8 0x8C45 +#define GL_SLUMINANCE 0x8C46 +#define GL_SLUMINANCE8 0x8C47 +#define GL_COMPRESSED_SLUMINANCE 0x8C4A +#define GL_COMPRESSED_SLUMINANCE_ALPHA 0x8C4B +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X2FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X4FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X3FVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glUniformMatrix2x3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix3x2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix2x4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix4x2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix3x4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix4x3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +#endif +#endif /* GL_VERSION_2_1 */ + +#ifndef GL_VERSION_3_0 +#define GL_VERSION_3_0 1 +typedef unsigned short GLhalf; +#define GL_COMPARE_REF_TO_TEXTURE 0x884E +#define GL_CLIP_DISTANCE0 0x3000 +#define GL_CLIP_DISTANCE1 0x3001 +#define GL_CLIP_DISTANCE2 0x3002 +#define GL_CLIP_DISTANCE3 0x3003 +#define GL_CLIP_DISTANCE4 0x3004 +#define GL_CLIP_DISTANCE5 0x3005 +#define GL_CLIP_DISTANCE6 0x3006 +#define GL_CLIP_DISTANCE7 0x3007 +#define GL_MAX_CLIP_DISTANCES 0x0D32 +#define GL_MAJOR_VERSION 0x821B +#define GL_MINOR_VERSION 0x821C +#define GL_NUM_EXTENSIONS 0x821D +#define GL_CONTEXT_FLAGS 0x821E +#define GL_COMPRESSED_RED 0x8225 +#define GL_COMPRESSED_RG 0x8226 +#define GL_CONTEXT_FLAG_FORWARD_COMPATIBLE_BIT 0x00000001 +#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_READ_COLOR 0x891C +#define GL_FIXED_ONLY 0x891D +#define GL_MAX_VARYING_COMPONENTS 0x8B4B +#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_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 +#define GL_BUFFER_ACCESS_FLAGS 0x911F +#define GL_BUFFER_MAP_LENGTH 0x9120 +#define GL_BUFFER_MAP_OFFSET 0x9121 +#define GL_DEPTH_COMPONENT32F 0x8CAC +#define GL_DEPTH32F_STENCIL8 0x8CAD +#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD +#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_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_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_DEPTH_TYPE 0x8C16 +#define GL_UNSIGNED_NORMALIZED 0x8C17 +#define GL_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_DRAW_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 +#define GL_INDEX 0x8222 +#define GL_TEXTURE_LUMINANCE_TYPE 0x8C14 +#define GL_TEXTURE_INTENSITY_TYPE 0x8C15 +#define GL_FRAMEBUFFER_SRGB 0x8DB9 +#define GL_HALF_FLOAT 0x140B +#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 +#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 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 GL_VERTEX_ARRAY_BINDING 0x85B5 +#define GL_CLAMP_VERTEX_COLOR 0x891A +#define GL_CLAMP_FRAGMENT_COLOR 0x891B +#define GL_ALPHA_INTEGER 0x8D97 +typedef void (APIENTRYP PFNGLCOLORMASKIPROC) (GLuint index, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +typedef void (APIENTRYP PFNGLGETBOOLEANI_VPROC) (GLenum target, GLuint index, GLboolean *data); +typedef void (APIENTRYP PFNGLGETINTEGERI_VPROC) (GLenum target, GLuint index, GLint *data); +typedef void (APIENTRYP PFNGLENABLEIPROC) (GLenum target, GLuint index); +typedef void (APIENTRYP PFNGLDISABLEIPROC) (GLenum target, GLuint index); +typedef GLboolean (APIENTRYP PFNGLISENABLEDIPROC) (GLenum target, GLuint index); +typedef void (APIENTRYP PFNGLBEGINTRANSFORMFEEDBACKPROC) (GLenum primitiveMode); +typedef void (APIENTRYP PFNGLENDTRANSFORMFEEDBACKPROC) (void); +typedef void (APIENTRYP PFNGLBINDBUFFERRANGEPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLBINDBUFFERBASEPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSPROC) (GLuint program, GLsizei count, const GLchar *const*varyings, GLenum bufferMode); +typedef void (APIENTRYP PFNGLGETTRANSFORMFEEDBACKVARYINGPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLCLAMPCOLORPROC) (GLenum target, GLenum clamp); +typedef void (APIENTRYP PFNGLBEGINCONDITIONALRENDERPROC) (GLuint id, GLenum mode); +typedef void (APIENTRYP PFNGLENDCONDITIONALRENDERPROC) (void); +typedef void (APIENTRYP PFNGLVERTEXATTRIBIPOINTERPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIIVPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIUIVPROC) (GLuint index, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IPROC) (GLuint index, GLint x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IPROC) (GLuint index, GLint x, GLint y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IPROC) (GLuint index, GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IPROC) (GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIPROC) (GLuint index, GLuint x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIPROC) (GLuint index, GLuint x, GLuint y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIPROC) (GLuint index, GLuint x, GLuint y, GLuint z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIPROC) (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIVPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4BVPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4SVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UBVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4USVPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLGETUNIFORMUIVPROC) (GLuint program, GLint location, GLuint *params); +typedef void (APIENTRYP PFNGLBINDFRAGDATALOCATIONPROC) (GLuint program, GLuint color, const GLchar *name); +typedef GLint (APIENTRYP PFNGLGETFRAGDATALOCATIONPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLUNIFORM1UIPROC) (GLint location, GLuint v0); +typedef void (APIENTRYP PFNGLUNIFORM2UIPROC) (GLint location, GLuint v0, GLuint v1); +typedef void (APIENTRYP PFNGLUNIFORM3UIPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (APIENTRYP PFNGLUNIFORM4UIPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (APIENTRYP PFNGLUNIFORM1UIVPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM2UIVPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM3UIVPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM4UIVPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLTEXPARAMETERIIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLTEXPARAMETERIUIVPROC) (GLenum target, GLenum pname, const GLuint *params); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIUIVPROC) (GLenum target, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLCLEARBUFFERIVPROC) (GLenum buffer, GLint drawbuffer, const GLint *value); +typedef void (APIENTRYP PFNGLCLEARBUFFERUIVPROC) (GLenum buffer, GLint drawbuffer, const GLuint *value); +typedef void (APIENTRYP PFNGLCLEARBUFFERFVPROC) (GLenum buffer, GLint drawbuffer, const GLfloat *value); +typedef void (APIENTRYP PFNGLCLEARBUFFERFIPROC) (GLenum buffer, GLint drawbuffer, GLfloat depth, GLint stencil); +typedef const GLubyte *(APIENTRYP PFNGLGETSTRINGIPROC) (GLenum name, GLuint index); +typedef GLboolean (APIENTRYP PFNGLISRENDERBUFFERPROC) (GLuint renderbuffer); +typedef void (APIENTRYP PFNGLBINDRENDERBUFFERPROC) (GLenum target, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLDELETERENDERBUFFERSPROC) (GLsizei n, const GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLGENRENDERBUFFERSPROC) (GLsizei n, GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETRENDERBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef GLboolean (APIENTRYP PFNGLISFRAMEBUFFERPROC) (GLuint framebuffer); +typedef void (APIENTRYP PFNGLBINDFRAMEBUFFERPROC) (GLenum target, GLuint framebuffer); +typedef void (APIENTRYP PFNGLDELETEFRAMEBUFFERSPROC) (GLsizei n, const GLuint *framebuffers); +typedef void (APIENTRYP PFNGLGENFRAMEBUFFERSPROC) (GLsizei n, GLuint *framebuffers); +typedef GLenum (APIENTRYP PFNGLCHECKFRAMEBUFFERSTATUSPROC) (GLenum target); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE1DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE3DPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (APIENTRYP PFNGLFRAMEBUFFERRENDERBUFFERPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVPROC) (GLenum target, GLenum attachment, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGENERATEMIPMAPPROC) (GLenum target); +typedef void (APIENTRYP PFNGLBLITFRAMEBUFFERPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURELAYERPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void *(APIENTRYP PFNGLMAPBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); +typedef void (APIENTRYP PFNGLFLUSHMAPPEDBUFFERRANGEPROC) (GLenum target, GLintptr offset, GLsizeiptr length); +typedef void (APIENTRYP PFNGLBINDVERTEXARRAYPROC) (GLuint array); +typedef void (APIENTRYP PFNGLDELETEVERTEXARRAYSPROC) (GLsizei n, const GLuint *arrays); +typedef void (APIENTRYP PFNGLGENVERTEXARRAYSPROC) (GLsizei n, GLuint *arrays); +typedef GLboolean (APIENTRYP PFNGLISVERTEXARRAYPROC) (GLuint array); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorMaski (GLuint index, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +GLAPI void APIENTRY glGetBooleani_v (GLenum target, GLuint index, GLboolean *data); +GLAPI void APIENTRY glGetIntegeri_v (GLenum target, GLuint index, GLint *data); +GLAPI void APIENTRY glEnablei (GLenum target, GLuint index); +GLAPI void APIENTRY glDisablei (GLenum target, GLuint index); +GLAPI GLboolean APIENTRY glIsEnabledi (GLenum target, GLuint index); +GLAPI void APIENTRY glBeginTransformFeedback (GLenum primitiveMode); +GLAPI void APIENTRY glEndTransformFeedback (void); +GLAPI void APIENTRY glBindBufferRange (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI void APIENTRY glBindBufferBase (GLenum target, GLuint index, GLuint buffer); +GLAPI void APIENTRY glTransformFeedbackVaryings (GLuint program, GLsizei count, const GLchar *const*varyings, GLenum bufferMode); +GLAPI void APIENTRY glGetTransformFeedbackVarying (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +GLAPI void APIENTRY glClampColor (GLenum target, GLenum clamp); +GLAPI void APIENTRY glBeginConditionalRender (GLuint id, GLenum mode); +GLAPI void APIENTRY glEndConditionalRender (void); +GLAPI void APIENTRY glVertexAttribIPointer (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glGetVertexAttribIiv (GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribIuiv (GLuint index, GLenum pname, GLuint *params); +GLAPI void APIENTRY glVertexAttribI1i (GLuint index, GLint x); +GLAPI void APIENTRY glVertexAttribI2i (GLuint index, GLint x, GLint y); +GLAPI void APIENTRY glVertexAttribI3i (GLuint index, GLint x, GLint y, GLint z); +GLAPI void APIENTRY glVertexAttribI4i (GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glVertexAttribI1ui (GLuint index, GLuint x); +GLAPI void APIENTRY glVertexAttribI2ui (GLuint index, GLuint x, GLuint y); +GLAPI void APIENTRY glVertexAttribI3ui (GLuint index, GLuint x, GLuint y, GLuint z); +GLAPI void APIENTRY glVertexAttribI4ui (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI void APIENTRY glVertexAttribI1iv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI2iv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI3iv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI4iv (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI1uiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI2uiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI3uiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI4uiv (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI4bv (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttribI4sv (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttribI4ubv (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttribI4usv (GLuint index, const GLushort *v); +GLAPI void APIENTRY glGetUniformuiv (GLuint program, GLint location, GLuint *params); +GLAPI void APIENTRY glBindFragDataLocation (GLuint program, GLuint color, const GLchar *name); +GLAPI GLint APIENTRY glGetFragDataLocation (GLuint program, const GLchar *name); +GLAPI void APIENTRY glUniform1ui (GLint location, GLuint v0); +GLAPI void APIENTRY glUniform2ui (GLint location, GLuint v0, GLuint v1); +GLAPI void APIENTRY glUniform3ui (GLint location, GLuint v0, GLuint v1, GLuint v2); +GLAPI void APIENTRY glUniform4ui (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +GLAPI void APIENTRY glUniform1uiv (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform2uiv (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform3uiv (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform4uiv (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glTexParameterIiv (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glTexParameterIuiv (GLenum target, GLenum pname, const GLuint *params); +GLAPI void APIENTRY glGetTexParameterIiv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetTexParameterIuiv (GLenum target, GLenum pname, GLuint *params); +GLAPI void APIENTRY glClearBufferiv (GLenum buffer, GLint drawbuffer, const GLint *value); +GLAPI void APIENTRY glClearBufferuiv (GLenum buffer, GLint drawbuffer, const GLuint *value); +GLAPI void APIENTRY glClearBufferfv (GLenum buffer, GLint drawbuffer, const GLfloat *value); +GLAPI void APIENTRY glClearBufferfi (GLenum buffer, GLint drawbuffer, GLfloat depth, GLint stencil); +GLAPI const GLubyte *APIENTRY glGetStringi (GLenum name, GLuint index); +GLAPI GLboolean APIENTRY glIsRenderbuffer (GLuint renderbuffer); +GLAPI void APIENTRY glBindRenderbuffer (GLenum target, GLuint renderbuffer); +GLAPI void APIENTRY glDeleteRenderbuffers (GLsizei n, const GLuint *renderbuffers); +GLAPI void APIENTRY glGenRenderbuffers (GLsizei n, GLuint *renderbuffers); +GLAPI void APIENTRY glRenderbufferStorage (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetRenderbufferParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI GLboolean APIENTRY glIsFramebuffer (GLuint framebuffer); +GLAPI void APIENTRY glBindFramebuffer (GLenum target, GLuint framebuffer); +GLAPI void APIENTRY glDeleteFramebuffers (GLsizei n, const GLuint *framebuffers); +GLAPI void APIENTRY glGenFramebuffers (GLsizei n, GLuint *framebuffers); +GLAPI GLenum APIENTRY glCheckFramebufferStatus (GLenum target); +GLAPI void APIENTRY glFramebufferTexture1D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTexture2D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTexture3D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +GLAPI void APIENTRY glFramebufferRenderbuffer (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +GLAPI void APIENTRY glGetFramebufferAttachmentParameteriv (GLenum target, GLenum attachment, GLenum pname, GLint *params); +GLAPI void APIENTRY glGenerateMipmap (GLenum target); +GLAPI void APIENTRY glBlitFramebuffer (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +GLAPI void APIENTRY glRenderbufferStorageMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glFramebufferTextureLayer (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +GLAPI void *APIENTRY glMapBufferRange (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); +GLAPI void APIENTRY glFlushMappedBufferRange (GLenum target, GLintptr offset, GLsizeiptr length); +GLAPI void APIENTRY glBindVertexArray (GLuint array); +GLAPI void APIENTRY glDeleteVertexArrays (GLsizei n, const GLuint *arrays); +GLAPI void APIENTRY glGenVertexArrays (GLsizei n, GLuint *arrays); +GLAPI GLboolean APIENTRY glIsVertexArray (GLuint array); +#endif +#endif /* GL_VERSION_3_0 */ + +#ifndef GL_VERSION_3_1 +#define GL_VERSION_3_1 1 +#define GL_SAMPLER_2D_RECT 0x8B63 +#define GL_SAMPLER_2D_RECT_SHADOW 0x8B64 +#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_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_RECTANGLE 0x84F5 +#define GL_TEXTURE_BINDING_RECTANGLE 0x84F6 +#define GL_PROXY_TEXTURE_RECTANGLE 0x84F7 +#define GL_MAX_RECTANGLE_TEXTURE_SIZE 0x84F8 +#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_COPY_READ_BUFFER 0x8F36 +#define GL_COPY_WRITE_BUFFER 0x8F37 +#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_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_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_FRAGMENT_SHADER 0x8A46 +#define GL_INVALID_INDEX 0xFFFFFFFFu +typedef void (APIENTRYP PFNGLDRAWARRAYSINSTANCEDPROC) (GLenum mode, GLint first, GLsizei count, GLsizei instancecount); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount); +typedef void (APIENTRYP PFNGLTEXBUFFERPROC) (GLenum target, GLenum internalformat, GLuint buffer); +typedef void (APIENTRYP PFNGLPRIMITIVERESTARTINDEXPROC) (GLuint index); +typedef void (APIENTRYP PFNGLCOPYBUFFERSUBDATAPROC) (GLenum readTarget, GLenum writeTarget, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLGETUNIFORMINDICESPROC) (GLuint program, GLsizei uniformCount, const GLchar *const*uniformNames, GLuint *uniformIndices); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMSIVPROC) (GLuint program, GLsizei uniformCount, const GLuint *uniformIndices, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMNAMEPROC) (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformName); +typedef GLuint (APIENTRYP PFNGLGETUNIFORMBLOCKINDEXPROC) (GLuint program, const GLchar *uniformBlockName); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMBLOCKIVPROC) (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMBLOCKNAMEPROC) (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformBlockName); +typedef void (APIENTRYP PFNGLUNIFORMBLOCKBINDINGPROC) (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawArraysInstanced (GLenum mode, GLint first, GLsizei count, GLsizei instancecount); +GLAPI void APIENTRY glDrawElementsInstanced (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount); +GLAPI void APIENTRY glTexBuffer (GLenum target, GLenum internalformat, GLuint buffer); +GLAPI void APIENTRY glPrimitiveRestartIndex (GLuint index); +GLAPI void APIENTRY glCopyBufferSubData (GLenum readTarget, GLenum writeTarget, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +GLAPI void APIENTRY glGetUniformIndices (GLuint program, GLsizei uniformCount, const GLchar *const*uniformNames, GLuint *uniformIndices); +GLAPI void APIENTRY glGetActiveUniformsiv (GLuint program, GLsizei uniformCount, const GLuint *uniformIndices, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetActiveUniformName (GLuint program, GLuint uniformIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformName); +GLAPI GLuint APIENTRY glGetUniformBlockIndex (GLuint program, const GLchar *uniformBlockName); +GLAPI void APIENTRY glGetActiveUniformBlockiv (GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetActiveUniformBlockName (GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei *length, GLchar *uniformBlockName); +GLAPI void APIENTRY glUniformBlockBinding (GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding); +#endif +#endif /* GL_VERSION_3_1 */ + +#ifndef GL_VERSION_3_2 +#define GL_VERSION_3_2 1 +typedef struct __GLsync *GLsync; +#ifndef GLEXT_64_TYPES_DEFINED +/* This code block is duplicated in glxext.h, so must be protected */ +#define GLEXT_64_TYPES_DEFINED +/* Define int32_t, int64_t, and uint64_t types for UST/MSC */ +/* (as used in the GL_EXT_timer_query extension). */ +#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L +#include +#elif defined(__sun__) || defined(__digital__) +#include +#if defined(__STDC__) +#if defined(__arch64__) || defined(_LP64) +typedef long int int64_t; +typedef unsigned long int uint64_t; +#else +typedef long long int int64_t; +typedef unsigned long long int uint64_t; +#endif /* __arch64__ */ +#endif /* __STDC__ */ +#elif defined( __VMS ) || defined(__sgi) +#include +#elif defined(__SCO__) || defined(__USLC__) +#include +#elif defined(__UNIXOS2__) || defined(__SOL64__) +typedef long int int32_t; +typedef long long int int64_t; +typedef unsigned long long int uint64_t; +#elif defined(_WIN32) && defined(__GNUC__) +#include +#elif defined(_WIN32) +typedef __int32 int32_t; +typedef __int64 int64_t; +typedef unsigned __int64 uint64_t; +#else +/* Fallback if nothing above works */ +#include +#endif +#endif +typedef uint64_t GLuint64; +typedef int64_t GLint64; +#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_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_GEOMETRY_VERTICES_OUT 0x8916 +#define GL_GEOMETRY_INPUT_TYPE 0x8917 +#define GL_GEOMETRY_OUTPUT_TYPE 0x8918 +#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 +#define GL_DEPTH_CLAMP 0x864F +#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 +#define GL_TEXTURE_CUBE_MAP_SEAMLESS 0x884F +#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 0xFFFFFFFFFFFFFFFFull +#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001 +#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 (APIENTRYP PFNGLDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLint basevertex); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTSBASEVERTEXPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices, GLint basevertex); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLint basevertex); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSBASEVERTEXPROC) (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount, const GLint *basevertex); +typedef void (APIENTRYP PFNGLPROVOKINGVERTEXPROC) (GLenum mode); +typedef GLsync (APIENTRYP PFNGLFENCESYNCPROC) (GLenum condition, GLbitfield flags); +typedef GLboolean (APIENTRYP PFNGLISSYNCPROC) (GLsync sync); +typedef void (APIENTRYP PFNGLDELETESYNCPROC) (GLsync sync); +typedef GLenum (APIENTRYP PFNGLCLIENTWAITSYNCPROC) (GLsync sync, GLbitfield flags, GLuint64 timeout); +typedef void (APIENTRYP PFNGLWAITSYNCPROC) (GLsync sync, GLbitfield flags, GLuint64 timeout); +typedef void (APIENTRYP PFNGLGETINTEGER64VPROC) (GLenum pname, GLint64 *data); +typedef void (APIENTRYP PFNGLGETSYNCIVPROC) (GLsync sync, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +typedef void (APIENTRYP PFNGLGETINTEGER64I_VPROC) (GLenum target, GLuint index, GLint64 *data); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERI64VPROC) (GLenum target, GLenum pname, GLint64 *params); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLTEXIMAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLTEXIMAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLGETMULTISAMPLEFVPROC) (GLenum pname, GLuint index, GLfloat *val); +typedef void (APIENTRYP PFNGLSAMPLEMASKIPROC) (GLuint maskNumber, GLbitfield mask); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawElementsBaseVertex (GLenum mode, GLsizei count, GLenum type, const void *indices, GLint basevertex); +GLAPI void APIENTRY glDrawRangeElementsBaseVertex (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices, GLint basevertex); +GLAPI void APIENTRY glDrawElementsInstancedBaseVertex (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLint basevertex); +GLAPI void APIENTRY glMultiDrawElementsBaseVertex (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei drawcount, const GLint *basevertex); +GLAPI void APIENTRY glProvokingVertex (GLenum mode); +GLAPI GLsync APIENTRY glFenceSync (GLenum condition, GLbitfield flags); +GLAPI GLboolean APIENTRY glIsSync (GLsync sync); +GLAPI void APIENTRY glDeleteSync (GLsync sync); +GLAPI GLenum APIENTRY glClientWaitSync (GLsync sync, GLbitfield flags, GLuint64 timeout); +GLAPI void APIENTRY glWaitSync (GLsync sync, GLbitfield flags, GLuint64 timeout); +GLAPI void APIENTRY glGetInteger64v (GLenum pname, GLint64 *data); +GLAPI void APIENTRY glGetSynciv (GLsync sync, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +GLAPI void APIENTRY glGetInteger64i_v (GLenum target, GLuint index, GLint64 *data); +GLAPI void APIENTRY glGetBufferParameteri64v (GLenum target, GLenum pname, GLint64 *params); +GLAPI void APIENTRY glFramebufferTexture (GLenum target, GLenum attachment, GLuint texture, GLint level); +GLAPI void APIENTRY glTexImage2DMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glTexImage3DMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glGetMultisamplefv (GLenum pname, GLuint index, GLfloat *val); +GLAPI void APIENTRY glSampleMaski (GLuint maskNumber, GLbitfield mask); +#endif +#endif /* GL_VERSION_3_2 */ + +#ifndef GL_VERSION_3_3 +#define GL_VERSION_3_3 1 +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE +#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 +#define GL_ANY_SAMPLES_PASSED 0x8C2F +#define GL_SAMPLER_BINDING 0x8919 +#define GL_RGB10_A2UI 0x906F +#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_TIME_ELAPSED 0x88BF +#define GL_TIMESTAMP 0x8E28 +#define GL_INT_2_10_10_10_REV 0x8D9F +typedef void (APIENTRYP PFNGLBINDFRAGDATALOCATIONINDEXEDPROC) (GLuint program, GLuint colorNumber, GLuint index, const GLchar *name); +typedef GLint (APIENTRYP PFNGLGETFRAGDATAINDEXPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGENSAMPLERSPROC) (GLsizei count, GLuint *samplers); +typedef void (APIENTRYP PFNGLDELETESAMPLERSPROC) (GLsizei count, const GLuint *samplers); +typedef GLboolean (APIENTRYP PFNGLISSAMPLERPROC) (GLuint sampler); +typedef void (APIENTRYP PFNGLBINDSAMPLERPROC) (GLuint unit, GLuint sampler); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERIPROC) (GLuint sampler, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, const GLint *param); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERFPROC) (GLuint sampler, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, const GLfloat *param); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, const GLint *param); +typedef void (APIENTRYP PFNGLSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, const GLuint *param); +typedef void (APIENTRYP PFNGLGETSAMPLERPARAMETERIVPROC) (GLuint sampler, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSAMPLERPARAMETERIIVPROC) (GLuint sampler, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSAMPLERPARAMETERFVPROC) (GLuint sampler, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETSAMPLERPARAMETERIUIVPROC) (GLuint sampler, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLQUERYCOUNTERPROC) (GLuint id, GLenum target); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTI64VPROC) (GLuint id, GLenum pname, GLint64 *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUI64VPROC) (GLuint id, GLenum pname, GLuint64 *params); +typedef void (APIENTRYP PFNGLVERTEXATTRIBDIVISORPROC) (GLuint index, GLuint divisor); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP1UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP1UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP2UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP2UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP3UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP3UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP4UIPROC) (GLuint index, GLenum type, GLboolean normalized, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXATTRIBP4UIVPROC) (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXP2UIPROC) (GLenum type, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXP2UIVPROC) (GLenum type, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXP3UIPROC) (GLenum type, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXP3UIVPROC) (GLenum type, const GLuint *value); +typedef void (APIENTRYP PFNGLVERTEXP4UIPROC) (GLenum type, GLuint value); +typedef void (APIENTRYP PFNGLVERTEXP4UIVPROC) (GLenum type, const GLuint *value); +typedef void (APIENTRYP PFNGLTEXCOORDP1UIPROC) (GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLTEXCOORDP1UIVPROC) (GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLTEXCOORDP2UIPROC) (GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLTEXCOORDP2UIVPROC) (GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLTEXCOORDP3UIPROC) (GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLTEXCOORDP3UIVPROC) (GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLTEXCOORDP4UIPROC) (GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLTEXCOORDP4UIVPROC) (GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP1UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP1UIVPROC) (GLenum texture, GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP2UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP2UIVPROC) (GLenum texture, GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP3UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP3UIVPROC) (GLenum texture, GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP4UIPROC) (GLenum texture, GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORDP4UIVPROC) (GLenum texture, GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLNORMALP3UIPROC) (GLenum type, GLuint coords); +typedef void (APIENTRYP PFNGLNORMALP3UIVPROC) (GLenum type, const GLuint *coords); +typedef void (APIENTRYP PFNGLCOLORP3UIPROC) (GLenum type, GLuint color); +typedef void (APIENTRYP PFNGLCOLORP3UIVPROC) (GLenum type, const GLuint *color); +typedef void (APIENTRYP PFNGLCOLORP4UIPROC) (GLenum type, GLuint color); +typedef void (APIENTRYP PFNGLCOLORP4UIVPROC) (GLenum type, const GLuint *color); +typedef void (APIENTRYP PFNGLSECONDARYCOLORP3UIPROC) (GLenum type, GLuint color); +typedef void (APIENTRYP PFNGLSECONDARYCOLORP3UIVPROC) (GLenum type, const GLuint *color); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindFragDataLocationIndexed (GLuint program, GLuint colorNumber, GLuint index, const GLchar *name); +GLAPI GLint APIENTRY glGetFragDataIndex (GLuint program, const GLchar *name); +GLAPI void APIENTRY glGenSamplers (GLsizei count, GLuint *samplers); +GLAPI void APIENTRY glDeleteSamplers (GLsizei count, const GLuint *samplers); +GLAPI GLboolean APIENTRY glIsSampler (GLuint sampler); +GLAPI void APIENTRY glBindSampler (GLuint unit, GLuint sampler); +GLAPI void APIENTRY glSamplerParameteri (GLuint sampler, GLenum pname, GLint param); +GLAPI void APIENTRY glSamplerParameteriv (GLuint sampler, GLenum pname, const GLint *param); +GLAPI void APIENTRY glSamplerParameterf (GLuint sampler, GLenum pname, GLfloat param); +GLAPI void APIENTRY glSamplerParameterfv (GLuint sampler, GLenum pname, const GLfloat *param); +GLAPI void APIENTRY glSamplerParameterIiv (GLuint sampler, GLenum pname, const GLint *param); +GLAPI void APIENTRY glSamplerParameterIuiv (GLuint sampler, GLenum pname, const GLuint *param); +GLAPI void APIENTRY glGetSamplerParameteriv (GLuint sampler, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetSamplerParameterIiv (GLuint sampler, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetSamplerParameterfv (GLuint sampler, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetSamplerParameterIuiv (GLuint sampler, GLenum pname, GLuint *params); +GLAPI void APIENTRY glQueryCounter (GLuint id, GLenum target); +GLAPI void APIENTRY glGetQueryObjecti64v (GLuint id, GLenum pname, GLint64 *params); +GLAPI void APIENTRY glGetQueryObjectui64v (GLuint id, GLenum pname, GLuint64 *params); +GLAPI void APIENTRY glVertexAttribDivisor (GLuint index, GLuint divisor); +GLAPI void APIENTRY glVertexAttribP1ui (GLuint index, GLenum type, GLboolean normalized, GLuint value); +GLAPI void APIENTRY glVertexAttribP1uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +GLAPI void APIENTRY glVertexAttribP2ui (GLuint index, GLenum type, GLboolean normalized, GLuint value); +GLAPI void APIENTRY glVertexAttribP2uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +GLAPI void APIENTRY glVertexAttribP3ui (GLuint index, GLenum type, GLboolean normalized, GLuint value); +GLAPI void APIENTRY glVertexAttribP3uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +GLAPI void APIENTRY glVertexAttribP4ui (GLuint index, GLenum type, GLboolean normalized, GLuint value); +GLAPI void APIENTRY glVertexAttribP4uiv (GLuint index, GLenum type, GLboolean normalized, const GLuint *value); +GLAPI void APIENTRY glVertexP2ui (GLenum type, GLuint value); +GLAPI void APIENTRY glVertexP2uiv (GLenum type, const GLuint *value); +GLAPI void APIENTRY glVertexP3ui (GLenum type, GLuint value); +GLAPI void APIENTRY glVertexP3uiv (GLenum type, const GLuint *value); +GLAPI void APIENTRY glVertexP4ui (GLenum type, GLuint value); +GLAPI void APIENTRY glVertexP4uiv (GLenum type, const GLuint *value); +GLAPI void APIENTRY glTexCoordP1ui (GLenum type, GLuint coords); +GLAPI void APIENTRY glTexCoordP1uiv (GLenum type, const GLuint *coords); +GLAPI void APIENTRY glTexCoordP2ui (GLenum type, GLuint coords); +GLAPI void APIENTRY glTexCoordP2uiv (GLenum type, const GLuint *coords); +GLAPI void APIENTRY glTexCoordP3ui (GLenum type, GLuint coords); +GLAPI void APIENTRY glTexCoordP3uiv (GLenum type, const GLuint *coords); +GLAPI void APIENTRY glTexCoordP4ui (GLenum type, GLuint coords); +GLAPI void APIENTRY glTexCoordP4uiv (GLenum type, const GLuint *coords); +GLAPI void APIENTRY glMultiTexCoordP1ui (GLenum texture, GLenum type, GLuint coords); +GLAPI void APIENTRY glMultiTexCoordP1uiv (GLenum texture, GLenum type, const GLuint *coords); +GLAPI void APIENTRY glMultiTexCoordP2ui (GLenum texture, GLenum type, GLuint coords); +GLAPI void APIENTRY glMultiTexCoordP2uiv (GLenum texture, GLenum type, const GLuint *coords); +GLAPI void APIENTRY glMultiTexCoordP3ui (GLenum texture, GLenum type, GLuint coords); +GLAPI void APIENTRY glMultiTexCoordP3uiv (GLenum texture, GLenum type, const GLuint *coords); +GLAPI void APIENTRY glMultiTexCoordP4ui (GLenum texture, GLenum type, GLuint coords); +GLAPI void APIENTRY glMultiTexCoordP4uiv (GLenum texture, GLenum type, const GLuint *coords); +GLAPI void APIENTRY glNormalP3ui (GLenum type, GLuint coords); +GLAPI void APIENTRY glNormalP3uiv (GLenum type, const GLuint *coords); +GLAPI void APIENTRY glColorP3ui (GLenum type, GLuint color); +GLAPI void APIENTRY glColorP3uiv (GLenum type, const GLuint *color); +GLAPI void APIENTRY glColorP4ui (GLenum type, GLuint color); +GLAPI void APIENTRY glColorP4uiv (GLenum type, const GLuint *color); +GLAPI void APIENTRY glSecondaryColorP3ui (GLenum type, GLuint color); +GLAPI void APIENTRY glSecondaryColorP3uiv (GLenum type, const GLuint *color); +#endif +#endif /* GL_VERSION_3_3 */ + +#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_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 +#define GL_DRAW_INDIRECT_BUFFER 0x8F3F +#define GL_DRAW_INDIRECT_BUFFER_BINDING 0x8F43 +#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 GL_DOUBLE_VEC2 0x8FFC +#define GL_DOUBLE_VEC3 0x8FFD +#define GL_DOUBLE_VEC4 0x8FFE +#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_ACTIVE_SUBROUTINES 0x8DE5 +#define GL_ACTIVE_SUBROUTINE_UNIFORMS 0x8DE6 +#define GL_ACTIVE_SUBROUTINE_UNIFORM_LOCATIONS 0x8E47 +#define GL_ACTIVE_SUBROUTINE_MAX_LENGTH 0x8E48 +#define GL_ACTIVE_SUBROUTINE_UNIFORM_MAX_LENGTH 0x8E49 +#define GL_MAX_SUBROUTINES 0x8DE7 +#define GL_MAX_SUBROUTINE_UNIFORM_LOCATIONS 0x8DE8 +#define GL_NUM_COMPATIBLE_SUBROUTINES 0x8E4A +#define GL_COMPATIBLE_SUBROUTINES 0x8E4B +#define GL_PATCHES 0x000E +#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_MAX_TESS_CONTROL_UNIFORM_BLOCKS 0x8E89 +#define GL_MAX_TESS_EVALUATION_UNIFORM_BLOCKS 0x8E8A +#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_UNIFORM_BLOCK_REFERENCED_BY_TESS_CONTROL_SHADER 0x84F0 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_TESS_EVALUATION_SHADER 0x84F1 +#define GL_TESS_EVALUATION_SHADER 0x8E87 +#define GL_TESS_CONTROL_SHADER 0x8E88 +#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 +#define GL_MAX_TRANSFORM_FEEDBACK_BUFFERS 0x8E70 +typedef void (APIENTRYP PFNGLMINSAMPLESHADINGPROC) (GLfloat value); +typedef void (APIENTRYP PFNGLBLENDEQUATIONIPROC) (GLuint buf, GLenum mode); +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEIPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +typedef void (APIENTRYP PFNGLBLENDFUNCIPROC) (GLuint buf, GLenum src, GLenum dst); +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEIPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +typedef void (APIENTRYP PFNGLDRAWARRAYSINDIRECTPROC) (GLenum mode, const void *indirect); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const void *indirect); +typedef void (APIENTRYP PFNGLUNIFORM1DPROC) (GLint location, GLdouble x); +typedef void (APIENTRYP PFNGLUNIFORM2DPROC) (GLint location, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLUNIFORM3DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLUNIFORM4DPROC) (GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLUNIFORM1DVPROC) (GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORM2DVPROC) (GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORM3DVPROC) (GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORM4DVPROC) (GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3X4DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X2DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4X3DVPROC) (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLGETUNIFORMDVPROC) (GLuint program, GLint location, GLdouble *params); +typedef GLint (APIENTRYP PFNGLGETSUBROUTINEUNIFORMLOCATIONPROC) (GLuint program, GLenum shadertype, const GLchar *name); +typedef GLuint (APIENTRYP PFNGLGETSUBROUTINEINDEXPROC) (GLuint program, GLenum shadertype, const GLchar *name); +typedef void (APIENTRYP PFNGLGETACTIVESUBROUTINEUNIFORMIVPROC) (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint *values); +typedef void (APIENTRYP PFNGLGETACTIVESUBROUTINEUNIFORMNAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei *length, GLchar *name); +typedef void (APIENTRYP PFNGLGETACTIVESUBROUTINENAMEPROC) (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei *length, GLchar *name); +typedef void (APIENTRYP PFNGLUNIFORMSUBROUTINESUIVPROC) (GLenum shadertype, GLsizei count, const GLuint *indices); +typedef void (APIENTRYP PFNGLGETUNIFORMSUBROUTINEUIVPROC) (GLenum shadertype, GLint location, GLuint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSTAGEIVPROC) (GLuint program, GLenum shadertype, GLenum pname, GLint *values); +typedef void (APIENTRYP PFNGLPATCHPARAMETERIPROC) (GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLPATCHPARAMETERFVPROC) (GLenum pname, const GLfloat *values); +typedef void (APIENTRYP PFNGLBINDTRANSFORMFEEDBACKPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLDELETETRANSFORMFEEDBACKSPROC) (GLsizei n, const GLuint *ids); +typedef void (APIENTRYP PFNGLGENTRANSFORMFEEDBACKSPROC) (GLsizei n, GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISTRANSFORMFEEDBACKPROC) (GLuint id); +typedef void (APIENTRYP PFNGLPAUSETRANSFORMFEEDBACKPROC) (void); +typedef void (APIENTRYP PFNGLRESUMETRANSFORMFEEDBACKPROC) (void); +typedef void (APIENTRYP PFNGLDRAWTRANSFORMFEEDBACKPROC) (GLenum mode, GLuint id); +typedef void (APIENTRYP PFNGLDRAWTRANSFORMFEEDBACKSTREAMPROC) (GLenum mode, GLuint id, GLuint stream); +typedef void (APIENTRYP PFNGLBEGINQUERYINDEXEDPROC) (GLenum target, GLuint index, GLuint id); +typedef void (APIENTRYP PFNGLENDQUERYINDEXEDPROC) (GLenum target, GLuint index); +typedef void (APIENTRYP PFNGLGETQUERYINDEXEDIVPROC) (GLenum target, GLuint index, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMinSampleShading (GLfloat value); +GLAPI void APIENTRY glBlendEquationi (GLuint buf, GLenum mode); +GLAPI void APIENTRY glBlendEquationSeparatei (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +GLAPI void APIENTRY glBlendFunci (GLuint buf, GLenum src, GLenum dst); +GLAPI void APIENTRY glBlendFuncSeparatei (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +GLAPI void APIENTRY glDrawArraysIndirect (GLenum mode, const void *indirect); +GLAPI void APIENTRY glDrawElementsIndirect (GLenum mode, GLenum type, const void *indirect); +GLAPI void APIENTRY glUniform1d (GLint location, GLdouble x); +GLAPI void APIENTRY glUniform2d (GLint location, GLdouble x, GLdouble y); +GLAPI void APIENTRY glUniform3d (GLint location, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glUniform4d (GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glUniform1dv (GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glUniform2dv (GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glUniform3dv (GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glUniform4dv (GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix2dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix3dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix4dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix2x3dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix2x4dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix3x2dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix3x4dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix4x2dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glUniformMatrix4x3dv (GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glGetUniformdv (GLuint program, GLint location, GLdouble *params); +GLAPI GLint APIENTRY glGetSubroutineUniformLocation (GLuint program, GLenum shadertype, const GLchar *name); +GLAPI GLuint APIENTRY glGetSubroutineIndex (GLuint program, GLenum shadertype, const GLchar *name); +GLAPI void APIENTRY glGetActiveSubroutineUniformiv (GLuint program, GLenum shadertype, GLuint index, GLenum pname, GLint *values); +GLAPI void APIENTRY glGetActiveSubroutineUniformName (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei *length, GLchar *name); +GLAPI void APIENTRY glGetActiveSubroutineName (GLuint program, GLenum shadertype, GLuint index, GLsizei bufsize, GLsizei *length, GLchar *name); +GLAPI void APIENTRY glUniformSubroutinesuiv (GLenum shadertype, GLsizei count, const GLuint *indices); +GLAPI void APIENTRY glGetUniformSubroutineuiv (GLenum shadertype, GLint location, GLuint *params); +GLAPI void APIENTRY glGetProgramStageiv (GLuint program, GLenum shadertype, GLenum pname, GLint *values); +GLAPI void APIENTRY glPatchParameteri (GLenum pname, GLint value); +GLAPI void APIENTRY glPatchParameterfv (GLenum pname, const GLfloat *values); +GLAPI void APIENTRY glBindTransformFeedback (GLenum target, GLuint id); +GLAPI void APIENTRY glDeleteTransformFeedbacks (GLsizei n, const GLuint *ids); +GLAPI void APIENTRY glGenTransformFeedbacks (GLsizei n, GLuint *ids); +GLAPI GLboolean APIENTRY glIsTransformFeedback (GLuint id); +GLAPI void APIENTRY glPauseTransformFeedback (void); +GLAPI void APIENTRY glResumeTransformFeedback (void); +GLAPI void APIENTRY glDrawTransformFeedback (GLenum mode, GLuint id); +GLAPI void APIENTRY glDrawTransformFeedbackStream (GLenum mode, GLuint id, GLuint stream); +GLAPI void APIENTRY glBeginQueryIndexed (GLenum target, GLuint index, GLuint id); +GLAPI void APIENTRY glEndQueryIndexed (GLenum target, GLuint index); +GLAPI void APIENTRY glGetQueryIndexediv (GLenum target, GLuint index, GLenum pname, GLint *params); +#endif +#endif /* GL_VERSION_4_0 */ + +#ifndef GL_VERSION_4_1 +#define GL_VERSION_4_1 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_COMPILER 0x8DFA +#define GL_SHADER_BINARY_FORMATS 0x8DF8 +#define GL_NUM_SHADER_BINARY_FORMATS 0x8DF9 +#define GL_MAX_VERTEX_UNIFORM_VECTORS 0x8DFB +#define GL_MAX_VARYING_VECTORS 0x8DFC +#define GL_MAX_FRAGMENT_UNIFORM_VECTORS 0x8DFD +#define GL_RGB565 0x8D62 +#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 +#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_ALL_SHADER_BITS 0xFFFFFFFF +#define GL_PROGRAM_SEPARABLE 0x8258 +#define GL_ACTIVE_PROGRAM 0x8259 +#define GL_PROGRAM_PIPELINE_BINDING 0x825A +#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 +typedef void (APIENTRYP PFNGLRELEASESHADERCOMPILERPROC) (void); +typedef void (APIENTRYP PFNGLSHADERBINARYPROC) (GLsizei count, const GLuint *shaders, GLenum binaryformat, const void *binary, GLsizei length); +typedef void (APIENTRYP PFNGLGETSHADERPRECISIONFORMATPROC) (GLenum shadertype, GLenum precisiontype, GLint *range, GLint *precision); +typedef void (APIENTRYP PFNGLDEPTHRANGEFPROC) (GLfloat n, GLfloat f); +typedef void (APIENTRYP PFNGLCLEARDEPTHFPROC) (GLfloat d); +typedef void (APIENTRYP PFNGLGETPROGRAMBINARYPROC) (GLuint program, GLsizei bufSize, GLsizei *length, GLenum *binaryFormat, void *binary); +typedef void (APIENTRYP PFNGLPROGRAMBINARYPROC) (GLuint program, GLenum binaryFormat, const void *binary, GLsizei length); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERIPROC) (GLuint program, GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLUSEPROGRAMSTAGESPROC) (GLuint pipeline, GLbitfield stages, GLuint program); +typedef void (APIENTRYP PFNGLACTIVESHADERPROGRAMPROC) (GLuint pipeline, GLuint program); +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROGRAMVPROC) (GLenum type, GLsizei count, const GLchar *const*strings); +typedef void (APIENTRYP PFNGLBINDPROGRAMPIPELINEPROC) (GLuint pipeline); +typedef void (APIENTRYP PFNGLDELETEPROGRAMPIPELINESPROC) (GLsizei n, const GLuint *pipelines); +typedef void (APIENTRYP PFNGLGENPROGRAMPIPELINESPROC) (GLsizei n, GLuint *pipelines); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMPIPELINEPROC) (GLuint pipeline); +typedef void (APIENTRYP PFNGLGETPROGRAMPIPELINEIVPROC) (GLuint pipeline, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1IPROC) (GLuint program, GLint location, GLint v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1IVPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1FPROC) (GLuint program, GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1DPROC) (GLuint program, GLint location, GLdouble v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UIPROC) (GLuint program, GLint location, GLuint v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2IPROC) (GLuint program, GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2IVPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2FPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2DPROC) (GLuint program, GLint location, GLdouble v0, GLdouble v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UIPROC) (GLuint program, GLint location, GLuint v0, GLuint v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3IPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3IVPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3FPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3DPROC) (GLuint program, GLint location, GLdouble v0, GLdouble v1, GLdouble v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UIPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4IPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4IVPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4FPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4FVPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4DPROC) (GLuint program, GLint location, GLdouble v0, GLdouble v1, GLdouble v2, GLdouble v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4DVPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UIPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UIVPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X2FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X4FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X3FVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X2DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X4DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X3DVPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMPIPELINEPROC) (GLuint pipeline); +typedef void (APIENTRYP PFNGLGETPROGRAMPIPELINEINFOLOGPROC) (GLuint pipeline, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1DPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2DPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4DPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4DVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBLPOINTERPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBLDVPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLVIEWPORTARRAYVPROC) (GLuint first, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVIEWPORTINDEXEDFPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat w, GLfloat h); +typedef void (APIENTRYP PFNGLVIEWPORTINDEXEDFVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLSCISSORARRAYVPROC) (GLuint first, GLsizei count, const GLint *v); +typedef void (APIENTRYP PFNGLSCISSORINDEXEDPROC) (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLSCISSORINDEXEDVPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLDEPTHRANGEARRAYVPROC) (GLuint first, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLDEPTHRANGEINDEXEDPROC) (GLuint index, GLdouble n, GLdouble f); +typedef void (APIENTRYP PFNGLGETFLOATI_VPROC) (GLenum target, GLuint index, GLfloat *data); +typedef void (APIENTRYP PFNGLGETDOUBLEI_VPROC) (GLenum target, GLuint index, GLdouble *data); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glReleaseShaderCompiler (void); +GLAPI void APIENTRY glShaderBinary (GLsizei count, const GLuint *shaders, GLenum binaryformat, const void *binary, GLsizei length); +GLAPI void APIENTRY glGetShaderPrecisionFormat (GLenum shadertype, GLenum precisiontype, GLint *range, GLint *precision); +GLAPI void APIENTRY glDepthRangef (GLfloat n, GLfloat f); +GLAPI void APIENTRY glClearDepthf (GLfloat d); +GLAPI void APIENTRY glGetProgramBinary (GLuint program, GLsizei bufSize, GLsizei *length, GLenum *binaryFormat, void *binary); +GLAPI void APIENTRY glProgramBinary (GLuint program, GLenum binaryFormat, const void *binary, GLsizei length); +GLAPI void APIENTRY glProgramParameteri (GLuint program, GLenum pname, GLint value); +GLAPI void APIENTRY glUseProgramStages (GLuint pipeline, GLbitfield stages, GLuint program); +GLAPI void APIENTRY glActiveShaderProgram (GLuint pipeline, GLuint program); +GLAPI GLuint APIENTRY glCreateShaderProgramv (GLenum type, GLsizei count, const GLchar *const*strings); +GLAPI void APIENTRY glBindProgramPipeline (GLuint pipeline); +GLAPI void APIENTRY glDeleteProgramPipelines (GLsizei n, const GLuint *pipelines); +GLAPI void APIENTRY glGenProgramPipelines (GLsizei n, GLuint *pipelines); +GLAPI GLboolean APIENTRY glIsProgramPipeline (GLuint pipeline); +GLAPI void APIENTRY glGetProgramPipelineiv (GLuint pipeline, GLenum pname, GLint *params); +GLAPI void APIENTRY glProgramUniform1i (GLuint program, GLint location, GLint v0); +GLAPI void APIENTRY glProgramUniform1iv (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform1f (GLuint program, GLint location, GLfloat v0); +GLAPI void APIENTRY glProgramUniform1fv (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform1d (GLuint program, GLint location, GLdouble v0); +GLAPI void APIENTRY glProgramUniform1dv (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform1ui (GLuint program, GLint location, GLuint v0); +GLAPI void APIENTRY glProgramUniform1uiv (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform2i (GLuint program, GLint location, GLint v0, GLint v1); +GLAPI void APIENTRY glProgramUniform2iv (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform2f (GLuint program, GLint location, GLfloat v0, GLfloat v1); +GLAPI void APIENTRY glProgramUniform2fv (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform2d (GLuint program, GLint location, GLdouble v0, GLdouble v1); +GLAPI void APIENTRY glProgramUniform2dv (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform2ui (GLuint program, GLint location, GLuint v0, GLuint v1); +GLAPI void APIENTRY glProgramUniform2uiv (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform3i (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); +GLAPI void APIENTRY glProgramUniform3iv (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform3f (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +GLAPI void APIENTRY glProgramUniform3fv (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform3d (GLuint program, GLint location, GLdouble v0, GLdouble v1, GLdouble v2); +GLAPI void APIENTRY glProgramUniform3dv (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform3ui (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); +GLAPI void APIENTRY glProgramUniform3uiv (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform4i (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +GLAPI void APIENTRY glProgramUniform4iv (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform4f (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +GLAPI void APIENTRY glProgramUniform4fv (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform4d (GLuint program, GLint location, GLdouble v0, GLdouble v1, GLdouble v2, GLdouble v3); +GLAPI void APIENTRY glProgramUniform4dv (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform4ui (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +GLAPI void APIENTRY glProgramUniform4uiv (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniformMatrix2fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix2dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix2x3fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3x2fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix2x4fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4x2fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3x4fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4x3fv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix2x3dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3x2dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix2x4dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4x2dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3x4dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4x3dv (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glValidateProgramPipeline (GLuint pipeline); +GLAPI void APIENTRY glGetProgramPipelineInfoLog (GLuint pipeline, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +GLAPI void APIENTRY glVertexAttribL1d (GLuint index, GLdouble x); +GLAPI void APIENTRY glVertexAttribL2d (GLuint index, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexAttribL3d (GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexAttribL4d (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexAttribL1dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL2dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL3dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL4dv (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribLPointer (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glGetVertexAttribLdv (GLuint index, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glViewportArrayv (GLuint first, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glViewportIndexedf (GLuint index, GLfloat x, GLfloat y, GLfloat w, GLfloat h); +GLAPI void APIENTRY glViewportIndexedfv (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glScissorArrayv (GLuint first, GLsizei count, const GLint *v); +GLAPI void APIENTRY glScissorIndexed (GLuint index, GLint left, GLint bottom, GLsizei width, GLsizei height); +GLAPI void APIENTRY glScissorIndexedv (GLuint index, const GLint *v); +GLAPI void APIENTRY glDepthRangeArrayv (GLuint first, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glDepthRangeIndexed (GLuint index, GLdouble n, GLdouble f); +GLAPI void APIENTRY glGetFloati_v (GLenum target, GLuint index, GLfloat *data); +GLAPI void APIENTRY glGetDoublei_v (GLenum target, GLuint index, GLdouble *data); +#endif +#endif /* GL_VERSION_4_1 */ + +#ifndef GL_VERSION_4_2 +#define GL_VERSION_4_2 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 GL_NUM_SAMPLE_COUNTS 0x9380 +#define GL_MIN_MAP_BUFFER_ALIGNMENT 0x90BC +#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_MAX_ATOMIC_COUNTER_BUFFER_BINDINGS 0x92DC +#define GL_ACTIVE_ATOMIC_COUNTER_BUFFERS 0x92D9 +#define GL_UNIFORM_ATOMIC_COUNTER_BUFFER_INDEX 0x92DA +#define GL_UNSIGNED_INT_ATOMIC_COUNTER 0x92DB +#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_ALL_BARRIER_BITS 0xFFFFFFFF +#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_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 GL_TEXTURE_IMMUTABLE_FORMAT 0x912F +typedef void (APIENTRYP PFNGLDRAWARRAYSINSTANCEDBASEINSTANCEPROC) (GLenum mode, GLint first, GLsizei count, GLsizei instancecount, GLuint baseinstance); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDBASEINSTANCEPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLuint baseinstance); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCEPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLint basevertex, GLuint baseinstance); +typedef void (APIENTRYP PFNGLGETINTERNALFORMATIVPROC) (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint *params); +typedef void (APIENTRYP PFNGLGETACTIVEATOMICCOUNTERBUFFERIVPROC) (GLuint program, GLuint bufferIndex, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLBINDIMAGETEXTUREPROC) (GLuint unit, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLenum format); +typedef void (APIENTRYP PFNGLMEMORYBARRIERPROC) (GLbitfield barriers); +typedef void (APIENTRYP PFNGLTEXSTORAGE1DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +typedef void (APIENTRYP PFNGLTEXSTORAGE2DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLTEXSTORAGE3DPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +typedef void (APIENTRYP PFNGLDRAWTRANSFORMFEEDBACKINSTANCEDPROC) (GLenum mode, GLuint id, GLsizei instancecount); +typedef void (APIENTRYP PFNGLDRAWTRANSFORMFEEDBACKSTREAMINSTANCEDPROC) (GLenum mode, GLuint id, GLuint stream, GLsizei instancecount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawArraysInstancedBaseInstance (GLenum mode, GLint first, GLsizei count, GLsizei instancecount, GLuint baseinstance); +GLAPI void APIENTRY glDrawElementsInstancedBaseInstance (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLuint baseinstance); +GLAPI void APIENTRY glDrawElementsInstancedBaseVertexBaseInstance (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei instancecount, GLint basevertex, GLuint baseinstance); +GLAPI void APIENTRY glGetInternalformativ (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint *params); +GLAPI void APIENTRY glGetActiveAtomicCounterBufferiv (GLuint program, GLuint bufferIndex, GLenum pname, GLint *params); +GLAPI void APIENTRY glBindImageTexture (GLuint unit, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLenum format); +GLAPI void APIENTRY glMemoryBarrier (GLbitfield barriers); +GLAPI void APIENTRY glTexStorage1D (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +GLAPI void APIENTRY glTexStorage2D (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glTexStorage3D (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +GLAPI void APIENTRY glDrawTransformFeedbackInstanced (GLenum mode, GLuint id, GLsizei instancecount); +GLAPI void APIENTRY glDrawTransformFeedbackStreamInstanced (GLenum mode, GLuint id, GLuint stream, GLsizei instancecount); +#endif +#endif /* GL_VERSION_4_2 */ + +#ifndef GL_VERSION_4_3 +#define GL_VERSION_4_3 1 +typedef void (APIENTRY *GLDEBUGPROC)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +#define GL_NUM_SHADING_LANGUAGE_VERSIONS 0x82E9 +#define GL_VERTEX_ATTRIB_ARRAY_LONG 0x874E +#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 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_PRIMITIVE_RESTART_FIXED_INDEX 0x8D69 +#define GL_ANY_SAMPLES_PASSED_CONSERVATIVE 0x8D6A +#define GL_MAX_ELEMENT_INDEX 0x8D6B +#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_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_MAX_COMPUTE_WORK_GROUP_INVOCATIONS 0x90EB +#define GL_MAX_COMPUTE_WORK_GROUP_COUNT 0x91BE +#define GL_MAX_COMPUTE_WORK_GROUP_SIZE 0x91BF +#define GL_COMPUTE_WORK_GROUP_SIZE 0x8267 +#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_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_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_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_MAX_LABEL_LENGTH 0x82E8 +#define GL_DEBUG_OUTPUT 0x92E0 +#define GL_CONTEXT_FLAG_DEBUG_BIT 0x00000002 +#define GL_MAX_UNIFORM_LOCATIONS 0x826E +#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 +#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_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 +#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_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 +#define GL_IS_PER_PATCH 0x92E7 +#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 +#define GL_SHADER_STORAGE_BARRIER_BIT 0x00002000 +#define GL_MAX_COMBINED_SHADER_OUTPUT_RESOURCES 0x8F39 +#define GL_DEPTH_STENCIL_TEXTURE_MODE 0x90EA +#define GL_TEXTURE_BUFFER_OFFSET 0x919D +#define GL_TEXTURE_BUFFER_SIZE 0x919E +#define GL_TEXTURE_BUFFER_OFFSET_ALIGNMENT 0x919F +#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 +#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 +#define GL_VERTEX_BINDING_BUFFER 0x8F4F +#define GL_DISPLAY_LIST 0x82E7 +typedef void (APIENTRYP PFNGLCLEARBUFFERDATAPROC) (GLenum target, GLenum internalformat, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLCLEARBUFFERSUBDATAPROC) (GLenum target, GLenum internalformat, GLintptr offset, GLsizeiptr size, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLDISPATCHCOMPUTEPROC) (GLuint num_groups_x, GLuint num_groups_y, GLuint num_groups_z); +typedef void (APIENTRYP PFNGLDISPATCHCOMPUTEINDIRECTPROC) (GLintptr indirect); +typedef void (APIENTRYP 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); +typedef void (APIENTRYP PFNGLFRAMEBUFFERPARAMETERIPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETINTERNALFORMATI64VPROC) (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint64 *params); +typedef void (APIENTRYP PFNGLINVALIDATETEXSUBIMAGEPROC) (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth); +typedef void (APIENTRYP PFNGLINVALIDATETEXIMAGEPROC) (GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLINVALIDATEBUFFERSUBDATAPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); +typedef void (APIENTRYP PFNGLINVALIDATEBUFFERDATAPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLINVALIDATEFRAMEBUFFERPROC) (GLenum target, GLsizei numAttachments, const GLenum *attachments); +typedef void (APIENTRYP PFNGLINVALIDATESUBFRAMEBUFFERPROC) (GLenum target, GLsizei numAttachments, const GLenum *attachments, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTPROC) (GLenum mode, const void *indirect, GLsizei drawcount, GLsizei stride); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTPROC) (GLenum mode, GLenum type, const void *indirect, GLsizei drawcount, GLsizei stride); +typedef void (APIENTRYP PFNGLGETPROGRAMINTERFACEIVPROC) (GLuint program, GLenum programInterface, GLenum pname, GLint *params); +typedef GLuint (APIENTRYP PFNGLGETPROGRAMRESOURCEINDEXPROC) (GLuint program, GLenum programInterface, const GLchar *name); +typedef void (APIENTRYP PFNGLGETPROGRAMRESOURCENAMEPROC) (GLuint program, GLenum programInterface, GLuint index, GLsizei bufSize, GLsizei *length, GLchar *name); +typedef void (APIENTRYP PFNGLGETPROGRAMRESOURCEIVPROC) (GLuint program, GLenum programInterface, GLuint index, GLsizei propCount, const GLenum *props, GLsizei bufSize, GLsizei *length, GLint *params); +typedef GLint (APIENTRYP PFNGLGETPROGRAMRESOURCELOCATIONPROC) (GLuint program, GLenum programInterface, const GLchar *name); +typedef GLint (APIENTRYP PFNGLGETPROGRAMRESOURCELOCATIONINDEXPROC) (GLuint program, GLenum programInterface, const GLchar *name); +typedef void (APIENTRYP PFNGLSHADERSTORAGEBLOCKBINDINGPROC) (GLuint program, GLuint storageBlockIndex, GLuint storageBlockBinding); +typedef void (APIENTRYP PFNGLTEXBUFFERRANGEPROC) (GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLTEXSTORAGE2DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLTEXSTORAGE3DMULTISAMPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLTEXTUREVIEWPROC) (GLuint texture, GLenum target, GLuint origtexture, GLenum internalformat, GLuint minlevel, GLuint numlevels, GLuint minlayer, GLuint numlayers); +typedef void (APIENTRYP PFNGLBINDVERTEXBUFFERPROC) (GLuint bindingindex, GLuint buffer, GLintptr offset, GLsizei stride); +typedef void (APIENTRYP PFNGLVERTEXATTRIBFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLboolean normalized, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXATTRIBIFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXATTRIBLFORMATPROC) (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXATTRIBBINDINGPROC) (GLuint attribindex, GLuint bindingindex); +typedef void (APIENTRYP PFNGLVERTEXBINDINGDIVISORPROC) (GLuint bindingindex, GLuint divisor); +typedef void (APIENTRYP PFNGLDEBUGMESSAGECONTROLPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKPROC) (GLDEBUGPROC callback, const void *userParam); +typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGPROC) (GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +typedef void (APIENTRYP PFNGLPUSHDEBUGGROUPPROC) (GLenum source, GLuint id, GLsizei length, const GLchar *message); +typedef void (APIENTRYP PFNGLPOPDEBUGGROUPPROC) (void); +typedef void (APIENTRYP PFNGLOBJECTLABELPROC) (GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +typedef void (APIENTRYP PFNGLGETOBJECTLABELPROC) (GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +typedef void (APIENTRYP PFNGLOBJECTPTRLABELPROC) (const void *ptr, GLsizei length, const GLchar *label); +typedef void (APIENTRYP PFNGLGETOBJECTPTRLABELPROC) (const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glClearBufferData (GLenum target, GLenum internalformat, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glClearBufferSubData (GLenum target, GLenum internalformat, GLintptr offset, GLsizeiptr size, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glDispatchCompute (GLuint num_groups_x, GLuint num_groups_y, GLuint num_groups_z); +GLAPI void APIENTRY glDispatchComputeIndirect (GLintptr indirect); +GLAPI void APIENTRY glCopyImageSubData (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); +GLAPI void APIENTRY glFramebufferParameteri (GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glGetFramebufferParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetInternalformati64v (GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize, GLint64 *params); +GLAPI void APIENTRY glInvalidateTexSubImage (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth); +GLAPI void APIENTRY glInvalidateTexImage (GLuint texture, GLint level); +GLAPI void APIENTRY glInvalidateBufferSubData (GLuint buffer, GLintptr offset, GLsizeiptr length); +GLAPI void APIENTRY glInvalidateBufferData (GLuint buffer); +GLAPI void APIENTRY glInvalidateFramebuffer (GLenum target, GLsizei numAttachments, const GLenum *attachments); +GLAPI void APIENTRY glInvalidateSubFramebuffer (GLenum target, GLsizei numAttachments, const GLenum *attachments, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glMultiDrawArraysIndirect (GLenum mode, const void *indirect, GLsizei drawcount, GLsizei stride); +GLAPI void APIENTRY glMultiDrawElementsIndirect (GLenum mode, GLenum type, const void *indirect, GLsizei drawcount, GLsizei stride); +GLAPI void APIENTRY glGetProgramInterfaceiv (GLuint program, GLenum programInterface, GLenum pname, GLint *params); +GLAPI GLuint APIENTRY glGetProgramResourceIndex (GLuint program, GLenum programInterface, const GLchar *name); +GLAPI void APIENTRY glGetProgramResourceName (GLuint program, GLenum programInterface, GLuint index, GLsizei bufSize, GLsizei *length, GLchar *name); +GLAPI void APIENTRY glGetProgramResourceiv (GLuint program, GLenum programInterface, GLuint index, GLsizei propCount, const GLenum *props, GLsizei bufSize, GLsizei *length, GLint *params); +GLAPI GLint APIENTRY glGetProgramResourceLocation (GLuint program, GLenum programInterface, const GLchar *name); +GLAPI GLint APIENTRY glGetProgramResourceLocationIndex (GLuint program, GLenum programInterface, const GLchar *name); +GLAPI void APIENTRY glShaderStorageBlockBinding (GLuint program, GLuint storageBlockIndex, GLuint storageBlockBinding); +GLAPI void APIENTRY glTexBufferRange (GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI void APIENTRY glTexStorage2DMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glTexStorage3DMultisample (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glTextureView (GLuint texture, GLenum target, GLuint origtexture, GLenum internalformat, GLuint minlevel, GLuint numlevels, GLuint minlayer, GLuint numlayers); +GLAPI void APIENTRY glBindVertexBuffer (GLuint bindingindex, GLuint buffer, GLintptr offset, GLsizei stride); +GLAPI void APIENTRY glVertexAttribFormat (GLuint attribindex, GLint size, GLenum type, GLboolean normalized, GLuint relativeoffset); +GLAPI void APIENTRY glVertexAttribIFormat (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +GLAPI void APIENTRY glVertexAttribLFormat (GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +GLAPI void APIENTRY glVertexAttribBinding (GLuint attribindex, GLuint bindingindex); +GLAPI void APIENTRY glVertexBindingDivisor (GLuint bindingindex, GLuint divisor); +GLAPI void APIENTRY glDebugMessageControl (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GLAPI void APIENTRY glDebugMessageInsert (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +GLAPI void APIENTRY glDebugMessageCallback (GLDEBUGPROC callback, const void *userParam); +GLAPI GLuint APIENTRY glGetDebugMessageLog (GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +GLAPI void APIENTRY glPushDebugGroup (GLenum source, GLuint id, GLsizei length, const GLchar *message); +GLAPI void APIENTRY glPopDebugGroup (void); +GLAPI void APIENTRY glObjectLabel (GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +GLAPI void APIENTRY glGetObjectLabel (GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +GLAPI void APIENTRY glObjectPtrLabel (const void *ptr, GLsizei length, const GLchar *label); +GLAPI void APIENTRY glGetObjectPtrLabel (const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +#endif +#endif /* GL_VERSION_4_3 */ + +#ifndef GL_VERSION_4_4 +#define GL_VERSION_4_4 1 +#define GL_MAX_VERTEX_ATTRIB_STRIDE 0x82E5 +#define GL_PRIMITIVE_RESTART_FOR_PATCHES_SUPPORTED 0x8221 +#define GL_TEXTURE_BUFFER_BINDING 0x8C2A +#define GL_MAP_PERSISTENT_BIT 0x0040 +#define GL_MAP_COHERENT_BIT 0x0080 +#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 +#define GL_CLEAR_TEXTURE 0x9365 +#define GL_LOCATION_COMPONENT 0x934A +#define GL_TRANSFORM_FEEDBACK_BUFFER_INDEX 0x934B +#define GL_TRANSFORM_FEEDBACK_BUFFER_STRIDE 0x934C +#define GL_QUERY_BUFFER 0x9192 +#define GL_QUERY_BUFFER_BARRIER_BIT 0x00008000 +#define GL_QUERY_BUFFER_BINDING 0x9193 +#define GL_QUERY_RESULT_NO_WAIT 0x9194 +#define GL_MIRROR_CLAMP_TO_EDGE 0x8743 +typedef void (APIENTRYP PFNGLBUFFERSTORAGEPROC) (GLenum target, GLsizeiptr size, const void *data, GLbitfield flags); +typedef void (APIENTRYP PFNGLCLEARTEXIMAGEPROC) (GLuint texture, GLint level, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLCLEARTEXSUBIMAGEPROC) (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLBINDBUFFERSBASEPROC) (GLenum target, GLuint first, GLsizei count, const GLuint *buffers); +typedef void (APIENTRYP PFNGLBINDBUFFERSRANGEPROC) (GLenum target, GLuint first, GLsizei count, const GLuint *buffers, const GLintptr *offsets, const GLsizeiptr *sizes); +typedef void (APIENTRYP PFNGLBINDTEXTURESPROC) (GLuint first, GLsizei count, const GLuint *textures); +typedef void (APIENTRYP PFNGLBINDSAMPLERSPROC) (GLuint first, GLsizei count, const GLuint *samplers); +typedef void (APIENTRYP PFNGLBINDIMAGETEXTURESPROC) (GLuint first, GLsizei count, const GLuint *textures); +typedef void (APIENTRYP PFNGLBINDVERTEXBUFFERSPROC) (GLuint first, GLsizei count, const GLuint *buffers, const GLintptr *offsets, const GLsizei *strides); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBufferStorage (GLenum target, GLsizeiptr size, const void *data, GLbitfield flags); +GLAPI void APIENTRY glClearTexImage (GLuint texture, GLint level, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glClearTexSubImage (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glBindBuffersBase (GLenum target, GLuint first, GLsizei count, const GLuint *buffers); +GLAPI void APIENTRY glBindBuffersRange (GLenum target, GLuint first, GLsizei count, const GLuint *buffers, const GLintptr *offsets, const GLsizeiptr *sizes); +GLAPI void APIENTRY glBindTextures (GLuint first, GLsizei count, const GLuint *textures); +GLAPI void APIENTRY glBindSamplers (GLuint first, GLsizei count, const GLuint *samplers); +GLAPI void APIENTRY glBindImageTextures (GLuint first, GLsizei count, const GLuint *textures); +GLAPI void APIENTRY glBindVertexBuffers (GLuint first, GLsizei count, const GLuint *buffers, const GLintptr *offsets, const GLsizei *strides); +#endif +#endif /* GL_VERSION_4_4 */ + +#ifndef GL_ARB_ES2_compatibility +#define GL_ARB_ES2_compatibility 1 +#endif /* GL_ARB_ES2_compatibility */ + +#ifndef GL_ARB_ES3_compatibility +#define GL_ARB_ES3_compatibility 1 +#endif /* GL_ARB_ES3_compatibility */ + +#ifndef GL_ARB_arrays_of_arrays +#define GL_ARB_arrays_of_arrays 1 +#endif /* GL_ARB_arrays_of_arrays */ + +#ifndef GL_ARB_base_instance +#define GL_ARB_base_instance 1 +#endif /* GL_ARB_base_instance */ + +#ifndef GL_ARB_bindless_texture +#define GL_ARB_bindless_texture 1 +typedef uint64_t GLuint64EXT; +#define GL_UNSIGNED_INT64_ARB 0x140F +typedef GLuint64 (APIENTRYP PFNGLGETTEXTUREHANDLEARBPROC) (GLuint texture); +typedef GLuint64 (APIENTRYP PFNGLGETTEXTURESAMPLERHANDLEARBPROC) (GLuint texture, GLuint sampler); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLERESIDENTARBPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLENONRESIDENTARBPROC) (GLuint64 handle); +typedef GLuint64 (APIENTRYP PFNGLGETIMAGEHANDLEARBPROC) (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLERESIDENTARBPROC) (GLuint64 handle, GLenum access); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLENONRESIDENTARBPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64ARBPROC) (GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64VARBPROC) (GLint location, GLsizei count, const GLuint64 *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64ARBPROC) (GLuint program, GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64VARBPROC) (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +typedef GLboolean (APIENTRYP PFNGLISTEXTUREHANDLERESIDENTARBPROC) (GLuint64 handle); +typedef GLboolean (APIENTRYP PFNGLISIMAGEHANDLERESIDENTARBPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1UI64ARBPROC) (GLuint index, GLuint64EXT x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1UI64VARBPROC) (GLuint index, const GLuint64EXT *v); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBLUI64VARBPROC) (GLuint index, GLenum pname, GLuint64EXT *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint64 APIENTRY glGetTextureHandleARB (GLuint texture); +GLAPI GLuint64 APIENTRY glGetTextureSamplerHandleARB (GLuint texture, GLuint sampler); +GLAPI void APIENTRY glMakeTextureHandleResidentARB (GLuint64 handle); +GLAPI void APIENTRY glMakeTextureHandleNonResidentARB (GLuint64 handle); +GLAPI GLuint64 APIENTRY glGetImageHandleARB (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +GLAPI void APIENTRY glMakeImageHandleResidentARB (GLuint64 handle, GLenum access); +GLAPI void APIENTRY glMakeImageHandleNonResidentARB (GLuint64 handle); +GLAPI void APIENTRY glUniformHandleui64ARB (GLint location, GLuint64 value); +GLAPI void APIENTRY glUniformHandleui64vARB (GLint location, GLsizei count, const GLuint64 *value); +GLAPI void APIENTRY glProgramUniformHandleui64ARB (GLuint program, GLint location, GLuint64 value); +GLAPI void APIENTRY glProgramUniformHandleui64vARB (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +GLAPI GLboolean APIENTRY glIsTextureHandleResidentARB (GLuint64 handle); +GLAPI GLboolean APIENTRY glIsImageHandleResidentARB (GLuint64 handle); +GLAPI void APIENTRY glVertexAttribL1ui64ARB (GLuint index, GLuint64EXT x); +GLAPI void APIENTRY glVertexAttribL1ui64vARB (GLuint index, const GLuint64EXT *v); +GLAPI void APIENTRY glGetVertexAttribLui64vARB (GLuint index, GLenum pname, GLuint64EXT *params); +#endif +#endif /* GL_ARB_bindless_texture */ + +#ifndef GL_ARB_blend_func_extended +#define GL_ARB_blend_func_extended 1 +#endif /* GL_ARB_blend_func_extended */ + +#ifndef GL_ARB_buffer_storage +#define GL_ARB_buffer_storage 1 +#endif /* GL_ARB_buffer_storage */ + +#ifndef GL_ARB_cl_event +#define GL_ARB_cl_event 1 +struct _cl_context; +struct _cl_event; +#define GL_SYNC_CL_EVENT_ARB 0x8240 +#define GL_SYNC_CL_EVENT_COMPLETE_ARB 0x8241 +typedef GLsync (APIENTRYP PFNGLCREATESYNCFROMCLEVENTARBPROC) (struct _cl_context *context, struct _cl_event *event, GLbitfield flags); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLsync APIENTRY glCreateSyncFromCLeventARB (struct _cl_context *context, struct _cl_event *event, GLbitfield flags); +#endif +#endif /* GL_ARB_cl_event */ + +#ifndef GL_ARB_clear_buffer_object +#define GL_ARB_clear_buffer_object 1 +#endif /* GL_ARB_clear_buffer_object */ + +#ifndef GL_ARB_clear_texture +#define GL_ARB_clear_texture 1 +#endif /* GL_ARB_clear_texture */ + +#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 (APIENTRYP PFNGLCLAMPCOLORARBPROC) (GLenum target, GLenum clamp); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glClampColorARB (GLenum target, GLenum clamp); +#endif +#endif /* GL_ARB_color_buffer_float */ + +#ifndef GL_ARB_compatibility +#define GL_ARB_compatibility 1 +#endif /* GL_ARB_compatibility */ + +#ifndef GL_ARB_compressed_texture_pixel_storage +#define GL_ARB_compressed_texture_pixel_storage 1 +#endif /* GL_ARB_compressed_texture_pixel_storage */ + +#ifndef GL_ARB_compute_shader +#define GL_ARB_compute_shader 1 +#define GL_COMPUTE_SHADER_BIT 0x00000020 +#endif /* GL_ARB_compute_shader */ + +#ifndef GL_ARB_compute_variable_group_size +#define GL_ARB_compute_variable_group_size 1 +#define GL_MAX_COMPUTE_VARIABLE_GROUP_INVOCATIONS_ARB 0x9344 +#define GL_MAX_COMPUTE_FIXED_GROUP_INVOCATIONS_ARB 0x90EB +#define GL_MAX_COMPUTE_VARIABLE_GROUP_SIZE_ARB 0x9345 +#define GL_MAX_COMPUTE_FIXED_GROUP_SIZE_ARB 0x91BF +typedef void (APIENTRYP 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); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDispatchComputeGroupSizeARB (GLuint num_groups_x, GLuint num_groups_y, GLuint num_groups_z, GLuint group_size_x, GLuint group_size_y, GLuint group_size_z); +#endif +#endif /* GL_ARB_compute_variable_group_size */ + +#ifndef GL_ARB_conservative_depth +#define GL_ARB_conservative_depth 1 +#endif /* GL_ARB_conservative_depth */ + +#ifndef GL_ARB_copy_buffer +#define GL_ARB_copy_buffer 1 +#define GL_COPY_READ_BUFFER_BINDING 0x8F36 +#define GL_COPY_WRITE_BUFFER_BINDING 0x8F37 +#endif /* GL_ARB_copy_buffer */ + +#ifndef GL_ARB_copy_image +#define GL_ARB_copy_image 1 +#endif /* GL_ARB_copy_image */ + +#ifndef GL_ARB_debug_output +#define GL_ARB_debug_output 1 +typedef void (APIENTRY *GLDEBUGPROCARB)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +#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 (APIENTRYP PFNGLDEBUGMESSAGECONTROLARBPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTARBPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKARBPROC) (GLDEBUGPROCARB callback, const void *userParam); +typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGARBPROC) (GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDebugMessageControlARB (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GLAPI void APIENTRY glDebugMessageInsertARB (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +GLAPI void APIENTRY glDebugMessageCallbackARB (GLDEBUGPROCARB callback, const void *userParam); +GLAPI GLuint APIENTRY glGetDebugMessageLogARB (GLuint count, GLsizei bufSize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +#endif +#endif /* GL_ARB_debug_output */ + +#ifndef GL_ARB_depth_buffer_float +#define GL_ARB_depth_buffer_float 1 +#endif /* GL_ARB_depth_buffer_float */ + +#ifndef GL_ARB_depth_clamp +#define GL_ARB_depth_clamp 1 +#endif /* GL_ARB_depth_clamp */ + +#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 +#endif /* GL_ARB_depth_texture */ + +#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 (APIENTRYP PFNGLDRAWBUFFERSARBPROC) (GLsizei n, const GLenum *bufs); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawBuffersARB (GLsizei n, const GLenum *bufs); +#endif +#endif /* GL_ARB_draw_buffers */ + +#ifndef GL_ARB_draw_buffers_blend +#define GL_ARB_draw_buffers_blend 1 +typedef void (APIENTRYP PFNGLBLENDEQUATIONIARBPROC) (GLuint buf, GLenum mode); +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEIARBPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +typedef void (APIENTRYP PFNGLBLENDFUNCIARBPROC) (GLuint buf, GLenum src, GLenum dst); +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEIARBPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationiARB (GLuint buf, GLenum mode); +GLAPI void APIENTRY glBlendEquationSeparateiARB (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +GLAPI void APIENTRY glBlendFunciARB (GLuint buf, GLenum src, GLenum dst); +GLAPI void APIENTRY glBlendFuncSeparateiARB (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +#endif +#endif /* GL_ARB_draw_buffers_blend */ + +#ifndef GL_ARB_draw_elements_base_vertex +#define GL_ARB_draw_elements_base_vertex 1 +#endif /* GL_ARB_draw_elements_base_vertex */ + +#ifndef GL_ARB_draw_indirect +#define GL_ARB_draw_indirect 1 +#endif /* GL_ARB_draw_indirect */ + +#ifndef GL_ARB_draw_instanced +#define GL_ARB_draw_instanced 1 +typedef void (APIENTRYP PFNGLDRAWARRAYSINSTANCEDARBPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDARBPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawArraysInstancedARB (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +GLAPI void APIENTRY glDrawElementsInstancedARB (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +#endif +#endif /* GL_ARB_draw_instanced */ + +#ifndef GL_ARB_enhanced_layouts +#define GL_ARB_enhanced_layouts 1 +#endif /* GL_ARB_enhanced_layouts */ + +#ifndef GL_ARB_explicit_attrib_location +#define GL_ARB_explicit_attrib_location 1 +#endif /* GL_ARB_explicit_attrib_location */ + +#ifndef GL_ARB_explicit_uniform_location +#define GL_ARB_explicit_uniform_location 1 +#endif /* GL_ARB_explicit_uniform_location */ + +#ifndef GL_ARB_fragment_coord_conventions +#define GL_ARB_fragment_coord_conventions 1 +#endif /* GL_ARB_fragment_coord_conventions */ + +#ifndef GL_ARB_fragment_layer_viewport +#define GL_ARB_fragment_layer_viewport 1 +#endif /* GL_ARB_fragment_layer_viewport */ + +#ifndef GL_ARB_fragment_program +#define GL_ARB_fragment_program 1 +#define GL_FRAGMENT_PROGRAM_ARB 0x8804 +#define GL_PROGRAM_FORMAT_ASCII_ARB 0x8875 +#define GL_PROGRAM_LENGTH_ARB 0x8627 +#define GL_PROGRAM_FORMAT_ARB 0x8876 +#define GL_PROGRAM_BINDING_ARB 0x8677 +#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_MAX_PROGRAM_LOCAL_PARAMETERS_ARB 0x88B4 +#define GL_MAX_PROGRAM_ENV_PARAMETERS_ARB 0x88B5 +#define GL_PROGRAM_UNDER_NATIVE_LIMITS_ARB 0x88B6 +#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_PROGRAM_STRING_ARB 0x8628 +#define GL_PROGRAM_ERROR_POSITION_ARB 0x864B +#define GL_CURRENT_MATRIX_ARB 0x8641 +#define GL_TRANSPOSE_CURRENT_MATRIX_ARB 0x88B7 +#define GL_CURRENT_MATRIX_STACK_DEPTH_ARB 0x8640 +#define GL_MAX_PROGRAM_MATRICES_ARB 0x862F +#define GL_MAX_PROGRAM_MATRIX_STACK_DEPTH_ARB 0x862E +#define GL_MAX_TEXTURE_COORDS_ARB 0x8871 +#define GL_MAX_TEXTURE_IMAGE_UNITS_ARB 0x8872 +#define GL_PROGRAM_ERROR_STRING_ARB 0x8874 +#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 (APIENTRYP PFNGLPROGRAMSTRINGARBPROC) (GLenum target, GLenum format, GLsizei len, const void *string); +typedef void (APIENTRYP PFNGLBINDPROGRAMARBPROC) (GLenum target, GLuint program); +typedef void (APIENTRYP PFNGLDELETEPROGRAMSARBPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLGENPROGRAMSARBPROC) (GLsizei n, GLuint *programs); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4DARBPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4DVARBPROC) (GLenum target, GLuint index, const GLdouble *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4FARBPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETER4FVARBPROC) (GLenum target, GLuint index, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERDVARBPROC) (GLenum target, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERFVARBPROC) (GLenum target, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSTRINGARBPROC) (GLenum target, GLenum pname, void *string); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMARBPROC) (GLuint program); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramStringARB (GLenum target, GLenum format, GLsizei len, const void *string); +GLAPI void APIENTRY glBindProgramARB (GLenum target, GLuint program); +GLAPI void APIENTRY glDeleteProgramsARB (GLsizei n, const GLuint *programs); +GLAPI void APIENTRY glGenProgramsARB (GLsizei n, GLuint *programs); +GLAPI void APIENTRY glProgramEnvParameter4dARB (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glProgramEnvParameter4dvARB (GLenum target, GLuint index, const GLdouble *params); +GLAPI void APIENTRY glProgramEnvParameter4fARB (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glProgramEnvParameter4fvARB (GLenum target, GLuint index, const GLfloat *params); +GLAPI void APIENTRY glProgramLocalParameter4dARB (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glProgramLocalParameter4dvARB (GLenum target, GLuint index, const GLdouble *params); +GLAPI void APIENTRY glProgramLocalParameter4fARB (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glProgramLocalParameter4fvARB (GLenum target, GLuint index, const GLfloat *params); +GLAPI void APIENTRY glGetProgramEnvParameterdvARB (GLenum target, GLuint index, GLdouble *params); +GLAPI void APIENTRY glGetProgramEnvParameterfvARB (GLenum target, GLuint index, GLfloat *params); +GLAPI void APIENTRY glGetProgramLocalParameterdvARB (GLenum target, GLuint index, GLdouble *params); +GLAPI void APIENTRY glGetProgramLocalParameterfvARB (GLenum target, GLuint index, GLfloat *params); +GLAPI void APIENTRY glGetProgramivARB (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetProgramStringARB (GLenum target, GLenum pname, void *string); +GLAPI GLboolean APIENTRY glIsProgramARB (GLuint program); +#endif +#endif /* GL_ARB_fragment_program */ + +#ifndef GL_ARB_fragment_program_shadow +#define GL_ARB_fragment_program_shadow 1 +#endif /* GL_ARB_fragment_program_shadow */ + +#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 +#endif /* GL_ARB_fragment_shader */ + +#ifndef GL_ARB_framebuffer_no_attachments +#define GL_ARB_framebuffer_no_attachments 1 +#endif /* GL_ARB_framebuffer_no_attachments */ + +#ifndef GL_ARB_framebuffer_object +#define GL_ARB_framebuffer_object 1 +#endif /* GL_ARB_framebuffer_object */ + +#ifndef GL_ARB_framebuffer_sRGB +#define GL_ARB_framebuffer_sRGB 1 +#endif /* GL_ARB_framebuffer_sRGB */ + +#ifndef GL_KHR_context_flush_control +#define GL_CONTEXT_RELEASE_BEHAVIOR 0x82FB +#define GL_CONTEXT_RELEASE_BEHAVIOR_FLUSH 0x82FC +#endif /* GL_KHR_context_flush_control */ + +#ifndef GL_ARB_geometry_shader4 +#define GL_ARB_geometry_shader4 1 +#define GL_LINES_ADJACENCY_ARB 0x000A +#define GL_LINE_STRIP_ADJACENCY_ARB 0x000B +#define GL_TRIANGLES_ADJACENCY_ARB 0x000C +#define GL_TRIANGLE_STRIP_ADJACENCY_ARB 0x000D +#define GL_PROGRAM_POINT_SIZE_ARB 0x8642 +#define GL_MAX_GEOMETRY_TEXTURE_IMAGE_UNITS_ARB 0x8C29 +#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 (APIENTRYP PFNGLPROGRAMPARAMETERIARBPROC) (GLuint program, GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURELAYERARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREFACEARBPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramParameteriARB (GLuint program, GLenum pname, GLint value); +GLAPI void APIENTRY glFramebufferTextureARB (GLenum target, GLenum attachment, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTextureLayerARB (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +GLAPI void APIENTRY glFramebufferTextureFaceARB (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +#endif +#endif /* GL_ARB_geometry_shader4 */ + +#ifndef GL_ARB_get_program_binary +#define GL_ARB_get_program_binary 1 +#endif /* GL_ARB_get_program_binary */ + +#ifndef GL_ARB_gpu_shader5 +#define GL_ARB_gpu_shader5 1 +#endif /* GL_ARB_gpu_shader5 */ + +#ifndef GL_ARB_gpu_shader_fp64 +#define GL_ARB_gpu_shader_fp64 1 +#endif /* GL_ARB_gpu_shader_fp64 */ + +#ifndef GL_ARB_half_float_pixel +#define GL_ARB_half_float_pixel 1 +typedef unsigned short GLhalfARB; +#define GL_HALF_FLOAT_ARB 0x140B +#endif /* GL_ARB_half_float_pixel */ + +#ifndef GL_ARB_half_float_vertex +#define GL_ARB_half_float_vertex 1 +#endif /* GL_ARB_half_float_vertex */ + +#ifndef GL_ARB_imaging +#define GL_ARB_imaging 1 +#define GL_BLEND_COLOR 0x8005 +#define GL_BLEND_EQUATION 0x8009 +#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_CONSTANT_BORDER 0x8151 +#define GL_REPLICATE_BORDER 0x8153 +#define GL_CONVOLUTION_BORDER_COLOR 0x8154 +typedef void (APIENTRYP PFNGLCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *table); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCOLORTABLEPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPROC) (GLenum target, GLenum format, GLenum type, void *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLCOPYCOLORSUBTABLEPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFPROC) (GLenum target, GLenum pname, GLfloat params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIPROC) (GLenum target, GLenum pname, GLint params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER1DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER2DPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONFILTERPROC) (GLenum target, GLenum format, GLenum type, void *image); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSEPARABLEFILTERPROC) (GLenum target, GLenum format, GLenum type, void *row, void *column, void *span); +typedef void (APIENTRYP PFNGLSEPARABLEFILTER2DPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *row, const void *column); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMINMAXPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERFVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERIVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLHISTOGRAMPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLMINMAXPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLRESETHISTOGRAMPROC) (GLenum target); +typedef void (APIENTRYP PFNGLRESETMINMAXPROC) (GLenum target); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorTable (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *table); +GLAPI void APIENTRY glColorTableParameterfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glColorTableParameteriv (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glCopyColorTable (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glGetColorTable (GLenum target, GLenum format, GLenum type, void *table); +GLAPI void APIENTRY glGetColorTableParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetColorTableParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glColorSubTable (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glCopyColorSubTable (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glConvolutionFilter1D (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *image); +GLAPI void APIENTRY glConvolutionFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *image); +GLAPI void APIENTRY glConvolutionParameterf (GLenum target, GLenum pname, GLfloat params); +GLAPI void APIENTRY glConvolutionParameterfv (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glConvolutionParameteri (GLenum target, GLenum pname, GLint params); +GLAPI void APIENTRY glConvolutionParameteriv (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glCopyConvolutionFilter1D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glCopyConvolutionFilter2D (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetConvolutionFilter (GLenum target, GLenum format, GLenum type, void *image); +GLAPI void APIENTRY glGetConvolutionParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetConvolutionParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetSeparableFilter (GLenum target, GLenum format, GLenum type, void *row, void *column, void *span); +GLAPI void APIENTRY glSeparableFilter2D (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *row, const void *column); +GLAPI void APIENTRY glGetHistogram (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +GLAPI void APIENTRY glGetHistogramParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetHistogramParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMinmax (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +GLAPI void APIENTRY glGetMinmaxParameterfv (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMinmaxParameteriv (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glHistogram (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +GLAPI void APIENTRY glMinmax (GLenum target, GLenum internalformat, GLboolean sink); +GLAPI void APIENTRY glResetHistogram (GLenum target); +GLAPI void APIENTRY glResetMinmax (GLenum target); +#endif +#endif /* GL_ARB_imaging */ + +#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 (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTCOUNTARBPROC) (GLenum mode, GLintptr indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTARBPROC) (GLenum mode, GLenum type, GLintptr indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiDrawArraysIndirectCountARB (GLenum mode, GLintptr indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); +GLAPI void APIENTRY glMultiDrawElementsIndirectCountARB (GLenum mode, GLenum type, GLintptr indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride); +#endif +#endif /* GL_ARB_indirect_parameters */ + +#ifndef GL_ARB_instanced_arrays +#define GL_ARB_instanced_arrays 1 +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ARB 0x88FE +typedef void (APIENTRYP PFNGLVERTEXATTRIBDIVISORARBPROC) (GLuint index, GLuint divisor); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribDivisorARB (GLuint index, GLuint divisor); +#endif +#endif /* GL_ARB_instanced_arrays */ + +#ifndef GL_ARB_internalformat_query +#define GL_ARB_internalformat_query 1 +#endif /* GL_ARB_internalformat_query */ + +#ifndef GL_ARB_internalformat_query2 +#define GL_ARB_internalformat_query2 1 +#define GL_SRGB_DECODE_ARB 0x8299 +#endif /* GL_ARB_internalformat_query2 */ + +#ifndef GL_ARB_invalidate_subdata +#define GL_ARB_invalidate_subdata 1 +#endif /* GL_ARB_invalidate_subdata */ + +#ifndef GL_ARB_map_buffer_alignment +#define GL_ARB_map_buffer_alignment 1 +#endif /* GL_ARB_map_buffer_alignment */ + +#ifndef GL_ARB_map_buffer_range +#define GL_ARB_map_buffer_range 1 +#endif /* GL_ARB_map_buffer_range */ + +#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 (APIENTRYP PFNGLCURRENTPALETTEMATRIXARBPROC) (GLint index); +typedef void (APIENTRYP PFNGLMATRIXINDEXUBVARBPROC) (GLint size, const GLubyte *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXUSVARBPROC) (GLint size, const GLushort *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXUIVARBPROC) (GLint size, const GLuint *indices); +typedef void (APIENTRYP PFNGLMATRIXINDEXPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCurrentPaletteMatrixARB (GLint index); +GLAPI void APIENTRY glMatrixIndexubvARB (GLint size, const GLubyte *indices); +GLAPI void APIENTRY glMatrixIndexusvARB (GLint size, const GLushort *indices); +GLAPI void APIENTRY glMatrixIndexuivARB (GLint size, const GLuint *indices); +GLAPI void APIENTRY glMatrixIndexPointerARB (GLint size, GLenum type, GLsizei stride, const void *pointer); +#endif +#endif /* GL_ARB_matrix_palette */ + +#ifndef GL_ARB_multi_bind +#define GL_ARB_multi_bind 1 +#endif /* GL_ARB_multi_bind */ + +#ifndef GL_ARB_multi_draw_indirect +#define GL_ARB_multi_draw_indirect 1 +#endif /* GL_ARB_multi_draw_indirect */ + +#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 (APIENTRYP PFNGLSAMPLECOVERAGEARBPROC) (GLfloat value, GLboolean invert); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleCoverageARB (GLfloat value, GLboolean invert); +#endif +#endif /* GL_ARB_multisample */ + +#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 (APIENTRYP PFNGLACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLCLIENTACTIVETEXTUREARBPROC) (GLenum texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DARBPROC) (GLenum target, GLdouble s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FARBPROC) (GLenum target, GLfloat s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IARBPROC) (GLenum target, GLint s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SARBPROC) (GLenum target, GLshort s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DARBPROC) (GLenum target, GLdouble s, GLdouble t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FARBPROC) (GLenum target, GLfloat s, GLfloat t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IARBPROC) (GLenum target, GLint s, GLint t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SARBPROC) (GLenum target, GLshort s, GLshort t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IARBPROC) (GLenum target, GLint s, GLint t, GLint r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3SVARBPROC) (GLenum target, const GLshort *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DARBPROC) (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4DVARBPROC) (GLenum target, const GLdouble *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FARBPROC) (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4FVARBPROC) (GLenum target, const GLfloat *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IARBPROC) (GLenum target, GLint s, GLint t, GLint r, GLint q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4IVARBPROC) (GLenum target, const GLint *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SARBPROC) (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4SVARBPROC) (GLenum target, const GLshort *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveTextureARB (GLenum texture); +GLAPI void APIENTRY glClientActiveTextureARB (GLenum texture); +GLAPI void APIENTRY glMultiTexCoord1dARB (GLenum target, GLdouble s); +GLAPI void APIENTRY glMultiTexCoord1dvARB (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord1fARB (GLenum target, GLfloat s); +GLAPI void APIENTRY glMultiTexCoord1fvARB (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord1iARB (GLenum target, GLint s); +GLAPI void APIENTRY glMultiTexCoord1ivARB (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord1sARB (GLenum target, GLshort s); +GLAPI void APIENTRY glMultiTexCoord1svARB (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord2dARB (GLenum target, GLdouble s, GLdouble t); +GLAPI void APIENTRY glMultiTexCoord2dvARB (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord2fARB (GLenum target, GLfloat s, GLfloat t); +GLAPI void APIENTRY glMultiTexCoord2fvARB (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord2iARB (GLenum target, GLint s, GLint t); +GLAPI void APIENTRY glMultiTexCoord2ivARB (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord2sARB (GLenum target, GLshort s, GLshort t); +GLAPI void APIENTRY glMultiTexCoord2svARB (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord3dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r); +GLAPI void APIENTRY glMultiTexCoord3dvARB (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord3fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r); +GLAPI void APIENTRY glMultiTexCoord3fvARB (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord3iARB (GLenum target, GLint s, GLint t, GLint r); +GLAPI void APIENTRY glMultiTexCoord3ivARB (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord3sARB (GLenum target, GLshort s, GLshort t, GLshort r); +GLAPI void APIENTRY glMultiTexCoord3svARB (GLenum target, const GLshort *v); +GLAPI void APIENTRY glMultiTexCoord4dARB (GLenum target, GLdouble s, GLdouble t, GLdouble r, GLdouble q); +GLAPI void APIENTRY glMultiTexCoord4dvARB (GLenum target, const GLdouble *v); +GLAPI void APIENTRY glMultiTexCoord4fARB (GLenum target, GLfloat s, GLfloat t, GLfloat r, GLfloat q); +GLAPI void APIENTRY glMultiTexCoord4fvARB (GLenum target, const GLfloat *v); +GLAPI void APIENTRY glMultiTexCoord4iARB (GLenum target, GLint s, GLint t, GLint r, GLint q); +GLAPI void APIENTRY glMultiTexCoord4ivARB (GLenum target, const GLint *v); +GLAPI void APIENTRY glMultiTexCoord4sARB (GLenum target, GLshort s, GLshort t, GLshort r, GLshort q); +GLAPI void APIENTRY glMultiTexCoord4svARB (GLenum target, const GLshort *v); +#endif +#endif /* GL_ARB_multitexture */ + +#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 (APIENTRYP PFNGLGENQUERIESARBPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEQUERIESARBPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISQUERYARBPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINQUERYARBPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLENDQUERYARBPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETQUERYIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTIVARBPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUIVARBPROC) (GLuint id, GLenum pname, GLuint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenQueriesARB (GLsizei n, GLuint *ids); +GLAPI void APIENTRY glDeleteQueriesARB (GLsizei n, const GLuint *ids); +GLAPI GLboolean APIENTRY glIsQueryARB (GLuint id); +GLAPI void APIENTRY glBeginQueryARB (GLenum target, GLuint id); +GLAPI void APIENTRY glEndQueryARB (GLenum target); +GLAPI void APIENTRY glGetQueryivARB (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetQueryObjectivARB (GLuint id, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetQueryObjectuivARB (GLuint id, GLenum pname, GLuint *params); +#endif +#endif /* GL_ARB_occlusion_query */ + +#ifndef GL_ARB_occlusion_query2 +#define GL_ARB_occlusion_query2 1 +#endif /* GL_ARB_occlusion_query2 */ + +#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 +#endif /* GL_ARB_pixel_buffer_object */ + +#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 (APIENTRYP PFNGLPOINTPARAMETERFARBPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVARBPROC) (GLenum pname, const GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfARB (GLenum pname, GLfloat param); +GLAPI void APIENTRY glPointParameterfvARB (GLenum pname, const GLfloat *params); +#endif +#endif /* GL_ARB_point_parameters */ + +#ifndef GL_ARB_point_sprite +#define GL_ARB_point_sprite 1 +#define GL_POINT_SPRITE_ARB 0x8861 +#define GL_COORD_REPLACE_ARB 0x8862 +#endif /* GL_ARB_point_sprite */ + +#ifndef GL_ARB_program_interface_query +#define GL_ARB_program_interface_query 1 +#endif /* GL_ARB_program_interface_query */ + +#ifndef GL_ARB_provoking_vertex +#define GL_ARB_provoking_vertex 1 +#endif /* GL_ARB_provoking_vertex */ + +#ifndef GL_ARB_query_buffer_object +#define GL_ARB_query_buffer_object 1 +#endif /* GL_ARB_query_buffer_object */ + +#ifndef GL_ARB_robust_buffer_access_behavior +#define GL_ARB_robust_buffer_access_behavior 1 +#endif /* GL_ARB_robust_buffer_access_behavior */ + +#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 (APIENTRYP PFNGLGETGRAPHICSRESETSTATUSARBPROC) (void); +typedef void (APIENTRYP PFNGLGETNTEXIMAGEARBPROC) (GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void *img); +typedef void (APIENTRYP PFNGLREADNPIXELSARBPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, void *data); +typedef void (APIENTRYP PFNGLGETNCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint lod, GLsizei bufSize, void *img); +typedef void (APIENTRYP PFNGLGETNUNIFORMFVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLfloat *params); +typedef void (APIENTRYP PFNGLGETNUNIFORMIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLint *params); +typedef void (APIENTRYP PFNGLGETNUNIFORMUIVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLuint *params); +typedef void (APIENTRYP PFNGLGETNUNIFORMDVARBPROC) (GLuint program, GLint location, GLsizei bufSize, GLdouble *params); +typedef void (APIENTRYP PFNGLGETNMAPDVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLdouble *v); +typedef void (APIENTRYP PFNGLGETNMAPFVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLfloat *v); +typedef void (APIENTRYP PFNGLGETNMAPIVARBPROC) (GLenum target, GLenum query, GLsizei bufSize, GLint *v); +typedef void (APIENTRYP PFNGLGETNPIXELMAPFVARBPROC) (GLenum map, GLsizei bufSize, GLfloat *values); +typedef void (APIENTRYP PFNGLGETNPIXELMAPUIVARBPROC) (GLenum map, GLsizei bufSize, GLuint *values); +typedef void (APIENTRYP PFNGLGETNPIXELMAPUSVARBPROC) (GLenum map, GLsizei bufSize, GLushort *values); +typedef void (APIENTRYP PFNGLGETNPOLYGONSTIPPLEARBPROC) (GLsizei bufSize, GLubyte *pattern); +typedef void (APIENTRYP PFNGLGETNCOLORTABLEARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *table); +typedef void (APIENTRYP PFNGLGETNCONVOLUTIONFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *image); +typedef void (APIENTRYP PFNGLGETNSEPARABLEFILTERARBPROC) (GLenum target, GLenum format, GLenum type, GLsizei rowBufSize, void *row, GLsizei columnBufSize, void *column, void *span); +typedef void (APIENTRYP PFNGLGETNHISTOGRAMARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +typedef void (APIENTRYP PFNGLGETNMINMAXARBPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLenum APIENTRY glGetGraphicsResetStatusARB (void); +GLAPI void APIENTRY glGetnTexImageARB (GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void *img); +GLAPI void APIENTRY glReadnPixelsARB (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, void *data); +GLAPI void APIENTRY glGetnCompressedTexImageARB (GLenum target, GLint lod, GLsizei bufSize, void *img); +GLAPI void APIENTRY glGetnUniformfvARB (GLuint program, GLint location, GLsizei bufSize, GLfloat *params); +GLAPI void APIENTRY glGetnUniformivARB (GLuint program, GLint location, GLsizei bufSize, GLint *params); +GLAPI void APIENTRY glGetnUniformuivARB (GLuint program, GLint location, GLsizei bufSize, GLuint *params); +GLAPI void APIENTRY glGetnUniformdvARB (GLuint program, GLint location, GLsizei bufSize, GLdouble *params); +GLAPI void APIENTRY glGetnMapdvARB (GLenum target, GLenum query, GLsizei bufSize, GLdouble *v); +GLAPI void APIENTRY glGetnMapfvARB (GLenum target, GLenum query, GLsizei bufSize, GLfloat *v); +GLAPI void APIENTRY glGetnMapivARB (GLenum target, GLenum query, GLsizei bufSize, GLint *v); +GLAPI void APIENTRY glGetnPixelMapfvARB (GLenum map, GLsizei bufSize, GLfloat *values); +GLAPI void APIENTRY glGetnPixelMapuivARB (GLenum map, GLsizei bufSize, GLuint *values); +GLAPI void APIENTRY glGetnPixelMapusvARB (GLenum map, GLsizei bufSize, GLushort *values); +GLAPI void APIENTRY glGetnPolygonStippleARB (GLsizei bufSize, GLubyte *pattern); +GLAPI void APIENTRY glGetnColorTableARB (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *table); +GLAPI void APIENTRY glGetnConvolutionFilterARB (GLenum target, GLenum format, GLenum type, GLsizei bufSize, void *image); +GLAPI void APIENTRY glGetnSeparableFilterARB (GLenum target, GLenum format, GLenum type, GLsizei rowBufSize, void *row, GLsizei columnBufSize, void *column, void *span); +GLAPI void APIENTRY glGetnHistogramARB (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +GLAPI void APIENTRY glGetnMinmaxARB (GLenum target, GLboolean reset, GLenum format, GLenum type, GLsizei bufSize, void *values); +#endif +#endif /* GL_ARB_robustness */ + +#ifndef GL_ARB_robustness_isolation +#define GL_ARB_robustness_isolation 1 +#endif /* GL_ARB_robustness_isolation */ + +#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 (APIENTRYP PFNGLMINSAMPLESHADINGARBPROC) (GLfloat value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMinSampleShadingARB (GLfloat value); +#endif +#endif /* GL_ARB_sample_shading */ + +#ifndef GL_ARB_sampler_objects +#define GL_ARB_sampler_objects 1 +#endif /* GL_ARB_sampler_objects */ + +#ifndef GL_ARB_seamless_cube_map +#define GL_ARB_seamless_cube_map 1 +#endif /* GL_ARB_seamless_cube_map */ + +#ifndef GL_ARB_seamless_cubemap_per_texture +#define GL_ARB_seamless_cubemap_per_texture 1 +#endif /* GL_ARB_seamless_cubemap_per_texture */ + +#ifndef GL_ARB_separate_shader_objects +#define GL_ARB_separate_shader_objects 1 +#endif /* GL_ARB_separate_shader_objects */ + +#ifndef GL_ARB_shader_atomic_counters +#define GL_ARB_shader_atomic_counters 1 +#endif /* GL_ARB_shader_atomic_counters */ + +#ifndef GL_ARB_shader_bit_encoding +#define GL_ARB_shader_bit_encoding 1 +#endif /* GL_ARB_shader_bit_encoding */ + +#ifndef GL_ARB_shader_draw_parameters +#define GL_ARB_shader_draw_parameters 1 +#endif /* GL_ARB_shader_draw_parameters */ + +#ifndef GL_ARB_shader_group_vote +#define GL_ARB_shader_group_vote 1 +#endif /* GL_ARB_shader_group_vote */ + +#ifndef GL_ARB_shader_image_load_store +#define GL_ARB_shader_image_load_store 1 +#endif /* GL_ARB_shader_image_load_store */ + +#ifndef GL_ARB_shader_image_size +#define GL_ARB_shader_image_size 1 +#endif /* GL_ARB_shader_image_size */ + +#ifndef GL_ARB_shader_objects +#define GL_ARB_shader_objects 1 +#ifdef __APPLE__ +typedef void *GLhandleARB; +#else +typedef unsigned int GLhandleARB; +#endif +typedef char GLcharARB; +#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 void (APIENTRYP PFNGLDELETEOBJECTARBPROC) (GLhandleARB obj); +typedef GLhandleARB (APIENTRYP PFNGLGETHANDLEARBPROC) (GLenum pname); +typedef void (APIENTRYP PFNGLDETACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB attachedObj); +typedef GLhandleARB (APIENTRYP PFNGLCREATESHADEROBJECTARBPROC) (GLenum shaderType); +typedef void (APIENTRYP PFNGLSHADERSOURCEARBPROC) (GLhandleARB shaderObj, GLsizei count, const GLcharARB **string, const GLint *length); +typedef void (APIENTRYP PFNGLCOMPILESHADERARBPROC) (GLhandleARB shaderObj); +typedef GLhandleARB (APIENTRYP PFNGLCREATEPROGRAMOBJECTARBPROC) (void); +typedef void (APIENTRYP PFNGLATTACHOBJECTARBPROC) (GLhandleARB containerObj, GLhandleARB obj); +typedef void (APIENTRYP PFNGLLINKPROGRAMARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLUSEPROGRAMOBJECTARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLVALIDATEPROGRAMARBPROC) (GLhandleARB programObj); +typedef void (APIENTRYP PFNGLUNIFORM1FARBPROC) (GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLUNIFORM2FARBPROC) (GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLUNIFORM3FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLUNIFORM4FARBPROC) (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLUNIFORM1IARBPROC) (GLint location, GLint v0); +typedef void (APIENTRYP PFNGLUNIFORM2IARBPROC) (GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLUNIFORM3IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLUNIFORM4IARBPROC) (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLUNIFORM1FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM2FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM3FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM4FVARBPROC) (GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORM1IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM2IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM3IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORM4IVARBPROC) (GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX2FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX3FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLUNIFORMMATRIX4FVARBPROC) (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLGETOBJECTPARAMETERFVARBPROC) (GLhandleARB obj, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETOBJECTPARAMETERIVARBPROC) (GLhandleARB obj, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETINFOLOGARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *infoLog); +typedef void (APIENTRYP PFNGLGETATTACHEDOBJECTSARBPROC) (GLhandleARB containerObj, GLsizei maxCount, GLsizei *count, GLhandleARB *obj); +typedef GLint (APIENTRYP PFNGLGETUNIFORMLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB *name); +typedef void (APIENTRYP PFNGLGETACTIVEUNIFORMARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +typedef void (APIENTRYP PFNGLGETUNIFORMFVARBPROC) (GLhandleARB programObj, GLint location, GLfloat *params); +typedef void (APIENTRYP PFNGLGETUNIFORMIVARBPROC) (GLhandleARB programObj, GLint location, GLint *params); +typedef void (APIENTRYP PFNGLGETSHADERSOURCEARBPROC) (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *source); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeleteObjectARB (GLhandleARB obj); +GLAPI GLhandleARB APIENTRY glGetHandleARB (GLenum pname); +GLAPI void APIENTRY glDetachObjectARB (GLhandleARB containerObj, GLhandleARB attachedObj); +GLAPI GLhandleARB APIENTRY glCreateShaderObjectARB (GLenum shaderType); +GLAPI void APIENTRY glShaderSourceARB (GLhandleARB shaderObj, GLsizei count, const GLcharARB **string, const GLint *length); +GLAPI void APIENTRY glCompileShaderARB (GLhandleARB shaderObj); +GLAPI GLhandleARB APIENTRY glCreateProgramObjectARB (void); +GLAPI void APIENTRY glAttachObjectARB (GLhandleARB containerObj, GLhandleARB obj); +GLAPI void APIENTRY glLinkProgramARB (GLhandleARB programObj); +GLAPI void APIENTRY glUseProgramObjectARB (GLhandleARB programObj); +GLAPI void APIENTRY glValidateProgramARB (GLhandleARB programObj); +GLAPI void APIENTRY glUniform1fARB (GLint location, GLfloat v0); +GLAPI void APIENTRY glUniform2fARB (GLint location, GLfloat v0, GLfloat v1); +GLAPI void APIENTRY glUniform3fARB (GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +GLAPI void APIENTRY glUniform4fARB (GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +GLAPI void APIENTRY glUniform1iARB (GLint location, GLint v0); +GLAPI void APIENTRY glUniform2iARB (GLint location, GLint v0, GLint v1); +GLAPI void APIENTRY glUniform3iARB (GLint location, GLint v0, GLint v1, GLint v2); +GLAPI void APIENTRY glUniform4iARB (GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +GLAPI void APIENTRY glUniform1fvARB (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform2fvARB (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform3fvARB (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform4fvARB (GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glUniform1ivARB (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform2ivARB (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform3ivARB (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniform4ivARB (GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glUniformMatrix2fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix3fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glUniformMatrix4fvARB (GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glGetObjectParameterfvARB (GLhandleARB obj, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetObjectParameterivARB (GLhandleARB obj, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetInfoLogARB (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *infoLog); +GLAPI void APIENTRY glGetAttachedObjectsARB (GLhandleARB containerObj, GLsizei maxCount, GLsizei *count, GLhandleARB *obj); +GLAPI GLint APIENTRY glGetUniformLocationARB (GLhandleARB programObj, const GLcharARB *name); +GLAPI void APIENTRY glGetActiveUniformARB (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +GLAPI void APIENTRY glGetUniformfvARB (GLhandleARB programObj, GLint location, GLfloat *params); +GLAPI void APIENTRY glGetUniformivARB (GLhandleARB programObj, GLint location, GLint *params); +GLAPI void APIENTRY glGetShaderSourceARB (GLhandleARB obj, GLsizei maxLength, GLsizei *length, GLcharARB *source); +#endif +#endif /* GL_ARB_shader_objects */ + +#ifndef GL_ARB_shader_precision +#define GL_ARB_shader_precision 1 +#endif /* GL_ARB_shader_precision */ + +#ifndef GL_ARB_shader_stencil_export +#define GL_ARB_shader_stencil_export 1 +#endif /* GL_ARB_shader_stencil_export */ + +#ifndef GL_ARB_shader_storage_buffer_object +#define GL_ARB_shader_storage_buffer_object 1 +#endif /* GL_ARB_shader_storage_buffer_object */ + +#ifndef GL_ARB_shader_subroutine +#define GL_ARB_shader_subroutine 1 +#endif /* GL_ARB_shader_subroutine */ + +#ifndef GL_ARB_shader_texture_lod +#define GL_ARB_shader_texture_lod 1 +#endif /* GL_ARB_shader_texture_lod */ + +#ifndef GL_ARB_shading_language_100 +#define GL_ARB_shading_language_100 1 +#define GL_SHADING_LANGUAGE_VERSION_ARB 0x8B8C +#endif /* GL_ARB_shading_language_100 */ + +#ifndef GL_ARB_shading_language_420pack +#define GL_ARB_shading_language_420pack 1 +#endif /* GL_ARB_shading_language_420pack */ + +#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 (APIENTRYP PFNGLNAMEDSTRINGARBPROC) (GLenum type, GLint namelen, const GLchar *name, GLint stringlen, const GLchar *string); +typedef void (APIENTRYP PFNGLDELETENAMEDSTRINGARBPROC) (GLint namelen, const GLchar *name); +typedef void (APIENTRYP PFNGLCOMPILESHADERINCLUDEARBPROC) (GLuint shader, GLsizei count, const GLchar *const*path, const GLint *length); +typedef GLboolean (APIENTRYP PFNGLISNAMEDSTRINGARBPROC) (GLint namelen, const GLchar *name); +typedef void (APIENTRYP PFNGLGETNAMEDSTRINGARBPROC) (GLint namelen, const GLchar *name, GLsizei bufSize, GLint *stringlen, GLchar *string); +typedef void (APIENTRYP PFNGLGETNAMEDSTRINGIVARBPROC) (GLint namelen, const GLchar *name, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glNamedStringARB (GLenum type, GLint namelen, const GLchar *name, GLint stringlen, const GLchar *string); +GLAPI void APIENTRY glDeleteNamedStringARB (GLint namelen, const GLchar *name); +GLAPI void APIENTRY glCompileShaderIncludeARB (GLuint shader, GLsizei count, const GLchar *const*path, const GLint *length); +GLAPI GLboolean APIENTRY glIsNamedStringARB (GLint namelen, const GLchar *name); +GLAPI void APIENTRY glGetNamedStringARB (GLint namelen, const GLchar *name, GLsizei bufSize, GLint *stringlen, GLchar *string); +GLAPI void APIENTRY glGetNamedStringivARB (GLint namelen, const GLchar *name, GLenum pname, GLint *params); +#endif +#endif /* GL_ARB_shading_language_include */ + +#ifndef GL_ARB_shading_language_packing +#define GL_ARB_shading_language_packing 1 +#endif /* GL_ARB_shading_language_packing */ + +#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 +#endif /* GL_ARB_shadow */ + +#ifndef GL_ARB_shadow_ambient +#define GL_ARB_shadow_ambient 1 +#define GL_TEXTURE_COMPARE_FAIL_VALUE_ARB 0x80BF +#endif /* GL_ARB_shadow_ambient */ + +#ifndef GL_ARB_sparse_texture +#define GL_ARB_sparse_texture 1 +#define GL_TEXTURE_SPARSE_ARB 0x91A6 +#define GL_VIRTUAL_PAGE_SIZE_INDEX_ARB 0x91A7 +#define GL_MIN_SPARSE_LEVEL_ARB 0x919B +#define GL_NUM_VIRTUAL_PAGE_SIZES_ARB 0x91A8 +#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_SPARSE_TEXTURE_FULL_ARRAY_CUBE_MIPMAPS_ARB 0x91A9 +typedef void (APIENTRYP PFNGLTEXPAGECOMMITMENTARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean resident); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexPageCommitmentARB (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean resident); +#endif +#endif /* GL_ARB_sparse_texture */ + +#ifndef GL_ARB_stencil_texturing +#define GL_ARB_stencil_texturing 1 +#endif /* GL_ARB_stencil_texturing */ + +#ifndef GL_ARB_sync +#define GL_ARB_sync 1 +#endif /* GL_ARB_sync */ + +#ifndef GL_ARB_tessellation_shader +#define GL_ARB_tessellation_shader 1 +#endif /* GL_ARB_tessellation_shader */ + +#ifndef GL_ARB_texture_border_clamp +#define GL_ARB_texture_border_clamp 1 +#define GL_CLAMP_TO_BORDER_ARB 0x812D +#endif /* GL_ARB_texture_border_clamp */ + +#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 (APIENTRYP PFNGLTEXBUFFERARBPROC) (GLenum target, GLenum internalformat, GLuint buffer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexBufferARB (GLenum target, GLenum internalformat, GLuint buffer); +#endif +#endif /* GL_ARB_texture_buffer_object */ + +#ifndef GL_ARB_texture_buffer_object_rgb32 +#define GL_ARB_texture_buffer_object_rgb32 1 +#endif /* GL_ARB_texture_buffer_object_rgb32 */ + +#ifndef GL_ARB_texture_buffer_range +#define GL_ARB_texture_buffer_range 1 +#endif /* GL_ARB_texture_buffer_range */ + +#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 (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE2DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXIMAGE1DARBPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *data); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE2DARBPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE1DARBPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *data); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXIMAGEARBPROC) (GLenum target, GLint level, void *img); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCompressedTexImage3DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexImage2DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexImage1DARB (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage3DARB (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage2DARB (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glCompressedTexSubImage1DARB (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *data); +GLAPI void APIENTRY glGetCompressedTexImageARB (GLenum target, GLint level, void *img); +#endif +#endif /* GL_ARB_texture_compression */ + +#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 +#endif /* GL_ARB_texture_compression_bptc */ + +#ifndef GL_ARB_texture_compression_rgtc +#define GL_ARB_texture_compression_rgtc 1 +#endif /* GL_ARB_texture_compression_rgtc */ + +#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 +#endif /* GL_ARB_texture_cube_map */ + +#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 +#endif /* GL_ARB_texture_cube_map_array */ + +#ifndef GL_ARB_texture_env_add +#define GL_ARB_texture_env_add 1 +#endif /* GL_ARB_texture_env_add */ + +#ifndef GL_ARB_texture_env_combine +#define GL_ARB_texture_env_combine 1 +#define GL_COMBINE_ARB 0x8570 +#define GL_COMBINE_RGB_ARB 0x8571 +#define GL_COMBINE_ALPHA_ARB 0x8572 +#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_RGB_SCALE_ARB 0x8573 +#define GL_ADD_SIGNED_ARB 0x8574 +#define GL_INTERPOLATE_ARB 0x8575 +#define GL_SUBTRACT_ARB 0x84E7 +#define GL_CONSTANT_ARB 0x8576 +#define GL_PRIMARY_COLOR_ARB 0x8577 +#define GL_PREVIOUS_ARB 0x8578 +#endif /* GL_ARB_texture_env_combine */ + +#ifndef GL_ARB_texture_env_crossbar +#define GL_ARB_texture_env_crossbar 1 +#endif /* GL_ARB_texture_env_crossbar */ + +#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 +#endif /* GL_ARB_texture_env_dot3 */ + +#ifndef GL_ARB_texture_float +#define GL_ARB_texture_float 1 +#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 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 +#endif /* GL_ARB_texture_float */ + +#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 +#endif /* GL_ARB_texture_gather */ + +#ifndef GL_ARB_texture_mirror_clamp_to_edge +#define GL_ARB_texture_mirror_clamp_to_edge 1 +#endif /* GL_ARB_texture_mirror_clamp_to_edge */ + +#ifndef GL_ARB_texture_mirrored_repeat +#define GL_ARB_texture_mirrored_repeat 1 +#define GL_MIRRORED_REPEAT_ARB 0x8370 +#endif /* GL_ARB_texture_mirrored_repeat */ + +#ifndef GL_ARB_texture_multisample +#define GL_ARB_texture_multisample 1 +#endif /* GL_ARB_texture_multisample */ + +#ifndef GL_ARB_texture_non_power_of_two +#define GL_ARB_texture_non_power_of_two 1 +#endif /* GL_ARB_texture_non_power_of_two */ + +#ifndef GL_ARB_texture_query_levels +#define GL_ARB_texture_query_levels 1 +#endif /* GL_ARB_texture_query_levels */ + +#ifndef GL_ARB_texture_query_lod +#define GL_ARB_texture_query_lod 1 +#endif /* GL_ARB_texture_query_lod */ + +#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 +#endif /* GL_ARB_texture_rectangle */ + +#ifndef GL_ARB_texture_rg +#define GL_ARB_texture_rg 1 +#endif /* GL_ARB_texture_rg */ + +#ifndef GL_ARB_texture_rgb10_a2ui +#define GL_ARB_texture_rgb10_a2ui 1 +#endif /* GL_ARB_texture_rgb10_a2ui */ + +#ifndef GL_ARB_texture_stencil8 +#define GL_ARB_texture_stencil8 1 +#endif /* GL_ARB_texture_stencil8 */ + +#ifndef GL_ARB_texture_storage +#define GL_ARB_texture_storage 1 +#endif /* GL_ARB_texture_storage */ + +#ifndef GL_ARB_texture_storage_multisample +#define GL_ARB_texture_storage_multisample 1 +#endif /* GL_ARB_texture_storage_multisample */ + +#ifndef GL_ARB_texture_swizzle +#define GL_ARB_texture_swizzle 1 +#endif /* GL_ARB_texture_swizzle */ + +#ifndef GL_ARB_texture_view +#define GL_ARB_texture_view 1 +#endif /* GL_ARB_texture_view */ + +#ifndef GL_ARB_timer_query +#define GL_ARB_timer_query 1 +#endif /* GL_ARB_timer_query */ + +#ifndef GL_ARB_transform_feedback2 +#define GL_ARB_transform_feedback2 1 +#define GL_TRANSFORM_FEEDBACK_PAUSED 0x8E23 +#define GL_TRANSFORM_FEEDBACK_ACTIVE 0x8E24 +#endif /* GL_ARB_transform_feedback2 */ + +#ifndef GL_ARB_transform_feedback3 +#define GL_ARB_transform_feedback3 1 +#endif /* GL_ARB_transform_feedback3 */ + +#ifndef GL_ARB_transform_feedback_instanced +#define GL_ARB_transform_feedback_instanced 1 +#endif /* GL_ARB_transform_feedback_instanced */ + +#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 (APIENTRYP PFNGLLOADTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXFARBPROC) (const GLfloat *m); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXDARBPROC) (const GLdouble *m); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glLoadTransposeMatrixfARB (const GLfloat *m); +GLAPI void APIENTRY glLoadTransposeMatrixdARB (const GLdouble *m); +GLAPI void APIENTRY glMultTransposeMatrixfARB (const GLfloat *m); +GLAPI void APIENTRY glMultTransposeMatrixdARB (const GLdouble *m); +#endif +#endif /* GL_ARB_transpose_matrix */ + +#ifndef GL_ARB_uniform_buffer_object +#define GL_ARB_uniform_buffer_object 1 +#define GL_MAX_GEOMETRY_UNIFORM_BLOCKS 0x8A2C +#define GL_MAX_COMBINED_GEOMETRY_UNIFORM_COMPONENTS 0x8A32 +#define GL_UNIFORM_BLOCK_REFERENCED_BY_GEOMETRY_SHADER 0x8A45 +#endif /* GL_ARB_uniform_buffer_object */ + +#ifndef GL_ARB_vertex_array_bgra +#define GL_ARB_vertex_array_bgra 1 +#endif /* GL_ARB_vertex_array_bgra */ + +#ifndef GL_ARB_vertex_array_object +#define GL_ARB_vertex_array_object 1 +#endif /* GL_ARB_vertex_array_object */ + +#ifndef GL_ARB_vertex_attrib_64bit +#define GL_ARB_vertex_attrib_64bit 1 +#endif /* GL_ARB_vertex_attrib_64bit */ + +#ifndef GL_ARB_vertex_attrib_binding +#define GL_ARB_vertex_attrib_binding 1 +#endif /* GL_ARB_vertex_attrib_binding */ + +#ifndef GL_ARB_vertex_blend +#define GL_ARB_vertex_blend 1 +#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_MODELVIEW0_ARB 0x1700 +#define GL_MODELVIEW1_ARB 0x850A +#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 (APIENTRYP PFNGLWEIGHTBVARBPROC) (GLint size, const GLbyte *weights); +typedef void (APIENTRYP PFNGLWEIGHTSVARBPROC) (GLint size, const GLshort *weights); +typedef void (APIENTRYP PFNGLWEIGHTIVARBPROC) (GLint size, const GLint *weights); +typedef void (APIENTRYP PFNGLWEIGHTFVARBPROC) (GLint size, const GLfloat *weights); +typedef void (APIENTRYP PFNGLWEIGHTDVARBPROC) (GLint size, const GLdouble *weights); +typedef void (APIENTRYP PFNGLWEIGHTUBVARBPROC) (GLint size, const GLubyte *weights); +typedef void (APIENTRYP PFNGLWEIGHTUSVARBPROC) (GLint size, const GLushort *weights); +typedef void (APIENTRYP PFNGLWEIGHTUIVARBPROC) (GLint size, const GLuint *weights); +typedef void (APIENTRYP PFNGLWEIGHTPOINTERARBPROC) (GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLVERTEXBLENDARBPROC) (GLint count); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWeightbvARB (GLint size, const GLbyte *weights); +GLAPI void APIENTRY glWeightsvARB (GLint size, const GLshort *weights); +GLAPI void APIENTRY glWeightivARB (GLint size, const GLint *weights); +GLAPI void APIENTRY glWeightfvARB (GLint size, const GLfloat *weights); +GLAPI void APIENTRY glWeightdvARB (GLint size, const GLdouble *weights); +GLAPI void APIENTRY glWeightubvARB (GLint size, const GLubyte *weights); +GLAPI void APIENTRY glWeightusvARB (GLint size, const GLushort *weights); +GLAPI void APIENTRY glWeightuivARB (GLint size, const GLuint *weights); +GLAPI void APIENTRY glWeightPointerARB (GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glVertexBlendARB (GLint count); +#endif +#endif /* GL_ARB_vertex_blend */ + +#ifndef GL_ARB_vertex_buffer_object +#define GL_ARB_vertex_buffer_object 1 +#ifdef __MACOSX__ /* The OS X headers haven't caught up with Khronos yet */ +typedef long GLsizeiptrARB; +typedef long GLintptrARB; +#else +typedef ptrdiff_t GLsizeiptrARB; +typedef ptrdiff_t GLintptrARB; +#endif +#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 void (APIENTRYP PFNGLBINDBUFFERARBPROC) (GLenum target, GLuint buffer); +typedef void (APIENTRYP PFNGLDELETEBUFFERSARBPROC) (GLsizei n, const GLuint *buffers); +typedef void (APIENTRYP PFNGLGENBUFFERSARBPROC) (GLsizei n, GLuint *buffers); +typedef GLboolean (APIENTRYP PFNGLISBUFFERARBPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLBUFFERDATAARBPROC) (GLenum target, GLsizeiptrARB size, const void *data, GLenum usage); +typedef void (APIENTRYP PFNGLBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const void *data); +typedef void (APIENTRYP PFNGLGETBUFFERSUBDATAARBPROC) (GLenum target, GLintptrARB offset, GLsizeiptrARB size, void *data); +typedef void *(APIENTRYP PFNGLMAPBUFFERARBPROC) (GLenum target, GLenum access); +typedef GLboolean (APIENTRYP PFNGLUNMAPBUFFERARBPROC) (GLenum target); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERIVARBPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETBUFFERPOINTERVARBPROC) (GLenum target, GLenum pname, void **params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindBufferARB (GLenum target, GLuint buffer); +GLAPI void APIENTRY glDeleteBuffersARB (GLsizei n, const GLuint *buffers); +GLAPI void APIENTRY glGenBuffersARB (GLsizei n, GLuint *buffers); +GLAPI GLboolean APIENTRY glIsBufferARB (GLuint buffer); +GLAPI void APIENTRY glBufferDataARB (GLenum target, GLsizeiptrARB size, const void *data, GLenum usage); +GLAPI void APIENTRY glBufferSubDataARB (GLenum target, GLintptrARB offset, GLsizeiptrARB size, const void *data); +GLAPI void APIENTRY glGetBufferSubDataARB (GLenum target, GLintptrARB offset, GLsizeiptrARB size, void *data); +GLAPI void *APIENTRY glMapBufferARB (GLenum target, GLenum access); +GLAPI GLboolean APIENTRY glUnmapBufferARB (GLenum target); +GLAPI void APIENTRY glGetBufferParameterivARB (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetBufferPointervARB (GLenum target, GLenum pname, void **params); +#endif +#endif /* GL_ARB_vertex_buffer_object */ + +#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_VERTEX_PROGRAM_POINT_SIZE_ARB 0x8642 +#define GL_VERTEX_PROGRAM_TWO_SIDE_ARB 0x8643 +#define GL_VERTEX_ATTRIB_ARRAY_POINTER_ARB 0x8645 +#define GL_MAX_VERTEX_ATTRIBS_ARB 0x8869 +#define GL_VERTEX_ATTRIB_ARRAY_NORMALIZED_ARB 0x886A +#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 +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DARBPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FARBPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SARBPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DARBPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FARBPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SARBPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NBVARBPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NIVARBPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NSVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBARBPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUBVARBPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUIVARBPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4NUSVARBPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4BVARBPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DARBPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVARBPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FARBPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVARBPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4IVARBPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SARBPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVARBPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVARBPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UIVARBPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4USVARBPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERARBPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLENABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBARRAYARBPROC) (GLuint index); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVARBPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVARBPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVARBPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVARBPROC) (GLuint index, GLenum pname, void **pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttrib1dARB (GLuint index, GLdouble x); +GLAPI void APIENTRY glVertexAttrib1dvARB (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib1fARB (GLuint index, GLfloat x); +GLAPI void APIENTRY glVertexAttrib1fvARB (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib1sARB (GLuint index, GLshort x); +GLAPI void APIENTRY glVertexAttrib1svARB (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib2dARB (GLuint index, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexAttrib2dvARB (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib2fARB (GLuint index, GLfloat x, GLfloat y); +GLAPI void APIENTRY glVertexAttrib2fvARB (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib2sARB (GLuint index, GLshort x, GLshort y); +GLAPI void APIENTRY glVertexAttrib2svARB (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib3dARB (GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexAttrib3dvARB (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib3fARB (GLuint index, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glVertexAttrib3fvARB (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib3sARB (GLuint index, GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glVertexAttrib3svARB (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4NbvARB (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttrib4NivARB (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttrib4NsvARB (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4NubARB (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +GLAPI void APIENTRY glVertexAttrib4NubvARB (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttrib4NuivARB (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttrib4NusvARB (GLuint index, const GLushort *v); +GLAPI void APIENTRY glVertexAttrib4bvARB (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttrib4dARB (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexAttrib4dvARB (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib4fARB (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glVertexAttrib4fvARB (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib4ivARB (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttrib4sARB (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void APIENTRY glVertexAttrib4svARB (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4ubvARB (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttrib4uivARB (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttrib4usvARB (GLuint index, const GLushort *v); +GLAPI void APIENTRY glVertexAttribPointerARB (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glEnableVertexAttribArrayARB (GLuint index); +GLAPI void APIENTRY glDisableVertexAttribArrayARB (GLuint index); +GLAPI void APIENTRY glGetVertexAttribdvARB (GLuint index, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glGetVertexAttribfvARB (GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVertexAttribivARB (GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribPointervARB (GLuint index, GLenum pname, void **pointer); +#endif +#endif /* GL_ARB_vertex_program */ + +#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 (APIENTRYP PFNGLBINDATTRIBLOCATIONARBPROC) (GLhandleARB programObj, GLuint index, const GLcharARB *name); +typedef void (APIENTRYP PFNGLGETACTIVEATTRIBARBPROC) (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +typedef GLint (APIENTRYP PFNGLGETATTRIBLOCATIONARBPROC) (GLhandleARB programObj, const GLcharARB *name); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindAttribLocationARB (GLhandleARB programObj, GLuint index, const GLcharARB *name); +GLAPI void APIENTRY glGetActiveAttribARB (GLhandleARB programObj, GLuint index, GLsizei maxLength, GLsizei *length, GLint *size, GLenum *type, GLcharARB *name); +GLAPI GLint APIENTRY glGetAttribLocationARB (GLhandleARB programObj, const GLcharARB *name); +#endif +#endif /* GL_ARB_vertex_shader */ + +#ifndef GL_ARB_vertex_type_10f_11f_11f_rev +#define GL_ARB_vertex_type_10f_11f_11f_rev 1 +#endif /* GL_ARB_vertex_type_10f_11f_11f_rev */ + +#ifndef GL_ARB_vertex_type_2_10_10_10_rev +#define GL_ARB_vertex_type_2_10_10_10_rev 1 +#endif /* GL_ARB_vertex_type_2_10_10_10_rev */ + +#ifndef GL_ARB_viewport_array +#define GL_ARB_viewport_array 1 +#endif /* GL_ARB_viewport_array */ + +#ifndef GL_ARB_window_pos +#define GL_ARB_window_pos 1 +typedef void (APIENTRYP PFNGLWINDOWPOS2DARBPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVARBPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FARBPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVARBPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IARBPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVARBPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SARBPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVARBPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DARBPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVARBPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FARBPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVARBPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IARBPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVARBPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SARBPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVARBPROC) (const GLshort *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWindowPos2dARB (GLdouble x, GLdouble y); +GLAPI void APIENTRY glWindowPos2dvARB (const GLdouble *v); +GLAPI void APIENTRY glWindowPos2fARB (GLfloat x, GLfloat y); +GLAPI void APIENTRY glWindowPos2fvARB (const GLfloat *v); +GLAPI void APIENTRY glWindowPos2iARB (GLint x, GLint y); +GLAPI void APIENTRY glWindowPos2ivARB (const GLint *v); +GLAPI void APIENTRY glWindowPos2sARB (GLshort x, GLshort y); +GLAPI void APIENTRY glWindowPos2svARB (const GLshort *v); +GLAPI void APIENTRY glWindowPos3dARB (GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glWindowPos3dvARB (const GLdouble *v); +GLAPI void APIENTRY glWindowPos3fARB (GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glWindowPos3fvARB (const GLfloat *v); +GLAPI void APIENTRY glWindowPos3iARB (GLint x, GLint y, GLint z); +GLAPI void APIENTRY glWindowPos3ivARB (const GLint *v); +GLAPI void APIENTRY glWindowPos3sARB (GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glWindowPos3svARB (const GLshort *v); +#endif +#endif /* GL_ARB_window_pos */ + +#ifndef GL_KHR_debug +#define GL_KHR_debug 1 +#endif /* GL_KHR_debug */ + +#ifndef GL_KHR_texture_compression_astc_hdr +#define GL_KHR_texture_compression_astc_hdr 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 +#endif /* GL_KHR_texture_compression_astc_hdr */ + +#ifndef GL_KHR_texture_compression_astc_ldr +#define GL_KHR_texture_compression_astc_ldr 1 +#endif /* GL_KHR_texture_compression_astc_ldr */ + +#ifndef GL_OES_byte_coordinates +#define GL_OES_byte_coordinates 1 +typedef void (APIENTRYP PFNGLMULTITEXCOORD1BOESPROC) (GLenum texture, GLbyte s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1BVOESPROC) (GLenum texture, const GLbyte *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2BOESPROC) (GLenum texture, GLbyte s, GLbyte t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2BVOESPROC) (GLenum texture, const GLbyte *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3BOESPROC) (GLenum texture, GLbyte s, GLbyte t, GLbyte r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3BVOESPROC) (GLenum texture, const GLbyte *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4BOESPROC) (GLenum texture, GLbyte s, GLbyte t, GLbyte r, GLbyte q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4BVOESPROC) (GLenum texture, const GLbyte *coords); +typedef void (APIENTRYP PFNGLTEXCOORD1BOESPROC) (GLbyte s); +typedef void (APIENTRYP PFNGLTEXCOORD1BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLTEXCOORD2BOESPROC) (GLbyte s, GLbyte t); +typedef void (APIENTRYP PFNGLTEXCOORD2BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLTEXCOORD3BOESPROC) (GLbyte s, GLbyte t, GLbyte r); +typedef void (APIENTRYP PFNGLTEXCOORD3BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLTEXCOORD4BOESPROC) (GLbyte s, GLbyte t, GLbyte r, GLbyte q); +typedef void (APIENTRYP PFNGLTEXCOORD4BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLVERTEX2BOESPROC) (GLbyte x); +typedef void (APIENTRYP PFNGLVERTEX2BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLVERTEX3BOESPROC) (GLbyte x, GLbyte y); +typedef void (APIENTRYP PFNGLVERTEX3BVOESPROC) (const GLbyte *coords); +typedef void (APIENTRYP PFNGLVERTEX4BOESPROC) (GLbyte x, GLbyte y, GLbyte z); +typedef void (APIENTRYP PFNGLVERTEX4BVOESPROC) (const GLbyte *coords); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiTexCoord1bOES (GLenum texture, GLbyte s); +GLAPI void APIENTRY glMultiTexCoord1bvOES (GLenum texture, const GLbyte *coords); +GLAPI void APIENTRY glMultiTexCoord2bOES (GLenum texture, GLbyte s, GLbyte t); +GLAPI void APIENTRY glMultiTexCoord2bvOES (GLenum texture, const GLbyte *coords); +GLAPI void APIENTRY glMultiTexCoord3bOES (GLenum texture, GLbyte s, GLbyte t, GLbyte r); +GLAPI void APIENTRY glMultiTexCoord3bvOES (GLenum texture, const GLbyte *coords); +GLAPI void APIENTRY glMultiTexCoord4bOES (GLenum texture, GLbyte s, GLbyte t, GLbyte r, GLbyte q); +GLAPI void APIENTRY glMultiTexCoord4bvOES (GLenum texture, const GLbyte *coords); +GLAPI void APIENTRY glTexCoord1bOES (GLbyte s); +GLAPI void APIENTRY glTexCoord1bvOES (const GLbyte *coords); +GLAPI void APIENTRY glTexCoord2bOES (GLbyte s, GLbyte t); +GLAPI void APIENTRY glTexCoord2bvOES (const GLbyte *coords); +GLAPI void APIENTRY glTexCoord3bOES (GLbyte s, GLbyte t, GLbyte r); +GLAPI void APIENTRY glTexCoord3bvOES (const GLbyte *coords); +GLAPI void APIENTRY glTexCoord4bOES (GLbyte s, GLbyte t, GLbyte r, GLbyte q); +GLAPI void APIENTRY glTexCoord4bvOES (const GLbyte *coords); +GLAPI void APIENTRY glVertex2bOES (GLbyte x); +GLAPI void APIENTRY glVertex2bvOES (const GLbyte *coords); +GLAPI void APIENTRY glVertex3bOES (GLbyte x, GLbyte y); +GLAPI void APIENTRY glVertex3bvOES (const GLbyte *coords); +GLAPI void APIENTRY glVertex4bOES (GLbyte x, GLbyte y, GLbyte z); +GLAPI void APIENTRY glVertex4bvOES (const GLbyte *coords); +#endif +#endif /* GL_OES_byte_coordinates */ + +#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 +#endif /* GL_OES_compressed_paletted_texture */ + +#ifndef GL_OES_fixed_point +#define GL_OES_fixed_point 1 +typedef GLint GLfixed; +#define GL_FIXED_OES 0x140C +typedef void (APIENTRYP PFNGLALPHAFUNCXOESPROC) (GLenum func, GLfixed ref); +typedef void (APIENTRYP PFNGLCLEARCOLORXOESPROC) (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +typedef void (APIENTRYP PFNGLCLEARDEPTHXOESPROC) (GLfixed depth); +typedef void (APIENTRYP PFNGLCLIPPLANEXOESPROC) (GLenum plane, const GLfixed *equation); +typedef void (APIENTRYP PFNGLCOLOR4XOESPROC) (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +typedef void (APIENTRYP PFNGLDEPTHRANGEXOESPROC) (GLfixed n, GLfixed f); +typedef void (APIENTRYP PFNGLFOGXOESPROC) (GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLFOGXVOESPROC) (GLenum pname, const GLfixed *param); +typedef void (APIENTRYP PFNGLFRUSTUMXOESPROC) (GLfixed l, GLfixed r, GLfixed b, GLfixed t, GLfixed n, GLfixed f); +typedef void (APIENTRYP PFNGLGETCLIPPLANEXOESPROC) (GLenum plane, GLfixed *equation); +typedef void (APIENTRYP PFNGLGETFIXEDVOESPROC) (GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETTEXENVXVOESPROC) (GLenum target, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERXVOESPROC) (GLenum target, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLLIGHTMODELXOESPROC) (GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLLIGHTMODELXVOESPROC) (GLenum pname, const GLfixed *param); +typedef void (APIENTRYP PFNGLLIGHTXOESPROC) (GLenum light, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLLIGHTXVOESPROC) (GLenum light, GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLLINEWIDTHXOESPROC) (GLfixed width); +typedef void (APIENTRYP PFNGLLOADMATRIXXOESPROC) (const GLfixed *m); +typedef void (APIENTRYP PFNGLMATERIALXOESPROC) (GLenum face, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLMATERIALXVOESPROC) (GLenum face, GLenum pname, const GLfixed *param); +typedef void (APIENTRYP PFNGLMULTMATRIXXOESPROC) (const GLfixed *m); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4XOESPROC) (GLenum texture, GLfixed s, GLfixed t, GLfixed r, GLfixed q); +typedef void (APIENTRYP PFNGLNORMAL3XOESPROC) (GLfixed nx, GLfixed ny, GLfixed nz); +typedef void (APIENTRYP PFNGLORTHOXOESPROC) (GLfixed l, GLfixed r, GLfixed b, GLfixed t, GLfixed n, GLfixed f); +typedef void (APIENTRYP PFNGLPOINTPARAMETERXVOESPROC) (GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLPOINTSIZEXOESPROC) (GLfixed size); +typedef void (APIENTRYP PFNGLPOLYGONOFFSETXOESPROC) (GLfixed factor, GLfixed units); +typedef void (APIENTRYP PFNGLROTATEXOESPROC) (GLfixed angle, GLfixed x, GLfixed y, GLfixed z); +typedef void (APIENTRYP PFNGLSAMPLECOVERAGEOESPROC) (GLfixed value, GLboolean invert); +typedef void (APIENTRYP PFNGLSCALEXOESPROC) (GLfixed x, GLfixed y, GLfixed z); +typedef void (APIENTRYP PFNGLTEXENVXOESPROC) (GLenum target, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLTEXENVXVOESPROC) (GLenum target, GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLTEXPARAMETERXOESPROC) (GLenum target, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLTEXPARAMETERXVOESPROC) (GLenum target, GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLTRANSLATEXOESPROC) (GLfixed x, GLfixed y, GLfixed z); +typedef void (APIENTRYP PFNGLACCUMXOESPROC) (GLenum op, GLfixed value); +typedef void (APIENTRYP PFNGLBITMAPXOESPROC) (GLsizei width, GLsizei height, GLfixed xorig, GLfixed yorig, GLfixed xmove, GLfixed ymove, const GLubyte *bitmap); +typedef void (APIENTRYP PFNGLBLENDCOLORXOESPROC) (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +typedef void (APIENTRYP PFNGLCLEARACCUMXOESPROC) (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +typedef void (APIENTRYP PFNGLCOLOR3XOESPROC) (GLfixed red, GLfixed green, GLfixed blue); +typedef void (APIENTRYP PFNGLCOLOR3XVOESPROC) (const GLfixed *components); +typedef void (APIENTRYP PFNGLCOLOR4XVOESPROC) (const GLfixed *components); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERXOESPROC) (GLenum target, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERXVOESPROC) (GLenum target, GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLEVALCOORD1XOESPROC) (GLfixed u); +typedef void (APIENTRYP PFNGLEVALCOORD1XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLEVALCOORD2XOESPROC) (GLfixed u, GLfixed v); +typedef void (APIENTRYP PFNGLEVALCOORD2XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLFEEDBACKBUFFERXOESPROC) (GLsizei n, GLenum type, const GLfixed *buffer); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERXVOESPROC) (GLenum target, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERXVOESPROC) (GLenum target, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETLIGHTXOESPROC) (GLenum light, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETMAPXVOESPROC) (GLenum target, GLenum query, GLfixed *v); +typedef void (APIENTRYP PFNGLGETMATERIALXOESPROC) (GLenum face, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLGETPIXELMAPXVPROC) (GLenum map, GLint size, GLfixed *values); +typedef void (APIENTRYP PFNGLGETTEXGENXVOESPROC) (GLenum coord, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLGETTEXLEVELPARAMETERXVOESPROC) (GLenum target, GLint level, GLenum pname, GLfixed *params); +typedef void (APIENTRYP PFNGLINDEXXOESPROC) (GLfixed component); +typedef void (APIENTRYP PFNGLINDEXXVOESPROC) (const GLfixed *component); +typedef void (APIENTRYP PFNGLLOADTRANSPOSEMATRIXXOESPROC) (const GLfixed *m); +typedef void (APIENTRYP PFNGLMAP1XOESPROC) (GLenum target, GLfixed u1, GLfixed u2, GLint stride, GLint order, GLfixed points); +typedef void (APIENTRYP PFNGLMAP2XOESPROC) (GLenum target, GLfixed u1, GLfixed u2, GLint ustride, GLint uorder, GLfixed v1, GLfixed v2, GLint vstride, GLint vorder, GLfixed points); +typedef void (APIENTRYP PFNGLMAPGRID1XOESPROC) (GLint n, GLfixed u1, GLfixed u2); +typedef void (APIENTRYP PFNGLMAPGRID2XOESPROC) (GLint n, GLfixed u1, GLfixed u2, GLfixed v1, GLfixed v2); +typedef void (APIENTRYP PFNGLMULTTRANSPOSEMATRIXXOESPROC) (const GLfixed *m); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1XOESPROC) (GLenum texture, GLfixed s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1XVOESPROC) (GLenum texture, const GLfixed *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2XOESPROC) (GLenum texture, GLfixed s, GLfixed t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2XVOESPROC) (GLenum texture, const GLfixed *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3XOESPROC) (GLenum texture, GLfixed s, GLfixed t, GLfixed r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3XVOESPROC) (GLenum texture, const GLfixed *coords); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4XVOESPROC) (GLenum texture, const GLfixed *coords); +typedef void (APIENTRYP PFNGLNORMAL3XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLPASSTHROUGHXOESPROC) (GLfixed token); +typedef void (APIENTRYP PFNGLPIXELMAPXPROC) (GLenum map, GLint size, const GLfixed *values); +typedef void (APIENTRYP PFNGLPIXELSTOREXPROC) (GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLPIXELTRANSFERXOESPROC) (GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLPIXELZOOMXOESPROC) (GLfixed xfactor, GLfixed yfactor); +typedef void (APIENTRYP PFNGLPRIORITIZETEXTURESXOESPROC) (GLsizei n, const GLuint *textures, const GLfixed *priorities); +typedef void (APIENTRYP PFNGLRASTERPOS2XOESPROC) (GLfixed x, GLfixed y); +typedef void (APIENTRYP PFNGLRASTERPOS2XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLRASTERPOS3XOESPROC) (GLfixed x, GLfixed y, GLfixed z); +typedef void (APIENTRYP PFNGLRASTERPOS3XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLRASTERPOS4XOESPROC) (GLfixed x, GLfixed y, GLfixed z, GLfixed w); +typedef void (APIENTRYP PFNGLRASTERPOS4XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLRECTXOESPROC) (GLfixed x1, GLfixed y1, GLfixed x2, GLfixed y2); +typedef void (APIENTRYP PFNGLRECTXVOESPROC) (const GLfixed *v1, const GLfixed *v2); +typedef void (APIENTRYP PFNGLTEXCOORD1XOESPROC) (GLfixed s); +typedef void (APIENTRYP PFNGLTEXCOORD1XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLTEXCOORD2XOESPROC) (GLfixed s, GLfixed t); +typedef void (APIENTRYP PFNGLTEXCOORD2XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLTEXCOORD3XOESPROC) (GLfixed s, GLfixed t, GLfixed r); +typedef void (APIENTRYP PFNGLTEXCOORD3XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLTEXCOORD4XOESPROC) (GLfixed s, GLfixed t, GLfixed r, GLfixed q); +typedef void (APIENTRYP PFNGLTEXCOORD4XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLTEXGENXOESPROC) (GLenum coord, GLenum pname, GLfixed param); +typedef void (APIENTRYP PFNGLTEXGENXVOESPROC) (GLenum coord, GLenum pname, const GLfixed *params); +typedef void (APIENTRYP PFNGLVERTEX2XOESPROC) (GLfixed x); +typedef void (APIENTRYP PFNGLVERTEX2XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLVERTEX3XOESPROC) (GLfixed x, GLfixed y); +typedef void (APIENTRYP PFNGLVERTEX3XVOESPROC) (const GLfixed *coords); +typedef void (APIENTRYP PFNGLVERTEX4XOESPROC) (GLfixed x, GLfixed y, GLfixed z); +typedef void (APIENTRYP PFNGLVERTEX4XVOESPROC) (const GLfixed *coords); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glAlphaFuncxOES (GLenum func, GLfixed ref); +GLAPI void APIENTRY glClearColorxOES (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +GLAPI void APIENTRY glClearDepthxOES (GLfixed depth); +GLAPI void APIENTRY glClipPlanexOES (GLenum plane, const GLfixed *equation); +GLAPI void APIENTRY glColor4xOES (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +GLAPI void APIENTRY glDepthRangexOES (GLfixed n, GLfixed f); +GLAPI void APIENTRY glFogxOES (GLenum pname, GLfixed param); +GLAPI void APIENTRY glFogxvOES (GLenum pname, const GLfixed *param); +GLAPI void APIENTRY glFrustumxOES (GLfixed l, GLfixed r, GLfixed b, GLfixed t, GLfixed n, GLfixed f); +GLAPI void APIENTRY glGetClipPlanexOES (GLenum plane, GLfixed *equation); +GLAPI void APIENTRY glGetFixedvOES (GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetTexEnvxvOES (GLenum target, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetTexParameterxvOES (GLenum target, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glLightModelxOES (GLenum pname, GLfixed param); +GLAPI void APIENTRY glLightModelxvOES (GLenum pname, const GLfixed *param); +GLAPI void APIENTRY glLightxOES (GLenum light, GLenum pname, GLfixed param); +GLAPI void APIENTRY glLightxvOES (GLenum light, GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glLineWidthxOES (GLfixed width); +GLAPI void APIENTRY glLoadMatrixxOES (const GLfixed *m); +GLAPI void APIENTRY glMaterialxOES (GLenum face, GLenum pname, GLfixed param); +GLAPI void APIENTRY glMaterialxvOES (GLenum face, GLenum pname, const GLfixed *param); +GLAPI void APIENTRY glMultMatrixxOES (const GLfixed *m); +GLAPI void APIENTRY glMultiTexCoord4xOES (GLenum texture, GLfixed s, GLfixed t, GLfixed r, GLfixed q); +GLAPI void APIENTRY glNormal3xOES (GLfixed nx, GLfixed ny, GLfixed nz); +GLAPI void APIENTRY glOrthoxOES (GLfixed l, GLfixed r, GLfixed b, GLfixed t, GLfixed n, GLfixed f); +GLAPI void APIENTRY glPointParameterxvOES (GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glPointSizexOES (GLfixed size); +GLAPI void APIENTRY glPolygonOffsetxOES (GLfixed factor, GLfixed units); +GLAPI void APIENTRY glRotatexOES (GLfixed angle, GLfixed x, GLfixed y, GLfixed z); +GLAPI void APIENTRY glSampleCoverageOES (GLfixed value, GLboolean invert); +GLAPI void APIENTRY glScalexOES (GLfixed x, GLfixed y, GLfixed z); +GLAPI void APIENTRY glTexEnvxOES (GLenum target, GLenum pname, GLfixed param); +GLAPI void APIENTRY glTexEnvxvOES (GLenum target, GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glTexParameterxOES (GLenum target, GLenum pname, GLfixed param); +GLAPI void APIENTRY glTexParameterxvOES (GLenum target, GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glTranslatexOES (GLfixed x, GLfixed y, GLfixed z); +GLAPI void APIENTRY glAccumxOES (GLenum op, GLfixed value); +GLAPI void APIENTRY glBitmapxOES (GLsizei width, GLsizei height, GLfixed xorig, GLfixed yorig, GLfixed xmove, GLfixed ymove, const GLubyte *bitmap); +GLAPI void APIENTRY glBlendColorxOES (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +GLAPI void APIENTRY glClearAccumxOES (GLfixed red, GLfixed green, GLfixed blue, GLfixed alpha); +GLAPI void APIENTRY glColor3xOES (GLfixed red, GLfixed green, GLfixed blue); +GLAPI void APIENTRY glColor3xvOES (const GLfixed *components); +GLAPI void APIENTRY glColor4xvOES (const GLfixed *components); +GLAPI void APIENTRY glConvolutionParameterxOES (GLenum target, GLenum pname, GLfixed param); +GLAPI void APIENTRY glConvolutionParameterxvOES (GLenum target, GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glEvalCoord1xOES (GLfixed u); +GLAPI void APIENTRY glEvalCoord1xvOES (const GLfixed *coords); +GLAPI void APIENTRY glEvalCoord2xOES (GLfixed u, GLfixed v); +GLAPI void APIENTRY glEvalCoord2xvOES (const GLfixed *coords); +GLAPI void APIENTRY glFeedbackBufferxOES (GLsizei n, GLenum type, const GLfixed *buffer); +GLAPI void APIENTRY glGetConvolutionParameterxvOES (GLenum target, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetHistogramParameterxvOES (GLenum target, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetLightxOES (GLenum light, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetMapxvOES (GLenum target, GLenum query, GLfixed *v); +GLAPI void APIENTRY glGetMaterialxOES (GLenum face, GLenum pname, GLfixed param); +GLAPI void APIENTRY glGetPixelMapxv (GLenum map, GLint size, GLfixed *values); +GLAPI void APIENTRY glGetTexGenxvOES (GLenum coord, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glGetTexLevelParameterxvOES (GLenum target, GLint level, GLenum pname, GLfixed *params); +GLAPI void APIENTRY glIndexxOES (GLfixed component); +GLAPI void APIENTRY glIndexxvOES (const GLfixed *component); +GLAPI void APIENTRY glLoadTransposeMatrixxOES (const GLfixed *m); +GLAPI void APIENTRY glMap1xOES (GLenum target, GLfixed u1, GLfixed u2, GLint stride, GLint order, GLfixed points); +GLAPI void APIENTRY glMap2xOES (GLenum target, GLfixed u1, GLfixed u2, GLint ustride, GLint uorder, GLfixed v1, GLfixed v2, GLint vstride, GLint vorder, GLfixed points); +GLAPI void APIENTRY glMapGrid1xOES (GLint n, GLfixed u1, GLfixed u2); +GLAPI void APIENTRY glMapGrid2xOES (GLint n, GLfixed u1, GLfixed u2, GLfixed v1, GLfixed v2); +GLAPI void APIENTRY glMultTransposeMatrixxOES (const GLfixed *m); +GLAPI void APIENTRY glMultiTexCoord1xOES (GLenum texture, GLfixed s); +GLAPI void APIENTRY glMultiTexCoord1xvOES (GLenum texture, const GLfixed *coords); +GLAPI void APIENTRY glMultiTexCoord2xOES (GLenum texture, GLfixed s, GLfixed t); +GLAPI void APIENTRY glMultiTexCoord2xvOES (GLenum texture, const GLfixed *coords); +GLAPI void APIENTRY glMultiTexCoord3xOES (GLenum texture, GLfixed s, GLfixed t, GLfixed r); +GLAPI void APIENTRY glMultiTexCoord3xvOES (GLenum texture, const GLfixed *coords); +GLAPI void APIENTRY glMultiTexCoord4xvOES (GLenum texture, const GLfixed *coords); +GLAPI void APIENTRY glNormal3xvOES (const GLfixed *coords); +GLAPI void APIENTRY glPassThroughxOES (GLfixed token); +GLAPI void APIENTRY glPixelMapx (GLenum map, GLint size, const GLfixed *values); +GLAPI void APIENTRY glPixelStorex (GLenum pname, GLfixed param); +GLAPI void APIENTRY glPixelTransferxOES (GLenum pname, GLfixed param); +GLAPI void APIENTRY glPixelZoomxOES (GLfixed xfactor, GLfixed yfactor); +GLAPI void APIENTRY glPrioritizeTexturesxOES (GLsizei n, const GLuint *textures, const GLfixed *priorities); +GLAPI void APIENTRY glRasterPos2xOES (GLfixed x, GLfixed y); +GLAPI void APIENTRY glRasterPos2xvOES (const GLfixed *coords); +GLAPI void APIENTRY glRasterPos3xOES (GLfixed x, GLfixed y, GLfixed z); +GLAPI void APIENTRY glRasterPos3xvOES (const GLfixed *coords); +GLAPI void APIENTRY glRasterPos4xOES (GLfixed x, GLfixed y, GLfixed z, GLfixed w); +GLAPI void APIENTRY glRasterPos4xvOES (const GLfixed *coords); +GLAPI void APIENTRY glRectxOES (GLfixed x1, GLfixed y1, GLfixed x2, GLfixed y2); +GLAPI void APIENTRY glRectxvOES (const GLfixed *v1, const GLfixed *v2); +GLAPI void APIENTRY glTexCoord1xOES (GLfixed s); +GLAPI void APIENTRY glTexCoord1xvOES (const GLfixed *coords); +GLAPI void APIENTRY glTexCoord2xOES (GLfixed s, GLfixed t); +GLAPI void APIENTRY glTexCoord2xvOES (const GLfixed *coords); +GLAPI void APIENTRY glTexCoord3xOES (GLfixed s, GLfixed t, GLfixed r); +GLAPI void APIENTRY glTexCoord3xvOES (const GLfixed *coords); +GLAPI void APIENTRY glTexCoord4xOES (GLfixed s, GLfixed t, GLfixed r, GLfixed q); +GLAPI void APIENTRY glTexCoord4xvOES (const GLfixed *coords); +GLAPI void APIENTRY glTexGenxOES (GLenum coord, GLenum pname, GLfixed param); +GLAPI void APIENTRY glTexGenxvOES (GLenum coord, GLenum pname, const GLfixed *params); +GLAPI void APIENTRY glVertex2xOES (GLfixed x); +GLAPI void APIENTRY glVertex2xvOES (const GLfixed *coords); +GLAPI void APIENTRY glVertex3xOES (GLfixed x, GLfixed y); +GLAPI void APIENTRY glVertex3xvOES (const GLfixed *coords); +GLAPI void APIENTRY glVertex4xOES (GLfixed x, GLfixed y, GLfixed z); +GLAPI void APIENTRY glVertex4xvOES (const GLfixed *coords); +#endif +#endif /* GL_OES_fixed_point */ + +#ifndef GL_OES_query_matrix +#define GL_OES_query_matrix 1 +typedef GLbitfield (APIENTRYP PFNGLQUERYMATRIXXOESPROC) (GLfixed *mantissa, GLint *exponent); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLbitfield APIENTRY glQueryMatrixxOES (GLfixed *mantissa, GLint *exponent); +#endif +#endif /* GL_OES_query_matrix */ + +#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 +#endif /* GL_OES_read_format */ + +#ifndef GL_OES_single_precision +#define GL_OES_single_precision 1 +typedef void (APIENTRYP PFNGLCLEARDEPTHFOESPROC) (GLclampf depth); +typedef void (APIENTRYP PFNGLCLIPPLANEFOESPROC) (GLenum plane, const GLfloat *equation); +typedef void (APIENTRYP PFNGLDEPTHRANGEFOESPROC) (GLclampf n, GLclampf f); +typedef void (APIENTRYP PFNGLFRUSTUMFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); +typedef void (APIENTRYP PFNGLGETCLIPPLANEFOESPROC) (GLenum plane, GLfloat *equation); +typedef void (APIENTRYP PFNGLORTHOFOESPROC) (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glClearDepthfOES (GLclampf depth); +GLAPI void APIENTRY glClipPlanefOES (GLenum plane, const GLfloat *equation); +GLAPI void APIENTRY glDepthRangefOES (GLclampf n, GLclampf f); +GLAPI void APIENTRY glFrustumfOES (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); +GLAPI void APIENTRY glGetClipPlanefOES (GLenum plane, GLfloat *equation); +GLAPI void APIENTRY glOrthofOES (GLfloat l, GLfloat r, GLfloat b, GLfloat t, GLfloat n, GLfloat f); +#endif +#endif /* GL_OES_single_precision */ + +#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 +#endif /* GL_3DFX_multisample */ + +#ifndef GL_3DFX_tbuffer +#define GL_3DFX_tbuffer 1 +typedef void (APIENTRYP PFNGLTBUFFERMASK3DFXPROC) (GLuint mask); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTbufferMask3DFX (GLuint mask); +#endif +#endif /* GL_3DFX_tbuffer */ + +#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 +#endif /* GL_3DFX_texture_compression_FXT1 */ + +#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 +#endif /* GL_AMD_blend_minmax_factor */ + +#ifndef GL_AMD_conservative_depth +#define GL_AMD_conservative_depth 1 +#endif /* GL_AMD_conservative_depth */ + +#ifndef GL_AMD_debug_output +#define GL_AMD_debug_output 1 +typedef void (APIENTRY *GLDEBUGPROCAMD)(GLuint id,GLenum category,GLenum severity,GLsizei length,const GLchar *message,void *userParam); +#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 (APIENTRYP PFNGLDEBUGMESSAGEENABLEAMDPROC) (GLenum category, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +typedef void (APIENTRYP PFNGLDEBUGMESSAGEINSERTAMDPROC) (GLenum category, GLenum severity, GLuint id, GLsizei length, const GLchar *buf); +typedef void (APIENTRYP PFNGLDEBUGMESSAGECALLBACKAMDPROC) (GLDEBUGPROCAMD callback, void *userParam); +typedef GLuint (APIENTRYP PFNGLGETDEBUGMESSAGELOGAMDPROC) (GLuint count, GLsizei bufsize, GLenum *categories, GLuint *severities, GLuint *ids, GLsizei *lengths, GLchar *message); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDebugMessageEnableAMD (GLenum category, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GLAPI void APIENTRY glDebugMessageInsertAMD (GLenum category, GLenum severity, GLuint id, GLsizei length, const GLchar *buf); +GLAPI void APIENTRY glDebugMessageCallbackAMD (GLDEBUGPROCAMD callback, void *userParam); +GLAPI GLuint APIENTRY glGetDebugMessageLogAMD (GLuint count, GLsizei bufsize, GLenum *categories, GLuint *severities, GLuint *ids, GLsizei *lengths, GLchar *message); +#endif +#endif /* GL_AMD_debug_output */ + +#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 +#endif /* GL_AMD_depth_clamp_separate */ + +#ifndef GL_AMD_draw_buffers_blend +#define GL_AMD_draw_buffers_blend 1 +typedef void (APIENTRYP PFNGLBLENDFUNCINDEXEDAMDPROC) (GLuint buf, GLenum src, GLenum dst); +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +typedef void (APIENTRYP PFNGLBLENDEQUATIONINDEXEDAMDPROC) (GLuint buf, GLenum mode); +typedef void (APIENTRYP PFNGLBLENDEQUATIONSEPARATEINDEXEDAMDPROC) (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncIndexedAMD (GLuint buf, GLenum src, GLenum dst); +GLAPI void APIENTRY glBlendFuncSeparateIndexedAMD (GLuint buf, GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +GLAPI void APIENTRY glBlendEquationIndexedAMD (GLuint buf, GLenum mode); +GLAPI void APIENTRY glBlendEquationSeparateIndexedAMD (GLuint buf, GLenum modeRGB, GLenum modeAlpha); +#endif +#endif /* GL_AMD_draw_buffers_blend */ + +#ifndef GL_AMD_gcn_shader +#define GL_AMD_gcn_shader 1 +#endif /* GL_AMD_gcn_shader */ + +#ifndef GL_AMD_gpu_shader_int64 +#define GL_AMD_gpu_shader_int64 1 +typedef int64_t GLint64EXT; +#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 (APIENTRYP PFNGLUNIFORM1I64NVPROC) (GLint location, GLint64EXT x); +typedef void (APIENTRYP PFNGLUNIFORM2I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y); +typedef void (APIENTRYP PFNGLUNIFORM3I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (APIENTRYP PFNGLUNIFORM4I64NVPROC) (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (APIENTRYP PFNGLUNIFORM1I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM2I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM3I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM4I64VNVPROC) (GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM1UI64NVPROC) (GLint location, GLuint64EXT x); +typedef void (APIENTRYP PFNGLUNIFORM2UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y); +typedef void (APIENTRYP PFNGLUNIFORM3UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (APIENTRYP PFNGLUNIFORM4UI64NVPROC) (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (APIENTRYP PFNGLUNIFORM1UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM2UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM3UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLUNIFORM4UI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLGETUNIFORMI64VNVPROC) (GLuint program, GLint location, GLint64EXT *params); +typedef void (APIENTRYP PFNGLGETUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLuint64EXT *params); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1I64NVPROC) (GLuint program, GLint location, GLint64EXT x); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4I64NVPROC) (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4I64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UI64NVPROC) (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glUniform1i64NV (GLint location, GLint64EXT x); +GLAPI void APIENTRY glUniform2i64NV (GLint location, GLint64EXT x, GLint64EXT y); +GLAPI void APIENTRY glUniform3i64NV (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +GLAPI void APIENTRY glUniform4i64NV (GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +GLAPI void APIENTRY glUniform1i64vNV (GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glUniform2i64vNV (GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glUniform3i64vNV (GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glUniform4i64vNV (GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glUniform1ui64NV (GLint location, GLuint64EXT x); +GLAPI void APIENTRY glUniform2ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y); +GLAPI void APIENTRY glUniform3ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +GLAPI void APIENTRY glUniform4ui64NV (GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +GLAPI void APIENTRY glUniform1ui64vNV (GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glUniform2ui64vNV (GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glUniform3ui64vNV (GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glUniform4ui64vNV (GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glGetUniformi64vNV (GLuint program, GLint location, GLint64EXT *params); +GLAPI void APIENTRY glGetUniformui64vNV (GLuint program, GLint location, GLuint64EXT *params); +GLAPI void APIENTRY glProgramUniform1i64NV (GLuint program, GLint location, GLint64EXT x); +GLAPI void APIENTRY glProgramUniform2i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y); +GLAPI void APIENTRY glProgramUniform3i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z); +GLAPI void APIENTRY glProgramUniform4i64NV (GLuint program, GLint location, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +GLAPI void APIENTRY glProgramUniform1i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glProgramUniform2i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glProgramUniform3i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glProgramUniform4i64vNV (GLuint program, GLint location, GLsizei count, const GLint64EXT *value); +GLAPI void APIENTRY glProgramUniform1ui64NV (GLuint program, GLint location, GLuint64EXT x); +GLAPI void APIENTRY glProgramUniform2ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y); +GLAPI void APIENTRY glProgramUniform3ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +GLAPI void APIENTRY glProgramUniform4ui64NV (GLuint program, GLint location, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +GLAPI void APIENTRY glProgramUniform1ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glProgramUniform2ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glProgramUniform3ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glProgramUniform4ui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +#endif +#endif /* GL_AMD_gpu_shader_int64 */ + +#ifndef GL_AMD_interleaved_elements +#define GL_AMD_interleaved_elements 1 +#define GL_VERTEX_ELEMENT_SWIZZLE_AMD 0x91A4 +#define GL_VERTEX_ID_SWIZZLE_AMD 0x91A5 +typedef void (APIENTRYP PFNGLVERTEXATTRIBPARAMETERIAMDPROC) (GLuint index, GLenum pname, GLint param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribParameteriAMD (GLuint index, GLenum pname, GLint param); +#endif +#endif /* GL_AMD_interleaved_elements */ + +#ifndef GL_AMD_multi_draw_indirect +#define GL_AMD_multi_draw_indirect 1 +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTAMDPROC) (GLenum mode, const void *indirect, GLsizei primcount, GLsizei stride); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTAMDPROC) (GLenum mode, GLenum type, const void *indirect, GLsizei primcount, GLsizei stride); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiDrawArraysIndirectAMD (GLenum mode, const void *indirect, GLsizei primcount, GLsizei stride); +GLAPI void APIENTRY glMultiDrawElementsIndirectAMD (GLenum mode, GLenum type, const void *indirect, GLsizei primcount, GLsizei stride); +#endif +#endif /* GL_AMD_multi_draw_indirect */ + +#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 (APIENTRYP PFNGLGENNAMESAMDPROC) (GLenum identifier, GLuint num, GLuint *names); +typedef void (APIENTRYP PFNGLDELETENAMESAMDPROC) (GLenum identifier, GLuint num, const GLuint *names); +typedef GLboolean (APIENTRYP PFNGLISNAMEAMDPROC) (GLenum identifier, GLuint name); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenNamesAMD (GLenum identifier, GLuint num, GLuint *names); +GLAPI void APIENTRY glDeleteNamesAMD (GLenum identifier, GLuint num, const GLuint *names); +GLAPI GLboolean APIENTRY glIsNameAMD (GLenum identifier, GLuint name); +#endif +#endif /* GL_AMD_name_gen_delete */ + +#ifndef GL_AMD_occlusion_query_event +#define GL_AMD_occlusion_query_event 1 +#define GL_OCCLUSION_QUERY_EVENT_MASK_AMD 0x874F +#define GL_QUERY_DEPTH_PASS_EVENT_BIT_AMD 0x00000001 +#define GL_QUERY_DEPTH_FAIL_EVENT_BIT_AMD 0x00000002 +#define GL_QUERY_STENCIL_FAIL_EVENT_BIT_AMD 0x00000004 +#define GL_QUERY_DEPTH_BOUNDS_FAIL_EVENT_BIT_AMD 0x00000008 +#define GL_QUERY_ALL_EVENT_BITS_AMD 0xFFFFFFFF +typedef void (APIENTRYP PFNGLQUERYOBJECTPARAMETERUIAMDPROC) (GLenum target, GLuint id, GLenum pname, GLuint param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glQueryObjectParameteruiAMD (GLenum target, GLuint id, GLenum pname, GLuint param); +#endif +#endif /* GL_AMD_occlusion_query_event */ + +#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 (APIENTRYP PFNGLGETPERFMONITORGROUPSAMDPROC) (GLint *numGroups, GLsizei groupsSize, GLuint *groups); +typedef void (APIENTRYP PFNGLGETPERFMONITORCOUNTERSAMDPROC) (GLuint group, GLint *numCounters, GLint *maxActiveCounters, GLsizei counterSize, GLuint *counters); +typedef void (APIENTRYP PFNGLGETPERFMONITORGROUPSTRINGAMDPROC) (GLuint group, GLsizei bufSize, GLsizei *length, GLchar *groupString); +typedef void (APIENTRYP PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC) (GLuint group, GLuint counter, GLsizei bufSize, GLsizei *length, GLchar *counterString); +typedef void (APIENTRYP PFNGLGETPERFMONITORCOUNTERINFOAMDPROC) (GLuint group, GLuint counter, GLenum pname, void *data); +typedef void (APIENTRYP PFNGLGENPERFMONITORSAMDPROC) (GLsizei n, GLuint *monitors); +typedef void (APIENTRYP PFNGLDELETEPERFMONITORSAMDPROC) (GLsizei n, GLuint *monitors); +typedef void (APIENTRYP PFNGLSELECTPERFMONITORCOUNTERSAMDPROC) (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint *counterList); +typedef void (APIENTRYP PFNGLBEGINPERFMONITORAMDPROC) (GLuint monitor); +typedef void (APIENTRYP PFNGLENDPERFMONITORAMDPROC) (GLuint monitor); +typedef void (APIENTRYP PFNGLGETPERFMONITORCOUNTERDATAAMDPROC) (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint *data, GLint *bytesWritten); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetPerfMonitorGroupsAMD (GLint *numGroups, GLsizei groupsSize, GLuint *groups); +GLAPI void APIENTRY glGetPerfMonitorCountersAMD (GLuint group, GLint *numCounters, GLint *maxActiveCounters, GLsizei counterSize, GLuint *counters); +GLAPI void APIENTRY glGetPerfMonitorGroupStringAMD (GLuint group, GLsizei bufSize, GLsizei *length, GLchar *groupString); +GLAPI void APIENTRY glGetPerfMonitorCounterStringAMD (GLuint group, GLuint counter, GLsizei bufSize, GLsizei *length, GLchar *counterString); +GLAPI void APIENTRY glGetPerfMonitorCounterInfoAMD (GLuint group, GLuint counter, GLenum pname, void *data); +GLAPI void APIENTRY glGenPerfMonitorsAMD (GLsizei n, GLuint *monitors); +GLAPI void APIENTRY glDeletePerfMonitorsAMD (GLsizei n, GLuint *monitors); +GLAPI void APIENTRY glSelectPerfMonitorCountersAMD (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint *counterList); +GLAPI void APIENTRY glBeginPerfMonitorAMD (GLuint monitor); +GLAPI void APIENTRY glEndPerfMonitorAMD (GLuint monitor); +GLAPI void APIENTRY glGetPerfMonitorCounterDataAMD (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint *data, GLint *bytesWritten); +#endif +#endif /* GL_AMD_performance_monitor */ + +#ifndef GL_AMD_pinned_memory +#define GL_AMD_pinned_memory 1 +#define GL_EXTERNAL_VIRTUAL_MEMORY_BUFFER_AMD 0x9160 +#endif /* GL_AMD_pinned_memory */ + +#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 +#endif /* GL_AMD_query_buffer_object */ + +#ifndef GL_AMD_sample_positions +#define GL_AMD_sample_positions 1 +#define GL_SUBSAMPLE_DISTANCE_AMD 0x883F +typedef void (APIENTRYP PFNGLSETMULTISAMPLEFVAMDPROC) (GLenum pname, GLuint index, const GLfloat *val); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSetMultisamplefvAMD (GLenum pname, GLuint index, const GLfloat *val); +#endif +#endif /* GL_AMD_sample_positions */ + +#ifndef GL_AMD_seamless_cubemap_per_texture +#define GL_AMD_seamless_cubemap_per_texture 1 +#endif /* GL_AMD_seamless_cubemap_per_texture */ + +#ifndef GL_AMD_shader_atomic_counter_ops +#define GL_AMD_shader_atomic_counter_ops 1 +#endif /* GL_AMD_shader_atomic_counter_ops */ + +#ifndef GL_AMD_shader_stencil_export +#define GL_AMD_shader_stencil_export 1 +#endif /* GL_AMD_shader_stencil_export */ + +#ifndef GL_AMD_shader_trinary_minmax +#define GL_AMD_shader_trinary_minmax 1 +#endif /* GL_AMD_shader_trinary_minmax */ + +#ifndef GL_AMD_sparse_texture +#define GL_AMD_sparse_texture 1 +#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 +#define GL_TEXTURE_STORAGE_SPARSE_BIT_AMD 0x00000001 +typedef void (APIENTRYP PFNGLTEXSTORAGESPARSEAMDPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); +typedef void (APIENTRYP PFNGLTEXTURESTORAGESPARSEAMDPROC) (GLuint texture, GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexStorageSparseAMD (GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); +GLAPI void APIENTRY glTextureStorageSparseAMD (GLuint texture, GLenum target, GLenum internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLsizei layers, GLbitfield flags); +#endif +#endif /* GL_AMD_sparse_texture */ + +#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 (APIENTRYP PFNGLSTENCILOPVALUEAMDPROC) (GLenum face, GLuint value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStencilOpValueAMD (GLenum face, GLuint value); +#endif +#endif /* GL_AMD_stencil_operation_extended */ + +#ifndef GL_AMD_texture_texture4 +#define GL_AMD_texture_texture4 1 +#endif /* GL_AMD_texture_texture4 */ + +#ifndef GL_AMD_transform_feedback3_lines_triangles +#define GL_AMD_transform_feedback3_lines_triangles 1 +#endif /* GL_AMD_transform_feedback3_lines_triangles */ + +#ifndef GL_AMD_transform_feedback4 +#define GL_AMD_transform_feedback4 1 +#define GL_STREAM_RASTERIZATION_AMD 0x91A0 +#endif /* GL_AMD_transform_feedback4 */ + +#ifndef GL_AMD_vertex_shader_layer +#define GL_AMD_vertex_shader_layer 1 +#endif /* GL_AMD_vertex_shader_layer */ + +#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 (APIENTRYP PFNGLTESSELLATIONFACTORAMDPROC) (GLfloat factor); +typedef void (APIENTRYP PFNGLTESSELLATIONMODEAMDPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTessellationFactorAMD (GLfloat factor); +GLAPI void APIENTRY glTessellationModeAMD (GLenum mode); +#endif +#endif /* GL_AMD_vertex_shader_tessellator */ + +#ifndef GL_AMD_vertex_shader_viewport_index +#define GL_AMD_vertex_shader_viewport_index 1 +#endif /* GL_AMD_vertex_shader_viewport_index */ + +#ifndef GL_APPLE_aux_depth_stencil +#define GL_APPLE_aux_depth_stencil 1 +#define GL_AUX_DEPTH_STENCIL_APPLE 0x8A14 +#endif /* GL_APPLE_aux_depth_stencil */ + +#ifndef GL_APPLE_client_storage +#define GL_APPLE_client_storage 1 +#define GL_UNPACK_CLIENT_STORAGE_APPLE 0x85B2 +#endif /* GL_APPLE_client_storage */ + +#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 (APIENTRYP PFNGLELEMENTPOINTERAPPLEPROC) (GLenum type, const void *pointer); +typedef void (APIENTRYP PFNGLDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTARRAYAPPLEPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWRANGEELEMENTARRAYAPPLEPROC) (GLenum mode, GLuint start, GLuint end, const GLint *first, const GLsizei *count, GLsizei primcount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glElementPointerAPPLE (GLenum type, const void *pointer); +GLAPI void APIENTRY glDrawElementArrayAPPLE (GLenum mode, GLint first, GLsizei count); +GLAPI void APIENTRY glDrawRangeElementArrayAPPLE (GLenum mode, GLuint start, GLuint end, GLint first, GLsizei count); +GLAPI void APIENTRY glMultiDrawElementArrayAPPLE (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +GLAPI void APIENTRY glMultiDrawRangeElementArrayAPPLE (GLenum mode, GLuint start, GLuint end, const GLint *first, const GLsizei *count, GLsizei primcount); +#endif +#endif /* GL_APPLE_element_array */ + +#ifndef GL_APPLE_fence +#define GL_APPLE_fence 1 +#define GL_DRAW_PIXELS_APPLE 0x8A0A +#define GL_FENCE_APPLE 0x8A0B +typedef void (APIENTRYP PFNGLGENFENCESAPPLEPROC) (GLsizei n, GLuint *fences); +typedef void (APIENTRYP PFNGLDELETEFENCESAPPLEPROC) (GLsizei n, const GLuint *fences); +typedef void (APIENTRYP PFNGLSETFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLISFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTFENCEAPPLEPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLFINISHFENCEAPPLEPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTOBJECTAPPLEPROC) (GLenum object, GLuint name); +typedef void (APIENTRYP PFNGLFINISHOBJECTAPPLEPROC) (GLenum object, GLint name); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenFencesAPPLE (GLsizei n, GLuint *fences); +GLAPI void APIENTRY glDeleteFencesAPPLE (GLsizei n, const GLuint *fences); +GLAPI void APIENTRY glSetFenceAPPLE (GLuint fence); +GLAPI GLboolean APIENTRY glIsFenceAPPLE (GLuint fence); +GLAPI GLboolean APIENTRY glTestFenceAPPLE (GLuint fence); +GLAPI void APIENTRY glFinishFenceAPPLE (GLuint fence); +GLAPI GLboolean APIENTRY glTestObjectAPPLE (GLenum object, GLuint name); +GLAPI void APIENTRY glFinishObjectAPPLE (GLenum object, GLint name); +#endif +#endif /* GL_APPLE_fence */ + +#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 +#endif /* GL_APPLE_float_pixels */ + +#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 (APIENTRYP PFNGLBUFFERPARAMETERIAPPLEPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFLUSHMAPPEDBUFFERRANGEAPPLEPROC) (GLenum target, GLintptr offset, GLsizeiptr size); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBufferParameteriAPPLE (GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glFlushMappedBufferRangeAPPLE (GLenum target, GLintptr offset, GLsizeiptr size); +#endif +#endif /* GL_APPLE_flush_buffer_range */ + +#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 GLenum (APIENTRYP PFNGLOBJECTPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); +typedef GLenum (APIENTRYP PFNGLOBJECTUNPURGEABLEAPPLEPROC) (GLenum objectType, GLuint name, GLenum option); +typedef void (APIENTRYP PFNGLGETOBJECTPARAMETERIVAPPLEPROC) (GLenum objectType, GLuint name, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLenum APIENTRY glObjectPurgeableAPPLE (GLenum objectType, GLuint name, GLenum option); +GLAPI GLenum APIENTRY glObjectUnpurgeableAPPLE (GLenum objectType, GLuint name, GLenum option); +GLAPI void APIENTRY glGetObjectParameterivAPPLE (GLenum objectType, GLuint name, GLenum pname, GLint *params); +#endif +#endif /* GL_APPLE_object_purgeable */ + +#ifndef GL_APPLE_rgb_422 +#define GL_APPLE_rgb_422 1 +#define GL_RGB_422_APPLE 0x8A1F +#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB +#define GL_RGB_RAW_422_APPLE 0x8A51 +#endif /* GL_APPLE_rgb_422 */ + +#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 +#endif /* GL_APPLE_row_bytes */ + +#ifndef GL_APPLE_specular_vector +#define GL_APPLE_specular_vector 1 +#define GL_LIGHT_MODEL_SPECULAR_VECTOR_APPLE 0x85B0 +#endif /* GL_APPLE_specular_vector */ + +#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 (APIENTRYP PFNGLTEXTURERANGEAPPLEPROC) (GLenum target, GLsizei length, const void *pointer); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERPOINTERVAPPLEPROC) (GLenum target, GLenum pname, void **params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureRangeAPPLE (GLenum target, GLsizei length, const void *pointer); +GLAPI void APIENTRY glGetTexParameterPointervAPPLE (GLenum target, GLenum pname, void **params); +#endif +#endif /* GL_APPLE_texture_range */ + +#ifndef GL_APPLE_transform_hint +#define GL_APPLE_transform_hint 1 +#define GL_TRANSFORM_HINT_APPLE 0x85B1 +#endif /* GL_APPLE_transform_hint */ + +#ifndef GL_APPLE_vertex_array_object +#define GL_APPLE_vertex_array_object 1 +#define GL_VERTEX_ARRAY_BINDING_APPLE 0x85B5 +typedef void (APIENTRYP PFNGLBINDVERTEXARRAYAPPLEPROC) (GLuint array); +typedef void (APIENTRYP PFNGLDELETEVERTEXARRAYSAPPLEPROC) (GLsizei n, const GLuint *arrays); +typedef void (APIENTRYP PFNGLGENVERTEXARRAYSAPPLEPROC) (GLsizei n, GLuint *arrays); +typedef GLboolean (APIENTRYP PFNGLISVERTEXARRAYAPPLEPROC) (GLuint array); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindVertexArrayAPPLE (GLuint array); +GLAPI void APIENTRY glDeleteVertexArraysAPPLE (GLsizei n, const GLuint *arrays); +GLAPI void APIENTRY glGenVertexArraysAPPLE (GLsizei n, GLuint *arrays); +GLAPI GLboolean APIENTRY glIsVertexArrayAPPLE (GLuint array); +#endif +#endif /* GL_APPLE_vertex_array_object */ + +#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_VERTEX_ARRAY_RANGE_POINTER_APPLE 0x8521 +#define GL_STORAGE_CLIENT_APPLE 0x85B4 +typedef void (APIENTRYP PFNGLVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void *pointer); +typedef void (APIENTRYP PFNGLFLUSHVERTEXARRAYRANGEAPPLEPROC) (GLsizei length, void *pointer); +typedef void (APIENTRYP PFNGLVERTEXARRAYPARAMETERIAPPLEPROC) (GLenum pname, GLint param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexArrayRangeAPPLE (GLsizei length, void *pointer); +GLAPI void APIENTRY glFlushVertexArrayRangeAPPLE (GLsizei length, void *pointer); +GLAPI void APIENTRY glVertexArrayParameteriAPPLE (GLenum pname, GLint param); +#endif +#endif /* GL_APPLE_vertex_array_range */ + +#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 (APIENTRYP PFNGLENABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); +typedef void (APIENTRYP PFNGLDISABLEVERTEXATTRIBAPPLEPROC) (GLuint index, GLenum pname); +typedef GLboolean (APIENTRYP PFNGLISVERTEXATTRIBENABLEDAPPLEPROC) (GLuint index, GLenum pname); +typedef void (APIENTRYP PFNGLMAPVERTEXATTRIB1DAPPLEPROC) (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); +typedef void (APIENTRYP PFNGLMAPVERTEXATTRIB1FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLMAPVERTEXATTRIB2FAPPLEPROC) (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glEnableVertexAttribAPPLE (GLuint index, GLenum pname); +GLAPI void APIENTRY glDisableVertexAttribAPPLE (GLuint index, GLenum pname); +GLAPI GLboolean APIENTRY glIsVertexAttribEnabledAPPLE (GLuint index, GLenum pname); +GLAPI void APIENTRY glMapVertexAttrib1dAPPLE (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint stride, GLint order, const GLdouble *points); +GLAPI void APIENTRY glMapVertexAttrib1fAPPLE (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint stride, GLint order, const GLfloat *points); +GLAPI void APIENTRY glMapVertexAttrib2dAPPLE (GLuint index, GLuint size, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, const GLdouble *points); +GLAPI void APIENTRY glMapVertexAttrib2fAPPLE (GLuint index, GLuint size, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, const GLfloat *points); +#endif +#endif /* GL_APPLE_vertex_program_evaluators */ + +#ifndef GL_APPLE_ycbcr_422 +#define GL_APPLE_ycbcr_422 1 +#define GL_YCBCR_422_APPLE 0x85B9 +#endif /* GL_APPLE_ycbcr_422 */ + +#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 (APIENTRYP PFNGLDRAWBUFFERSATIPROC) (GLsizei n, const GLenum *bufs); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawBuffersATI (GLsizei n, const GLenum *bufs); +#endif +#endif /* GL_ATI_draw_buffers */ + +#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 (APIENTRYP PFNGLELEMENTPOINTERATIPROC) (GLenum type, const void *pointer); +typedef void (APIENTRYP PFNGLDRAWELEMENTARRAYATIPROC) (GLenum mode, GLsizei count); +typedef void (APIENTRYP PFNGLDRAWRANGEELEMENTARRAYATIPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glElementPointerATI (GLenum type, const void *pointer); +GLAPI void APIENTRY glDrawElementArrayATI (GLenum mode, GLsizei count); +GLAPI void APIENTRY glDrawRangeElementArrayATI (GLenum mode, GLuint start, GLuint end, GLsizei count); +#endif +#endif /* GL_ATI_element_array */ + +#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 (APIENTRYP PFNGLTEXBUMPPARAMETERIVATIPROC) (GLenum pname, const GLint *param); +typedef void (APIENTRYP PFNGLTEXBUMPPARAMETERFVATIPROC) (GLenum pname, const GLfloat *param); +typedef void (APIENTRYP PFNGLGETTEXBUMPPARAMETERIVATIPROC) (GLenum pname, GLint *param); +typedef void (APIENTRYP PFNGLGETTEXBUMPPARAMETERFVATIPROC) (GLenum pname, GLfloat *param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexBumpParameterivATI (GLenum pname, const GLint *param); +GLAPI void APIENTRY glTexBumpParameterfvATI (GLenum pname, const GLfloat *param); +GLAPI void APIENTRY glGetTexBumpParameterivATI (GLenum pname, GLint *param); +GLAPI void APIENTRY glGetTexBumpParameterfvATI (GLenum pname, GLfloat *param); +#endif +#endif /* GL_ATI_envmap_bumpmap */ + +#ifndef GL_ATI_fragment_shader +#define GL_ATI_fragment_shader 1 +#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_REG_6_ATI 0x8927 +#define GL_REG_7_ATI 0x8928 +#define GL_REG_8_ATI 0x8929 +#define GL_REG_9_ATI 0x892A +#define GL_REG_10_ATI 0x892B +#define GL_REG_11_ATI 0x892C +#define GL_REG_12_ATI 0x892D +#define GL_REG_13_ATI 0x892E +#define GL_REG_14_ATI 0x892F +#define GL_REG_15_ATI 0x8930 +#define GL_REG_16_ATI 0x8931 +#define GL_REG_17_ATI 0x8932 +#define GL_REG_18_ATI 0x8933 +#define GL_REG_19_ATI 0x8934 +#define GL_REG_20_ATI 0x8935 +#define GL_REG_21_ATI 0x8936 +#define GL_REG_22_ATI 0x8937 +#define GL_REG_23_ATI 0x8938 +#define GL_REG_24_ATI 0x8939 +#define GL_REG_25_ATI 0x893A +#define GL_REG_26_ATI 0x893B +#define GL_REG_27_ATI 0x893C +#define GL_REG_28_ATI 0x893D +#define GL_REG_29_ATI 0x893E +#define GL_REG_30_ATI 0x893F +#define GL_REG_31_ATI 0x8940 +#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_CON_8_ATI 0x8949 +#define GL_CON_9_ATI 0x894A +#define GL_CON_10_ATI 0x894B +#define GL_CON_11_ATI 0x894C +#define GL_CON_12_ATI 0x894D +#define GL_CON_13_ATI 0x894E +#define GL_CON_14_ATI 0x894F +#define GL_CON_15_ATI 0x8950 +#define GL_CON_16_ATI 0x8951 +#define GL_CON_17_ATI 0x8952 +#define GL_CON_18_ATI 0x8953 +#define GL_CON_19_ATI 0x8954 +#define GL_CON_20_ATI 0x8955 +#define GL_CON_21_ATI 0x8956 +#define GL_CON_22_ATI 0x8957 +#define GL_CON_23_ATI 0x8958 +#define GL_CON_24_ATI 0x8959 +#define GL_CON_25_ATI 0x895A +#define GL_CON_26_ATI 0x895B +#define GL_CON_27_ATI 0x895C +#define GL_CON_28_ATI 0x895D +#define GL_CON_29_ATI 0x895E +#define GL_CON_30_ATI 0x895F +#define GL_CON_31_ATI 0x8960 +#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 +#define GL_RED_BIT_ATI 0x00000001 +#define GL_GREEN_BIT_ATI 0x00000002 +#define GL_BLUE_BIT_ATI 0x00000004 +#define GL_2X_BIT_ATI 0x00000001 +#define GL_4X_BIT_ATI 0x00000002 +#define GL_8X_BIT_ATI 0x00000004 +#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_COMP_BIT_ATI 0x00000002 +#define GL_NEGATE_BIT_ATI 0x00000004 +#define GL_BIAS_BIT_ATI 0x00000008 +typedef GLuint (APIENTRYP PFNGLGENFRAGMENTSHADERSATIPROC) (GLuint range); +typedef void (APIENTRYP PFNGLBINDFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (APIENTRYP PFNGLDELETEFRAGMENTSHADERATIPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINFRAGMENTSHADERATIPROC) (void); +typedef void (APIENTRYP PFNGLENDFRAGMENTSHADERATIPROC) (void); +typedef void (APIENTRYP PFNGLPASSTEXCOORDATIPROC) (GLuint dst, GLuint coord, GLenum swizzle); +typedef void (APIENTRYP PFNGLSAMPLEMAPATIPROC) (GLuint dst, GLuint interp, GLenum swizzle); +typedef void (APIENTRYP PFNGLCOLORFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (APIENTRYP PFNGLCOLORFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLALPHAFRAGMENTOP1ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +typedef void (APIENTRYP PFNGLALPHAFRAGMENTOP2ATIPROC) (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLSETFRAGMENTSHADERCONSTANTATIPROC) (GLuint dst, const GLfloat *value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glGenFragmentShadersATI (GLuint range); +GLAPI void APIENTRY glBindFragmentShaderATI (GLuint id); +GLAPI void APIENTRY glDeleteFragmentShaderATI (GLuint id); +GLAPI void APIENTRY glBeginFragmentShaderATI (void); +GLAPI void APIENTRY glEndFragmentShaderATI (void); +GLAPI void APIENTRY glPassTexCoordATI (GLuint dst, GLuint coord, GLenum swizzle); +GLAPI void APIENTRY glSampleMapATI (GLuint dst, GLuint interp, GLenum swizzle); +GLAPI void APIENTRY glColorFragmentOp1ATI (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +GLAPI void APIENTRY glColorFragmentOp2ATI (GLenum op, GLuint dst, GLuint dstMask, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +GLAPI void APIENTRY glColorFragmentOp3ATI (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); +GLAPI void APIENTRY glAlphaFragmentOp1ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod); +GLAPI void APIENTRY glAlphaFragmentOp2ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod); +GLAPI void APIENTRY glAlphaFragmentOp3ATI (GLenum op, GLuint dst, GLuint dstMod, GLuint arg1, GLuint arg1Rep, GLuint arg1Mod, GLuint arg2, GLuint arg2Rep, GLuint arg2Mod, GLuint arg3, GLuint arg3Rep, GLuint arg3Mod); +GLAPI void APIENTRY glSetFragmentShaderConstantATI (GLuint dst, const GLfloat *value); +#endif +#endif /* GL_ATI_fragment_shader */ + +#ifndef GL_ATI_map_object_buffer +#define GL_ATI_map_object_buffer 1 +typedef void *(APIENTRYP PFNGLMAPOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLUNMAPOBJECTBUFFERATIPROC) (GLuint buffer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void *APIENTRY glMapObjectBufferATI (GLuint buffer); +GLAPI void APIENTRY glUnmapObjectBufferATI (GLuint buffer); +#endif +#endif /* GL_ATI_map_object_buffer */ + +#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 +#endif /* GL_ATI_meminfo */ + +#ifndef GL_ATI_pixel_format_float +#define GL_ATI_pixel_format_float 1 +#define GL_RGBA_FLOAT_MODE_ATI 0x8820 +#define GL_COLOR_CLEAR_UNCLAMPED_VALUE_ATI 0x8835 +#endif /* GL_ATI_pixel_format_float */ + +#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 (APIENTRYP PFNGLPNTRIANGLESIATIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPNTRIANGLESFATIPROC) (GLenum pname, GLfloat param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPNTrianglesiATI (GLenum pname, GLint param); +GLAPI void APIENTRY glPNTrianglesfATI (GLenum pname, GLfloat param); +#endif +#endif /* GL_ATI_pn_triangles */ + +#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 (APIENTRYP PFNGLSTENCILOPSEPARATEATIPROC) (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +typedef void (APIENTRYP PFNGLSTENCILFUNCSEPARATEATIPROC) (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStencilOpSeparateATI (GLenum face, GLenum sfail, GLenum dpfail, GLenum dppass); +GLAPI void APIENTRY glStencilFuncSeparateATI (GLenum frontfunc, GLenum backfunc, GLint ref, GLuint mask); +#endif +#endif /* GL_ATI_separate_stencil */ + +#ifndef GL_ATI_text_fragment_shader +#define GL_ATI_text_fragment_shader 1 +#define GL_TEXT_FRAGMENT_SHADER_ATI 0x8200 +#endif /* GL_ATI_text_fragment_shader */ + +#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 +#endif /* GL_ATI_texture_env_combine3 */ + +#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 +#endif /* GL_ATI_texture_float */ + +#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 +#endif /* GL_ATI_texture_mirror_once */ + +#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 GLuint (APIENTRYP PFNGLNEWOBJECTBUFFERATIPROC) (GLsizei size, const void *pointer, GLenum usage); +typedef GLboolean (APIENTRYP PFNGLISOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLUPDATEOBJECTBUFFERATIPROC) (GLuint buffer, GLuint offset, GLsizei size, const void *pointer, GLenum preserve); +typedef void (APIENTRYP PFNGLGETOBJECTBUFFERFVATIPROC) (GLuint buffer, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETOBJECTBUFFERIVATIPROC) (GLuint buffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLFREEOBJECTBUFFERATIPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLARRAYOBJECTATIPROC) (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETARRAYOBJECTFVATIPROC) (GLenum array, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETARRAYOBJECTIVATIPROC) (GLenum array, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLVARIANTARRAYOBJECTATIPROC) (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETVARIANTARRAYOBJECTFVATIPROC) (GLuint id, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVARIANTARRAYOBJECTIVATIPROC) (GLuint id, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glNewObjectBufferATI (GLsizei size, const void *pointer, GLenum usage); +GLAPI GLboolean APIENTRY glIsObjectBufferATI (GLuint buffer); +GLAPI void APIENTRY glUpdateObjectBufferATI (GLuint buffer, GLuint offset, GLsizei size, const void *pointer, GLenum preserve); +GLAPI void APIENTRY glGetObjectBufferfvATI (GLuint buffer, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetObjectBufferivATI (GLuint buffer, GLenum pname, GLint *params); +GLAPI void APIENTRY glFreeObjectBufferATI (GLuint buffer); +GLAPI void APIENTRY glArrayObjectATI (GLenum array, GLint size, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +GLAPI void APIENTRY glGetArrayObjectfvATI (GLenum array, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetArrayObjectivATI (GLenum array, GLenum pname, GLint *params); +GLAPI void APIENTRY glVariantArrayObjectATI (GLuint id, GLenum type, GLsizei stride, GLuint buffer, GLuint offset); +GLAPI void APIENTRY glGetVariantArrayObjectfvATI (GLuint id, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVariantArrayObjectivATI (GLuint id, GLenum pname, GLint *params); +#endif +#endif /* GL_ATI_vertex_array_object */ + +#ifndef GL_ATI_vertex_attrib_array_object +#define GL_ATI_vertex_attrib_array_object 1 +typedef void (APIENTRYP PFNGLVERTEXATTRIBARRAYOBJECTATIPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBARRAYOBJECTFVATIPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBARRAYOBJECTIVATIPROC) (GLuint index, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribArrayObjectATI (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLuint buffer, GLuint offset); +GLAPI void APIENTRY glGetVertexAttribArrayObjectfvATI (GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVertexAttribArrayObjectivATI (GLuint index, GLenum pname, GLint *params); +#endif +#endif /* GL_ATI_vertex_attrib_array_object */ + +#ifndef GL_ATI_vertex_streams +#define GL_ATI_vertex_streams 1 +#define GL_MAX_VERTEX_STREAMS_ATI 0x876B +#define GL_VERTEX_STREAM0_ATI 0x876C +#define GL_VERTEX_STREAM1_ATI 0x876D +#define GL_VERTEX_STREAM2_ATI 0x876E +#define GL_VERTEX_STREAM3_ATI 0x876F +#define GL_VERTEX_STREAM4_ATI 0x8770 +#define GL_VERTEX_STREAM5_ATI 0x8771 +#define GL_VERTEX_STREAM6_ATI 0x8772 +#define GL_VERTEX_STREAM7_ATI 0x8773 +#define GL_VERTEX_SOURCE_ATI 0x8774 +typedef void (APIENTRYP PFNGLVERTEXSTREAM1SATIPROC) (GLenum stream, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1IATIPROC) (GLenum stream, GLint x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1FATIPROC) (GLenum stream, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1DATIPROC) (GLenum stream, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXSTREAM1DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2SATIPROC) (GLenum stream, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2IATIPROC) (GLenum stream, GLint x, GLint y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2FATIPROC) (GLenum stream, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2DATIPROC) (GLenum stream, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXSTREAM2DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3IATIPROC) (GLenum stream, GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4SATIPROC) (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4IATIPROC) (GLenum stream, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4FATIPROC) (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4DATIPROC) (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXSTREAM4DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3BATIPROC) (GLenum stream, GLbyte nx, GLbyte ny, GLbyte nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3BVATIPROC) (GLenum stream, const GLbyte *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3SATIPROC) (GLenum stream, GLshort nx, GLshort ny, GLshort nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3SVATIPROC) (GLenum stream, const GLshort *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3IATIPROC) (GLenum stream, GLint nx, GLint ny, GLint nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3IVATIPROC) (GLenum stream, const GLint *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3FATIPROC) (GLenum stream, GLfloat nx, GLfloat ny, GLfloat nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3FVATIPROC) (GLenum stream, const GLfloat *coords); +typedef void (APIENTRYP PFNGLNORMALSTREAM3DATIPROC) (GLenum stream, GLdouble nx, GLdouble ny, GLdouble nz); +typedef void (APIENTRYP PFNGLNORMALSTREAM3DVATIPROC) (GLenum stream, const GLdouble *coords); +typedef void (APIENTRYP PFNGLCLIENTACTIVEVERTEXSTREAMATIPROC) (GLenum stream); +typedef void (APIENTRYP PFNGLVERTEXBLENDENVIATIPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLVERTEXBLENDENVFATIPROC) (GLenum pname, GLfloat param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexStream1sATI (GLenum stream, GLshort x); +GLAPI void APIENTRY glVertexStream1svATI (GLenum stream, const GLshort *coords); +GLAPI void APIENTRY glVertexStream1iATI (GLenum stream, GLint x); +GLAPI void APIENTRY glVertexStream1ivATI (GLenum stream, const GLint *coords); +GLAPI void APIENTRY glVertexStream1fATI (GLenum stream, GLfloat x); +GLAPI void APIENTRY glVertexStream1fvATI (GLenum stream, const GLfloat *coords); +GLAPI void APIENTRY glVertexStream1dATI (GLenum stream, GLdouble x); +GLAPI void APIENTRY glVertexStream1dvATI (GLenum stream, const GLdouble *coords); +GLAPI void APIENTRY glVertexStream2sATI (GLenum stream, GLshort x, GLshort y); +GLAPI void APIENTRY glVertexStream2svATI (GLenum stream, const GLshort *coords); +GLAPI void APIENTRY glVertexStream2iATI (GLenum stream, GLint x, GLint y); +GLAPI void APIENTRY glVertexStream2ivATI (GLenum stream, const GLint *coords); +GLAPI void APIENTRY glVertexStream2fATI (GLenum stream, GLfloat x, GLfloat y); +GLAPI void APIENTRY glVertexStream2fvATI (GLenum stream, const GLfloat *coords); +GLAPI void APIENTRY glVertexStream2dATI (GLenum stream, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexStream2dvATI (GLenum stream, const GLdouble *coords); +GLAPI void APIENTRY glVertexStream3sATI (GLenum stream, GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glVertexStream3svATI (GLenum stream, const GLshort *coords); +GLAPI void APIENTRY glVertexStream3iATI (GLenum stream, GLint x, GLint y, GLint z); +GLAPI void APIENTRY glVertexStream3ivATI (GLenum stream, const GLint *coords); +GLAPI void APIENTRY glVertexStream3fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glVertexStream3fvATI (GLenum stream, const GLfloat *coords); +GLAPI void APIENTRY glVertexStream3dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexStream3dvATI (GLenum stream, const GLdouble *coords); +GLAPI void APIENTRY glVertexStream4sATI (GLenum stream, GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void APIENTRY glVertexStream4svATI (GLenum stream, const GLshort *coords); +GLAPI void APIENTRY glVertexStream4iATI (GLenum stream, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glVertexStream4ivATI (GLenum stream, const GLint *coords); +GLAPI void APIENTRY glVertexStream4fATI (GLenum stream, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glVertexStream4fvATI (GLenum stream, const GLfloat *coords); +GLAPI void APIENTRY glVertexStream4dATI (GLenum stream, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexStream4dvATI (GLenum stream, const GLdouble *coords); +GLAPI void APIENTRY glNormalStream3bATI (GLenum stream, GLbyte nx, GLbyte ny, GLbyte nz); +GLAPI void APIENTRY glNormalStream3bvATI (GLenum stream, const GLbyte *coords); +GLAPI void APIENTRY glNormalStream3sATI (GLenum stream, GLshort nx, GLshort ny, GLshort nz); +GLAPI void APIENTRY glNormalStream3svATI (GLenum stream, const GLshort *coords); +GLAPI void APIENTRY glNormalStream3iATI (GLenum stream, GLint nx, GLint ny, GLint nz); +GLAPI void APIENTRY glNormalStream3ivATI (GLenum stream, const GLint *coords); +GLAPI void APIENTRY glNormalStream3fATI (GLenum stream, GLfloat nx, GLfloat ny, GLfloat nz); +GLAPI void APIENTRY glNormalStream3fvATI (GLenum stream, const GLfloat *coords); +GLAPI void APIENTRY glNormalStream3dATI (GLenum stream, GLdouble nx, GLdouble ny, GLdouble nz); +GLAPI void APIENTRY glNormalStream3dvATI (GLenum stream, const GLdouble *coords); +GLAPI void APIENTRY glClientActiveVertexStreamATI (GLenum stream); +GLAPI void APIENTRY glVertexBlendEnviATI (GLenum pname, GLint param); +GLAPI void APIENTRY glVertexBlendEnvfATI (GLenum pname, GLfloat param); +#endif +#endif /* GL_ATI_vertex_streams */ + +#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 +#endif /* GL_EXT_422_pixels */ + +#ifndef GL_EXT_abgr +#define GL_EXT_abgr 1 +#define GL_ABGR_EXT 0x8000 +#endif /* GL_EXT_abgr */ + +#ifndef GL_EXT_bgra +#define GL_EXT_bgra 1 +#define GL_BGR_EXT 0x80E0 +#define GL_BGRA_EXT 0x80E1 +#endif /* GL_EXT_bgra */ + +#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 void (APIENTRYP PFNGLUNIFORMBUFFEREXTPROC) (GLuint program, GLint location, GLuint buffer); +typedef GLint (APIENTRYP PFNGLGETUNIFORMBUFFERSIZEEXTPROC) (GLuint program, GLint location); +typedef GLintptr (APIENTRYP PFNGLGETUNIFORMOFFSETEXTPROC) (GLuint program, GLint location); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glUniformBufferEXT (GLuint program, GLint location, GLuint buffer); +GLAPI GLint APIENTRY glGetUniformBufferSizeEXT (GLuint program, GLint location); +GLAPI GLintptr APIENTRY glGetUniformOffsetEXT (GLuint program, GLint location); +#endif +#endif /* GL_EXT_bindable_uniform */ + +#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 (APIENTRYP PFNGLBLENDCOLOREXTPROC) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendColorEXT (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha); +#endif +#endif /* GL_EXT_blend_color */ + +#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 (APIENTRYP PFNGLBLENDEQUATIONSEPARATEEXTPROC) (GLenum modeRGB, GLenum modeAlpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationSeparateEXT (GLenum modeRGB, GLenum modeAlpha); +#endif +#endif /* GL_EXT_blend_equation_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 (APIENTRYP PFNGLBLENDFUNCSEPARATEEXTPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparateEXT (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#endif +#endif /* GL_EXT_blend_func_separate */ + +#ifndef GL_EXT_blend_logic_op +#define GL_EXT_blend_logic_op 1 +#endif /* GL_EXT_blend_logic_op */ + +#ifndef GL_EXT_blend_minmax +#define GL_EXT_blend_minmax 1 +#define GL_MIN_EXT 0x8007 +#define GL_MAX_EXT 0x8008 +#define GL_FUNC_ADD_EXT 0x8006 +#define GL_BLEND_EQUATION_EXT 0x8009 +typedef void (APIENTRYP PFNGLBLENDEQUATIONEXTPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendEquationEXT (GLenum mode); +#endif +#endif /* GL_EXT_blend_minmax */ + +#ifndef GL_EXT_blend_subtract +#define GL_EXT_blend_subtract 1 +#define GL_FUNC_SUBTRACT_EXT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT_EXT 0x800B +#endif /* GL_EXT_blend_subtract */ + +#ifndef GL_EXT_clip_volume_hint +#define GL_EXT_clip_volume_hint 1 +#define GL_CLIP_VOLUME_CLIPPING_HINT_EXT 0x80F0 +#endif /* GL_EXT_clip_volume_hint */ + +#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 +#endif /* GL_EXT_cmyka */ + +#ifndef GL_EXT_color_subtable +#define GL_EXT_color_subtable 1 +typedef void (APIENTRYP PFNGLCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLCOPYCOLORSUBTABLEEXTPROC) (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorSubTableEXT (GLenum target, GLsizei start, GLsizei count, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glCopyColorSubTableEXT (GLenum target, GLsizei start, GLint x, GLint y, GLsizei width); +#endif +#endif /* GL_EXT_color_subtable */ + +#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 (APIENTRYP PFNGLLOCKARRAYSEXTPROC) (GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLUNLOCKARRAYSEXTPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glLockArraysEXT (GLint first, GLsizei count); +GLAPI void APIENTRY glUnlockArraysEXT (void); +#endif +#endif /* GL_EXT_compiled_vertex_array */ + +#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 (APIENTRYP PFNGLCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *image); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint params); +typedef void (APIENTRYP PFNGLCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER1DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYCONVOLUTIONFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void *image); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCONVOLUTIONPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETSEPARABLEFILTEREXTPROC) (GLenum target, GLenum format, GLenum type, void *row, void *column, void *span); +typedef void (APIENTRYP PFNGLSEPARABLEFILTER2DEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *row, const void *column); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glConvolutionFilter1DEXT (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *image); +GLAPI void APIENTRY glConvolutionFilter2DEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *image); +GLAPI void APIENTRY glConvolutionParameterfEXT (GLenum target, GLenum pname, GLfloat params); +GLAPI void APIENTRY glConvolutionParameterfvEXT (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glConvolutionParameteriEXT (GLenum target, GLenum pname, GLint params); +GLAPI void APIENTRY glConvolutionParameterivEXT (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glCopyConvolutionFilter1DEXT (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glCopyConvolutionFilter2DEXT (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetConvolutionFilterEXT (GLenum target, GLenum format, GLenum type, void *image); +GLAPI void APIENTRY glGetConvolutionParameterfvEXT (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetConvolutionParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetSeparableFilterEXT (GLenum target, GLenum format, GLenum type, void *row, void *column, void *span); +GLAPI void APIENTRY glSeparableFilter2DEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *row, const void *column); +#endif +#endif /* GL_EXT_convolution */ + +#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 (APIENTRYP PFNGLTANGENT3BEXTPROC) (GLbyte tx, GLbyte ty, GLbyte tz); +typedef void (APIENTRYP PFNGLTANGENT3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLTANGENT3DEXTPROC) (GLdouble tx, GLdouble ty, GLdouble tz); +typedef void (APIENTRYP PFNGLTANGENT3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLTANGENT3FEXTPROC) (GLfloat tx, GLfloat ty, GLfloat tz); +typedef void (APIENTRYP PFNGLTANGENT3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLTANGENT3IEXTPROC) (GLint tx, GLint ty, GLint tz); +typedef void (APIENTRYP PFNGLTANGENT3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLTANGENT3SEXTPROC) (GLshort tx, GLshort ty, GLshort tz); +typedef void (APIENTRYP PFNGLTANGENT3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLBINORMAL3BEXTPROC) (GLbyte bx, GLbyte by, GLbyte bz); +typedef void (APIENTRYP PFNGLBINORMAL3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLBINORMAL3DEXTPROC) (GLdouble bx, GLdouble by, GLdouble bz); +typedef void (APIENTRYP PFNGLBINORMAL3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLBINORMAL3FEXTPROC) (GLfloat bx, GLfloat by, GLfloat bz); +typedef void (APIENTRYP PFNGLBINORMAL3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLBINORMAL3IEXTPROC) (GLint bx, GLint by, GLint bz); +typedef void (APIENTRYP PFNGLBINORMAL3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLBINORMAL3SEXTPROC) (GLshort bx, GLshort by, GLshort bz); +typedef void (APIENTRYP PFNGLBINORMAL3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLTANGENTPOINTEREXTPROC) (GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLBINORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTangent3bEXT (GLbyte tx, GLbyte ty, GLbyte tz); +GLAPI void APIENTRY glTangent3bvEXT (const GLbyte *v); +GLAPI void APIENTRY glTangent3dEXT (GLdouble tx, GLdouble ty, GLdouble tz); +GLAPI void APIENTRY glTangent3dvEXT (const GLdouble *v); +GLAPI void APIENTRY glTangent3fEXT (GLfloat tx, GLfloat ty, GLfloat tz); +GLAPI void APIENTRY glTangent3fvEXT (const GLfloat *v); +GLAPI void APIENTRY glTangent3iEXT (GLint tx, GLint ty, GLint tz); +GLAPI void APIENTRY glTangent3ivEXT (const GLint *v); +GLAPI void APIENTRY glTangent3sEXT (GLshort tx, GLshort ty, GLshort tz); +GLAPI void APIENTRY glTangent3svEXT (const GLshort *v); +GLAPI void APIENTRY glBinormal3bEXT (GLbyte bx, GLbyte by, GLbyte bz); +GLAPI void APIENTRY glBinormal3bvEXT (const GLbyte *v); +GLAPI void APIENTRY glBinormal3dEXT (GLdouble bx, GLdouble by, GLdouble bz); +GLAPI void APIENTRY glBinormal3dvEXT (const GLdouble *v); +GLAPI void APIENTRY glBinormal3fEXT (GLfloat bx, GLfloat by, GLfloat bz); +GLAPI void APIENTRY glBinormal3fvEXT (const GLfloat *v); +GLAPI void APIENTRY glBinormal3iEXT (GLint bx, GLint by, GLint bz); +GLAPI void APIENTRY glBinormal3ivEXT (const GLint *v); +GLAPI void APIENTRY glBinormal3sEXT (GLshort bx, GLshort by, GLshort bz); +GLAPI void APIENTRY glBinormal3svEXT (const GLshort *v); +GLAPI void APIENTRY glTangentPointerEXT (GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glBinormalPointerEXT (GLenum type, GLsizei stride, const void *pointer); +#endif +#endif /* GL_EXT_coordinate_frame */ + +#ifndef GL_EXT_copy_texture +#define GL_EXT_copy_texture 1 +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE1DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXIMAGE2DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLCOPYTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCopyTexImage1DEXT (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI void APIENTRY glCopyTexImage2DEXT (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI void APIENTRY glCopyTexSubImage1DEXT (GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glCopyTexSubImage2DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glCopyTexSubImage3DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +#endif +#endif /* GL_EXT_copy_texture */ + +#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 (APIENTRYP PFNGLCULLPARAMETERDVEXTPROC) (GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLCULLPARAMETERFVEXTPROC) (GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCullParameterdvEXT (GLenum pname, GLdouble *params); +GLAPI void APIENTRY glCullParameterfvEXT (GLenum pname, GLfloat *params); +#endif +#endif /* GL_EXT_cull_vertex */ + +#ifndef GL_EXT_debug_label +#define GL_EXT_debug_label 1 +#define GL_PROGRAM_PIPELINE_OBJECT_EXT 0x8A4F +#define GL_PROGRAM_OBJECT_EXT 0x8B40 +#define GL_SHADER_OBJECT_EXT 0x8B48 +#define GL_BUFFER_OBJECT_EXT 0x9151 +#define GL_QUERY_OBJECT_EXT 0x9153 +#define GL_VERTEX_ARRAY_OBJECT_EXT 0x9154 +typedef void (APIENTRYP PFNGLLABELOBJECTEXTPROC) (GLenum type, GLuint object, GLsizei length, const GLchar *label); +typedef void (APIENTRYP PFNGLGETOBJECTLABELEXTPROC) (GLenum type, GLuint object, GLsizei bufSize, GLsizei *length, GLchar *label); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glLabelObjectEXT (GLenum type, GLuint object, GLsizei length, const GLchar *label); +GLAPI void APIENTRY glGetObjectLabelEXT (GLenum type, GLuint object, GLsizei bufSize, GLsizei *length, GLchar *label); +#endif +#endif /* GL_EXT_debug_label */ + +#ifndef GL_EXT_debug_marker +#define GL_EXT_debug_marker 1 +typedef void (APIENTRYP PFNGLINSERTEVENTMARKEREXTPROC) (GLsizei length, const GLchar *marker); +typedef void (APIENTRYP PFNGLPUSHGROUPMARKEREXTPROC) (GLsizei length, const GLchar *marker); +typedef void (APIENTRYP PFNGLPOPGROUPMARKEREXTPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glInsertEventMarkerEXT (GLsizei length, const GLchar *marker); +GLAPI void APIENTRY glPushGroupMarkerEXT (GLsizei length, const GLchar *marker); +GLAPI void APIENTRY glPopGroupMarkerEXT (void); +#endif +#endif /* GL_EXT_debug_marker */ + +#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 (APIENTRYP PFNGLDEPTHBOUNDSEXTPROC) (GLclampd zmin, GLclampd zmax); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDepthBoundsEXT (GLclampd zmin, GLclampd zmax); +#endif +#endif /* GL_EXT_depth_bounds_test */ + +#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 (APIENTRYP PFNGLMATRIXLOADFEXTPROC) (GLenum mode, const GLfloat *m); +typedef void (APIENTRYP PFNGLMATRIXLOADDEXTPROC) (GLenum mode, const GLdouble *m); +typedef void (APIENTRYP PFNGLMATRIXMULTFEXTPROC) (GLenum mode, const GLfloat *m); +typedef void (APIENTRYP PFNGLMATRIXMULTDEXTPROC) (GLenum mode, const GLdouble *m); +typedef void (APIENTRYP PFNGLMATRIXLOADIDENTITYEXTPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLMATRIXROTATEFEXTPROC) (GLenum mode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLMATRIXROTATEDEXTPROC) (GLenum mode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLMATRIXSCALEFEXTPROC) (GLenum mode, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLMATRIXSCALEDEXTPROC) (GLenum mode, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLMATRIXTRANSLATEFEXTPROC) (GLenum mode, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLMATRIXTRANSLATEDEXTPROC) (GLenum mode, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLMATRIXFRUSTUMEXTPROC) (GLenum mode, GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +typedef void (APIENTRYP PFNGLMATRIXORTHOEXTPROC) (GLenum mode, GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +typedef void (APIENTRYP PFNGLMATRIXPOPEXTPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLMATRIXPUSHEXTPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); +typedef void (APIENTRYP PFNGLPUSHCLIENTATTRIBDEFAULTEXTPROC) (GLbitfield mask); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERFEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERIEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLCOPYTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (APIENTRYP PFNGLCOPYTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, void *pixels); +typedef void (APIENTRYP PFNGLGETTEXTUREPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETTEXTUREPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETTEXTURELEVELPARAMETERFVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETTEXTURELEVELPARAMETERIVEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum pname, GLint *params); +typedef void (APIENTRYP 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 (APIENTRYP 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 void (APIENTRYP PFNGLCOPYTEXTURESUBIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLBINDMULTITEXTUREEXTPROC) (GLenum texunit, GLenum target, GLuint texture); +typedef void (APIENTRYP PFNGLMULTITEXCOORDPOINTEREXTPROC) (GLenum texunit, GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLMULTITEXENVFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLMULTITEXENVIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLMULTITEXGENDEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble param); +typedef void (APIENTRYP PFNGLMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLdouble *params); +typedef void (APIENTRYP PFNGLMULTITEXGENFEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLMULTITEXGENIEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLGETMULTITEXENVFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMULTITEXENVIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMULTITEXGENDVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETMULTITEXGENFVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMULTITEXGENIVEXTPROC) (GLenum texunit, GLenum coord, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERIEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERFEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLCOPYMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +typedef void (APIENTRYP PFNGLCOPYMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +typedef void (APIENTRYP PFNGLCOPYMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLCOPYMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, void *pixels); +typedef void (APIENTRYP PFNGLGETMULTITEXPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMULTITEXPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMULTITEXLEVELPARAMETERFVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMULTITEXLEVELPARAMETERIVEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint *params); +typedef void (APIENTRYP 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 (APIENTRYP 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 (APIENTRYP PFNGLCOPYMULTITEXSUBIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLENABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); +typedef void (APIENTRYP PFNGLDISABLECLIENTSTATEINDEXEDEXTPROC) (GLenum array, GLuint index); +typedef void (APIENTRYP PFNGLGETFLOATINDEXEDVEXTPROC) (GLenum target, GLuint index, GLfloat *data); +typedef void (APIENTRYP PFNGLGETDOUBLEINDEXEDVEXTPROC) (GLenum target, GLuint index, GLdouble *data); +typedef void (APIENTRYP PFNGLGETPOINTERINDEXEDVEXTPROC) (GLenum target, GLuint index, void **data); +typedef void (APIENTRYP PFNGLENABLEINDEXEDEXTPROC) (GLenum target, GLuint index); +typedef void (APIENTRYP PFNGLDISABLEINDEXEDEXTPROC) (GLenum target, GLuint index); +typedef GLboolean (APIENTRYP PFNGLISENABLEDINDEXEDEXTPROC) (GLenum target, GLuint index); +typedef void (APIENTRYP PFNGLGETINTEGERINDEXEDVEXTPROC) (GLenum target, GLuint index, GLint *data); +typedef void (APIENTRYP PFNGLGETBOOLEANINDEXEDVEXTPROC) (GLenum target, GLuint index, GLboolean *data); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXTUREIMAGE3DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXTUREIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXTUREIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP 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 *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXTURESUBIMAGE2DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDTEXTURESUBIMAGE1DEXTPROC) (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDTEXTUREIMAGEEXTPROC) (GLuint texture, GLenum target, GLint lod, void *img); +typedef void (APIENTRYP PFNGLCOMPRESSEDMULTITEXIMAGE3DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDMULTITEXIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDMULTITEXIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP 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 *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDMULTITEXSUBIMAGE2DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLCOMPRESSEDMULTITEXSUBIMAGE1DEXTPROC) (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *bits); +typedef void (APIENTRYP PFNGLGETCOMPRESSEDMULTITEXIMAGEEXTPROC) (GLenum texunit, GLenum target, GLint lod, void *img); +typedef void (APIENTRYP PFNGLMATRIXLOADTRANSPOSEFEXTPROC) (GLenum mode, const GLfloat *m); +typedef void (APIENTRYP PFNGLMATRIXLOADTRANSPOSEDEXTPROC) (GLenum mode, const GLdouble *m); +typedef void (APIENTRYP PFNGLMATRIXMULTTRANSPOSEFEXTPROC) (GLenum mode, const GLfloat *m); +typedef void (APIENTRYP PFNGLMATRIXMULTTRANSPOSEDEXTPROC) (GLenum mode, const GLdouble *m); +typedef void (APIENTRYP PFNGLNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLsizeiptr size, const void *data, GLenum usage); +typedef void (APIENTRYP PFNGLNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, const void *data); +typedef void *(APIENTRYP PFNGLMAPNAMEDBUFFEREXTPROC) (GLuint buffer, GLenum access); +typedef GLboolean (APIENTRYP PFNGLUNMAPNAMEDBUFFEREXTPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLGETNAMEDBUFFERPARAMETERIVEXTPROC) (GLuint buffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETNAMEDBUFFERPOINTERVEXTPROC) (GLuint buffer, GLenum pname, void **params); +typedef void (APIENTRYP PFNGLGETNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr size, void *data); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1FEXTPROC) (GLuint program, GLint location, GLfloat v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4FEXTPROC) (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1IEXTPROC) (GLuint program, GLint location, GLint v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4IEXTPROC) (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (APIENTRYP PFNGLTEXTUREBUFFEREXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer); +typedef void (APIENTRYP PFNGLMULTITEXBUFFEREXTPROC) (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, const GLuint *params); +typedef void (APIENTRYP PFNGLGETTEXTUREPARAMETERIIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETTEXTUREPARAMETERIUIVEXTPROC) (GLuint texture, GLenum target, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, const GLuint *params); +typedef void (APIENTRYP PFNGLGETMULTITEXPARAMETERIIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMULTITEXPARAMETERIUIVEXTPROC) (GLenum texunit, GLenum target, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UIEXTPROC) (GLuint program, GLint location, GLuint v0); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UIEXTPROC) (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4UIVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat *params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERI4IEXTPROC) (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLint *params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERSI4IVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint *params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLuint *params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETERSI4UIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMLOCALPARAMETERIIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLint *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMLOCALPARAMETERIUIVEXTPROC) (GLuint program, GLenum target, GLuint index, GLuint *params); +typedef void (APIENTRYP PFNGLENABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); +typedef void (APIENTRYP PFNGLDISABLECLIENTSTATEIEXTPROC) (GLenum array, GLuint index); +typedef void (APIENTRYP PFNGLGETFLOATI_VEXTPROC) (GLenum pname, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETDOUBLEI_VEXTPROC) (GLenum pname, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPOINTERI_VEXTPROC) (GLenum pname, GLuint index, void **params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum format, GLsizei len, const void *string); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETER4DEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETER4DVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLdouble *params); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETER4FEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLNAMEDPROGRAMLOCALPARAMETER4FVEXTPROC) (GLuint program, GLenum target, GLuint index, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMLOCALPARAMETERDVEXTPROC) (GLuint program, GLenum target, GLuint index, GLdouble *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMLOCALPARAMETERFVEXTPROC) (GLuint program, GLenum target, GLuint index, GLfloat *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMIVEXTPROC) (GLuint program, GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETNAMEDPROGRAMSTRINGEXTPROC) (GLuint program, GLenum target, GLenum pname, void *string); +typedef void (APIENTRYP PFNGLNAMEDRENDERBUFFERSTORAGEEXTPROC) (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETNAMEDRENDERBUFFERPARAMETERIVEXTPROC) (GLuint renderbuffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLNAMEDRENDERBUFFERSTORAGEMULTISAMPLECOVERAGEEXTPROC) (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); +typedef GLenum (APIENTRYP PFNGLCHECKNAMEDFRAMEBUFFERSTATUSEXTPROC) (GLuint framebuffer, GLenum target); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTURE1DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTURE2DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTURE3DEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERRENDERBUFFEREXTPROC) (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLGETNAMEDFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum attachment, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGENERATETEXTUREMIPMAPEXTPROC) (GLuint texture, GLenum target); +typedef void (APIENTRYP PFNGLGENERATEMULTITEXMIPMAPEXTPROC) (GLenum texunit, GLenum target); +typedef void (APIENTRYP PFNGLFRAMEBUFFERDRAWBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); +typedef void (APIENTRYP PFNGLFRAMEBUFFERDRAWBUFFERSEXTPROC) (GLuint framebuffer, GLsizei n, const GLenum *bufs); +typedef void (APIENTRYP PFNGLFRAMEBUFFERREADBUFFEREXTPROC) (GLuint framebuffer, GLenum mode); +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLNAMEDCOPYBUFFERSUBDATAEXTPROC) (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTUREEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTURELAYEREXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERTEXTUREFACEEXTPROC) (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face); +typedef void (APIENTRYP PFNGLTEXTURERENDERBUFFEREXTPROC) (GLuint texture, GLenum target, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLMULTITEXRENDERBUFFEREXTPROC) (GLenum texunit, GLenum target, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYEDGEFLAGOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYINDEXOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYNORMALOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYTEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYMULTITEXCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYFOGCOORDOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYSECONDARYCOLOROFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBIOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLENABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); +typedef void (APIENTRYP PFNGLDISABLEVERTEXARRAYEXTPROC) (GLuint vaobj, GLenum array); +typedef void (APIENTRYP PFNGLENABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); +typedef void (APIENTRYP PFNGLDISABLEVERTEXARRAYATTRIBEXTPROC) (GLuint vaobj, GLuint index); +typedef void (APIENTRYP PFNGLGETVERTEXARRAYINTEGERVEXTPROC) (GLuint vaobj, GLenum pname, GLint *param); +typedef void (APIENTRYP PFNGLGETVERTEXARRAYPOINTERVEXTPROC) (GLuint vaobj, GLenum pname, void **param); +typedef void (APIENTRYP PFNGLGETVERTEXARRAYINTEGERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, GLint *param); +typedef void (APIENTRYP PFNGLGETVERTEXARRAYPOINTERI_VEXTPROC) (GLuint vaobj, GLuint index, GLenum pname, void **param); +typedef void *(APIENTRYP PFNGLMAPNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access); +typedef void (APIENTRYP PFNGLFLUSHMAPPEDNAMEDBUFFERRANGEEXTPROC) (GLuint buffer, GLintptr offset, GLsizeiptr length); +typedef void (APIENTRYP PFNGLNAMEDBUFFERSTORAGEEXTPROC) (GLuint buffer, GLsizeiptr size, const void *data, GLbitfield flags); +typedef void (APIENTRYP PFNGLCLEARNAMEDBUFFERDATAEXTPROC) (GLuint buffer, GLenum internalformat, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLCLEARNAMEDBUFFERSUBDATAEXTPROC) (GLuint buffer, GLenum internalformat, GLsizeiptr offset, GLsizeiptr size, GLenum format, GLenum type, const void *data); +typedef void (APIENTRYP PFNGLNAMEDFRAMEBUFFERPARAMETERIEXTPROC) (GLuint framebuffer, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLGETNAMEDFRAMEBUFFERPARAMETERIVEXTPROC) (GLuint framebuffer, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1DEXTPROC) (GLuint program, GLint location, GLdouble x); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4DEXTPROC) (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM1DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM2DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM3DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORM4DVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2X4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3X4DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X2DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4X3DVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +typedef void (APIENTRYP PFNGLTEXTUREBUFFERRANGEEXTPROC) (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLTEXTURESTORAGE1DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +typedef void (APIENTRYP PFNGLTEXTURESTORAGE2DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLTEXTURESTORAGE3DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +typedef void (APIENTRYP PFNGLTEXTURESTORAGE2DMULTISAMPLEEXTPROC) (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLTEXTURESTORAGE3DMULTISAMPLEEXTPROC) (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +typedef void (APIENTRYP PFNGLVERTEXARRAYBINDVERTEXBUFFEREXTPROC) (GLuint vaobj, GLuint bindingindex, GLuint buffer, GLintptr offset, GLsizei stride); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBFORMATEXTPROC) (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLboolean normalized, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBIFORMATEXTPROC) (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBLFORMATEXTPROC) (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBBINDINGEXTPROC) (GLuint vaobj, GLuint attribindex, GLuint bindingindex); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXBINDINGDIVISOREXTPROC) (GLuint vaobj, GLuint bindingindex, GLuint divisor); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBLOFFSETEXTPROC) (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +typedef void (APIENTRYP PFNGLTEXTUREPAGECOMMITMENTEXTPROC) (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean resident); +typedef void (APIENTRYP PFNGLVERTEXARRAYVERTEXATTRIBDIVISOREXTPROC) (GLuint vaobj, GLuint index, GLuint divisor); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMatrixLoadfEXT (GLenum mode, const GLfloat *m); +GLAPI void APIENTRY glMatrixLoaddEXT (GLenum mode, const GLdouble *m); +GLAPI void APIENTRY glMatrixMultfEXT (GLenum mode, const GLfloat *m); +GLAPI void APIENTRY glMatrixMultdEXT (GLenum mode, const GLdouble *m); +GLAPI void APIENTRY glMatrixLoadIdentityEXT (GLenum mode); +GLAPI void APIENTRY glMatrixRotatefEXT (GLenum mode, GLfloat angle, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glMatrixRotatedEXT (GLenum mode, GLdouble angle, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glMatrixScalefEXT (GLenum mode, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glMatrixScaledEXT (GLenum mode, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glMatrixTranslatefEXT (GLenum mode, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glMatrixTranslatedEXT (GLenum mode, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glMatrixFrustumEXT (GLenum mode, GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI void APIENTRY glMatrixOrthoEXT (GLenum mode, GLdouble left, GLdouble right, GLdouble bottom, GLdouble top, GLdouble zNear, GLdouble zFar); +GLAPI void APIENTRY glMatrixPopEXT (GLenum mode); +GLAPI void APIENTRY glMatrixPushEXT (GLenum mode); +GLAPI void APIENTRY glClientAttribDefaultEXT (GLbitfield mask); +GLAPI void APIENTRY glPushClientAttribDefaultEXT (GLbitfield mask); +GLAPI void APIENTRY glTextureParameterfEXT (GLuint texture, GLenum target, GLenum pname, GLfloat param); +GLAPI void APIENTRY glTextureParameterfvEXT (GLuint texture, GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glTextureParameteriEXT (GLuint texture, GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glTextureParameterivEXT (GLuint texture, GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glCopyTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI void APIENTRY glCopyTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI void APIENTRY glCopyTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glCopyTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetTextureImageEXT (GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, void *pixels); +GLAPI void APIENTRY glGetTextureParameterfvEXT (GLuint texture, GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetTextureParameterivEXT (GLuint texture, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetTextureLevelParameterfvEXT (GLuint texture, GLenum target, GLint level, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetTextureLevelParameterivEXT (GLuint texture, GLenum target, GLint level, GLenum pname, GLint *params); +GLAPI void APIENTRY glTextureImage3DEXT (GLuint texture, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTextureSubImage3DEXT (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); +GLAPI void APIENTRY glCopyTextureSubImage3DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glBindMultiTextureEXT (GLenum texunit, GLenum target, GLuint texture); +GLAPI void APIENTRY glMultiTexCoordPointerEXT (GLenum texunit, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glMultiTexEnvfEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +GLAPI void APIENTRY glMultiTexEnvfvEXT (GLenum texunit, GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glMultiTexEnviEXT (GLenum texunit, GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glMultiTexEnvivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glMultiTexGendEXT (GLenum texunit, GLenum coord, GLenum pname, GLdouble param); +GLAPI void APIENTRY glMultiTexGendvEXT (GLenum texunit, GLenum coord, GLenum pname, const GLdouble *params); +GLAPI void APIENTRY glMultiTexGenfEXT (GLenum texunit, GLenum coord, GLenum pname, GLfloat param); +GLAPI void APIENTRY glMultiTexGenfvEXT (GLenum texunit, GLenum coord, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glMultiTexGeniEXT (GLenum texunit, GLenum coord, GLenum pname, GLint param); +GLAPI void APIENTRY glMultiTexGenivEXT (GLenum texunit, GLenum coord, GLenum pname, const GLint *params); +GLAPI void APIENTRY glGetMultiTexEnvfvEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMultiTexEnvivEXT (GLenum texunit, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMultiTexGendvEXT (GLenum texunit, GLenum coord, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glGetMultiTexGenfvEXT (GLenum texunit, GLenum coord, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMultiTexGenivEXT (GLenum texunit, GLenum coord, GLenum pname, GLint *params); +GLAPI void APIENTRY glMultiTexParameteriEXT (GLenum texunit, GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glMultiTexParameterivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glMultiTexParameterfEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat param); +GLAPI void APIENTRY glMultiTexParameterfvEXT (GLenum texunit, GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glCopyMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLint border); +GLAPI void APIENTRY glCopyMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GLAPI void APIENTRY glCopyMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glCopyMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetMultiTexImageEXT (GLenum texunit, GLenum target, GLint level, GLenum format, GLenum type, void *pixels); +GLAPI void APIENTRY glGetMultiTexParameterfvEXT (GLenum texunit, GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMultiTexParameterivEXT (GLenum texunit, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMultiTexLevelParameterfvEXT (GLenum texunit, GLenum target, GLint level, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMultiTexLevelParameterivEXT (GLenum texunit, GLenum target, GLint level, GLenum pname, GLint *params); +GLAPI void APIENTRY glMultiTexImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glMultiTexSubImage3DEXT (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); +GLAPI void APIENTRY glCopyMultiTexSubImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GLAPI void APIENTRY glEnableClientStateIndexedEXT (GLenum array, GLuint index); +GLAPI void APIENTRY glDisableClientStateIndexedEXT (GLenum array, GLuint index); +GLAPI void APIENTRY glGetFloatIndexedvEXT (GLenum target, GLuint index, GLfloat *data); +GLAPI void APIENTRY glGetDoubleIndexedvEXT (GLenum target, GLuint index, GLdouble *data); +GLAPI void APIENTRY glGetPointerIndexedvEXT (GLenum target, GLuint index, void **data); +GLAPI void APIENTRY glEnableIndexedEXT (GLenum target, GLuint index); +GLAPI void APIENTRY glDisableIndexedEXT (GLenum target, GLuint index); +GLAPI GLboolean APIENTRY glIsEnabledIndexedEXT (GLenum target, GLuint index); +GLAPI void APIENTRY glGetIntegerIndexedvEXT (GLenum target, GLuint index, GLint *data); +GLAPI void APIENTRY glGetBooleanIndexedvEXT (GLenum target, GLuint index, GLboolean *data); +GLAPI void APIENTRY glCompressedTextureImage3DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedTextureImage2DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedTextureImage1DEXT (GLuint texture, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedTextureSubImage3DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedTextureSubImage2DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedTextureSubImage1DEXT (GLuint texture, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glGetCompressedTextureImageEXT (GLuint texture, GLenum target, GLint lod, void *img); +GLAPI void APIENTRY glCompressedMultiTexImage3DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedMultiTexImage2DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedMultiTexImage1DEXT (GLenum texunit, GLenum target, GLint level, GLenum internalformat, GLsizei width, GLint border, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedMultiTexSubImage3DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedMultiTexSubImage2DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glCompressedMultiTexSubImage1DEXT (GLenum texunit, GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLsizei imageSize, const void *bits); +GLAPI void APIENTRY glGetCompressedMultiTexImageEXT (GLenum texunit, GLenum target, GLint lod, void *img); +GLAPI void APIENTRY glMatrixLoadTransposefEXT (GLenum mode, const GLfloat *m); +GLAPI void APIENTRY glMatrixLoadTransposedEXT (GLenum mode, const GLdouble *m); +GLAPI void APIENTRY glMatrixMultTransposefEXT (GLenum mode, const GLfloat *m); +GLAPI void APIENTRY glMatrixMultTransposedEXT (GLenum mode, const GLdouble *m); +GLAPI void APIENTRY glNamedBufferDataEXT (GLuint buffer, GLsizeiptr size, const void *data, GLenum usage); +GLAPI void APIENTRY glNamedBufferSubDataEXT (GLuint buffer, GLintptr offset, GLsizeiptr size, const void *data); +GLAPI void *APIENTRY glMapNamedBufferEXT (GLuint buffer, GLenum access); +GLAPI GLboolean APIENTRY glUnmapNamedBufferEXT (GLuint buffer); +GLAPI void APIENTRY glGetNamedBufferParameterivEXT (GLuint buffer, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetNamedBufferPointervEXT (GLuint buffer, GLenum pname, void **params); +GLAPI void APIENTRY glGetNamedBufferSubDataEXT (GLuint buffer, GLintptr offset, GLsizeiptr size, void *data); +GLAPI void APIENTRY glProgramUniform1fEXT (GLuint program, GLint location, GLfloat v0); +GLAPI void APIENTRY glProgramUniform2fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1); +GLAPI void APIENTRY glProgramUniform3fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2); +GLAPI void APIENTRY glProgramUniform4fEXT (GLuint program, GLint location, GLfloat v0, GLfloat v1, GLfloat v2, GLfloat v3); +GLAPI void APIENTRY glProgramUniform1iEXT (GLuint program, GLint location, GLint v0); +GLAPI void APIENTRY glProgramUniform2iEXT (GLuint program, GLint location, GLint v0, GLint v1); +GLAPI void APIENTRY glProgramUniform3iEXT (GLuint program, GLint location, GLint v0, GLint v1, GLint v2); +GLAPI void APIENTRY glProgramUniform4iEXT (GLuint program, GLint location, GLint v0, GLint v1, GLint v2, GLint v3); +GLAPI void APIENTRY glProgramUniform1fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform2fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform3fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform4fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GLAPI void APIENTRY glProgramUniform1ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform2ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform3ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniform4ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GLAPI void APIENTRY glProgramUniformMatrix2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix2x3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3x2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix2x4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4x2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix3x4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glProgramUniformMatrix4x3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GLAPI void APIENTRY glTextureBufferEXT (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer); +GLAPI void APIENTRY glMultiTexBufferEXT (GLenum texunit, GLenum target, GLenum internalformat, GLuint buffer); +GLAPI void APIENTRY glTextureParameterIivEXT (GLuint texture, GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glTextureParameterIuivEXT (GLuint texture, GLenum target, GLenum pname, const GLuint *params); +GLAPI void APIENTRY glGetTextureParameterIivEXT (GLuint texture, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetTextureParameterIuivEXT (GLuint texture, GLenum target, GLenum pname, GLuint *params); +GLAPI void APIENTRY glMultiTexParameterIivEXT (GLenum texunit, GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glMultiTexParameterIuivEXT (GLenum texunit, GLenum target, GLenum pname, const GLuint *params); +GLAPI void APIENTRY glGetMultiTexParameterIivEXT (GLenum texunit, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMultiTexParameterIuivEXT (GLenum texunit, GLenum target, GLenum pname, GLuint *params); +GLAPI void APIENTRY glProgramUniform1uiEXT (GLuint program, GLint location, GLuint v0); +GLAPI void APIENTRY glProgramUniform2uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1); +GLAPI void APIENTRY glProgramUniform3uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2); +GLAPI void APIENTRY glProgramUniform4uiEXT (GLuint program, GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +GLAPI void APIENTRY glProgramUniform1uivEXT (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform2uivEXT (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform3uivEXT (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glProgramUniform4uivEXT (GLuint program, GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glNamedProgramLocalParameters4fvEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLfloat *params); +GLAPI void APIENTRY glNamedProgramLocalParameterI4iEXT (GLuint program, GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glNamedProgramLocalParameterI4ivEXT (GLuint program, GLenum target, GLuint index, const GLint *params); +GLAPI void APIENTRY glNamedProgramLocalParametersI4ivEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLint *params); +GLAPI void APIENTRY glNamedProgramLocalParameterI4uiEXT (GLuint program, GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI void APIENTRY glNamedProgramLocalParameterI4uivEXT (GLuint program, GLenum target, GLuint index, const GLuint *params); +GLAPI void APIENTRY glNamedProgramLocalParametersI4uivEXT (GLuint program, GLenum target, GLuint index, GLsizei count, const GLuint *params); +GLAPI void APIENTRY glGetNamedProgramLocalParameterIivEXT (GLuint program, GLenum target, GLuint index, GLint *params); +GLAPI void APIENTRY glGetNamedProgramLocalParameterIuivEXT (GLuint program, GLenum target, GLuint index, GLuint *params); +GLAPI void APIENTRY glEnableClientStateiEXT (GLenum array, GLuint index); +GLAPI void APIENTRY glDisableClientStateiEXT (GLenum array, GLuint index); +GLAPI void APIENTRY glGetFloati_vEXT (GLenum pname, GLuint index, GLfloat *params); +GLAPI void APIENTRY glGetDoublei_vEXT (GLenum pname, GLuint index, GLdouble *params); +GLAPI void APIENTRY glGetPointeri_vEXT (GLenum pname, GLuint index, void **params); +GLAPI void APIENTRY glNamedProgramStringEXT (GLuint program, GLenum target, GLenum format, GLsizei len, const void *string); +GLAPI void APIENTRY glNamedProgramLocalParameter4dEXT (GLuint program, GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glNamedProgramLocalParameter4dvEXT (GLuint program, GLenum target, GLuint index, const GLdouble *params); +GLAPI void APIENTRY glNamedProgramLocalParameter4fEXT (GLuint program, GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glNamedProgramLocalParameter4fvEXT (GLuint program, GLenum target, GLuint index, const GLfloat *params); +GLAPI void APIENTRY glGetNamedProgramLocalParameterdvEXT (GLuint program, GLenum target, GLuint index, GLdouble *params); +GLAPI void APIENTRY glGetNamedProgramLocalParameterfvEXT (GLuint program, GLenum target, GLuint index, GLfloat *params); +GLAPI void APIENTRY glGetNamedProgramivEXT (GLuint program, GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetNamedProgramStringEXT (GLuint program, GLenum target, GLenum pname, void *string); +GLAPI void APIENTRY glNamedRenderbufferStorageEXT (GLuint renderbuffer, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetNamedRenderbufferParameterivEXT (GLuint renderbuffer, GLenum pname, GLint *params); +GLAPI void APIENTRY glNamedRenderbufferStorageMultisampleEXT (GLuint renderbuffer, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glNamedRenderbufferStorageMultisampleCoverageEXT (GLuint renderbuffer, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI GLenum APIENTRY glCheckNamedFramebufferStatusEXT (GLuint framebuffer, GLenum target); +GLAPI void APIENTRY glNamedFramebufferTexture1DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glNamedFramebufferTexture2DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glNamedFramebufferTexture3DEXT (GLuint framebuffer, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +GLAPI void APIENTRY glNamedFramebufferRenderbufferEXT (GLuint framebuffer, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +GLAPI void APIENTRY glGetNamedFramebufferAttachmentParameterivEXT (GLuint framebuffer, GLenum attachment, GLenum pname, GLint *params); +GLAPI void APIENTRY glGenerateTextureMipmapEXT (GLuint texture, GLenum target); +GLAPI void APIENTRY glGenerateMultiTexMipmapEXT (GLenum texunit, GLenum target); +GLAPI void APIENTRY glFramebufferDrawBufferEXT (GLuint framebuffer, GLenum mode); +GLAPI void APIENTRY glFramebufferDrawBuffersEXT (GLuint framebuffer, GLsizei n, const GLenum *bufs); +GLAPI void APIENTRY glFramebufferReadBufferEXT (GLuint framebuffer, GLenum mode); +GLAPI void APIENTRY glGetFramebufferParameterivEXT (GLuint framebuffer, GLenum pname, GLint *params); +GLAPI void APIENTRY glNamedCopyBufferSubDataEXT (GLuint readBuffer, GLuint writeBuffer, GLintptr readOffset, GLintptr writeOffset, GLsizeiptr size); +GLAPI void APIENTRY glNamedFramebufferTextureEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level); +GLAPI void APIENTRY glNamedFramebufferTextureLayerEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLint layer); +GLAPI void APIENTRY glNamedFramebufferTextureFaceEXT (GLuint framebuffer, GLenum attachment, GLuint texture, GLint level, GLenum face); +GLAPI void APIENTRY glTextureRenderbufferEXT (GLuint texture, GLenum target, GLuint renderbuffer); +GLAPI void APIENTRY glMultiTexRenderbufferEXT (GLenum texunit, GLenum target, GLuint renderbuffer); +GLAPI void APIENTRY glVertexArrayVertexOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayColorOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayEdgeFlagOffsetEXT (GLuint vaobj, GLuint buffer, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayIndexOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayNormalOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayTexCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayMultiTexCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLenum texunit, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayFogCoordOffsetEXT (GLuint vaobj, GLuint buffer, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArraySecondaryColorOffsetEXT (GLuint vaobj, GLuint buffer, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayVertexAttribOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glVertexArrayVertexAttribIOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glEnableVertexArrayEXT (GLuint vaobj, GLenum array); +GLAPI void APIENTRY glDisableVertexArrayEXT (GLuint vaobj, GLenum array); +GLAPI void APIENTRY glEnableVertexArrayAttribEXT (GLuint vaobj, GLuint index); +GLAPI void APIENTRY glDisableVertexArrayAttribEXT (GLuint vaobj, GLuint index); +GLAPI void APIENTRY glGetVertexArrayIntegervEXT (GLuint vaobj, GLenum pname, GLint *param); +GLAPI void APIENTRY glGetVertexArrayPointervEXT (GLuint vaobj, GLenum pname, void **param); +GLAPI void APIENTRY glGetVertexArrayIntegeri_vEXT (GLuint vaobj, GLuint index, GLenum pname, GLint *param); +GLAPI void APIENTRY glGetVertexArrayPointeri_vEXT (GLuint vaobj, GLuint index, GLenum pname, void **param); +GLAPI void *APIENTRY glMapNamedBufferRangeEXT (GLuint buffer, GLintptr offset, GLsizeiptr length, GLbitfield access); +GLAPI void APIENTRY glFlushMappedNamedBufferRangeEXT (GLuint buffer, GLintptr offset, GLsizeiptr length); +GLAPI void APIENTRY glNamedBufferStorageEXT (GLuint buffer, GLsizeiptr size, const void *data, GLbitfield flags); +GLAPI void APIENTRY glClearNamedBufferDataEXT (GLuint buffer, GLenum internalformat, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glClearNamedBufferSubDataEXT (GLuint buffer, GLenum internalformat, GLsizeiptr offset, GLsizeiptr size, GLenum format, GLenum type, const void *data); +GLAPI void APIENTRY glNamedFramebufferParameteriEXT (GLuint framebuffer, GLenum pname, GLint param); +GLAPI void APIENTRY glGetNamedFramebufferParameterivEXT (GLuint framebuffer, GLenum pname, GLint *params); +GLAPI void APIENTRY glProgramUniform1dEXT (GLuint program, GLint location, GLdouble x); +GLAPI void APIENTRY glProgramUniform2dEXT (GLuint program, GLint location, GLdouble x, GLdouble y); +GLAPI void APIENTRY glProgramUniform3dEXT (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glProgramUniform4dEXT (GLuint program, GLint location, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glProgramUniform1dvEXT (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform2dvEXT (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform3dvEXT (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniform4dvEXT (GLuint program, GLint location, GLsizei count, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix2dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix2x3dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix2x4dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3x2dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix3x4dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4x2dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glProgramUniformMatrix4x3dvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLdouble *value); +GLAPI void APIENTRY glTextureBufferRangeEXT (GLuint texture, GLenum target, GLenum internalformat, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI void APIENTRY glTextureStorage1DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +GLAPI void APIENTRY glTextureStorage2DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glTextureStorage3DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +GLAPI void APIENTRY glTextureStorage2DMultisampleEXT (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glTextureStorage3DMultisampleEXT (GLuint texture, GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedsamplelocations); +GLAPI void APIENTRY glVertexArrayBindVertexBufferEXT (GLuint vaobj, GLuint bindingindex, GLuint buffer, GLintptr offset, GLsizei stride); +GLAPI void APIENTRY glVertexArrayVertexAttribFormatEXT (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLboolean normalized, GLuint relativeoffset); +GLAPI void APIENTRY glVertexArrayVertexAttribIFormatEXT (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +GLAPI void APIENTRY glVertexArrayVertexAttribLFormatEXT (GLuint vaobj, GLuint attribindex, GLint size, GLenum type, GLuint relativeoffset); +GLAPI void APIENTRY glVertexArrayVertexAttribBindingEXT (GLuint vaobj, GLuint attribindex, GLuint bindingindex); +GLAPI void APIENTRY glVertexArrayVertexBindingDivisorEXT (GLuint vaobj, GLuint bindingindex, GLuint divisor); +GLAPI void APIENTRY glVertexArrayVertexAttribLOffsetEXT (GLuint vaobj, GLuint buffer, GLuint index, GLint size, GLenum type, GLsizei stride, GLintptr offset); +GLAPI void APIENTRY glTexturePageCommitmentEXT (GLuint texture, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLboolean resident); +GLAPI void APIENTRY glVertexArrayVertexAttribDivisorEXT (GLuint vaobj, GLuint index, GLuint divisor); +#endif +#endif /* GL_EXT_direct_state_access */ + +#ifndef GL_EXT_draw_buffers2 +#define GL_EXT_draw_buffers2 1 +typedef void (APIENTRYP PFNGLCOLORMASKINDEXEDEXTPROC) (GLuint index, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorMaskIndexedEXT (GLuint index, GLboolean r, GLboolean g, GLboolean b, GLboolean a); +#endif +#endif /* GL_EXT_draw_buffers2 */ + +#ifndef GL_EXT_draw_instanced +#define GL_EXT_draw_instanced 1 +typedef void (APIENTRYP PFNGLDRAWARRAYSINSTANCEDEXTPROC) (GLenum mode, GLint start, GLsizei count, GLsizei primcount); +typedef void (APIENTRYP PFNGLDRAWELEMENTSINSTANCEDEXTPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawArraysInstancedEXT (GLenum mode, GLint start, GLsizei count, GLsizei primcount); +GLAPI void APIENTRY glDrawElementsInstancedEXT (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +#endif +#endif /* GL_EXT_draw_instanced */ + +#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 (APIENTRYP PFNGLDRAWRANGEELEMENTSEXTPROC) (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawRangeElementsEXT (GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type, const void *indices); +#endif +#endif /* GL_EXT_draw_range_elements */ + +#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 (APIENTRYP PFNGLFOGCOORDFEXTPROC) (GLfloat coord); +typedef void (APIENTRYP PFNGLFOGCOORDFVEXTPROC) (const GLfloat *coord); +typedef void (APIENTRYP PFNGLFOGCOORDDEXTPROC) (GLdouble coord); +typedef void (APIENTRYP PFNGLFOGCOORDDVEXTPROC) (const GLdouble *coord); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTEREXTPROC) (GLenum type, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFogCoordfEXT (GLfloat coord); +GLAPI void APIENTRY glFogCoordfvEXT (const GLfloat *coord); +GLAPI void APIENTRY glFogCoorddEXT (GLdouble coord); +GLAPI void APIENTRY glFogCoorddvEXT (const GLdouble *coord); +GLAPI void APIENTRY glFogCoordPointerEXT (GLenum type, GLsizei stride, const void *pointer); +#endif +#endif /* GL_EXT_fog_coord */ + +#ifndef GL_EXT_framebuffer_blit +#define GL_EXT_framebuffer_blit 1 +#define GL_READ_FRAMEBUFFER_EXT 0x8CA8 +#define GL_DRAW_FRAMEBUFFER_EXT 0x8CA9 +#define GL_DRAW_FRAMEBUFFER_BINDING_EXT 0x8CA6 +#define GL_READ_FRAMEBUFFER_BINDING_EXT 0x8CAA +typedef void (APIENTRYP PFNGLBLITFRAMEBUFFEREXTPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlitFramebufferEXT (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#endif +#endif /* GL_EXT_framebuffer_blit */ + +#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 (APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glRenderbufferStorageMultisampleEXT (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#endif +#endif /* GL_EXT_framebuffer_multisample */ + +#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 +#endif /* GL_EXT_framebuffer_multisample_blit_scaled */ + +#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 GLboolean (APIENTRYP PFNGLISRENDERBUFFEREXTPROC) (GLuint renderbuffer); +typedef void (APIENTRYP PFNGLBINDRENDERBUFFEREXTPROC) (GLenum target, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLDELETERENDERBUFFERSEXTPROC) (GLsizei n, const GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLGENRENDERBUFFERSEXTPROC) (GLsizei n, GLuint *renderbuffers); +typedef void (APIENTRYP PFNGLRENDERBUFFERSTORAGEEXTPROC) (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (APIENTRYP PFNGLGETRENDERBUFFERPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef GLboolean (APIENTRYP PFNGLISFRAMEBUFFEREXTPROC) (GLuint framebuffer); +typedef void (APIENTRYP PFNGLBINDFRAMEBUFFEREXTPROC) (GLenum target, GLuint framebuffer); +typedef void (APIENTRYP PFNGLDELETEFRAMEBUFFERSEXTPROC) (GLsizei n, const GLuint *framebuffers); +typedef void (APIENTRYP PFNGLGENFRAMEBUFFERSEXTPROC) (GLsizei n, GLuint *framebuffers); +typedef GLenum (APIENTRYP PFNGLCHECKFRAMEBUFFERSTATUSEXTPROC) (GLenum target); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE1DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURE3DEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +typedef void (APIENTRYP PFNGLFRAMEBUFFERRENDERBUFFEREXTPROC) (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +typedef void (APIENTRYP PFNGLGETFRAMEBUFFERATTACHMENTPARAMETERIVEXTPROC) (GLenum target, GLenum attachment, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGENERATEMIPMAPEXTPROC) (GLenum target); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glIsRenderbufferEXT (GLuint renderbuffer); +GLAPI void APIENTRY glBindRenderbufferEXT (GLenum target, GLuint renderbuffer); +GLAPI void APIENTRY glDeleteRenderbuffersEXT (GLsizei n, const GLuint *renderbuffers); +GLAPI void APIENTRY glGenRenderbuffersEXT (GLsizei n, GLuint *renderbuffers); +GLAPI void APIENTRY glRenderbufferStorageEXT (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +GLAPI void APIENTRY glGetRenderbufferParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI GLboolean APIENTRY glIsFramebufferEXT (GLuint framebuffer); +GLAPI void APIENTRY glBindFramebufferEXT (GLenum target, GLuint framebuffer); +GLAPI void APIENTRY glDeleteFramebuffersEXT (GLsizei n, const GLuint *framebuffers); +GLAPI void APIENTRY glGenFramebuffersEXT (GLsizei n, GLuint *framebuffers); +GLAPI GLenum APIENTRY glCheckFramebufferStatusEXT (GLenum target); +GLAPI void APIENTRY glFramebufferTexture1DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTexture2DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTexture3DEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +GLAPI void APIENTRY glFramebufferRenderbufferEXT (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +GLAPI void APIENTRY glGetFramebufferAttachmentParameterivEXT (GLenum target, GLenum attachment, GLenum pname, GLint *params); +GLAPI void APIENTRY glGenerateMipmapEXT (GLenum target); +#endif +#endif /* GL_EXT_framebuffer_object */ + +#ifndef GL_EXT_framebuffer_sRGB +#define GL_EXT_framebuffer_sRGB 1 +#define GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 +#define GL_FRAMEBUFFER_SRGB_CAPABLE_EXT 0x8DBA +#endif /* GL_EXT_framebuffer_sRGB */ + +#ifndef GL_EXT_geometry_shader4 +#define GL_EXT_geometry_shader4 1 +#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_TEXTURE_IMAGE_UNITS_EXT 0x8C29 +#define GL_MAX_GEOMETRY_VARYING_COMPONENTS_EXT 0x8DDD +#define GL_MAX_VERTEX_VARYING_COMPONENTS_EXT 0x8DDE +#define GL_MAX_VARYING_COMPONENTS_EXT 0x8B4B +#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 +#define GL_LINES_ADJACENCY_EXT 0x000A +#define GL_LINE_STRIP_ADJACENCY_EXT 0x000B +#define GL_TRIANGLES_ADJACENCY_EXT 0x000C +#define GL_TRIANGLE_STRIP_ADJACENCY_EXT 0x000D +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_TARGETS_EXT 0x8DA8 +#define GL_FRAMEBUFFER_INCOMPLETE_LAYER_COUNT_EXT 0x8DA9 +#define GL_FRAMEBUFFER_ATTACHMENT_LAYERED_EXT 0x8DA7 +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER_EXT 0x8CD4 +#define GL_PROGRAM_POINT_SIZE_EXT 0x8642 +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERIEXTPROC) (GLuint program, GLenum pname, GLint value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramParameteriEXT (GLuint program, GLenum pname, GLint value); +#endif +#endif /* GL_EXT_geometry_shader4 */ + +#ifndef GL_EXT_gpu_program_parameters +#define GL_EXT_gpu_program_parameters 1 +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERS4FVEXTPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramEnvParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat *params); +GLAPI void APIENTRY glProgramLocalParameters4fvEXT (GLenum target, GLuint index, GLsizei count, const GLfloat *params); +#endif +#endif /* GL_EXT_gpu_program_parameters */ + +#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 +#define GL_MIN_PROGRAM_TEXEL_OFFSET_EXT 0x8904 +#define GL_MAX_PROGRAM_TEXEL_OFFSET_EXT 0x8905 +typedef void (APIENTRYP PFNGLGETUNIFORMUIVEXTPROC) (GLuint program, GLint location, GLuint *params); +typedef void (APIENTRYP PFNGLBINDFRAGDATALOCATIONEXTPROC) (GLuint program, GLuint color, const GLchar *name); +typedef GLint (APIENTRYP PFNGLGETFRAGDATALOCATIONEXTPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLUNIFORM1UIEXTPROC) (GLint location, GLuint v0); +typedef void (APIENTRYP PFNGLUNIFORM2UIEXTPROC) (GLint location, GLuint v0, GLuint v1); +typedef void (APIENTRYP PFNGLUNIFORM3UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2); +typedef void (APIENTRYP PFNGLUNIFORM4UIEXTPROC) (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +typedef void (APIENTRYP PFNGLUNIFORM1UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM2UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM3UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +typedef void (APIENTRYP PFNGLUNIFORM4UIVEXTPROC) (GLint location, GLsizei count, const GLuint *value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetUniformuivEXT (GLuint program, GLint location, GLuint *params); +GLAPI void APIENTRY glBindFragDataLocationEXT (GLuint program, GLuint color, const GLchar *name); +GLAPI GLint APIENTRY glGetFragDataLocationEXT (GLuint program, const GLchar *name); +GLAPI void APIENTRY glUniform1uiEXT (GLint location, GLuint v0); +GLAPI void APIENTRY glUniform2uiEXT (GLint location, GLuint v0, GLuint v1); +GLAPI void APIENTRY glUniform3uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2); +GLAPI void APIENTRY glUniform4uiEXT (GLint location, GLuint v0, GLuint v1, GLuint v2, GLuint v3); +GLAPI void APIENTRY glUniform1uivEXT (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform2uivEXT (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform3uivEXT (GLint location, GLsizei count, const GLuint *value); +GLAPI void APIENTRY glUniform4uivEXT (GLint location, GLsizei count, const GLuint *value); +#endif +#endif /* GL_EXT_gpu_shader4 */ + +#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 +#define GL_TABLE_TOO_LARGE_EXT 0x8031 +typedef void (APIENTRYP PFNGLGETHISTOGRAMEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETHISTOGRAMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMINMAXEXTPROC) (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMINMAXPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLHISTOGRAMEXTPROC) (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLMINMAXEXTPROC) (GLenum target, GLenum internalformat, GLboolean sink); +typedef void (APIENTRYP PFNGLRESETHISTOGRAMEXTPROC) (GLenum target); +typedef void (APIENTRYP PFNGLRESETMINMAXEXTPROC) (GLenum target); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetHistogramEXT (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +GLAPI void APIENTRY glGetHistogramParameterfvEXT (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetHistogramParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMinmaxEXT (GLenum target, GLboolean reset, GLenum format, GLenum type, void *values); +GLAPI void APIENTRY glGetMinmaxParameterfvEXT (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMinmaxParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glHistogramEXT (GLenum target, GLsizei width, GLenum internalformat, GLboolean sink); +GLAPI void APIENTRY glMinmaxEXT (GLenum target, GLenum internalformat, GLboolean sink); +GLAPI void APIENTRY glResetHistogramEXT (GLenum target); +GLAPI void APIENTRY glResetMinmaxEXT (GLenum target); +#endif +#endif /* GL_EXT_histogram */ + +#ifndef GL_EXT_index_array_formats +#define GL_EXT_index_array_formats 1 +#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 /* GL_EXT_index_array_formats */ + +#ifndef GL_EXT_index_func +#define GL_EXT_index_func 1 +#define GL_INDEX_TEST_EXT 0x81B5 +#define GL_INDEX_TEST_FUNC_EXT 0x81B6 +#define GL_INDEX_TEST_REF_EXT 0x81B7 +typedef void (APIENTRYP PFNGLINDEXFUNCEXTPROC) (GLenum func, GLclampf ref); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIndexFuncEXT (GLenum func, GLclampf ref); +#endif +#endif /* GL_EXT_index_func */ + +#ifndef GL_EXT_index_material +#define GL_EXT_index_material 1 +#define GL_INDEX_MATERIAL_EXT 0x81B8 +#define GL_INDEX_MATERIAL_PARAMETER_EXT 0x81B9 +#define GL_INDEX_MATERIAL_FACE_EXT 0x81BA +typedef void (APIENTRYP PFNGLINDEXMATERIALEXTPROC) (GLenum face, GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIndexMaterialEXT (GLenum face, GLenum mode); +#endif +#endif /* GL_EXT_index_material */ + +#ifndef GL_EXT_index_texture +#define GL_EXT_index_texture 1 +#endif /* GL_EXT_index_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 (APIENTRYP PFNGLAPPLYTEXTUREEXTPROC) (GLenum mode); +typedef void (APIENTRYP PFNGLTEXTURELIGHTEXTPROC) (GLenum pname); +typedef void (APIENTRYP PFNGLTEXTUREMATERIALEXTPROC) (GLenum face, GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glApplyTextureEXT (GLenum mode); +GLAPI void APIENTRY glTextureLightEXT (GLenum pname); +GLAPI void APIENTRY glTextureMaterialEXT (GLenum face, GLenum mode); +#endif +#endif /* GL_EXT_light_texture */ + +#ifndef GL_EXT_misc_attribute +#define GL_EXT_misc_attribute 1 +#endif /* GL_EXT_misc_attribute */ + +#ifndef GL_EXT_multi_draw_arrays +#define GL_EXT_multi_draw_arrays 1 +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei primcount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiDrawArraysEXT (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +GLAPI void APIENTRY glMultiDrawElementsEXT (GLenum mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei primcount); +#endif +#endif /* GL_EXT_multi_draw_arrays */ + +#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 (APIENTRYP PFNGLSAMPLEMASKEXTPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLEPATTERNEXTPROC) (GLenum pattern); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleMaskEXT (GLclampf value, GLboolean invert); +GLAPI void APIENTRY glSamplePatternEXT (GLenum pattern); +#endif +#endif /* GL_EXT_multisample */ + +#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 +#endif /* GL_EXT_packed_depth_stencil */ + +#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 +#endif /* GL_EXT_packed_float */ + +#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 +#endif /* GL_EXT_packed_pixels */ + +#ifndef GL_EXT_paletted_texture +#define GL_EXT_paletted_texture 1 +#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 +typedef void (APIENTRYP PFNGLCOLORTABLEEXTPROC) (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const void *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEEXTPROC) (GLenum target, GLenum format, GLenum type, void *data); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorTableEXT (GLenum target, GLenum internalFormat, GLsizei width, GLenum format, GLenum type, const void *table); +GLAPI void APIENTRY glGetColorTableEXT (GLenum target, GLenum format, GLenum type, void *data); +GLAPI void APIENTRY glGetColorTableParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetColorTableParameterfvEXT (GLenum target, GLenum pname, GLfloat *params); +#endif +#endif /* GL_EXT_paletted_texture */ + +#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 +#endif /* GL_EXT_pixel_buffer_object */ + +#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 (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERIEXTPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERFEXTPROC) (GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETPIXELTRANSFORMPARAMETERIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPIXELTRANSFORMPARAMETERFVEXTPROC) (GLenum target, GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTransformParameteriEXT (GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glPixelTransformParameterfEXT (GLenum target, GLenum pname, GLfloat param); +GLAPI void APIENTRY glPixelTransformParameterivEXT (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glPixelTransformParameterfvEXT (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glGetPixelTransformParameterivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetPixelTransformParameterfvEXT (GLenum target, GLenum pname, GLfloat *params); +#endif +#endif /* GL_EXT_pixel_transform */ + +#ifndef GL_EXT_pixel_transform_color_table +#define GL_EXT_pixel_transform_color_table 1 +#endif /* GL_EXT_pixel_transform_color_table */ + +#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 (APIENTRYP PFNGLPOINTPARAMETERFEXTPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVEXTPROC) (GLenum pname, const GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfEXT (GLenum pname, GLfloat param); +GLAPI void APIENTRY glPointParameterfvEXT (GLenum pname, const GLfloat *params); +#endif +#endif /* GL_EXT_point_parameters */ + +#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 (APIENTRYP PFNGLPOLYGONOFFSETEXTPROC) (GLfloat factor, GLfloat bias); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPolygonOffsetEXT (GLfloat factor, GLfloat bias); +#endif +#endif /* GL_EXT_polygon_offset */ + +#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 (APIENTRYP PFNGLPROVOKINGVERTEXEXTPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProvokingVertexEXT (GLenum mode); +#endif +#endif /* GL_EXT_provoking_vertex */ + +#ifndef GL_EXT_rescale_normal +#define GL_EXT_rescale_normal 1 +#define GL_RESCALE_NORMAL_EXT 0x803A +#endif /* GL_EXT_rescale_normal */ + +#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 (APIENTRYP PFNGLSECONDARYCOLOR3BEXTPROC) (GLbyte red, GLbyte green, GLbyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3BVEXTPROC) (const GLbyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DEXTPROC) (GLdouble red, GLdouble green, GLdouble blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3DVEXTPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FEXTPROC) (GLfloat red, GLfloat green, GLfloat blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3FVEXTPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IEXTPROC) (GLint red, GLint green, GLint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3IVEXTPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SEXTPROC) (GLshort red, GLshort green, GLshort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3SVEXTPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBEXTPROC) (GLubyte red, GLubyte green, GLubyte blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UBVEXTPROC) (const GLubyte *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIEXTPROC) (GLuint red, GLuint green, GLuint blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3UIVEXTPROC) (const GLuint *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USEXTPROC) (GLushort red, GLushort green, GLushort blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3USVEXTPROC) (const GLushort *v); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSecondaryColor3bEXT (GLbyte red, GLbyte green, GLbyte blue); +GLAPI void APIENTRY glSecondaryColor3bvEXT (const GLbyte *v); +GLAPI void APIENTRY glSecondaryColor3dEXT (GLdouble red, GLdouble green, GLdouble blue); +GLAPI void APIENTRY glSecondaryColor3dvEXT (const GLdouble *v); +GLAPI void APIENTRY glSecondaryColor3fEXT (GLfloat red, GLfloat green, GLfloat blue); +GLAPI void APIENTRY glSecondaryColor3fvEXT (const GLfloat *v); +GLAPI void APIENTRY glSecondaryColor3iEXT (GLint red, GLint green, GLint blue); +GLAPI void APIENTRY glSecondaryColor3ivEXT (const GLint *v); +GLAPI void APIENTRY glSecondaryColor3sEXT (GLshort red, GLshort green, GLshort blue); +GLAPI void APIENTRY glSecondaryColor3svEXT (const GLshort *v); +GLAPI void APIENTRY glSecondaryColor3ubEXT (GLubyte red, GLubyte green, GLubyte blue); +GLAPI void APIENTRY glSecondaryColor3ubvEXT (const GLubyte *v); +GLAPI void APIENTRY glSecondaryColor3uiEXT (GLuint red, GLuint green, GLuint blue); +GLAPI void APIENTRY glSecondaryColor3uivEXT (const GLuint *v); +GLAPI void APIENTRY glSecondaryColor3usEXT (GLushort red, GLushort green, GLushort blue); +GLAPI void APIENTRY glSecondaryColor3usvEXT (const GLushort *v); +GLAPI void APIENTRY glSecondaryColorPointerEXT (GLint size, GLenum type, GLsizei stride, const void *pointer); +#endif +#endif /* GL_EXT_secondary_color */ + +#ifndef GL_EXT_separate_shader_objects +#define GL_EXT_separate_shader_objects 1 +#define GL_ACTIVE_PROGRAM_EXT 0x8B8D +typedef void (APIENTRYP PFNGLUSESHADERPROGRAMEXTPROC) (GLenum type, GLuint program); +typedef void (APIENTRYP PFNGLACTIVEPROGRAMEXTPROC) (GLuint program); +typedef GLuint (APIENTRYP PFNGLCREATESHADERPROGRAMEXTPROC) (GLenum type, const GLchar *string); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glUseShaderProgramEXT (GLenum type, GLuint program); +GLAPI void APIENTRY glActiveProgramEXT (GLuint program); +GLAPI GLuint APIENTRY glCreateShaderProgramEXT (GLenum type, const GLchar *string); +#endif +#endif /* GL_EXT_separate_shader_objects */ + +#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 +#endif /* GL_EXT_separate_specular_color */ + +#ifndef GL_EXT_shader_image_load_formatted +#define GL_EXT_shader_image_load_formatted 1 +#endif /* GL_EXT_shader_image_load_formatted */ + +#ifndef GL_EXT_shader_image_load_store +#define GL_EXT_shader_image_load_store 1 +#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_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_ALL_BARRIER_BITS_EXT 0xFFFFFFFF +typedef void (APIENTRYP PFNGLBINDIMAGETEXTUREEXTPROC) (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format); +typedef void (APIENTRYP PFNGLMEMORYBARRIEREXTPROC) (GLbitfield barriers); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindImageTextureEXT (GLuint index, GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum access, GLint format); +GLAPI void APIENTRY glMemoryBarrierEXT (GLbitfield barriers); +#endif +#endif /* GL_EXT_shader_image_load_store */ + +#ifndef GL_EXT_shader_integer_mix +#define GL_EXT_shader_integer_mix 1 +#endif /* GL_EXT_shader_integer_mix */ + +#ifndef GL_EXT_shadow_funcs +#define GL_EXT_shadow_funcs 1 +#endif /* GL_EXT_shadow_funcs */ + +#ifndef GL_EXT_shared_texture_palette +#define GL_EXT_shared_texture_palette 1 +#define GL_SHARED_TEXTURE_PALETTE_EXT 0x81FB +#endif /* GL_EXT_shared_texture_palette */ + +#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 +typedef void (APIENTRYP PFNGLSTENCILCLEARTAGEXTPROC) (GLsizei stencilTagBits, GLuint stencilClearTag); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStencilClearTagEXT (GLsizei stencilTagBits, GLuint stencilClearTag); +#endif +#endif /* GL_EXT_stencil_clear_tag */ + +#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 (APIENTRYP PFNGLACTIVESTENCILFACEEXTPROC) (GLenum face); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glActiveStencilFaceEXT (GLenum face); +#endif +#endif /* GL_EXT_stencil_two_side */ + +#ifndef GL_EXT_stencil_wrap +#define GL_EXT_stencil_wrap 1 +#define GL_INCR_WRAP_EXT 0x8507 +#define GL_DECR_WRAP_EXT 0x8508 +#endif /* GL_EXT_stencil_wrap */ + +#ifndef GL_EXT_subtexture +#define GL_EXT_subtexture 1 +typedef void (APIENTRYP PFNGLTEXSUBIMAGE1DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE2DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexSubImage1DEXT (GLenum target, GLint level, GLint xoffset, GLsizei width, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTexSubImage2DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const void *pixels); +#endif +#endif /* GL_EXT_subtexture */ + +#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 GL_TEXTURE_TOO_LARGE_EXT 0x8065 +#endif /* GL_EXT_texture */ + +#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 (APIENTRYP PFNGLTEXIMAGE3DEXTPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP PFNGLTEXSUBIMAGE3DEXTPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *pixels); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexImage3DEXT (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTexSubImage3DEXT (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const void *pixels); +#endif +#endif /* GL_EXT_texture3D */ + +#ifndef GL_EXT_texture_array +#define GL_EXT_texture_array 1 +#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 +#define GL_MAX_ARRAY_TEXTURE_LAYERS_EXT 0x88FF +#define GL_COMPARE_REF_DEPTH_TO_TEXTURE_EXT 0x884E +#endif /* GL_EXT_texture_array */ + +#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 (APIENTRYP PFNGLTEXBUFFEREXTPROC) (GLenum target, GLenum internalformat, GLuint buffer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexBufferEXT (GLenum target, GLenum internalformat, GLuint buffer); +#endif +#endif /* GL_EXT_texture_buffer_object */ + +#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 +#endif /* GL_EXT_texture_compression_latc */ + +#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 +#endif /* GL_EXT_texture_compression_rgtc */ + +#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 +#endif /* GL_EXT_texture_compression_s3tc */ + +#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 +#endif /* GL_EXT_texture_cube_map */ + +#ifndef GL_EXT_texture_env_add +#define GL_EXT_texture_env_add 1 +#endif /* GL_EXT_texture_env_add */ + +#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 +#endif /* GL_EXT_texture_env_combine */ + +#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 +#endif /* GL_EXT_texture_env_dot3 */ + +#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 +#endif /* GL_EXT_texture_filter_anisotropic */ + +#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 (APIENTRYP PFNGLTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, const GLuint *params); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETTEXPARAMETERIUIVEXTPROC) (GLenum target, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLCLEARCOLORIIEXTPROC) (GLint red, GLint green, GLint blue, GLint alpha); +typedef void (APIENTRYP PFNGLCLEARCOLORIUIEXTPROC) (GLuint red, GLuint green, GLuint blue, GLuint alpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexParameterIivEXT (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glTexParameterIuivEXT (GLenum target, GLenum pname, const GLuint *params); +GLAPI void APIENTRY glGetTexParameterIivEXT (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetTexParameterIuivEXT (GLenum target, GLenum pname, GLuint *params); +GLAPI void APIENTRY glClearColorIiEXT (GLint red, GLint green, GLint blue, GLint alpha); +GLAPI void APIENTRY glClearColorIuiEXT (GLuint red, GLuint green, GLuint blue, GLuint alpha); +#endif +#endif /* GL_EXT_texture_integer */ + +#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 +#endif /* GL_EXT_texture_lod_bias */ + +#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 +#endif /* GL_EXT_texture_mirror_clamp */ + +#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 (APIENTRYP PFNGLARETEXTURESRESIDENTEXTPROC) (GLsizei n, const GLuint *textures, GLboolean *residences); +typedef void (APIENTRYP PFNGLBINDTEXTUREEXTPROC) (GLenum target, GLuint texture); +typedef void (APIENTRYP PFNGLDELETETEXTURESEXTPROC) (GLsizei n, const GLuint *textures); +typedef void (APIENTRYP PFNGLGENTEXTURESEXTPROC) (GLsizei n, GLuint *textures); +typedef GLboolean (APIENTRYP PFNGLISTEXTUREEXTPROC) (GLuint texture); +typedef void (APIENTRYP PFNGLPRIORITIZETEXTURESEXTPROC) (GLsizei n, const GLuint *textures, const GLclampf *priorities); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glAreTexturesResidentEXT (GLsizei n, const GLuint *textures, GLboolean *residences); +GLAPI void APIENTRY glBindTextureEXT (GLenum target, GLuint texture); +GLAPI void APIENTRY glDeleteTexturesEXT (GLsizei n, const GLuint *textures); +GLAPI void APIENTRY glGenTexturesEXT (GLsizei n, GLuint *textures); +GLAPI GLboolean APIENTRY glIsTextureEXT (GLuint texture); +GLAPI void APIENTRY glPrioritizeTexturesEXT (GLsizei n, const GLuint *textures, const GLclampf *priorities); +#endif +#endif /* GL_EXT_texture_object */ + +#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 (APIENTRYP PFNGLTEXTURENORMALEXTPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureNormalEXT (GLenum mode); +#endif +#endif /* GL_EXT_texture_perturb_normal */ + +#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 +#endif /* GL_EXT_texture_sRGB */ + +#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 +#endif /* GL_EXT_texture_sRGB_decode */ + +#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 +#endif /* GL_EXT_texture_shared_exponent */ + +#ifndef GL_EXT_texture_snorm +#define GL_EXT_texture_snorm 1 +#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 GL_RED_SNORM 0x8F90 +#define GL_RG_SNORM 0x8F91 +#define GL_RGB_SNORM 0x8F92 +#define GL_RGBA_SNORM 0x8F93 +#endif /* GL_EXT_texture_snorm */ + +#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 +#endif /* GL_EXT_texture_swizzle */ + +#ifndef GL_EXT_timer_query +#define GL_EXT_timer_query 1 +#define GL_TIME_ELAPSED_EXT 0x88BF +typedef void (APIENTRYP PFNGLGETQUERYOBJECTI64VEXTPROC) (GLuint id, GLenum pname, GLint64 *params); +typedef void (APIENTRYP PFNGLGETQUERYOBJECTUI64VEXTPROC) (GLuint id, GLenum pname, GLuint64 *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetQueryObjecti64vEXT (GLuint id, GLenum pname, GLint64 *params); +GLAPI void APIENTRY glGetQueryObjectui64vEXT (GLuint id, GLenum pname, GLuint64 *params); +#endif +#endif /* GL_EXT_timer_query */ + +#ifndef GL_EXT_transform_feedback +#define GL_EXT_transform_feedback 1 +#define GL_TRANSFORM_FEEDBACK_BUFFER_EXT 0x8C8E +#define GL_TRANSFORM_FEEDBACK_BUFFER_START_EXT 0x8C84 +#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE_EXT 0x8C85 +#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING_EXT 0x8C8F +#define GL_INTERLEAVED_ATTRIBS_EXT 0x8C8C +#define GL_SEPARATE_ATTRIBS_EXT 0x8C8D +#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_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS_EXT 0x8C80 +#define GL_TRANSFORM_FEEDBACK_VARYINGS_EXT 0x8C83 +#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE_EXT 0x8C7F +#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH_EXT 0x8C76 +typedef void (APIENTRYP PFNGLBEGINTRANSFORMFEEDBACKEXTPROC) (GLenum primitiveMode); +typedef void (APIENTRYP PFNGLENDTRANSFORMFEEDBACKEXTPROC) (void); +typedef void (APIENTRYP PFNGLBINDBUFFERRANGEEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLBINDBUFFEROFFSETEXTPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +typedef void (APIENTRYP PFNGLBINDBUFFERBASEEXTPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSEXTPROC) (GLuint program, GLsizei count, const GLchar *const*varyings, GLenum bufferMode); +typedef void (APIENTRYP PFNGLGETTRANSFORMFEEDBACKVARYINGEXTPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginTransformFeedbackEXT (GLenum primitiveMode); +GLAPI void APIENTRY glEndTransformFeedbackEXT (void); +GLAPI void APIENTRY glBindBufferRangeEXT (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI void APIENTRY glBindBufferOffsetEXT (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +GLAPI void APIENTRY glBindBufferBaseEXT (GLenum target, GLuint index, GLuint buffer); +GLAPI void APIENTRY glTransformFeedbackVaryingsEXT (GLuint program, GLsizei count, const GLchar *const*varyings, GLenum bufferMode); +GLAPI void APIENTRY glGetTransformFeedbackVaryingEXT (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +#endif +#endif /* GL_EXT_transform_feedback */ + +#ifndef GL_EXT_vertex_array +#define GL_EXT_vertex_array 1 +#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 (APIENTRYP PFNGLARRAYELEMENTEXTPROC) (GLint i); +typedef void (APIENTRYP PFNGLCOLORPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +typedef void (APIENTRYP PFNGLDRAWARRAYSEXTPROC) (GLenum mode, GLint first, GLsizei count); +typedef void (APIENTRYP PFNGLEDGEFLAGPOINTEREXTPROC) (GLsizei stride, GLsizei count, const GLboolean *pointer); +typedef void (APIENTRYP PFNGLGETPOINTERVEXTPROC) (GLenum pname, void **params); +typedef void (APIENTRYP PFNGLINDEXPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void *pointer); +typedef void (APIENTRYP PFNGLNORMALPOINTEREXTPROC) (GLenum type, GLsizei stride, GLsizei count, const void *pointer); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +typedef void (APIENTRYP PFNGLVERTEXPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glArrayElementEXT (GLint i); +GLAPI void APIENTRY glColorPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +GLAPI void APIENTRY glDrawArraysEXT (GLenum mode, GLint first, GLsizei count); +GLAPI void APIENTRY glEdgeFlagPointerEXT (GLsizei stride, GLsizei count, const GLboolean *pointer); +GLAPI void APIENTRY glGetPointervEXT (GLenum pname, void **params); +GLAPI void APIENTRY glIndexPointerEXT (GLenum type, GLsizei stride, GLsizei count, const void *pointer); +GLAPI void APIENTRY glNormalPointerEXT (GLenum type, GLsizei stride, GLsizei count, const void *pointer); +GLAPI void APIENTRY glTexCoordPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +GLAPI void APIENTRY glVertexPointerEXT (GLint size, GLenum type, GLsizei stride, GLsizei count, const void *pointer); +#endif +#endif /* GL_EXT_vertex_array */ + +#ifndef GL_EXT_vertex_array_bgra +#define GL_EXT_vertex_array_bgra 1 +#endif /* GL_EXT_vertex_array_bgra */ + +#ifndef GL_EXT_vertex_attrib_64bit +#define GL_EXT_vertex_attrib_64bit 1 +#define GL_DOUBLE_VEC2_EXT 0x8FFC +#define GL_DOUBLE_VEC3_EXT 0x8FFD +#define GL_DOUBLE_VEC4_EXT 0x8FFE +#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 +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1DEXTPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2DEXTPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4DEXTPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1DVEXTPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2DVEXTPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3DVEXTPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4DVEXTPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBLPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBLDVEXTPROC) (GLuint index, GLenum pname, GLdouble *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribL1dEXT (GLuint index, GLdouble x); +GLAPI void APIENTRY glVertexAttribL2dEXT (GLuint index, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexAttribL3dEXT (GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexAttribL4dEXT (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexAttribL1dvEXT (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL2dvEXT (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL3dvEXT (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribL4dvEXT (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribLPointerEXT (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glGetVertexAttribLdvEXT (GLuint index, GLenum pname, GLdouble *params); +#endif +#endif /* GL_EXT_vertex_attrib_64bit */ + +#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_LOCAL_CONSTANTS_EXT 0x87CC +#define GL_MAX_OPTIMIZED_VERTEX_SHADER_INVARIANTS_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 (APIENTRYP PFNGLBEGINVERTEXSHADEREXTPROC) (void); +typedef void (APIENTRYP PFNGLENDVERTEXSHADEREXTPROC) (void); +typedef void (APIENTRYP PFNGLBINDVERTEXSHADEREXTPROC) (GLuint id); +typedef GLuint (APIENTRYP PFNGLGENVERTEXSHADERSEXTPROC) (GLuint range); +typedef void (APIENTRYP PFNGLDELETEVERTEXSHADEREXTPROC) (GLuint id); +typedef void (APIENTRYP PFNGLSHADEROP1EXTPROC) (GLenum op, GLuint res, GLuint arg1); +typedef void (APIENTRYP PFNGLSHADEROP2EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2); +typedef void (APIENTRYP PFNGLSHADEROP3EXTPROC) (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); +typedef void (APIENTRYP PFNGLSWIZZLEEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +typedef void (APIENTRYP PFNGLWRITEMASKEXTPROC) (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +typedef void (APIENTRYP PFNGLINSERTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef void (APIENTRYP PFNGLEXTRACTCOMPONENTEXTPROC) (GLuint res, GLuint src, GLuint num); +typedef GLuint (APIENTRYP PFNGLGENSYMBOLSEXTPROC) (GLenum datatype, GLenum storagetype, GLenum range, GLuint components); +typedef void (APIENTRYP PFNGLSETINVARIANTEXTPROC) (GLuint id, GLenum type, const void *addr); +typedef void (APIENTRYP PFNGLSETLOCALCONSTANTEXTPROC) (GLuint id, GLenum type, const void *addr); +typedef void (APIENTRYP PFNGLVARIANTBVEXTPROC) (GLuint id, const GLbyte *addr); +typedef void (APIENTRYP PFNGLVARIANTSVEXTPROC) (GLuint id, const GLshort *addr); +typedef void (APIENTRYP PFNGLVARIANTIVEXTPROC) (GLuint id, const GLint *addr); +typedef void (APIENTRYP PFNGLVARIANTFVEXTPROC) (GLuint id, const GLfloat *addr); +typedef void (APIENTRYP PFNGLVARIANTDVEXTPROC) (GLuint id, const GLdouble *addr); +typedef void (APIENTRYP PFNGLVARIANTUBVEXTPROC) (GLuint id, const GLubyte *addr); +typedef void (APIENTRYP PFNGLVARIANTUSVEXTPROC) (GLuint id, const GLushort *addr); +typedef void (APIENTRYP PFNGLVARIANTUIVEXTPROC) (GLuint id, const GLuint *addr); +typedef void (APIENTRYP PFNGLVARIANTPOINTEREXTPROC) (GLuint id, GLenum type, GLuint stride, const void *addr); +typedef void (APIENTRYP PFNGLENABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef void (APIENTRYP PFNGLDISABLEVARIANTCLIENTSTATEEXTPROC) (GLuint id); +typedef GLuint (APIENTRYP PFNGLBINDLIGHTPARAMETEREXTPROC) (GLenum light, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDMATERIALPARAMETEREXTPROC) (GLenum face, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDTEXGENPARAMETEREXTPROC) (GLenum unit, GLenum coord, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDTEXTUREUNITPARAMETEREXTPROC) (GLenum unit, GLenum value); +typedef GLuint (APIENTRYP PFNGLBINDPARAMETEREXTPROC) (GLenum value); +typedef GLboolean (APIENTRYP PFNGLISVARIANTENABLEDEXTPROC) (GLuint id, GLenum cap); +typedef void (APIENTRYP PFNGLGETVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (APIENTRYP PFNGLGETVARIANTPOINTERVEXTPROC) (GLuint id, GLenum value, void **data); +typedef void (APIENTRYP PFNGLGETINVARIANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETINVARIANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETINVARIANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTBOOLEANVEXTPROC) (GLuint id, GLenum value, GLboolean *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTINTEGERVEXTPROC) (GLuint id, GLenum value, GLint *data); +typedef void (APIENTRYP PFNGLGETLOCALCONSTANTFLOATVEXTPROC) (GLuint id, GLenum value, GLfloat *data); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginVertexShaderEXT (void); +GLAPI void APIENTRY glEndVertexShaderEXT (void); +GLAPI void APIENTRY glBindVertexShaderEXT (GLuint id); +GLAPI GLuint APIENTRY glGenVertexShadersEXT (GLuint range); +GLAPI void APIENTRY glDeleteVertexShaderEXT (GLuint id); +GLAPI void APIENTRY glShaderOp1EXT (GLenum op, GLuint res, GLuint arg1); +GLAPI void APIENTRY glShaderOp2EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2); +GLAPI void APIENTRY glShaderOp3EXT (GLenum op, GLuint res, GLuint arg1, GLuint arg2, GLuint arg3); +GLAPI void APIENTRY glSwizzleEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +GLAPI void APIENTRY glWriteMaskEXT (GLuint res, GLuint in, GLenum outX, GLenum outY, GLenum outZ, GLenum outW); +GLAPI void APIENTRY glInsertComponentEXT (GLuint res, GLuint src, GLuint num); +GLAPI void APIENTRY glExtractComponentEXT (GLuint res, GLuint src, GLuint num); +GLAPI GLuint APIENTRY glGenSymbolsEXT (GLenum datatype, GLenum storagetype, GLenum range, GLuint components); +GLAPI void APIENTRY glSetInvariantEXT (GLuint id, GLenum type, const void *addr); +GLAPI void APIENTRY glSetLocalConstantEXT (GLuint id, GLenum type, const void *addr); +GLAPI void APIENTRY glVariantbvEXT (GLuint id, const GLbyte *addr); +GLAPI void APIENTRY glVariantsvEXT (GLuint id, const GLshort *addr); +GLAPI void APIENTRY glVariantivEXT (GLuint id, const GLint *addr); +GLAPI void APIENTRY glVariantfvEXT (GLuint id, const GLfloat *addr); +GLAPI void APIENTRY glVariantdvEXT (GLuint id, const GLdouble *addr); +GLAPI void APIENTRY glVariantubvEXT (GLuint id, const GLubyte *addr); +GLAPI void APIENTRY glVariantusvEXT (GLuint id, const GLushort *addr); +GLAPI void APIENTRY glVariantuivEXT (GLuint id, const GLuint *addr); +GLAPI void APIENTRY glVariantPointerEXT (GLuint id, GLenum type, GLuint stride, const void *addr); +GLAPI void APIENTRY glEnableVariantClientStateEXT (GLuint id); +GLAPI void APIENTRY glDisableVariantClientStateEXT (GLuint id); +GLAPI GLuint APIENTRY glBindLightParameterEXT (GLenum light, GLenum value); +GLAPI GLuint APIENTRY glBindMaterialParameterEXT (GLenum face, GLenum value); +GLAPI GLuint APIENTRY glBindTexGenParameterEXT (GLenum unit, GLenum coord, GLenum value); +GLAPI GLuint APIENTRY glBindTextureUnitParameterEXT (GLenum unit, GLenum value); +GLAPI GLuint APIENTRY glBindParameterEXT (GLenum value); +GLAPI GLboolean APIENTRY glIsVariantEnabledEXT (GLuint id, GLenum cap); +GLAPI void APIENTRY glGetVariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data); +GLAPI void APIENTRY glGetVariantIntegervEXT (GLuint id, GLenum value, GLint *data); +GLAPI void APIENTRY glGetVariantFloatvEXT (GLuint id, GLenum value, GLfloat *data); +GLAPI void APIENTRY glGetVariantPointervEXT (GLuint id, GLenum value, void **data); +GLAPI void APIENTRY glGetInvariantBooleanvEXT (GLuint id, GLenum value, GLboolean *data); +GLAPI void APIENTRY glGetInvariantIntegervEXT (GLuint id, GLenum value, GLint *data); +GLAPI void APIENTRY glGetInvariantFloatvEXT (GLuint id, GLenum value, GLfloat *data); +GLAPI void APIENTRY glGetLocalConstantBooleanvEXT (GLuint id, GLenum value, GLboolean *data); +GLAPI void APIENTRY glGetLocalConstantIntegervEXT (GLuint id, GLenum value, GLint *data); +GLAPI void APIENTRY glGetLocalConstantFloatvEXT (GLuint id, GLenum value, GLfloat *data); +#endif +#endif /* GL_EXT_vertex_shader */ + +#ifndef GL_EXT_vertex_weighting +#define GL_EXT_vertex_weighting 1 +#define GL_MODELVIEW0_STACK_DEPTH_EXT 0x0BA3 +#define GL_MODELVIEW1_STACK_DEPTH_EXT 0x8502 +#define GL_MODELVIEW0_MATRIX_EXT 0x0BA6 +#define GL_MODELVIEW1_MATRIX_EXT 0x8506 +#define GL_VERTEX_WEIGHTING_EXT 0x8509 +#define GL_MODELVIEW0_EXT 0x1700 +#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 (APIENTRYP PFNGLVERTEXWEIGHTFEXTPROC) (GLfloat weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTFVEXTPROC) (const GLfloat *weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTPOINTEREXTPROC) (GLint size, GLenum type, GLsizei stride, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexWeightfEXT (GLfloat weight); +GLAPI void APIENTRY glVertexWeightfvEXT (const GLfloat *weight); +GLAPI void APIENTRY glVertexWeightPointerEXT (GLint size, GLenum type, GLsizei stride, const void *pointer); +#endif +#endif /* GL_EXT_vertex_weighting */ + +#ifndef GL_EXT_x11_sync_object +#define GL_EXT_x11_sync_object 1 +#define GL_SYNC_X11_FENCE_EXT 0x90E1 +typedef GLsync (APIENTRYP PFNGLIMPORTSYNCEXTPROC) (GLenum external_sync_type, GLintptr external_sync, GLbitfield flags); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLsync APIENTRY glImportSyncEXT (GLenum external_sync_type, GLintptr external_sync, GLbitfield flags); +#endif +#endif /* GL_EXT_x11_sync_object */ + +#ifndef GL_GREMEDY_frame_terminator +#define GL_GREMEDY_frame_terminator 1 +typedef void (APIENTRYP PFNGLFRAMETERMINATORGREMEDYPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFrameTerminatorGREMEDY (void); +#endif +#endif /* GL_GREMEDY_frame_terminator */ + +#ifndef GL_GREMEDY_string_marker +#define GL_GREMEDY_string_marker 1 +typedef void (APIENTRYP PFNGLSTRINGMARKERGREMEDYPROC) (GLsizei len, const void *string); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glStringMarkerGREMEDY (GLsizei len, const void *string); +#endif +#endif /* GL_GREMEDY_string_marker */ + +#ifndef GL_HP_convolution_border_modes +#define GL_HP_convolution_border_modes 1 +#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 /* GL_HP_convolution_border_modes */ + +#ifndef GL_HP_image_transform +#define GL_HP_image_transform 1 +#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 +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERIHPPROC) (GLenum target, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERFHPPROC) (GLenum target, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETIMAGETRANSFORMPARAMETERIVHPPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETIMAGETRANSFORMPARAMETERFVHPPROC) (GLenum target, GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glImageTransformParameteriHP (GLenum target, GLenum pname, GLint param); +GLAPI void APIENTRY glImageTransformParameterfHP (GLenum target, GLenum pname, GLfloat param); +GLAPI void APIENTRY glImageTransformParameterivHP (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glImageTransformParameterfvHP (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glGetImageTransformParameterivHP (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetImageTransformParameterfvHP (GLenum target, GLenum pname, GLfloat *params); +#endif +#endif /* GL_HP_image_transform */ + +#ifndef GL_HP_occlusion_test +#define GL_HP_occlusion_test 1 +#define GL_OCCLUSION_TEST_HP 0x8165 +#define GL_OCCLUSION_TEST_RESULT_HP 0x8166 +#endif /* GL_HP_occlusion_test */ + +#ifndef GL_HP_texture_lighting +#define GL_HP_texture_lighting 1 +#define GL_TEXTURE_LIGHTING_MODE_HP 0x8167 +#define GL_TEXTURE_POST_SPECULAR_HP 0x8168 +#define GL_TEXTURE_PRE_SPECULAR_HP 0x8169 +#endif /* GL_HP_texture_lighting */ + +#ifndef GL_IBM_cull_vertex +#define GL_IBM_cull_vertex 1 +#define GL_CULL_VERTEX_IBM 103050 +#endif /* GL_IBM_cull_vertex */ + +#ifndef GL_IBM_multimode_draw_arrays +#define GL_IBM_multimode_draw_arrays 1 +typedef void (APIENTRYP PFNGLMULTIMODEDRAWARRAYSIBMPROC) (const GLenum *mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); +typedef void (APIENTRYP PFNGLMULTIMODEDRAWELEMENTSIBMPROC) (const GLenum *mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei primcount, GLint modestride); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiModeDrawArraysIBM (const GLenum *mode, const GLint *first, const GLsizei *count, GLsizei primcount, GLint modestride); +GLAPI void APIENTRY glMultiModeDrawElementsIBM (const GLenum *mode, const GLsizei *count, GLenum type, const void *const*indices, GLsizei primcount, GLint modestride); +#endif +#endif /* GL_IBM_multimode_draw_arrays */ + +#ifndef GL_IBM_rasterpos_clip +#define GL_IBM_rasterpos_clip 1 +#define GL_RASTER_POSITION_UNCLIPPED_IBM 0x19262 +#endif /* GL_IBM_rasterpos_clip */ + +#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 +typedef void (APIENTRYP PFNGLFLUSHSTATICDATAIBMPROC) (GLenum target); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFlushStaticDataIBM (GLenum target); +#endif +#endif /* GL_IBM_static_data */ + +#ifndef GL_IBM_texture_mirrored_repeat +#define GL_IBM_texture_mirrored_repeat 1 +#define GL_MIRRORED_REPEAT_IBM 0x8370 +#endif /* GL_IBM_texture_mirrored_repeat */ + +#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 (APIENTRYP PFNGLCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLSECONDARYCOLORPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLEDGEFLAGPOINTERLISTIBMPROC) (GLint stride, const GLboolean **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLFOGCOORDPOINTERLISTIBMPROC) (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLINDEXPOINTERLISTIBMPROC) (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLNORMALPOINTERLISTIBMPROC) (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +typedef void (APIENTRYP PFNGLVERTEXPOINTERLISTIBMPROC) (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorPointerListIBM (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glSecondaryColorPointerListIBM (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glEdgeFlagPointerListIBM (GLint stride, const GLboolean **pointer, GLint ptrstride); +GLAPI void APIENTRY glFogCoordPointerListIBM (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glIndexPointerListIBM (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glNormalPointerListIBM (GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glTexCoordPointerListIBM (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +GLAPI void APIENTRY glVertexPointerListIBM (GLint size, GLenum type, GLint stride, const void **pointer, GLint ptrstride); +#endif +#endif /* GL_IBM_vertex_array_lists */ + +#ifndef GL_INGR_blend_func_separate +#define GL_INGR_blend_func_separate 1 +typedef void (APIENTRYP PFNGLBLENDFUNCSEPARATEINGRPROC) (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendFuncSeparateINGR (GLenum sfactorRGB, GLenum dfactorRGB, GLenum sfactorAlpha, GLenum dfactorAlpha); +#endif +#endif /* GL_INGR_blend_func_separate */ + +#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 +#endif /* GL_INGR_color_clamp */ + +#ifndef GL_INGR_interlace_read +#define GL_INGR_interlace_read 1 +#define GL_INTERLACE_READ_INGR 0x8568 +#endif /* GL_INGR_interlace_read */ + +#ifndef GL_INTEL_fragment_shader_ordering +#define GL_INTEL_fragment_shader_ordering 1 +#endif /* GL_INTEL_fragment_shader_ordering */ + +#ifndef GL_INTEL_map_texture +#define GL_INTEL_map_texture 1 +#define GL_TEXTURE_MEMORY_LAYOUT_INTEL 0x83FF +#define GL_LAYOUT_DEFAULT_INTEL 0 +#define GL_LAYOUT_LINEAR_INTEL 1 +#define GL_LAYOUT_LINEAR_CPU_CACHED_INTEL 2 +typedef void (APIENTRYP PFNGLSYNCTEXTUREINTELPROC) (GLuint texture); +typedef void (APIENTRYP PFNGLUNMAPTEXTURE2DINTELPROC) (GLuint texture, GLint level); +typedef void *(APIENTRYP PFNGLMAPTEXTURE2DINTELPROC) (GLuint texture, GLint level, GLbitfield access, GLint *stride, GLenum *layout); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSyncTextureINTEL (GLuint texture); +GLAPI void APIENTRY glUnmapTexture2DINTEL (GLuint texture, GLint level); +GLAPI void *APIENTRY glMapTexture2DINTEL (GLuint texture, GLint level, GLbitfield access, GLint *stride, GLenum *layout); +#endif +#endif /* GL_INTEL_map_texture */ + +#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 (APIENTRYP PFNGLVERTEXPOINTERVINTELPROC) (GLint size, GLenum type, const void **pointer); +typedef void (APIENTRYP PFNGLNORMALPOINTERVINTELPROC) (GLenum type, const void **pointer); +typedef void (APIENTRYP PFNGLCOLORPOINTERVINTELPROC) (GLint size, GLenum type, const void **pointer); +typedef void (APIENTRYP PFNGLTEXCOORDPOINTERVINTELPROC) (GLint size, GLenum type, const void **pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexPointervINTEL (GLint size, GLenum type, const void **pointer); +GLAPI void APIENTRY glNormalPointervINTEL (GLenum type, const void **pointer); +GLAPI void APIENTRY glColorPointervINTEL (GLint size, GLenum type, const void **pointer); +GLAPI void APIENTRY glTexCoordPointervINTEL (GLint size, GLenum type, const void **pointer); +#endif +#endif /* GL_INTEL_parallel_arrays */ + +#ifndef GL_INTEL_performance_query +#define GL_INTEL_performance_query 1 +#define GL_PERFQUERY_SINGLE_CONTEXT_INTEL 0x00000000 +#define GL_PERFQUERY_GLOBAL_CONTEXT_INTEL 0x00000001 +#define GL_PERFQUERY_WAIT_INTEL 0x83FB +#define GL_PERFQUERY_FLUSH_INTEL 0x83FA +#define GL_PERFQUERY_DONOT_FLUSH_INTEL 0x83F9 +#define GL_PERFQUERY_COUNTER_EVENT_INTEL 0x94F0 +#define GL_PERFQUERY_COUNTER_DURATION_NORM_INTEL 0x94F1 +#define GL_PERFQUERY_COUNTER_DURATION_RAW_INTEL 0x94F2 +#define GL_PERFQUERY_COUNTER_THROUGHPUT_INTEL 0x94F3 +#define GL_PERFQUERY_COUNTER_RAW_INTEL 0x94F4 +#define GL_PERFQUERY_COUNTER_TIMESTAMP_INTEL 0x94F5 +#define GL_PERFQUERY_COUNTER_DATA_UINT32_INTEL 0x94F8 +#define GL_PERFQUERY_COUNTER_DATA_UINT64_INTEL 0x94F9 +#define GL_PERFQUERY_COUNTER_DATA_FLOAT_INTEL 0x94FA +#define GL_PERFQUERY_COUNTER_DATA_DOUBLE_INTEL 0x94FB +#define GL_PERFQUERY_COUNTER_DATA_BOOL32_INTEL 0x94FC +#define GL_PERFQUERY_QUERY_NAME_LENGTH_MAX_INTEL 0x94FD +#define GL_PERFQUERY_COUNTER_NAME_LENGTH_MAX_INTEL 0x94FE +#define GL_PERFQUERY_COUNTER_DESC_LENGTH_MAX_INTEL 0x94FF +#define GL_PERFQUERY_GPA_EXTENDED_COUNTERS_INTEL 0x9500 +typedef void (APIENTRYP PFNGLBEGINPERFQUERYINTELPROC) (GLuint queryHandle); +typedef void (APIENTRYP PFNGLCREATEPERFQUERYINTELPROC) (GLuint queryId, GLuint *queryHandle); +typedef void (APIENTRYP PFNGLDELETEPERFQUERYINTELPROC) (GLuint queryHandle); +typedef void (APIENTRYP PFNGLENDPERFQUERYINTELPROC) (GLuint queryHandle); +typedef void (APIENTRYP PFNGLGETFIRSTPERFQUERYIDINTELPROC) (GLuint *queryId); +typedef void (APIENTRYP PFNGLGETNEXTPERFQUERYIDINTELPROC) (GLuint queryId, GLuint *nextQueryId); +typedef void (APIENTRYP PFNGLGETPERFCOUNTERINFOINTELPROC) (GLuint queryId, GLuint counterId, GLuint counterNameLength, GLchar *counterName, GLuint counterDescLength, GLchar *counterDesc, GLuint *counterOffset, GLuint *counterDataSize, GLuint *counterTypeEnum, GLuint *counterDataTypeEnum, GLuint64 *rawCounterMaxValue); +typedef void (APIENTRYP PFNGLGETPERFQUERYDATAINTELPROC) (GLuint queryHandle, GLuint flags, GLsizei dataSize, GLvoid *data, GLuint *bytesWritten); +typedef void (APIENTRYP PFNGLGETPERFQUERYIDBYNAMEINTELPROC) (GLchar *queryName, GLuint *queryId); +typedef void (APIENTRYP PFNGLGETPERFQUERYINFOINTELPROC) (GLuint queryId, GLuint queryNameLength, GLchar *queryName, GLuint *dataSize, GLuint *noCounters, GLuint *noInstances, GLuint *capsMask); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginPerfQueryINTEL (GLuint queryHandle); +GLAPI void APIENTRY glCreatePerfQueryINTEL (GLuint queryId, GLuint *queryHandle); +GLAPI void APIENTRY glDeletePerfQueryINTEL (GLuint queryHandle); +GLAPI void APIENTRY glEndPerfQueryINTEL (GLuint queryHandle); +GLAPI void APIENTRY glGetFirstPerfQueryIdINTEL (GLuint *queryId); +GLAPI void APIENTRY glGetNextPerfQueryIdINTEL (GLuint queryId, GLuint *nextQueryId); +GLAPI void APIENTRY glGetPerfCounterInfoINTEL (GLuint queryId, GLuint counterId, GLuint counterNameLength, GLchar *counterName, GLuint counterDescLength, GLchar *counterDesc, GLuint *counterOffset, GLuint *counterDataSize, GLuint *counterTypeEnum, GLuint *counterDataTypeEnum, GLuint64 *rawCounterMaxValue); +GLAPI void APIENTRY glGetPerfQueryDataINTEL (GLuint queryHandle, GLuint flags, GLsizei dataSize, GLvoid *data, GLuint *bytesWritten); +GLAPI void APIENTRY glGetPerfQueryIdByNameINTEL (GLchar *queryName, GLuint *queryId); +GLAPI void APIENTRY glGetPerfQueryInfoINTEL (GLuint queryId, GLuint queryNameLength, GLchar *queryName, GLuint *dataSize, GLuint *noCounters, GLuint *noInstances, GLuint *capsMask); +#endif +#endif /* GL_INTEL_performance_query */ + +#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 +#endif /* GL_MESAX_texture_stack */ + +#ifndef GL_MESA_pack_invert +#define GL_MESA_pack_invert 1 +#define GL_PACK_INVERT_MESA 0x8758 +#endif /* GL_MESA_pack_invert */ + +#ifndef GL_MESA_resize_buffers +#define GL_MESA_resize_buffers 1 +typedef void (APIENTRYP PFNGLRESIZEBUFFERSMESAPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glResizeBuffersMESA (void); +#endif +#endif /* GL_MESA_resize_buffers */ + +#ifndef GL_MESA_window_pos +#define GL_MESA_window_pos 1 +typedef void (APIENTRYP PFNGLWINDOWPOS2DMESAPROC) (GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLWINDOWPOS2DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2FMESAPROC) (GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLWINDOWPOS2FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2IMESAPROC) (GLint x, GLint y); +typedef void (APIENTRYP PFNGLWINDOWPOS2IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS2SMESAPROC) (GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLWINDOWPOS2SVMESAPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3DMESAPROC) (GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLWINDOWPOS3DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3FMESAPROC) (GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLWINDOWPOS3FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3IMESAPROC) (GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLWINDOWPOS3IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS3SMESAPROC) (GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLWINDOWPOS3SVMESAPROC) (const GLshort *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4DMESAPROC) (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLWINDOWPOS4DVMESAPROC) (const GLdouble *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4FMESAPROC) (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLWINDOWPOS4FVMESAPROC) (const GLfloat *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4IMESAPROC) (GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLWINDOWPOS4IVMESAPROC) (const GLint *v); +typedef void (APIENTRYP PFNGLWINDOWPOS4SMESAPROC) (GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLWINDOWPOS4SVMESAPROC) (const GLshort *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glWindowPos2dMESA (GLdouble x, GLdouble y); +GLAPI void APIENTRY glWindowPos2dvMESA (const GLdouble *v); +GLAPI void APIENTRY glWindowPos2fMESA (GLfloat x, GLfloat y); +GLAPI void APIENTRY glWindowPos2fvMESA (const GLfloat *v); +GLAPI void APIENTRY glWindowPos2iMESA (GLint x, GLint y); +GLAPI void APIENTRY glWindowPos2ivMESA (const GLint *v); +GLAPI void APIENTRY glWindowPos2sMESA (GLshort x, GLshort y); +GLAPI void APIENTRY glWindowPos2svMESA (const GLshort *v); +GLAPI void APIENTRY glWindowPos3dMESA (GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glWindowPos3dvMESA (const GLdouble *v); +GLAPI void APIENTRY glWindowPos3fMESA (GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glWindowPos3fvMESA (const GLfloat *v); +GLAPI void APIENTRY glWindowPos3iMESA (GLint x, GLint y, GLint z); +GLAPI void APIENTRY glWindowPos3ivMESA (const GLint *v); +GLAPI void APIENTRY glWindowPos3sMESA (GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glWindowPos3svMESA (const GLshort *v); +GLAPI void APIENTRY glWindowPos4dMESA (GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glWindowPos4dvMESA (const GLdouble *v); +GLAPI void APIENTRY glWindowPos4fMESA (GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glWindowPos4fvMESA (const GLfloat *v); +GLAPI void APIENTRY glWindowPos4iMESA (GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glWindowPos4ivMESA (const GLint *v); +GLAPI void APIENTRY glWindowPos4sMESA (GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void APIENTRY glWindowPos4svMESA (const GLshort *v); +#endif +#endif /* GL_MESA_window_pos */ + +#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 +#endif /* GL_MESA_ycbcr_texture */ + +#ifndef GL_NVX_conditional_render +#define GL_NVX_conditional_render 1 +typedef void (APIENTRYP PFNGLBEGINCONDITIONALRENDERNVXPROC) (GLuint id); +typedef void (APIENTRYP PFNGLENDCONDITIONALRENDERNVXPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginConditionalRenderNVX (GLuint id); +GLAPI void APIENTRY glEndConditionalRenderNVX (void); +#endif +#endif /* GL_NVX_conditional_render */ + +#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 +#endif /* GL_NVX_gpu_memory_info */ + +#ifndef GL_NV_bindless_multi_draw_indirect +#define GL_NV_bindless_multi_draw_indirect 1 +typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTBINDLESSNVPROC) (GLenum mode, const void *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); +typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTBINDLESSNVPROC) (GLenum mode, GLenum type, const void *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMultiDrawArraysIndirectBindlessNV (GLenum mode, const void *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); +GLAPI void APIENTRY glMultiDrawElementsIndirectBindlessNV (GLenum mode, GLenum type, const void *indirect, GLsizei drawCount, GLsizei stride, GLint vertexBufferCount); +#endif +#endif /* GL_NV_bindless_multi_draw_indirect */ + +#ifndef GL_NV_bindless_texture +#define GL_NV_bindless_texture 1 +typedef GLuint64 (APIENTRYP PFNGLGETTEXTUREHANDLENVPROC) (GLuint texture); +typedef GLuint64 (APIENTRYP PFNGLGETTEXTURESAMPLERHANDLENVPROC) (GLuint texture, GLuint sampler); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLMAKETEXTUREHANDLENONRESIDENTNVPROC) (GLuint64 handle); +typedef GLuint64 (APIENTRYP PFNGLGETIMAGEHANDLENVPROC) (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle, GLenum access); +typedef void (APIENTRYP PFNGLMAKEIMAGEHANDLENONRESIDENTNVPROC) (GLuint64 handle); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64NVPROC) (GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLUNIFORMHANDLEUI64VNVPROC) (GLint location, GLsizei count, const GLuint64 *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64NVPROC) (GLuint program, GLint location, GLuint64 value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMHANDLEUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +typedef GLboolean (APIENTRYP PFNGLISTEXTUREHANDLERESIDENTNVPROC) (GLuint64 handle); +typedef GLboolean (APIENTRYP PFNGLISIMAGEHANDLERESIDENTNVPROC) (GLuint64 handle); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint64 APIENTRY glGetTextureHandleNV (GLuint texture); +GLAPI GLuint64 APIENTRY glGetTextureSamplerHandleNV (GLuint texture, GLuint sampler); +GLAPI void APIENTRY glMakeTextureHandleResidentNV (GLuint64 handle); +GLAPI void APIENTRY glMakeTextureHandleNonResidentNV (GLuint64 handle); +GLAPI GLuint64 APIENTRY glGetImageHandleNV (GLuint texture, GLint level, GLboolean layered, GLint layer, GLenum format); +GLAPI void APIENTRY glMakeImageHandleResidentNV (GLuint64 handle, GLenum access); +GLAPI void APIENTRY glMakeImageHandleNonResidentNV (GLuint64 handle); +GLAPI void APIENTRY glUniformHandleui64NV (GLint location, GLuint64 value); +GLAPI void APIENTRY glUniformHandleui64vNV (GLint location, GLsizei count, const GLuint64 *value); +GLAPI void APIENTRY glProgramUniformHandleui64NV (GLuint program, GLint location, GLuint64 value); +GLAPI void APIENTRY glProgramUniformHandleui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64 *values); +GLAPI GLboolean APIENTRY glIsTextureHandleResidentNV (GLuint64 handle); +GLAPI GLboolean APIENTRY glIsImageHandleResidentNV (GLuint64 handle); +#endif +#endif /* GL_NV_bindless_texture */ + +#ifndef GL_NV_blend_equation_advanced +#define GL_NV_blend_equation_advanced 1 +#define GL_BLEND_OVERLAP_NV 0x9281 +#define GL_BLEND_PREMULTIPLIED_SRC_NV 0x9280 +#define GL_BLUE_NV 0x1905 +#define GL_COLORBURN_NV 0x929A +#define GL_COLORDODGE_NV 0x9299 +#define GL_CONJOINT_NV 0x9284 +#define GL_CONTRAST_NV 0x92A1 +#define GL_DARKEN_NV 0x9297 +#define GL_DIFFERENCE_NV 0x929E +#define GL_DISJOINT_NV 0x9283 +#define GL_DST_ATOP_NV 0x928F +#define GL_DST_IN_NV 0x928B +#define GL_DST_NV 0x9287 +#define GL_DST_OUT_NV 0x928D +#define GL_DST_OVER_NV 0x9289 +#define GL_EXCLUSION_NV 0x92A0 +#define GL_GREEN_NV 0x1904 +#define GL_HARDLIGHT_NV 0x929B +#define GL_HARDMIX_NV 0x92A9 +#define GL_HSL_COLOR_NV 0x92AF +#define GL_HSL_HUE_NV 0x92AD +#define GL_HSL_LUMINOSITY_NV 0x92B0 +#define GL_HSL_SATURATION_NV 0x92AE +#define GL_INVERT_OVG_NV 0x92B4 +#define GL_INVERT_RGB_NV 0x92A3 +#define GL_LIGHTEN_NV 0x9298 +#define GL_LINEARBURN_NV 0x92A5 +#define GL_LINEARDODGE_NV 0x92A4 +#define GL_LINEARLIGHT_NV 0x92A7 +#define GL_MINUS_CLAMPED_NV 0x92B3 +#define GL_MINUS_NV 0x929F +#define GL_MULTIPLY_NV 0x9294 +#define GL_OVERLAY_NV 0x9296 +#define GL_PINLIGHT_NV 0x92A8 +#define GL_PLUS_CLAMPED_ALPHA_NV 0x92B2 +#define GL_PLUS_CLAMPED_NV 0x92B1 +#define GL_PLUS_DARKER_NV 0x9292 +#define GL_PLUS_NV 0x9291 +#define GL_RED_NV 0x1903 +#define GL_SCREEN_NV 0x9295 +#define GL_SOFTLIGHT_NV 0x929C +#define GL_SRC_ATOP_NV 0x928E +#define GL_SRC_IN_NV 0x928A +#define GL_SRC_NV 0x9286 +#define GL_SRC_OUT_NV 0x928C +#define GL_SRC_OVER_NV 0x9288 +#define GL_UNCORRELATED_NV 0x9282 +#define GL_VIVIDLIGHT_NV 0x92A6 +#define GL_XOR_NV 0x1506 +typedef void (APIENTRYP PFNGLBLENDPARAMETERINVPROC) (GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLBLENDBARRIERNVPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBlendParameteriNV (GLenum pname, GLint value); +GLAPI void APIENTRY glBlendBarrierNV (void); +#endif +#endif /* GL_NV_blend_equation_advanced */ + +#ifndef GL_NV_blend_equation_advanced_coherent +#define GL_NV_blend_equation_advanced_coherent 1 +#define GL_BLEND_ADVANCED_COHERENT_NV 0x9285 +#endif /* GL_NV_blend_equation_advanced_coherent */ + +#ifndef GL_NV_blend_square +#define GL_NV_blend_square 1 +#endif /* GL_NV_blend_square */ + +#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 +#endif /* GL_NV_compute_program5 */ + +#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 (APIENTRYP PFNGLBEGINCONDITIONALRENDERNVPROC) (GLuint id, GLenum mode); +typedef void (APIENTRYP PFNGLENDCONDITIONALRENDERNVPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginConditionalRenderNV (GLuint id, GLenum mode); +GLAPI void APIENTRY glEndConditionalRenderNV (void); +#endif +#endif /* GL_NV_conditional_render */ + +#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 +#endif /* GL_NV_copy_depth_to_color */ + +#ifndef GL_NV_copy_image +#define GL_NV_copy_image 1 +typedef void (APIENTRYP 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); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCopyImageSubDataNV (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); +#endif +#endif /* GL_NV_copy_image */ + +#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 +#endif /* GL_NV_deep_texture3D */ + +#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 (APIENTRYP PFNGLDEPTHRANGEDNVPROC) (GLdouble zNear, GLdouble zFar); +typedef void (APIENTRYP PFNGLCLEARDEPTHDNVPROC) (GLdouble depth); +typedef void (APIENTRYP PFNGLDEPTHBOUNDSDNVPROC) (GLdouble zmin, GLdouble zmax); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDepthRangedNV (GLdouble zNear, GLdouble zFar); +GLAPI void APIENTRY glClearDepthdNV (GLdouble depth); +GLAPI void APIENTRY glDepthBoundsdNV (GLdouble zmin, GLdouble zmax); +#endif +#endif /* GL_NV_depth_buffer_float */ + +#ifndef GL_NV_depth_clamp +#define GL_NV_depth_clamp 1 +#define GL_DEPTH_CLAMP_NV 0x864F +#endif /* GL_NV_depth_clamp */ + +#ifndef GL_NV_draw_texture +#define GL_NV_draw_texture 1 +typedef void (APIENTRYP PFNGLDRAWTEXTURENVPROC) (GLuint texture, GLuint sampler, GLfloat x0, GLfloat y0, GLfloat x1, GLfloat y1, GLfloat z, GLfloat s0, GLfloat t0, GLfloat s1, GLfloat t1); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawTextureNV (GLuint texture, GLuint sampler, GLfloat x0, GLfloat y0, GLfloat x1, GLfloat y1, GLfloat z, GLfloat s0, GLfloat t0, GLfloat s1, GLfloat t1); +#endif +#endif /* GL_NV_draw_texture */ + +#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 (APIENTRYP PFNGLMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const void *points); +typedef void (APIENTRYP PFNGLMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETMAPCONTROLPOINTSNVPROC) (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, void *points); +typedef void (APIENTRYP PFNGLGETMAPPARAMETERIVNVPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMAPPARAMETERFVNVPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETMAPATTRIBPARAMETERIVNVPROC) (GLenum target, GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETMAPATTRIBPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLEVALMAPSNVPROC) (GLenum target, GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMapControlPointsNV (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLint uorder, GLint vorder, GLboolean packed, const void *points); +GLAPI void APIENTRY glMapParameterivNV (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glMapParameterfvNV (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glGetMapControlPointsNV (GLenum target, GLuint index, GLenum type, GLsizei ustride, GLsizei vstride, GLboolean packed, void *points); +GLAPI void APIENTRY glGetMapParameterivNV (GLenum target, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMapParameterfvNV (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetMapAttribParameterivNV (GLenum target, GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetMapAttribParameterfvNV (GLenum target, GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glEvalMapsNV (GLenum target, GLenum mode); +#endif +#endif /* GL_NV_evaluators */ + +#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 (APIENTRYP PFNGLGETMULTISAMPLEFVNVPROC) (GLenum pname, GLuint index, GLfloat *val); +typedef void (APIENTRYP PFNGLSAMPLEMASKINDEXEDNVPROC) (GLuint index, GLbitfield mask); +typedef void (APIENTRYP PFNGLTEXRENDERBUFFERNVPROC) (GLenum target, GLuint renderbuffer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetMultisamplefvNV (GLenum pname, GLuint index, GLfloat *val); +GLAPI void APIENTRY glSampleMaskIndexedNV (GLuint index, GLbitfield mask); +GLAPI void APIENTRY glTexRenderbufferNV (GLenum target, GLuint renderbuffer); +#endif +#endif /* GL_NV_explicit_multisample */ + +#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 (APIENTRYP PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint *fences); +typedef void (APIENTRYP PFNGLGENFENCESNVPROC) (GLsizei n, GLuint *fences); +typedef GLboolean (APIENTRYP PFNGLISFENCENVPROC) (GLuint fence); +typedef GLboolean (APIENTRYP PFNGLTESTFENCENVPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLFINISHFENCENVPROC) (GLuint fence); +typedef void (APIENTRYP PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeleteFencesNV (GLsizei n, const GLuint *fences); +GLAPI void APIENTRY glGenFencesNV (GLsizei n, GLuint *fences); +GLAPI GLboolean APIENTRY glIsFenceNV (GLuint fence); +GLAPI GLboolean APIENTRY glTestFenceNV (GLuint fence); +GLAPI void APIENTRY glGetFenceivNV (GLuint fence, GLenum pname, GLint *params); +GLAPI void APIENTRY glFinishFenceNV (GLuint fence); +GLAPI void APIENTRY glSetFenceNV (GLuint fence, GLenum condition); +#endif +#endif /* GL_NV_fence */ + +#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 +#endif /* GL_NV_float_buffer */ + +#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 +#endif /* GL_NV_fog_distance */ + +#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 (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4FNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4FVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, const GLfloat *v); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4DNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMNAMEDPARAMETER4DVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, const GLdouble *v); +typedef void (APIENTRYP PFNGLGETPROGRAMNAMEDPARAMETERFVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMNAMEDPARAMETERDVNVPROC) (GLuint id, GLsizei len, const GLubyte *name, GLdouble *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramNamedParameter4fNV (GLuint id, GLsizei len, const GLubyte *name, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glProgramNamedParameter4fvNV (GLuint id, GLsizei len, const GLubyte *name, const GLfloat *v); +GLAPI void APIENTRY glProgramNamedParameter4dNV (GLuint id, GLsizei len, const GLubyte *name, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glProgramNamedParameter4dvNV (GLuint id, GLsizei len, const GLubyte *name, const GLdouble *v); +GLAPI void APIENTRY glGetProgramNamedParameterfvNV (GLuint id, GLsizei len, const GLubyte *name, GLfloat *params); +GLAPI void APIENTRY glGetProgramNamedParameterdvNV (GLuint id, GLsizei len, const GLubyte *name, GLdouble *params); +#endif +#endif /* GL_NV_fragment_program */ + +#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 +#endif /* GL_NV_fragment_program2 */ + +#ifndef GL_NV_fragment_program4 +#define GL_NV_fragment_program4 1 +#endif /* GL_NV_fragment_program4 */ + +#ifndef GL_NV_fragment_program_option +#define GL_NV_fragment_program_option 1 +#endif /* GL_NV_fragment_program_option */ + +#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 (APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glRenderbufferStorageMultisampleCoverageNV (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLenum internalformat, GLsizei width, GLsizei height); +#endif +#endif /* GL_NV_framebuffer_multisample_coverage */ + +#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 (APIENTRYP PFNGLPROGRAMVERTEXLIMITNVPROC) (GLenum target, GLint limit); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTURELAYEREXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +typedef void (APIENTRYP PFNGLFRAMEBUFFERTEXTUREFACEEXTPROC) (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramVertexLimitNV (GLenum target, GLint limit); +GLAPI void APIENTRY glFramebufferTextureEXT (GLenum target, GLenum attachment, GLuint texture, GLint level); +GLAPI void APIENTRY glFramebufferTextureLayerEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer); +GLAPI void APIENTRY glFramebufferTextureFaceEXT (GLenum target, GLenum attachment, GLuint texture, GLint level, GLenum face); +#endif +#endif /* GL_NV_geometry_program4 */ + +#ifndef GL_NV_geometry_shader4 +#define GL_NV_geometry_shader4 1 +#endif /* GL_NV_geometry_shader4 */ + +#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 (APIENTRYP PFNGLPROGRAMLOCALPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); +typedef void (APIENTRYP PFNGLPROGRAMLOCALPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERI4INVPROC) (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERI4IVNVPROC) (GLenum target, GLuint index, const GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERSI4IVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERI4UINVPROC) (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERI4UIVNVPROC) (GLenum target, GLuint index, const GLuint *params); +typedef void (APIENTRYP PFNGLPROGRAMENVPARAMETERSI4UIVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLuint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERIIVNVPROC) (GLenum target, GLuint index, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMLOCALPARAMETERIUIVNVPROC) (GLenum target, GLuint index, GLuint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERIIVNVPROC) (GLenum target, GLuint index, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMENVPARAMETERIUIVNVPROC) (GLenum target, GLuint index, GLuint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramLocalParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glProgramLocalParameterI4ivNV (GLenum target, GLuint index, const GLint *params); +GLAPI void APIENTRY glProgramLocalParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params); +GLAPI void APIENTRY glProgramLocalParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI void APIENTRY glProgramLocalParameterI4uivNV (GLenum target, GLuint index, const GLuint *params); +GLAPI void APIENTRY glProgramLocalParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params); +GLAPI void APIENTRY glProgramEnvParameterI4iNV (GLenum target, GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glProgramEnvParameterI4ivNV (GLenum target, GLuint index, const GLint *params); +GLAPI void APIENTRY glProgramEnvParametersI4ivNV (GLenum target, GLuint index, GLsizei count, const GLint *params); +GLAPI void APIENTRY glProgramEnvParameterI4uiNV (GLenum target, GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI void APIENTRY glProgramEnvParameterI4uivNV (GLenum target, GLuint index, const GLuint *params); +GLAPI void APIENTRY glProgramEnvParametersI4uivNV (GLenum target, GLuint index, GLsizei count, const GLuint *params); +GLAPI void APIENTRY glGetProgramLocalParameterIivNV (GLenum target, GLuint index, GLint *params); +GLAPI void APIENTRY glGetProgramLocalParameterIuivNV (GLenum target, GLuint index, GLuint *params); +GLAPI void APIENTRY glGetProgramEnvParameterIivNV (GLenum target, GLuint index, GLint *params); +GLAPI void APIENTRY glGetProgramEnvParameterIuivNV (GLenum target, GLuint index, GLuint *params); +#endif +#endif /* GL_NV_gpu_program4 */ + +#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 GL_MAX_PROGRAM_SUBROUTINE_PARAMETERS_NV 0x8F44 +#define GL_MAX_PROGRAM_SUBROUTINE_NUM_NV 0x8F45 +typedef void (APIENTRYP PFNGLPROGRAMSUBROUTINEPARAMETERSUIVNVPROC) (GLenum target, GLsizei count, const GLuint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSUBROUTINEPARAMETERUIVNVPROC) (GLenum target, GLuint index, GLuint *param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramSubroutineParametersuivNV (GLenum target, GLsizei count, const GLuint *params); +GLAPI void APIENTRY glGetProgramSubroutineParameteruivNV (GLenum target, GLuint index, GLuint *param); +#endif +#endif /* GL_NV_gpu_program5 */ + +#ifndef GL_NV_gpu_program5_mem_extended +#define GL_NV_gpu_program5_mem_extended 1 +#endif /* GL_NV_gpu_program5_mem_extended */ + +#ifndef GL_NV_gpu_shader5 +#define GL_NV_gpu_shader5 1 +#endif /* GL_NV_gpu_shader5 */ + +#ifndef GL_NV_half_float +#define GL_NV_half_float 1 +typedef unsigned short GLhalfNV; +#define GL_HALF_FLOAT_NV 0x140B +typedef void (APIENTRYP PFNGLVERTEX2HNVPROC) (GLhalfNV x, GLhalfNV y); +typedef void (APIENTRYP PFNGLVERTEX2HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEX3HNVPROC) (GLhalfNV x, GLhalfNV y, GLhalfNV z); +typedef void (APIENTRYP PFNGLVERTEX3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEX4HNVPROC) (GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +typedef void (APIENTRYP PFNGLVERTEX4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLNORMAL3HNVPROC) (GLhalfNV nx, GLhalfNV ny, GLhalfNV nz); +typedef void (APIENTRYP PFNGLNORMAL3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLCOLOR3HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +typedef void (APIENTRYP PFNGLCOLOR3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLCOLOR4HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue, GLhalfNV alpha); +typedef void (APIENTRYP PFNGLCOLOR4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD1HNVPROC) (GLhalfNV s); +typedef void (APIENTRYP PFNGLTEXCOORD1HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD2HNVPROC) (GLhalfNV s, GLhalfNV t); +typedef void (APIENTRYP PFNGLTEXCOORD2HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD3HNVPROC) (GLhalfNV s, GLhalfNV t, GLhalfNV r); +typedef void (APIENTRYP PFNGLTEXCOORD3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLTEXCOORD4HNVPROC) (GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +typedef void (APIENTRYP PFNGLTEXCOORD4HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1HNVPROC) (GLenum target, GLhalfNV s); +typedef void (APIENTRYP PFNGLMULTITEXCOORD1HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t); +typedef void (APIENTRYP PFNGLMULTITEXCOORD2HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r); +typedef void (APIENTRYP PFNGLMULTITEXCOORD3HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4HNVPROC) (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +typedef void (APIENTRYP PFNGLMULTITEXCOORD4HVNVPROC) (GLenum target, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLFOGCOORDHNVPROC) (GLhalfNV fog); +typedef void (APIENTRYP PFNGLFOGCOORDHVNVPROC) (const GLhalfNV *fog); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3HNVPROC) (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +typedef void (APIENTRYP PFNGLSECONDARYCOLOR3HVNVPROC) (const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTHNVPROC) (GLhalfNV weight); +typedef void (APIENTRYP PFNGLVERTEXWEIGHTHVNVPROC) (const GLhalfNV *weight); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1HNVPROC) (GLuint index, GLhalfNV x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4HNVPROC) (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4HVNVPROC) (GLuint index, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4HVNVPROC) (GLuint index, GLsizei n, const GLhalfNV *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertex2hNV (GLhalfNV x, GLhalfNV y); +GLAPI void APIENTRY glVertex2hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glVertex3hNV (GLhalfNV x, GLhalfNV y, GLhalfNV z); +GLAPI void APIENTRY glVertex3hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glVertex4hNV (GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +GLAPI void APIENTRY glVertex4hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glNormal3hNV (GLhalfNV nx, GLhalfNV ny, GLhalfNV nz); +GLAPI void APIENTRY glNormal3hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glColor3hNV (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +GLAPI void APIENTRY glColor3hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glColor4hNV (GLhalfNV red, GLhalfNV green, GLhalfNV blue, GLhalfNV alpha); +GLAPI void APIENTRY glColor4hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glTexCoord1hNV (GLhalfNV s); +GLAPI void APIENTRY glTexCoord1hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glTexCoord2hNV (GLhalfNV s, GLhalfNV t); +GLAPI void APIENTRY glTexCoord2hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glTexCoord3hNV (GLhalfNV s, GLhalfNV t, GLhalfNV r); +GLAPI void APIENTRY glTexCoord3hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glTexCoord4hNV (GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +GLAPI void APIENTRY glTexCoord4hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glMultiTexCoord1hNV (GLenum target, GLhalfNV s); +GLAPI void APIENTRY glMultiTexCoord1hvNV (GLenum target, const GLhalfNV *v); +GLAPI void APIENTRY glMultiTexCoord2hNV (GLenum target, GLhalfNV s, GLhalfNV t); +GLAPI void APIENTRY glMultiTexCoord2hvNV (GLenum target, const GLhalfNV *v); +GLAPI void APIENTRY glMultiTexCoord3hNV (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r); +GLAPI void APIENTRY glMultiTexCoord3hvNV (GLenum target, const GLhalfNV *v); +GLAPI void APIENTRY glMultiTexCoord4hNV (GLenum target, GLhalfNV s, GLhalfNV t, GLhalfNV r, GLhalfNV q); +GLAPI void APIENTRY glMultiTexCoord4hvNV (GLenum target, const GLhalfNV *v); +GLAPI void APIENTRY glFogCoordhNV (GLhalfNV fog); +GLAPI void APIENTRY glFogCoordhvNV (const GLhalfNV *fog); +GLAPI void APIENTRY glSecondaryColor3hNV (GLhalfNV red, GLhalfNV green, GLhalfNV blue); +GLAPI void APIENTRY glSecondaryColor3hvNV (const GLhalfNV *v); +GLAPI void APIENTRY glVertexWeighthNV (GLhalfNV weight); +GLAPI void APIENTRY glVertexWeighthvNV (const GLhalfNV *weight); +GLAPI void APIENTRY glVertexAttrib1hNV (GLuint index, GLhalfNV x); +GLAPI void APIENTRY glVertexAttrib1hvNV (GLuint index, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttrib2hNV (GLuint index, GLhalfNV x, GLhalfNV y); +GLAPI void APIENTRY glVertexAttrib2hvNV (GLuint index, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttrib3hNV (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z); +GLAPI void APIENTRY glVertexAttrib3hvNV (GLuint index, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttrib4hNV (GLuint index, GLhalfNV x, GLhalfNV y, GLhalfNV z, GLhalfNV w); +GLAPI void APIENTRY glVertexAttrib4hvNV (GLuint index, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttribs1hvNV (GLuint index, GLsizei n, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttribs2hvNV (GLuint index, GLsizei n, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttribs3hvNV (GLuint index, GLsizei n, const GLhalfNV *v); +GLAPI void APIENTRY glVertexAttribs4hvNV (GLuint index, GLsizei n, const GLhalfNV *v); +#endif +#endif /* GL_NV_half_float */ + +#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 +#endif /* GL_NV_light_max_exponent */ + +#ifndef GL_NV_multisample_coverage +#define GL_NV_multisample_coverage 1 +#define GL_COLOR_SAMPLES_NV 0x8E20 +#endif /* GL_NV_multisample_coverage */ + +#ifndef GL_NV_multisample_filter_hint +#define GL_NV_multisample_filter_hint 1 +#define GL_MULTISAMPLE_FILTER_HINT_NV 0x8534 +#endif /* GL_NV_multisample_filter_hint */ + +#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 (APIENTRYP PFNGLGENOCCLUSIONQUERIESNVPROC) (GLsizei n, GLuint *ids); +typedef void (APIENTRYP PFNGLDELETEOCCLUSIONQUERIESNVPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISOCCLUSIONQUERYNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLBEGINOCCLUSIONQUERYNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLENDOCCLUSIONQUERYNVPROC) (void); +typedef void (APIENTRYP PFNGLGETOCCLUSIONQUERYIVNVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETOCCLUSIONQUERYUIVNVPROC) (GLuint id, GLenum pname, GLuint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGenOcclusionQueriesNV (GLsizei n, GLuint *ids); +GLAPI void APIENTRY glDeleteOcclusionQueriesNV (GLsizei n, const GLuint *ids); +GLAPI GLboolean APIENTRY glIsOcclusionQueryNV (GLuint id); +GLAPI void APIENTRY glBeginOcclusionQueryNV (GLuint id); +GLAPI void APIENTRY glEndOcclusionQueryNV (void); +GLAPI void APIENTRY glGetOcclusionQueryivNV (GLuint id, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetOcclusionQueryuivNV (GLuint id, GLenum pname, GLuint *params); +#endif +#endif /* GL_NV_occlusion_query */ + +#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 +#endif /* GL_NV_packed_depth_stencil */ + +#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 (APIENTRYP PFNGLPROGRAMBUFFERPARAMETERSFVNVPROC) (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLfloat *params); +typedef void (APIENTRYP PFNGLPROGRAMBUFFERPARAMETERSIIVNVPROC) (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLint *params); +typedef void (APIENTRYP PFNGLPROGRAMBUFFERPARAMETERSIUIVNVPROC) (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLuint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glProgramBufferParametersfvNV (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLfloat *params); +GLAPI void APIENTRY glProgramBufferParametersIivNV (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLint *params); +GLAPI void APIENTRY glProgramBufferParametersIuivNV (GLenum target, GLuint bindingIndex, GLuint wordIndex, GLsizei count, const GLuint *params); +#endif +#endif /* GL_NV_parameter_buffer_object */ + +#ifndef GL_NV_parameter_buffer_object2 +#define GL_NV_parameter_buffer_object2 1 +#endif /* GL_NV_parameter_buffer_object2 */ + +#ifndef GL_NV_path_rendering +#define GL_NV_path_rendering 1 +#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_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_PATH_DASH_OFFSET_RESET_NV 0x90B4 +#define GL_MOVE_TO_RESETS_NV 0x90B5 +#define GL_MOVE_TO_CONTINUES_NV 0x90B6 +#define GL_CLOSE_PATH_NV 0x00 +#define GL_MOVE_TO_NV 0x02 +#define GL_RELATIVE_MOVE_TO_NV 0x03 +#define GL_LINE_TO_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_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_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_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_BOLD_BIT_NV 0x01 +#define GL_ITALIC_BIT_NV 0x02 +#define GL_GLYPH_WIDTH_BIT_NV 0x01 +#define GL_GLYPH_HEIGHT_BIT_NV 0x02 +#define GL_GLYPH_HORIZONTAL_BEARING_X_BIT_NV 0x04 +#define GL_GLYPH_HORIZONTAL_BEARING_Y_BIT_NV 0x08 +#define GL_GLYPH_HORIZONTAL_BEARING_ADVANCE_BIT_NV 0x10 +#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_GLYPH_HAS_KERNING_BIT_NV 0x100 +#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 +#define GL_PRIMARY_COLOR_NV 0x852C +#define GL_SECONDARY_COLOR_NV 0x852D +typedef GLuint (APIENTRYP PFNGLGENPATHSNVPROC) (GLsizei range); +typedef void (APIENTRYP PFNGLDELETEPATHSNVPROC) (GLuint path, GLsizei range); +typedef GLboolean (APIENTRYP PFNGLISPATHNVPROC) (GLuint path); +typedef void (APIENTRYP PFNGLPATHCOMMANDSNVPROC) (GLuint path, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const void *coords); +typedef void (APIENTRYP PFNGLPATHCOORDSNVPROC) (GLuint path, GLsizei numCoords, GLenum coordType, const void *coords); +typedef void (APIENTRYP PFNGLPATHSUBCOMMANDSNVPROC) (GLuint path, GLsizei commandStart, GLsizei commandsToDelete, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const void *coords); +typedef void (APIENTRYP PFNGLPATHSUBCOORDSNVPROC) (GLuint path, GLsizei coordStart, GLsizei numCoords, GLenum coordType, const void *coords); +typedef void (APIENTRYP PFNGLPATHSTRINGNVPROC) (GLuint path, GLenum format, GLsizei length, const void *pathString); +typedef void (APIENTRYP PFNGLPATHGLYPHSNVPROC) (GLuint firstPathName, GLenum fontTarget, const void *fontName, GLbitfield fontStyle, GLsizei numGlyphs, GLenum type, const void *charcodes, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +typedef void (APIENTRYP PFNGLPATHGLYPHRANGENVPROC) (GLuint firstPathName, GLenum fontTarget, const void *fontName, GLbitfield fontStyle, GLuint firstGlyph, GLsizei numGlyphs, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +typedef void (APIENTRYP PFNGLWEIGHTPATHSNVPROC) (GLuint resultPath, GLsizei numPaths, const GLuint *paths, const GLfloat *weights); +typedef void (APIENTRYP PFNGLCOPYPATHNVPROC) (GLuint resultPath, GLuint srcPath); +typedef void (APIENTRYP PFNGLINTERPOLATEPATHSNVPROC) (GLuint resultPath, GLuint pathA, GLuint pathB, GLfloat weight); +typedef void (APIENTRYP PFNGLTRANSFORMPATHNVPROC) (GLuint resultPath, GLuint srcPath, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLPATHPARAMETERIVNVPROC) (GLuint path, GLenum pname, const GLint *value); +typedef void (APIENTRYP PFNGLPATHPARAMETERINVPROC) (GLuint path, GLenum pname, GLint value); +typedef void (APIENTRYP PFNGLPATHPARAMETERFVNVPROC) (GLuint path, GLenum pname, const GLfloat *value); +typedef void (APIENTRYP PFNGLPATHPARAMETERFNVPROC) (GLuint path, GLenum pname, GLfloat value); +typedef void (APIENTRYP PFNGLPATHDASHARRAYNVPROC) (GLuint path, GLsizei dashCount, const GLfloat *dashArray); +typedef void (APIENTRYP PFNGLPATHSTENCILFUNCNVPROC) (GLenum func, GLint ref, GLuint mask); +typedef void (APIENTRYP PFNGLPATHSTENCILDEPTHOFFSETNVPROC) (GLfloat factor, GLfloat units); +typedef void (APIENTRYP PFNGLSTENCILFILLPATHNVPROC) (GLuint path, GLenum fillMode, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILSTROKEPATHNVPROC) (GLuint path, GLint reference, GLuint mask); +typedef void (APIENTRYP PFNGLSTENCILFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum fillMode, GLuint mask, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLSTENCILSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLint reference, GLuint mask, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLPATHCOVERDEPTHFUNCNVPROC) (GLenum func); +typedef void (APIENTRYP PFNGLPATHCOLORGENNVPROC) (GLenum color, GLenum genMode, GLenum colorFormat, const GLfloat *coeffs); +typedef void (APIENTRYP PFNGLPATHTEXGENNVPROC) (GLenum texCoordSet, GLenum genMode, GLint components, const GLfloat *coeffs); +typedef void (APIENTRYP PFNGLPATHFOGGENNVPROC) (GLenum genMode); +typedef void (APIENTRYP PFNGLCOVERFILLPATHNVPROC) (GLuint path, GLenum coverMode); +typedef void (APIENTRYP PFNGLCOVERSTROKEPATHNVPROC) (GLuint path, GLenum coverMode); +typedef void (APIENTRYP PFNGLCOVERFILLPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLCOVERSTROKEPATHINSTANCEDNVPROC) (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +typedef void (APIENTRYP PFNGLGETPATHPARAMETERIVNVPROC) (GLuint path, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHPARAMETERFVNVPROC) (GLuint path, GLenum pname, GLfloat *value); +typedef void (APIENTRYP PFNGLGETPATHCOMMANDSNVPROC) (GLuint path, GLubyte *commands); +typedef void (APIENTRYP PFNGLGETPATHCOORDSNVPROC) (GLuint path, GLfloat *coords); +typedef void (APIENTRYP PFNGLGETPATHDASHARRAYNVPROC) (GLuint path, GLfloat *dashArray); +typedef void (APIENTRYP PFNGLGETPATHMETRICSNVPROC) (GLbitfield metricQueryMask, GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLsizei stride, GLfloat *metrics); +typedef void (APIENTRYP PFNGLGETPATHMETRICRANGENVPROC) (GLbitfield metricQueryMask, GLuint firstPathName, GLsizei numPaths, GLsizei stride, GLfloat *metrics); +typedef void (APIENTRYP PFNGLGETPATHSPACINGNVPROC) (GLenum pathListMode, GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLfloat advanceScale, GLfloat kerningScale, GLenum transformType, GLfloat *returnedSpacing); +typedef void (APIENTRYP PFNGLGETPATHCOLORGENIVNVPROC) (GLenum color, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHCOLORGENFVNVPROC) (GLenum color, GLenum pname, GLfloat *value); +typedef void (APIENTRYP PFNGLGETPATHTEXGENIVNVPROC) (GLenum texCoordSet, GLenum pname, GLint *value); +typedef void (APIENTRYP PFNGLGETPATHTEXGENFVNVPROC) (GLenum texCoordSet, GLenum pname, GLfloat *value); +typedef GLboolean (APIENTRYP PFNGLISPOINTINFILLPATHNVPROC) (GLuint path, GLuint mask, GLfloat x, GLfloat y); +typedef GLboolean (APIENTRYP PFNGLISPOINTINSTROKEPATHNVPROC) (GLuint path, GLfloat x, GLfloat y); +typedef GLfloat (APIENTRYP PFNGLGETPATHLENGTHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments); +typedef GLboolean (APIENTRYP PFNGLPOINTALONGPATHNVPROC) (GLuint path, GLsizei startSegment, GLsizei numSegments, GLfloat distance, GLfloat *x, GLfloat *y, GLfloat *tangentX, GLfloat *tangentY); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLuint APIENTRY glGenPathsNV (GLsizei range); +GLAPI void APIENTRY glDeletePathsNV (GLuint path, GLsizei range); +GLAPI GLboolean APIENTRY glIsPathNV (GLuint path); +GLAPI void APIENTRY glPathCommandsNV (GLuint path, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const void *coords); +GLAPI void APIENTRY glPathCoordsNV (GLuint path, GLsizei numCoords, GLenum coordType, const void *coords); +GLAPI void APIENTRY glPathSubCommandsNV (GLuint path, GLsizei commandStart, GLsizei commandsToDelete, GLsizei numCommands, const GLubyte *commands, GLsizei numCoords, GLenum coordType, const void *coords); +GLAPI void APIENTRY glPathSubCoordsNV (GLuint path, GLsizei coordStart, GLsizei numCoords, GLenum coordType, const void *coords); +GLAPI void APIENTRY glPathStringNV (GLuint path, GLenum format, GLsizei length, const void *pathString); +GLAPI void APIENTRY glPathGlyphsNV (GLuint firstPathName, GLenum fontTarget, const void *fontName, GLbitfield fontStyle, GLsizei numGlyphs, GLenum type, const void *charcodes, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +GLAPI void APIENTRY glPathGlyphRangeNV (GLuint firstPathName, GLenum fontTarget, const void *fontName, GLbitfield fontStyle, GLuint firstGlyph, GLsizei numGlyphs, GLenum handleMissingGlyphs, GLuint pathParameterTemplate, GLfloat emScale); +GLAPI void APIENTRY glWeightPathsNV (GLuint resultPath, GLsizei numPaths, const GLuint *paths, const GLfloat *weights); +GLAPI void APIENTRY glCopyPathNV (GLuint resultPath, GLuint srcPath); +GLAPI void APIENTRY glInterpolatePathsNV (GLuint resultPath, GLuint pathA, GLuint pathB, GLfloat weight); +GLAPI void APIENTRY glTransformPathNV (GLuint resultPath, GLuint srcPath, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glPathParameterivNV (GLuint path, GLenum pname, const GLint *value); +GLAPI void APIENTRY glPathParameteriNV (GLuint path, GLenum pname, GLint value); +GLAPI void APIENTRY glPathParameterfvNV (GLuint path, GLenum pname, const GLfloat *value); +GLAPI void APIENTRY glPathParameterfNV (GLuint path, GLenum pname, GLfloat value); +GLAPI void APIENTRY glPathDashArrayNV (GLuint path, GLsizei dashCount, const GLfloat *dashArray); +GLAPI void APIENTRY glPathStencilFuncNV (GLenum func, GLint ref, GLuint mask); +GLAPI void APIENTRY glPathStencilDepthOffsetNV (GLfloat factor, GLfloat units); +GLAPI void APIENTRY glStencilFillPathNV (GLuint path, GLenum fillMode, GLuint mask); +GLAPI void APIENTRY glStencilStrokePathNV (GLuint path, GLint reference, GLuint mask); +GLAPI void APIENTRY glStencilFillPathInstancedNV (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum fillMode, GLuint mask, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glStencilStrokePathInstancedNV (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLint reference, GLuint mask, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glPathCoverDepthFuncNV (GLenum func); +GLAPI void APIENTRY glPathColorGenNV (GLenum color, GLenum genMode, GLenum colorFormat, const GLfloat *coeffs); +GLAPI void APIENTRY glPathTexGenNV (GLenum texCoordSet, GLenum genMode, GLint components, const GLfloat *coeffs); +GLAPI void APIENTRY glPathFogGenNV (GLenum genMode); +GLAPI void APIENTRY glCoverFillPathNV (GLuint path, GLenum coverMode); +GLAPI void APIENTRY glCoverStrokePathNV (GLuint path, GLenum coverMode); +GLAPI void APIENTRY glCoverFillPathInstancedNV (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glCoverStrokePathInstancedNV (GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLenum coverMode, GLenum transformType, const GLfloat *transformValues); +GLAPI void APIENTRY glGetPathParameterivNV (GLuint path, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathParameterfvNV (GLuint path, GLenum pname, GLfloat *value); +GLAPI void APIENTRY glGetPathCommandsNV (GLuint path, GLubyte *commands); +GLAPI void APIENTRY glGetPathCoordsNV (GLuint path, GLfloat *coords); +GLAPI void APIENTRY glGetPathDashArrayNV (GLuint path, GLfloat *dashArray); +GLAPI void APIENTRY glGetPathMetricsNV (GLbitfield metricQueryMask, GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLsizei stride, GLfloat *metrics); +GLAPI void APIENTRY glGetPathMetricRangeNV (GLbitfield metricQueryMask, GLuint firstPathName, GLsizei numPaths, GLsizei stride, GLfloat *metrics); +GLAPI void APIENTRY glGetPathSpacingNV (GLenum pathListMode, GLsizei numPaths, GLenum pathNameType, const void *paths, GLuint pathBase, GLfloat advanceScale, GLfloat kerningScale, GLenum transformType, GLfloat *returnedSpacing); +GLAPI void APIENTRY glGetPathColorGenivNV (GLenum color, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathColorGenfvNV (GLenum color, GLenum pname, GLfloat *value); +GLAPI void APIENTRY glGetPathTexGenivNV (GLenum texCoordSet, GLenum pname, GLint *value); +GLAPI void APIENTRY glGetPathTexGenfvNV (GLenum texCoordSet, GLenum pname, GLfloat *value); +GLAPI GLboolean APIENTRY glIsPointInFillPathNV (GLuint path, GLuint mask, GLfloat x, GLfloat y); +GLAPI GLboolean APIENTRY glIsPointInStrokePathNV (GLuint path, GLfloat x, GLfloat y); +GLAPI GLfloat APIENTRY glGetPathLengthNV (GLuint path, GLsizei startSegment, GLsizei numSegments); +GLAPI GLboolean APIENTRY glPointAlongPathNV (GLuint path, GLsizei startSegment, GLsizei numSegments, GLfloat distance, GLfloat *x, GLfloat *y, GLfloat *tangentX, GLfloat *tangentY); +#endif +#endif /* GL_NV_path_rendering */ + +#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 (APIENTRYP PFNGLPIXELDATARANGENVPROC) (GLenum target, GLsizei length, const void *pointer); +typedef void (APIENTRYP PFNGLFLUSHPIXELDATARANGENVPROC) (GLenum target); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelDataRangeNV (GLenum target, GLsizei length, const void *pointer); +GLAPI void APIENTRY glFlushPixelDataRangeNV (GLenum target); +#endif +#endif /* GL_NV_pixel_data_range */ + +#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 (APIENTRYP PFNGLPOINTPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERIVNVPROC) (GLenum pname, const GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameteriNV (GLenum pname, GLint param); +GLAPI void APIENTRY glPointParameterivNV (GLenum pname, const GLint *params); +#endif +#endif /* GL_NV_point_sprite */ + +#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 (APIENTRYP PFNGLPRESENTFRAMEKEYEDNVPROC) (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLGETVIDEOIVNVPROC) (GLuint video_slot, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVIDEOUIVNVPROC) (GLuint video_slot, GLenum pname, GLuint *params); +typedef void (APIENTRYP PFNGLGETVIDEOI64VNVPROC) (GLuint video_slot, GLenum pname, GLint64EXT *params); +typedef void (APIENTRYP PFNGLGETVIDEOUI64VNVPROC) (GLuint video_slot, GLenum pname, GLuint64EXT *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPresentFrameKeyedNV (GLuint video_slot, GLuint64EXT minPresentTime, GLuint beginPresentTimeId, GLuint presentDurationId, GLenum type, GLenum target0, GLuint fill0, GLuint key0, GLenum target1, GLuint fill1, GLuint key1); +GLAPI void APIENTRY glPresentFrameDualFillNV (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); +GLAPI void APIENTRY glGetVideoivNV (GLuint video_slot, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVideouivNV (GLuint video_slot, GLenum pname, GLuint *params); +GLAPI void APIENTRY glGetVideoi64vNV (GLuint video_slot, GLenum pname, GLint64EXT *params); +GLAPI void APIENTRY glGetVideoui64vNV (GLuint video_slot, GLenum pname, GLuint64EXT *params); +#endif +#endif /* GL_NV_present_video */ + +#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 (APIENTRYP PFNGLPRIMITIVERESTARTNVPROC) (void); +typedef void (APIENTRYP PFNGLPRIMITIVERESTARTINDEXNVPROC) (GLuint index); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPrimitiveRestartNV (void); +GLAPI void APIENTRY glPrimitiveRestartIndexNV (GLuint index); +#endif +#endif /* GL_NV_primitive_restart */ + +#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_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 (APIENTRYP PFNGLCOMBINERPARAMETERFVNVPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERFNVPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERIVNVPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOMBINERPARAMETERINVPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLCOMBINERINPUTNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (APIENTRYP PFNGLCOMBINEROUTPUTNVPROC) (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); +typedef void (APIENTRYP PFNGLFINALCOMBINERINPUTNVPROC) (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +typedef void (APIENTRYP PFNGLGETCOMBINERINPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINERINPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETCOMBINEROUTPUTPARAMETERFVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINEROUTPUTPARAMETERIVNVPROC) (GLenum stage, GLenum portion, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETFINALCOMBINERINPUTPARAMETERFVNVPROC) (GLenum variable, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFINALCOMBINERINPUTPARAMETERIVNVPROC) (GLenum variable, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCombinerParameterfvNV (GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glCombinerParameterfNV (GLenum pname, GLfloat param); +GLAPI void APIENTRY glCombinerParameterivNV (GLenum pname, const GLint *params); +GLAPI void APIENTRY glCombinerParameteriNV (GLenum pname, GLint param); +GLAPI void APIENTRY glCombinerInputNV (GLenum stage, GLenum portion, GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +GLAPI void APIENTRY glCombinerOutputNV (GLenum stage, GLenum portion, GLenum abOutput, GLenum cdOutput, GLenum sumOutput, GLenum scale, GLenum bias, GLboolean abDotProduct, GLboolean cdDotProduct, GLboolean muxSum); +GLAPI void APIENTRY glFinalCombinerInputNV (GLenum variable, GLenum input, GLenum mapping, GLenum componentUsage); +GLAPI void APIENTRY glGetCombinerInputParameterfvNV (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetCombinerInputParameterivNV (GLenum stage, GLenum portion, GLenum variable, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetCombinerOutputParameterfvNV (GLenum stage, GLenum portion, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetCombinerOutputParameterivNV (GLenum stage, GLenum portion, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetFinalCombinerInputParameterfvNV (GLenum variable, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetFinalCombinerInputParameterivNV (GLenum variable, GLenum pname, GLint *params); +#endif +#endif /* GL_NV_register_combiners */ + +#ifndef GL_NV_register_combiners2 +#define GL_NV_register_combiners2 1 +#define GL_PER_STAGE_CONSTANTS_NV 0x8535 +typedef void (APIENTRYP PFNGLCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOMBINERSTAGEPARAMETERFVNVPROC) (GLenum stage, GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glCombinerStageParameterfvNV (GLenum stage, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glGetCombinerStageParameterfvNV (GLenum stage, GLenum pname, GLfloat *params); +#endif +#endif /* GL_NV_register_combiners2 */ + +#ifndef GL_NV_shader_atomic_counters +#define GL_NV_shader_atomic_counters 1 +#endif /* GL_NV_shader_atomic_counters */ + +#ifndef GL_NV_shader_atomic_float +#define GL_NV_shader_atomic_float 1 +#endif /* GL_NV_shader_atomic_float */ + +#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 (APIENTRYP PFNGLMAKEBUFFERRESIDENTNVPROC) (GLenum target, GLenum access); +typedef void (APIENTRYP PFNGLMAKEBUFFERNONRESIDENTNVPROC) (GLenum target); +typedef GLboolean (APIENTRYP PFNGLISBUFFERRESIDENTNVPROC) (GLenum target); +typedef void (APIENTRYP PFNGLMAKENAMEDBUFFERRESIDENTNVPROC) (GLuint buffer, GLenum access); +typedef void (APIENTRYP PFNGLMAKENAMEDBUFFERNONRESIDENTNVPROC) (GLuint buffer); +typedef GLboolean (APIENTRYP PFNGLISNAMEDBUFFERRESIDENTNVPROC) (GLuint buffer); +typedef void (APIENTRYP PFNGLGETBUFFERPARAMETERUI64VNVPROC) (GLenum target, GLenum pname, GLuint64EXT *params); +typedef void (APIENTRYP PFNGLGETNAMEDBUFFERPARAMETERUI64VNVPROC) (GLuint buffer, GLenum pname, GLuint64EXT *params); +typedef void (APIENTRYP PFNGLGETINTEGERUI64VNVPROC) (GLenum value, GLuint64EXT *result); +typedef void (APIENTRYP PFNGLUNIFORMUI64NVPROC) (GLint location, GLuint64EXT value); +typedef void (APIENTRYP PFNGLUNIFORMUI64VNVPROC) (GLint location, GLsizei count, const GLuint64EXT *value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMUI64NVPROC) (GLuint program, GLint location, GLuint64EXT value); +typedef void (APIENTRYP PFNGLPROGRAMUNIFORMUI64VNVPROC) (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glMakeBufferResidentNV (GLenum target, GLenum access); +GLAPI void APIENTRY glMakeBufferNonResidentNV (GLenum target); +GLAPI GLboolean APIENTRY glIsBufferResidentNV (GLenum target); +GLAPI void APIENTRY glMakeNamedBufferResidentNV (GLuint buffer, GLenum access); +GLAPI void APIENTRY glMakeNamedBufferNonResidentNV (GLuint buffer); +GLAPI GLboolean APIENTRY glIsNamedBufferResidentNV (GLuint buffer); +GLAPI void APIENTRY glGetBufferParameterui64vNV (GLenum target, GLenum pname, GLuint64EXT *params); +GLAPI void APIENTRY glGetNamedBufferParameterui64vNV (GLuint buffer, GLenum pname, GLuint64EXT *params); +GLAPI void APIENTRY glGetIntegerui64vNV (GLenum value, GLuint64EXT *result); +GLAPI void APIENTRY glUniformui64NV (GLint location, GLuint64EXT value); +GLAPI void APIENTRY glUniformui64vNV (GLint location, GLsizei count, const GLuint64EXT *value); +GLAPI void APIENTRY glProgramUniformui64NV (GLuint program, GLint location, GLuint64EXT value); +GLAPI void APIENTRY glProgramUniformui64vNV (GLuint program, GLint location, GLsizei count, const GLuint64EXT *value); +#endif +#endif /* GL_NV_shader_buffer_load */ + +#ifndef GL_NV_shader_buffer_store +#define GL_NV_shader_buffer_store 1 +#define GL_SHADER_GLOBAL_ACCESS_BARRIER_BIT_NV 0x00000010 +#endif /* GL_NV_shader_buffer_store */ + +#ifndef GL_NV_shader_storage_buffer_object +#define GL_NV_shader_storage_buffer_object 1 +#endif /* GL_NV_shader_storage_buffer_object */ + +#ifndef GL_NV_shader_thread_group +#define GL_NV_shader_thread_group 1 +#define GL_WARP_SIZE_NV 0x9339 +#define GL_WARPS_PER_SM_NV 0x933A +#define GL_SM_COUNT_NV 0x933B +#endif /* GL_NV_shader_thread_group */ + +#ifndef GL_NV_shader_thread_shuffle +#define GL_NV_shader_thread_shuffle 1 +#endif /* GL_NV_shader_thread_shuffle */ + +#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 +#endif /* GL_NV_tessellation_program5 */ + +#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 +#endif /* GL_NV_texgen_emboss */ + +#ifndef GL_NV_texgen_reflection +#define GL_NV_texgen_reflection 1 +#define GL_NORMAL_MAP_NV 0x8511 +#define GL_REFLECTION_MAP_NV 0x8512 +#endif /* GL_NV_texgen_reflection */ + +#ifndef GL_NV_texture_barrier +#define GL_NV_texture_barrier 1 +typedef void (APIENTRYP PFNGLTEXTUREBARRIERNVPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureBarrierNV (void); +#endif +#endif /* GL_NV_texture_barrier */ + +#ifndef GL_NV_texture_compression_vtc +#define GL_NV_texture_compression_vtc 1 +#endif /* GL_NV_texture_compression_vtc */ + +#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 +#endif /* GL_NV_texture_env_combine4 */ + +#ifndef GL_NV_texture_expand_normal +#define GL_NV_texture_expand_normal 1 +#define GL_TEXTURE_UNSIGNED_REMAP_MODE_NV 0x888F +#endif /* GL_NV_texture_expand_normal */ + +#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 (APIENTRYP PFNGLTEXIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +typedef void (APIENTRYP PFNGLTEXIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE2DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE3DMULTISAMPLENVPROC) (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE2DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +typedef void (APIENTRYP PFNGLTEXTUREIMAGE3DMULTISAMPLECOVERAGENVPROC) (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexImage2DMultisampleCoverageNV (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +GLAPI void APIENTRY glTexImage3DMultisampleCoverageNV (GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +GLAPI void APIENTRY glTextureImage2DMultisampleNV (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +GLAPI void APIENTRY glTextureImage3DMultisampleNV (GLuint texture, GLenum target, GLsizei samples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +GLAPI void APIENTRY glTextureImage2DMultisampleCoverageNV (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLboolean fixedSampleLocations); +GLAPI void APIENTRY glTextureImage3DMultisampleCoverageNV (GLuint texture, GLenum target, GLsizei coverageSamples, GLsizei colorSamples, GLint internalFormat, GLsizei width, GLsizei height, GLsizei depth, GLboolean fixedSampleLocations); +#endif +#endif /* GL_NV_texture_multisample */ + +#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 +#endif /* GL_NV_texture_rectangle */ + +#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_MATRIX_NV 0x86E1 +#define GL_OFFSET_TEXTURE_SCALE_NV 0x86E2 +#define GL_OFFSET_TEXTURE_BIAS_NV 0x86E3 +#define GL_OFFSET_TEXTURE_2D_MATRIX_NV 0x86E1 +#define GL_OFFSET_TEXTURE_2D_SCALE_NV 0x86E2 +#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 +#endif /* GL_NV_texture_shader */ + +#ifndef GL_NV_texture_shader2 +#define GL_NV_texture_shader2 1 +#define GL_DOT_PRODUCT_TEXTURE_3D_NV 0x86EF +#endif /* GL_NV_texture_shader2 */ + +#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 +#endif /* GL_NV_texture_shader3 */ + +#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 +#define GL_LAYER_NV 0x8DAA +#define GL_NEXT_BUFFER_NV -2 +#define GL_SKIP_COMPONENTS4_NV -3 +#define GL_SKIP_COMPONENTS3_NV -4 +#define GL_SKIP_COMPONENTS2_NV -5 +#define GL_SKIP_COMPONENTS1_NV -6 +typedef void (APIENTRYP PFNGLBEGINTRANSFORMFEEDBACKNVPROC) (GLenum primitiveMode); +typedef void (APIENTRYP PFNGLENDTRANSFORMFEEDBACKNVPROC) (void); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKATTRIBSNVPROC) (GLuint count, const GLint *attribs, GLenum bufferMode); +typedef void (APIENTRYP PFNGLBINDBUFFERRANGENVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +typedef void (APIENTRYP PFNGLBINDBUFFEROFFSETNVPROC) (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +typedef void (APIENTRYP PFNGLBINDBUFFERBASENVPROC) (GLenum target, GLuint index, GLuint buffer); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKVARYINGSNVPROC) (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode); +typedef void (APIENTRYP PFNGLACTIVEVARYINGNVPROC) (GLuint program, const GLchar *name); +typedef GLint (APIENTRYP PFNGLGETVARYINGLOCATIONNVPROC) (GLuint program, const GLchar *name); +typedef void (APIENTRYP PFNGLGETACTIVEVARYINGNVPROC) (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +typedef void (APIENTRYP PFNGLGETTRANSFORMFEEDBACKVARYINGNVPROC) (GLuint program, GLuint index, GLint *location); +typedef void (APIENTRYP PFNGLTRANSFORMFEEDBACKSTREAMATTRIBSNVPROC) (GLsizei count, const GLint *attribs, GLsizei nbuffers, const GLint *bufstreams, GLenum bufferMode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginTransformFeedbackNV (GLenum primitiveMode); +GLAPI void APIENTRY glEndTransformFeedbackNV (void); +GLAPI void APIENTRY glTransformFeedbackAttribsNV (GLuint count, const GLint *attribs, GLenum bufferMode); +GLAPI void APIENTRY glBindBufferRangeNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset, GLsizeiptr size); +GLAPI void APIENTRY glBindBufferOffsetNV (GLenum target, GLuint index, GLuint buffer, GLintptr offset); +GLAPI void APIENTRY glBindBufferBaseNV (GLenum target, GLuint index, GLuint buffer); +GLAPI void APIENTRY glTransformFeedbackVaryingsNV (GLuint program, GLsizei count, const GLint *locations, GLenum bufferMode); +GLAPI void APIENTRY glActiveVaryingNV (GLuint program, const GLchar *name); +GLAPI GLint APIENTRY glGetVaryingLocationNV (GLuint program, const GLchar *name); +GLAPI void APIENTRY glGetActiveVaryingNV (GLuint program, GLuint index, GLsizei bufSize, GLsizei *length, GLsizei *size, GLenum *type, GLchar *name); +GLAPI void APIENTRY glGetTransformFeedbackVaryingNV (GLuint program, GLuint index, GLint *location); +GLAPI void APIENTRY glTransformFeedbackStreamAttribsNV (GLsizei count, const GLint *attribs, GLsizei nbuffers, const GLint *bufstreams, GLenum bufferMode); +#endif +#endif /* GL_NV_transform_feedback */ + +#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 (APIENTRYP PFNGLBINDTRANSFORMFEEDBACKNVPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLDELETETRANSFORMFEEDBACKSNVPROC) (GLsizei n, const GLuint *ids); +typedef void (APIENTRYP PFNGLGENTRANSFORMFEEDBACKSNVPROC) (GLsizei n, GLuint *ids); +typedef GLboolean (APIENTRYP PFNGLISTRANSFORMFEEDBACKNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLPAUSETRANSFORMFEEDBACKNVPROC) (void); +typedef void (APIENTRYP PFNGLRESUMETRANSFORMFEEDBACKNVPROC) (void); +typedef void (APIENTRYP PFNGLDRAWTRANSFORMFEEDBACKNVPROC) (GLenum mode, GLuint id); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBindTransformFeedbackNV (GLenum target, GLuint id); +GLAPI void APIENTRY glDeleteTransformFeedbacksNV (GLsizei n, const GLuint *ids); +GLAPI void APIENTRY glGenTransformFeedbacksNV (GLsizei n, GLuint *ids); +GLAPI GLboolean APIENTRY glIsTransformFeedbackNV (GLuint id); +GLAPI void APIENTRY glPauseTransformFeedbackNV (void); +GLAPI void APIENTRY glResumeTransformFeedbackNV (void); +GLAPI void APIENTRY glDrawTransformFeedbackNV (GLenum mode, GLuint id); +#endif +#endif /* GL_NV_transform_feedback2 */ + +#ifndef GL_NV_vdpau_interop +#define GL_NV_vdpau_interop 1 +typedef GLintptr GLvdpauSurfaceNV; +#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 void (APIENTRYP PFNGLVDPAUINITNVPROC) (const void *vdpDevice, const void *getProcAddress); +typedef void (APIENTRYP PFNGLVDPAUFININVPROC) (void); +typedef GLvdpauSurfaceNV (APIENTRYP PFNGLVDPAUREGISTERVIDEOSURFACENVPROC) (const void *vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); +typedef GLvdpauSurfaceNV (APIENTRYP PFNGLVDPAUREGISTEROUTPUTSURFACENVPROC) (const void *vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); +typedef GLboolean (APIENTRYP PFNGLVDPAUISSURFACENVPROC) (GLvdpauSurfaceNV surface); +typedef void (APIENTRYP PFNGLVDPAUUNREGISTERSURFACENVPROC) (GLvdpauSurfaceNV surface); +typedef void (APIENTRYP PFNGLVDPAUGETSURFACEIVNVPROC) (GLvdpauSurfaceNV surface, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +typedef void (APIENTRYP PFNGLVDPAUSURFACEACCESSNVPROC) (GLvdpauSurfaceNV surface, GLenum access); +typedef void (APIENTRYP PFNGLVDPAUMAPSURFACESNVPROC) (GLsizei numSurfaces, const GLvdpauSurfaceNV *surfaces); +typedef void (APIENTRYP PFNGLVDPAUUNMAPSURFACESNVPROC) (GLsizei numSurface, const GLvdpauSurfaceNV *surfaces); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVDPAUInitNV (const void *vdpDevice, const void *getProcAddress); +GLAPI void APIENTRY glVDPAUFiniNV (void); +GLAPI GLvdpauSurfaceNV APIENTRY glVDPAURegisterVideoSurfaceNV (const void *vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); +GLAPI GLvdpauSurfaceNV APIENTRY glVDPAURegisterOutputSurfaceNV (const void *vdpSurface, GLenum target, GLsizei numTextureNames, const GLuint *textureNames); +GLAPI GLboolean APIENTRY glVDPAUIsSurfaceNV (GLvdpauSurfaceNV surface); +GLAPI void APIENTRY glVDPAUUnregisterSurfaceNV (GLvdpauSurfaceNV surface); +GLAPI void APIENTRY glVDPAUGetSurfaceivNV (GLvdpauSurfaceNV surface, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +GLAPI void APIENTRY glVDPAUSurfaceAccessNV (GLvdpauSurfaceNV surface, GLenum access); +GLAPI void APIENTRY glVDPAUMapSurfacesNV (GLsizei numSurfaces, const GLvdpauSurfaceNV *surfaces); +GLAPI void APIENTRY glVDPAUUnmapSurfacesNV (GLsizei numSurface, const GLvdpauSurfaceNV *surfaces); +#endif +#endif /* GL_NV_vdpau_interop */ + +#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 (APIENTRYP PFNGLFLUSHVERTEXARRAYRANGENVPROC) (void); +typedef void (APIENTRYP PFNGLVERTEXARRAYRANGENVPROC) (GLsizei length, const void *pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFlushVertexArrayRangeNV (void); +GLAPI void APIENTRY glVertexArrayRangeNV (GLsizei length, const void *pointer); +#endif +#endif /* GL_NV_vertex_array_range */ + +#ifndef GL_NV_vertex_array_range2 +#define GL_NV_vertex_array_range2 1 +#define GL_VERTEX_ARRAY_RANGE_WITHOUT_FLUSH_NV 0x8533 +#endif /* GL_NV_vertex_array_range2 */ + +#ifndef GL_NV_vertex_attrib_integer_64bit +#define GL_NV_vertex_attrib_integer_64bit 1 +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1I64NVPROC) (GLuint index, GLint64EXT x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4I64NVPROC) (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1I64VNVPROC) (GLuint index, const GLint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2I64VNVPROC) (GLuint index, const GLint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3I64VNVPROC) (GLuint index, const GLint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4I64VNVPROC) (GLuint index, const GLint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1UI64NVPROC) (GLuint index, GLuint64EXT x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4UI64NVPROC) (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL1UI64VNVPROC) (GLuint index, const GLuint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL2UI64VNVPROC) (GLuint index, const GLuint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL3UI64VNVPROC) (GLuint index, const GLuint64EXT *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBL4UI64VNVPROC) (GLuint index, const GLuint64EXT *v); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBLI64VNVPROC) (GLuint index, GLenum pname, GLint64EXT *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBLUI64VNVPROC) (GLuint index, GLenum pname, GLuint64EXT *params); +typedef void (APIENTRYP PFNGLVERTEXATTRIBLFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribL1i64NV (GLuint index, GLint64EXT x); +GLAPI void APIENTRY glVertexAttribL2i64NV (GLuint index, GLint64EXT x, GLint64EXT y); +GLAPI void APIENTRY glVertexAttribL3i64NV (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z); +GLAPI void APIENTRY glVertexAttribL4i64NV (GLuint index, GLint64EXT x, GLint64EXT y, GLint64EXT z, GLint64EXT w); +GLAPI void APIENTRY glVertexAttribL1i64vNV (GLuint index, const GLint64EXT *v); +GLAPI void APIENTRY glVertexAttribL2i64vNV (GLuint index, const GLint64EXT *v); +GLAPI void APIENTRY glVertexAttribL3i64vNV (GLuint index, const GLint64EXT *v); +GLAPI void APIENTRY glVertexAttribL4i64vNV (GLuint index, const GLint64EXT *v); +GLAPI void APIENTRY glVertexAttribL1ui64NV (GLuint index, GLuint64EXT x); +GLAPI void APIENTRY glVertexAttribL2ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y); +GLAPI void APIENTRY glVertexAttribL3ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z); +GLAPI void APIENTRY glVertexAttribL4ui64NV (GLuint index, GLuint64EXT x, GLuint64EXT y, GLuint64EXT z, GLuint64EXT w); +GLAPI void APIENTRY glVertexAttribL1ui64vNV (GLuint index, const GLuint64EXT *v); +GLAPI void APIENTRY glVertexAttribL2ui64vNV (GLuint index, const GLuint64EXT *v); +GLAPI void APIENTRY glVertexAttribL3ui64vNV (GLuint index, const GLuint64EXT *v); +GLAPI void APIENTRY glVertexAttribL4ui64vNV (GLuint index, const GLuint64EXT *v); +GLAPI void APIENTRY glGetVertexAttribLi64vNV (GLuint index, GLenum pname, GLint64EXT *params); +GLAPI void APIENTRY glGetVertexAttribLui64vNV (GLuint index, GLenum pname, GLuint64EXT *params); +GLAPI void APIENTRY glVertexAttribLFormatNV (GLuint index, GLint size, GLenum type, GLsizei stride); +#endif +#endif /* GL_NV_vertex_attrib_integer_64bit */ + +#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 (APIENTRYP PFNGLBUFFERADDRESSRANGENVPROC) (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length); +typedef void (APIENTRYP PFNGLVERTEXFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLNORMALFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLINDEXFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLTEXCOORDFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLEDGEFLAGFORMATNVPROC) (GLsizei stride); +typedef void (APIENTRYP PFNGLSECONDARYCOLORFORMATNVPROC) (GLint size, GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLFOGCOORDFORMATNVPROC) (GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLVERTEXATTRIBFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride); +typedef void (APIENTRYP PFNGLVERTEXATTRIBIFORMATNVPROC) (GLuint index, GLint size, GLenum type, GLsizei stride); +typedef void (APIENTRYP PFNGLGETINTEGERUI64I_VNVPROC) (GLenum value, GLuint index, GLuint64EXT *result); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBufferAddressRangeNV (GLenum pname, GLuint index, GLuint64EXT address, GLsizeiptr length); +GLAPI void APIENTRY glVertexFormatNV (GLint size, GLenum type, GLsizei stride); +GLAPI void APIENTRY glNormalFormatNV (GLenum type, GLsizei stride); +GLAPI void APIENTRY glColorFormatNV (GLint size, GLenum type, GLsizei stride); +GLAPI void APIENTRY glIndexFormatNV (GLenum type, GLsizei stride); +GLAPI void APIENTRY glTexCoordFormatNV (GLint size, GLenum type, GLsizei stride); +GLAPI void APIENTRY glEdgeFlagFormatNV (GLsizei stride); +GLAPI void APIENTRY glSecondaryColorFormatNV (GLint size, GLenum type, GLsizei stride); +GLAPI void APIENTRY glFogCoordFormatNV (GLenum type, GLsizei stride); +GLAPI void APIENTRY glVertexAttribFormatNV (GLuint index, GLint size, GLenum type, GLboolean normalized, GLsizei stride); +GLAPI void APIENTRY glVertexAttribIFormatNV (GLuint index, GLint size, GLenum type, GLsizei stride); +GLAPI void APIENTRY glGetIntegerui64i_vNV (GLenum value, GLuint index, GLuint64EXT *result); +#endif +#endif /* GL_NV_vertex_buffer_unified_memory */ + +#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 (APIENTRYP PFNGLAREPROGRAMSRESIDENTNVPROC) (GLsizei n, const GLuint *programs, GLboolean *residences); +typedef void (APIENTRYP PFNGLBINDPROGRAMNVPROC) (GLenum target, GLuint id); +typedef void (APIENTRYP PFNGLDELETEPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLEXECUTEPROGRAMNVPROC) (GLenum target, GLuint id, const GLfloat *params); +typedef void (APIENTRYP PFNGLGENPROGRAMSNVPROC) (GLsizei n, GLuint *programs); +typedef void (APIENTRYP PFNGLGETPROGRAMPARAMETERDVNVPROC) (GLenum target, GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETPROGRAMPARAMETERFVNVPROC) (GLenum target, GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETPROGRAMIVNVPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPROGRAMSTRINGNVPROC) (GLuint id, GLenum pname, GLubyte *program); +typedef void (APIENTRYP PFNGLGETTRACKMATRIXIVNVPROC) (GLenum target, GLuint address, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBDVNVPROC) (GLuint index, GLenum pname, GLdouble *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBFVNVPROC) (GLuint index, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIVNVPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBPOINTERVNVPROC) (GLuint index, GLenum pname, void **pointer); +typedef GLboolean (APIENTRYP PFNGLISPROGRAMNVPROC) (GLuint id); +typedef void (APIENTRYP PFNGLLOADPROGRAMNVPROC) (GLenum target, GLuint id, GLsizei len, const GLubyte *program); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4DNVPROC) (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4DVNVPROC) (GLenum target, GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4FNVPROC) (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETER4FVNVPROC) (GLenum target, GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERS4DVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLPROGRAMPARAMETERS4FVNVPROC) (GLenum target, GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLREQUESTRESIDENTPROGRAMSNVPROC) (GLsizei n, const GLuint *programs); +typedef void (APIENTRYP PFNGLTRACKMATRIXNVPROC) (GLenum target, GLuint address, GLenum matrix, GLenum transform); +typedef void (APIENTRYP PFNGLVERTEXATTRIBPOINTERNVPROC) (GLuint index, GLint fsize, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DNVPROC) (GLuint index, GLdouble x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FNVPROC) (GLuint index, GLfloat x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SNVPROC) (GLuint index, GLshort x); +typedef void (APIENTRYP PFNGLVERTEXATTRIB1SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DNVPROC) (GLuint index, GLdouble x, GLdouble y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FNVPROC) (GLuint index, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SNVPROC) (GLuint index, GLshort x, GLshort y); +typedef void (APIENTRYP PFNGLVERTEXATTRIB2SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z); +typedef void (APIENTRYP PFNGLVERTEXATTRIB3SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DNVPROC) (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4DVNVPROC) (GLuint index, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FNVPROC) (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4FVNVPROC) (GLuint index, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SNVPROC) (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4SVNVPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBNVPROC) (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +typedef void (APIENTRYP PFNGLVERTEXATTRIB4UBVNVPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS1SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS2SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS3SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4DVNVPROC) (GLuint index, GLsizei count, const GLdouble *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4FVNVPROC) (GLuint index, GLsizei count, const GLfloat *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4SVNVPROC) (GLuint index, GLsizei count, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBS4UBVNVPROC) (GLuint index, GLsizei count, const GLubyte *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLboolean APIENTRY glAreProgramsResidentNV (GLsizei n, const GLuint *programs, GLboolean *residences); +GLAPI void APIENTRY glBindProgramNV (GLenum target, GLuint id); +GLAPI void APIENTRY glDeleteProgramsNV (GLsizei n, const GLuint *programs); +GLAPI void APIENTRY glExecuteProgramNV (GLenum target, GLuint id, const GLfloat *params); +GLAPI void APIENTRY glGenProgramsNV (GLsizei n, GLuint *programs); +GLAPI void APIENTRY glGetProgramParameterdvNV (GLenum target, GLuint index, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glGetProgramParameterfvNV (GLenum target, GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetProgramivNV (GLuint id, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetProgramStringNV (GLuint id, GLenum pname, GLubyte *program); +GLAPI void APIENTRY glGetTrackMatrixivNV (GLenum target, GLuint address, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribdvNV (GLuint index, GLenum pname, GLdouble *params); +GLAPI void APIENTRY glGetVertexAttribfvNV (GLuint index, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVertexAttribivNV (GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribPointervNV (GLuint index, GLenum pname, void **pointer); +GLAPI GLboolean APIENTRY glIsProgramNV (GLuint id); +GLAPI void APIENTRY glLoadProgramNV (GLenum target, GLuint id, GLsizei len, const GLubyte *program); +GLAPI void APIENTRY glProgramParameter4dNV (GLenum target, GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glProgramParameter4dvNV (GLenum target, GLuint index, const GLdouble *v); +GLAPI void APIENTRY glProgramParameter4fNV (GLenum target, GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glProgramParameter4fvNV (GLenum target, GLuint index, const GLfloat *v); +GLAPI void APIENTRY glProgramParameters4dvNV (GLenum target, GLuint index, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glProgramParameters4fvNV (GLenum target, GLuint index, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glRequestResidentProgramsNV (GLsizei n, const GLuint *programs); +GLAPI void APIENTRY glTrackMatrixNV (GLenum target, GLuint address, GLenum matrix, GLenum transform); +GLAPI void APIENTRY glVertexAttribPointerNV (GLuint index, GLint fsize, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glVertexAttrib1dNV (GLuint index, GLdouble x); +GLAPI void APIENTRY glVertexAttrib1dvNV (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib1fNV (GLuint index, GLfloat x); +GLAPI void APIENTRY glVertexAttrib1fvNV (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib1sNV (GLuint index, GLshort x); +GLAPI void APIENTRY glVertexAttrib1svNV (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib2dNV (GLuint index, GLdouble x, GLdouble y); +GLAPI void APIENTRY glVertexAttrib2dvNV (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib2fNV (GLuint index, GLfloat x, GLfloat y); +GLAPI void APIENTRY glVertexAttrib2fvNV (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib2sNV (GLuint index, GLshort x, GLshort y); +GLAPI void APIENTRY glVertexAttrib2svNV (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib3dNV (GLuint index, GLdouble x, GLdouble y, GLdouble z); +GLAPI void APIENTRY glVertexAttrib3dvNV (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib3fNV (GLuint index, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glVertexAttrib3fvNV (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib3sNV (GLuint index, GLshort x, GLshort y, GLshort z); +GLAPI void APIENTRY glVertexAttrib3svNV (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4dNV (GLuint index, GLdouble x, GLdouble y, GLdouble z, GLdouble w); +GLAPI void APIENTRY glVertexAttrib4dvNV (GLuint index, const GLdouble *v); +GLAPI void APIENTRY glVertexAttrib4fNV (GLuint index, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glVertexAttrib4fvNV (GLuint index, const GLfloat *v); +GLAPI void APIENTRY glVertexAttrib4sNV (GLuint index, GLshort x, GLshort y, GLshort z, GLshort w); +GLAPI void APIENTRY glVertexAttrib4svNV (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttrib4ubNV (GLuint index, GLubyte x, GLubyte y, GLubyte z, GLubyte w); +GLAPI void APIENTRY glVertexAttrib4ubvNV (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttribs1dvNV (GLuint index, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribs1fvNV (GLuint index, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glVertexAttribs1svNV (GLuint index, GLsizei count, const GLshort *v); +GLAPI void APIENTRY glVertexAttribs2dvNV (GLuint index, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribs2fvNV (GLuint index, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glVertexAttribs2svNV (GLuint index, GLsizei count, const GLshort *v); +GLAPI void APIENTRY glVertexAttribs3dvNV (GLuint index, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribs3fvNV (GLuint index, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glVertexAttribs3svNV (GLuint index, GLsizei count, const GLshort *v); +GLAPI void APIENTRY glVertexAttribs4dvNV (GLuint index, GLsizei count, const GLdouble *v); +GLAPI void APIENTRY glVertexAttribs4fvNV (GLuint index, GLsizei count, const GLfloat *v); +GLAPI void APIENTRY glVertexAttribs4svNV (GLuint index, GLsizei count, const GLshort *v); +GLAPI void APIENTRY glVertexAttribs4ubvNV (GLuint index, GLsizei count, const GLubyte *v); +#endif +#endif /* GL_NV_vertex_program */ + +#ifndef GL_NV_vertex_program1_1 +#define GL_NV_vertex_program1_1 1 +#endif /* GL_NV_vertex_program1_1 */ + +#ifndef GL_NV_vertex_program2 +#define GL_NV_vertex_program2 1 +#endif /* GL_NV_vertex_program2 */ + +#ifndef GL_NV_vertex_program2_option +#define GL_NV_vertex_program2_option 1 +#endif /* GL_NV_vertex_program2_option */ + +#ifndef GL_NV_vertex_program3 +#define GL_NV_vertex_program3 1 +#endif /* GL_NV_vertex_program3 */ + +#ifndef GL_NV_vertex_program4 +#define GL_NV_vertex_program4 1 +#define GL_VERTEX_ATTRIB_ARRAY_INTEGER_NV 0x88FD +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IEXTPROC) (GLuint index, GLint x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IEXTPROC) (GLuint index, GLint x, GLint y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IEXTPROC) (GLuint index, GLint x, GLint y, GLint z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IEXTPROC) (GLuint index, GLint x, GLint y, GLint z, GLint w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIEXTPROC) (GLuint index, GLuint x); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIEXTPROC) (GLuint index, GLuint x, GLuint y); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIEXTPROC) (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1IVEXTPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2IVEXTPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3IVEXTPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4IVEXTPROC) (GLuint index, const GLint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI1UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI2UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI3UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UIVEXTPROC) (GLuint index, const GLuint *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4BVEXTPROC) (GLuint index, const GLbyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4SVEXTPROC) (GLuint index, const GLshort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4UBVEXTPROC) (GLuint index, const GLubyte *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBI4USVEXTPROC) (GLuint index, const GLushort *v); +typedef void (APIENTRYP PFNGLVERTEXATTRIBIPOINTEREXTPROC) (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIIVEXTPROC) (GLuint index, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVERTEXATTRIBIUIVEXTPROC) (GLuint index, GLenum pname, GLuint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glVertexAttribI1iEXT (GLuint index, GLint x); +GLAPI void APIENTRY glVertexAttribI2iEXT (GLuint index, GLint x, GLint y); +GLAPI void APIENTRY glVertexAttribI3iEXT (GLuint index, GLint x, GLint y, GLint z); +GLAPI void APIENTRY glVertexAttribI4iEXT (GLuint index, GLint x, GLint y, GLint z, GLint w); +GLAPI void APIENTRY glVertexAttribI1uiEXT (GLuint index, GLuint x); +GLAPI void APIENTRY glVertexAttribI2uiEXT (GLuint index, GLuint x, GLuint y); +GLAPI void APIENTRY glVertexAttribI3uiEXT (GLuint index, GLuint x, GLuint y, GLuint z); +GLAPI void APIENTRY glVertexAttribI4uiEXT (GLuint index, GLuint x, GLuint y, GLuint z, GLuint w); +GLAPI void APIENTRY glVertexAttribI1ivEXT (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI2ivEXT (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI3ivEXT (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI4ivEXT (GLuint index, const GLint *v); +GLAPI void APIENTRY glVertexAttribI1uivEXT (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI2uivEXT (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI3uivEXT (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI4uivEXT (GLuint index, const GLuint *v); +GLAPI void APIENTRY glVertexAttribI4bvEXT (GLuint index, const GLbyte *v); +GLAPI void APIENTRY glVertexAttribI4svEXT (GLuint index, const GLshort *v); +GLAPI void APIENTRY glVertexAttribI4ubvEXT (GLuint index, const GLubyte *v); +GLAPI void APIENTRY glVertexAttribI4usvEXT (GLuint index, const GLushort *v); +GLAPI void APIENTRY glVertexAttribIPointerEXT (GLuint index, GLint size, GLenum type, GLsizei stride, const void *pointer); +GLAPI void APIENTRY glGetVertexAttribIivEXT (GLuint index, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVertexAttribIuivEXT (GLuint index, GLenum pname, GLuint *params); +#endif +#endif /* GL_NV_vertex_program4 */ + +#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 (APIENTRYP PFNGLBEGINVIDEOCAPTURENVPROC) (GLuint video_capture_slot); +typedef void (APIENTRYP PFNGLBINDVIDEOCAPTURESTREAMBUFFERNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLintptrARB offset); +typedef void (APIENTRYP PFNGLBINDVIDEOCAPTURESTREAMTEXTURENVPROC) (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLenum target, GLuint texture); +typedef void (APIENTRYP PFNGLENDVIDEOCAPTURENVPROC) (GLuint video_capture_slot); +typedef void (APIENTRYP PFNGLGETVIDEOCAPTUREIVNVPROC) (GLuint video_capture_slot, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVIDEOCAPTURESTREAMIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETVIDEOCAPTURESTREAMFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETVIDEOCAPTURESTREAMDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, GLdouble *params); +typedef GLenum (APIENTRYP PFNGLVIDEOCAPTURENVPROC) (GLuint video_capture_slot, GLuint *sequence_num, GLuint64EXT *capture_time); +typedef void (APIENTRYP PFNGLVIDEOCAPTURESTREAMPARAMETERIVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLVIDEOCAPTURESTREAMPARAMETERFVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLVIDEOCAPTURESTREAMPARAMETERDVNVPROC) (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLdouble *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glBeginVideoCaptureNV (GLuint video_capture_slot); +GLAPI void APIENTRY glBindVideoCaptureStreamBufferNV (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLintptrARB offset); +GLAPI void APIENTRY glBindVideoCaptureStreamTextureNV (GLuint video_capture_slot, GLuint stream, GLenum frame_region, GLenum target, GLuint texture); +GLAPI void APIENTRY glEndVideoCaptureNV (GLuint video_capture_slot); +GLAPI void APIENTRY glGetVideoCaptureivNV (GLuint video_capture_slot, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVideoCaptureStreamivNV (GLuint video_capture_slot, GLuint stream, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetVideoCaptureStreamfvNV (GLuint video_capture_slot, GLuint stream, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetVideoCaptureStreamdvNV (GLuint video_capture_slot, GLuint stream, GLenum pname, GLdouble *params); +GLAPI GLenum APIENTRY glVideoCaptureNV (GLuint video_capture_slot, GLuint *sequence_num, GLuint64EXT *capture_time); +GLAPI void APIENTRY glVideoCaptureStreamParameterivNV (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLint *params); +GLAPI void APIENTRY glVideoCaptureStreamParameterfvNV (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glVideoCaptureStreamParameterdvNV (GLuint video_capture_slot, GLuint stream, GLenum pname, const GLdouble *params); +#endif +#endif /* GL_NV_video_capture */ + +#ifndef GL_OML_interlace +#define GL_OML_interlace 1 +#define GL_INTERLACE_OML 0x8980 +#define GL_INTERLACE_READ_OML 0x8981 +#endif /* GL_OML_interlace */ + +#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 +#endif /* GL_OML_resample */ + +#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 +#endif /* GL_OML_subsample */ + +#ifndef GL_PGI_misc_hints +#define GL_PGI_misc_hints 1 +#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 +typedef void (APIENTRYP PFNGLHINTPGIPROC) (GLenum target, GLint mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glHintPGI (GLenum target, GLint mode); +#endif +#endif /* GL_PGI_misc_hints */ + +#ifndef GL_PGI_vertex_hints +#define GL_PGI_vertex_hints 1 +#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 /* GL_PGI_vertex_hints */ + +#ifndef GL_REND_screen_coordinates +#define GL_REND_screen_coordinates 1 +#define GL_SCREEN_COORDINATES_REND 0x8490 +#define GL_INVERTED_SCREEN_W_REND 0x8491 +#endif /* GL_REND_screen_coordinates */ + +#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 +#endif /* GL_S3_s3tc */ + +#ifndef GL_SGIS_detail_texture +#define GL_SGIS_detail_texture 1 +#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 +typedef void (APIENTRYP PFNGLDETAILTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETDETAILTEXFUNCSGISPROC) (GLenum target, GLfloat *points); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDetailTexFuncSGIS (GLenum target, GLsizei n, const GLfloat *points); +GLAPI void APIENTRY glGetDetailTexFuncSGIS (GLenum target, GLfloat *points); +#endif +#endif /* GL_SGIS_detail_texture */ + +#ifndef GL_SGIS_fog_function +#define GL_SGIS_fog_function 1 +#define GL_FOG_FUNC_SGIS 0x812A +#define GL_FOG_FUNC_POINTS_SGIS 0x812B +#define GL_MAX_FOG_FUNC_POINTS_SGIS 0x812C +typedef void (APIENTRYP PFNGLFOGFUNCSGISPROC) (GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETFOGFUNCSGISPROC) (GLfloat *points); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFogFuncSGIS (GLsizei n, const GLfloat *points); +GLAPI void APIENTRY glGetFogFuncSGIS (GLfloat *points); +#endif +#endif /* GL_SGIS_fog_function */ + +#ifndef GL_SGIS_generate_mipmap +#define GL_SGIS_generate_mipmap 1 +#define GL_GENERATE_MIPMAP_SGIS 0x8191 +#define GL_GENERATE_MIPMAP_HINT_SGIS 0x8192 +#endif /* GL_SGIS_generate_mipmap */ + +#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 (APIENTRYP PFNGLSAMPLEMASKSGISPROC) (GLclampf value, GLboolean invert); +typedef void (APIENTRYP PFNGLSAMPLEPATTERNSGISPROC) (GLenum pattern); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSampleMaskSGIS (GLclampf value, GLboolean invert); +GLAPI void APIENTRY glSamplePatternSGIS (GLenum pattern); +#endif +#endif /* GL_SGIS_multisample */ + +#ifndef GL_SGIS_pixel_texture +#define GL_SGIS_pixel_texture 1 +#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 +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERISGISPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERFSGISPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLGETPIXELTEXGENPARAMETERIVSGISPROC) (GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETPIXELTEXGENPARAMETERFVSGISPROC) (GLenum pname, GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTexGenParameteriSGIS (GLenum pname, GLint param); +GLAPI void APIENTRY glPixelTexGenParameterivSGIS (GLenum pname, const GLint *params); +GLAPI void APIENTRY glPixelTexGenParameterfSGIS (GLenum pname, GLfloat param); +GLAPI void APIENTRY glPixelTexGenParameterfvSGIS (GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glGetPixelTexGenParameterivSGIS (GLenum pname, GLint *params); +GLAPI void APIENTRY glGetPixelTexGenParameterfvSGIS (GLenum pname, GLfloat *params); +#endif +#endif /* GL_SGIS_pixel_texture */ + +#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 +#endif /* GL_SGIS_point_line_texgen */ + +#ifndef GL_SGIS_point_parameters +#define GL_SGIS_point_parameters 1 +#define GL_POINT_SIZE_MIN_SGIS 0x8126 +#define GL_POINT_SIZE_MAX_SGIS 0x8127 +#define GL_POINT_FADE_THRESHOLD_SIZE_SGIS 0x8128 +#define GL_DISTANCE_ATTENUATION_SGIS 0x8129 +typedef void (APIENTRYP PFNGLPOINTPARAMETERFSGISPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLPOINTPARAMETERFVSGISPROC) (GLenum pname, const GLfloat *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPointParameterfSGIS (GLenum pname, GLfloat param); +GLAPI void APIENTRY glPointParameterfvSGIS (GLenum pname, const GLfloat *params); +#endif +#endif /* GL_SGIS_point_parameters */ + +#ifndef GL_SGIS_sharpen_texture +#define GL_SGIS_sharpen_texture 1 +#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 +typedef void (APIENTRYP PFNGLSHARPENTEXFUNCSGISPROC) (GLenum target, GLsizei n, const GLfloat *points); +typedef void (APIENTRYP PFNGLGETSHARPENTEXFUNCSGISPROC) (GLenum target, GLfloat *points); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSharpenTexFuncSGIS (GLenum target, GLsizei n, const GLfloat *points); +GLAPI void APIENTRY glGetSharpenTexFuncSGIS (GLenum target, GLfloat *points); +#endif +#endif /* GL_SGIS_sharpen_texture */ + +#ifndef GL_SGIS_texture4D +#define GL_SGIS_texture4D 1 +#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 +typedef void (APIENTRYP PFNGLTEXIMAGE4DSGISPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLint border, GLenum format, GLenum type, const void *pixels); +typedef void (APIENTRYP 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 void *pixels); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTexImage4DSGIS (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLsizei size4d, GLint border, GLenum format, GLenum type, const void *pixels); +GLAPI void APIENTRY glTexSubImage4DSGIS (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 void *pixels); +#endif +#endif /* GL_SGIS_texture4D */ + +#ifndef GL_SGIS_texture_border_clamp +#define GL_SGIS_texture_border_clamp 1 +#define GL_CLAMP_TO_BORDER_SGIS 0x812D +#endif /* GL_SGIS_texture_border_clamp */ + +#ifndef GL_SGIS_texture_color_mask +#define GL_SGIS_texture_color_mask 1 +#define GL_TEXTURE_COLOR_WRITEMASK_SGIS 0x81EF +typedef void (APIENTRYP PFNGLTEXTURECOLORMASKSGISPROC) (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTextureColorMaskSGIS (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +#endif +#endif /* GL_SGIS_texture_color_mask */ + +#ifndef GL_SGIS_texture_edge_clamp +#define GL_SGIS_texture_edge_clamp 1 +#define GL_CLAMP_TO_EDGE_SGIS 0x812F +#endif /* GL_SGIS_texture_edge_clamp */ + +#ifndef GL_SGIS_texture_filter4 +#define GL_SGIS_texture_filter4 1 +#define GL_FILTER4_SGIS 0x8146 +#define GL_TEXTURE_FILTER4_SIZE_SGIS 0x8147 +typedef void (APIENTRYP PFNGLGETTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLfloat *weights); +typedef void (APIENTRYP PFNGLTEXFILTERFUNCSGISPROC) (GLenum target, GLenum filter, GLsizei n, const GLfloat *weights); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetTexFilterFuncSGIS (GLenum target, GLenum filter, GLfloat *weights); +GLAPI void APIENTRY glTexFilterFuncSGIS (GLenum target, GLenum filter, GLsizei n, const GLfloat *weights); +#endif +#endif /* GL_SGIS_texture_filter4 */ + +#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 +#endif /* GL_SGIS_texture_lod */ + +#ifndef GL_SGIS_texture_select +#define GL_SGIS_texture_select 1 +#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 /* GL_SGIS_texture_select */ + +#ifndef GL_SGIX_async +#define GL_SGIX_async 1 +#define GL_ASYNC_MARKER_SGIX 0x8329 +typedef void (APIENTRYP PFNGLASYNCMARKERSGIXPROC) (GLuint marker); +typedef GLint (APIENTRYP PFNGLFINISHASYNCSGIXPROC) (GLuint *markerp); +typedef GLint (APIENTRYP PFNGLPOLLASYNCSGIXPROC) (GLuint *markerp); +typedef GLuint (APIENTRYP PFNGLGENASYNCMARKERSSGIXPROC) (GLsizei range); +typedef void (APIENTRYP PFNGLDELETEASYNCMARKERSSGIXPROC) (GLuint marker, GLsizei range); +typedef GLboolean (APIENTRYP PFNGLISASYNCMARKERSGIXPROC) (GLuint marker); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glAsyncMarkerSGIX (GLuint marker); +GLAPI GLint APIENTRY glFinishAsyncSGIX (GLuint *markerp); +GLAPI GLint APIENTRY glPollAsyncSGIX (GLuint *markerp); +GLAPI GLuint APIENTRY glGenAsyncMarkersSGIX (GLsizei range); +GLAPI void APIENTRY glDeleteAsyncMarkersSGIX (GLuint marker, GLsizei range); +GLAPI GLboolean APIENTRY glIsAsyncMarkerSGIX (GLuint marker); +#endif +#endif /* GL_SGIX_async */ + +#ifndef GL_SGIX_async_histogram +#define GL_SGIX_async_histogram 1 +#define GL_ASYNC_HISTOGRAM_SGIX 0x832C +#define GL_MAX_ASYNC_HISTOGRAM_SGIX 0x832D +#endif /* GL_SGIX_async_histogram */ + +#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 +#endif /* GL_SGIX_async_pixel */ + +#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 +#endif /* GL_SGIX_blend_alpha_minmax */ + +#ifndef GL_SGIX_calligraphic_fragment +#define GL_SGIX_calligraphic_fragment 1 +#define GL_CALLIGRAPHIC_FRAGMENT_SGIX 0x8183 +#endif /* GL_SGIX_calligraphic_fragment */ + +#ifndef GL_SGIX_clipmap +#define GL_SGIX_clipmap 1 +#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 /* GL_SGIX_clipmap */ + +#ifndef GL_SGIX_convolution_accuracy +#define GL_SGIX_convolution_accuracy 1 +#define GL_CONVOLUTION_HINT_SGIX 0x8316 +#endif /* GL_SGIX_convolution_accuracy */ + +#ifndef GL_SGIX_depth_pass_instrument +#define GL_SGIX_depth_pass_instrument 1 +#endif /* GL_SGIX_depth_pass_instrument */ + +#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 +#endif /* GL_SGIX_depth_texture */ + +#ifndef GL_SGIX_flush_raster +#define GL_SGIX_flush_raster 1 +typedef void (APIENTRYP PFNGLFLUSHRASTERSGIXPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFlushRasterSGIX (void); +#endif +#endif /* GL_SGIX_flush_raster */ + +#ifndef GL_SGIX_fog_offset +#define GL_SGIX_fog_offset 1 +#define GL_FOG_OFFSET_SGIX 0x8198 +#define GL_FOG_OFFSET_VALUE_SGIX 0x8199 +#endif /* GL_SGIX_fog_offset */ + +#ifndef GL_SGIX_fragment_lighting +#define GL_SGIX_fragment_lighting 1 +#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 +typedef void (APIENTRYP PFNGLFRAGMENTCOLORMATERIALSGIXPROC) (GLenum face, GLenum mode); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTFSGIXPROC) (GLenum light, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTISGIXPROC) (GLenum light, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELFVSGIXPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELISGIXPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTLIGHTMODELIVSGIXPROC) (GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALFSGIXPROC) (GLenum face, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALISGIXPROC) (GLenum face, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTLIGHTFVSGIXPROC) (GLenum light, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTLIGHTIVSGIXPROC) (GLenum light, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTMATERIALFVSGIXPROC) (GLenum face, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETFRAGMENTMATERIALIVSGIXPROC) (GLenum face, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLLIGHTENVISGIXPROC) (GLenum pname, GLint param); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFragmentColorMaterialSGIX (GLenum face, GLenum mode); +GLAPI void APIENTRY glFragmentLightfSGIX (GLenum light, GLenum pname, GLfloat param); +GLAPI void APIENTRY glFragmentLightfvSGIX (GLenum light, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glFragmentLightiSGIX (GLenum light, GLenum pname, GLint param); +GLAPI void APIENTRY glFragmentLightivSGIX (GLenum light, GLenum pname, const GLint *params); +GLAPI void APIENTRY glFragmentLightModelfSGIX (GLenum pname, GLfloat param); +GLAPI void APIENTRY glFragmentLightModelfvSGIX (GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glFragmentLightModeliSGIX (GLenum pname, GLint param); +GLAPI void APIENTRY glFragmentLightModelivSGIX (GLenum pname, const GLint *params); +GLAPI void APIENTRY glFragmentMaterialfSGIX (GLenum face, GLenum pname, GLfloat param); +GLAPI void APIENTRY glFragmentMaterialfvSGIX (GLenum face, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glFragmentMaterialiSGIX (GLenum face, GLenum pname, GLint param); +GLAPI void APIENTRY glFragmentMaterialivSGIX (GLenum face, GLenum pname, const GLint *params); +GLAPI void APIENTRY glGetFragmentLightfvSGIX (GLenum light, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetFragmentLightivSGIX (GLenum light, GLenum pname, GLint *params); +GLAPI void APIENTRY glGetFragmentMaterialfvSGIX (GLenum face, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetFragmentMaterialivSGIX (GLenum face, GLenum pname, GLint *params); +GLAPI void APIENTRY glLightEnviSGIX (GLenum pname, GLint param); +#endif +#endif /* GL_SGIX_fragment_lighting */ + +#ifndef GL_SGIX_framezoom +#define GL_SGIX_framezoom 1 +#define GL_FRAMEZOOM_SGIX 0x818B +#define GL_FRAMEZOOM_FACTOR_SGIX 0x818C +#define GL_MAX_FRAMEZOOM_FACTOR_SGIX 0x818D +typedef void (APIENTRYP PFNGLFRAMEZOOMSGIXPROC) (GLint factor); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFrameZoomSGIX (GLint factor); +#endif +#endif /* GL_SGIX_framezoom */ + +#ifndef GL_SGIX_igloo_interface +#define GL_SGIX_igloo_interface 1 +typedef void (APIENTRYP PFNGLIGLOOINTERFACESGIXPROC) (GLenum pname, const void *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glIglooInterfaceSGIX (GLenum pname, const void *params); +#endif +#endif /* GL_SGIX_igloo_interface */ + +#ifndef GL_SGIX_instruments +#define GL_SGIX_instruments 1 +#define GL_INSTRUMENT_BUFFER_POINTER_SGIX 0x8180 +#define GL_INSTRUMENT_MEASUREMENTS_SGIX 0x8181 +typedef GLint (APIENTRYP PFNGLGETINSTRUMENTSSGIXPROC) (void); +typedef void (APIENTRYP PFNGLINSTRUMENTSBUFFERSGIXPROC) (GLsizei size, GLint *buffer); +typedef GLint (APIENTRYP PFNGLPOLLINSTRUMENTSSGIXPROC) (GLint *marker_p); +typedef void (APIENTRYP PFNGLREADINSTRUMENTSSGIXPROC) (GLint marker); +typedef void (APIENTRYP PFNGLSTARTINSTRUMENTSSGIXPROC) (void); +typedef void (APIENTRYP PFNGLSTOPINSTRUMENTSSGIXPROC) (GLint marker); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI GLint APIENTRY glGetInstrumentsSGIX (void); +GLAPI void APIENTRY glInstrumentsBufferSGIX (GLsizei size, GLint *buffer); +GLAPI GLint APIENTRY glPollInstrumentsSGIX (GLint *marker_p); +GLAPI void APIENTRY glReadInstrumentsSGIX (GLint marker); +GLAPI void APIENTRY glStartInstrumentsSGIX (void); +GLAPI void APIENTRY glStopInstrumentsSGIX (GLint marker); +#endif +#endif /* GL_SGIX_instruments */ + +#ifndef GL_SGIX_interlace +#define GL_SGIX_interlace 1 +#define GL_INTERLACE_SGIX 0x8094 +#endif /* GL_SGIX_interlace */ + +#ifndef GL_SGIX_ir_instrument1 +#define GL_SGIX_ir_instrument1 1 +#define GL_IR_INSTRUMENT1_SGIX 0x817F +#endif /* GL_SGIX_ir_instrument1 */ + +#ifndef GL_SGIX_list_priority +#define GL_SGIX_list_priority 1 +#define GL_LIST_PRIORITY_SGIX 0x8182 +typedef void (APIENTRYP PFNGLGETLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, GLint *params); +typedef void (APIENTRYP PFNGLLISTPARAMETERFSGIXPROC) (GLuint list, GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLLISTPARAMETERFVSGIXPROC) (GLuint list, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLLISTPARAMETERISGIXPROC) (GLuint list, GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLLISTPARAMETERIVSGIXPROC) (GLuint list, GLenum pname, const GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGetListParameterfvSGIX (GLuint list, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetListParameterivSGIX (GLuint list, GLenum pname, GLint *params); +GLAPI void APIENTRY glListParameterfSGIX (GLuint list, GLenum pname, GLfloat param); +GLAPI void APIENTRY glListParameterfvSGIX (GLuint list, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glListParameteriSGIX (GLuint list, GLenum pname, GLint param); +GLAPI void APIENTRY glListParameterivSGIX (GLuint list, GLenum pname, const GLint *params); +#endif +#endif /* GL_SGIX_list_priority */ + +#ifndef GL_SGIX_pixel_texture +#define GL_SGIX_pixel_texture 1 +#define GL_PIXEL_TEX_GEN_SGIX 0x8139 +#define GL_PIXEL_TEX_GEN_MODE_SGIX 0x832B +typedef void (APIENTRYP PFNGLPIXELTEXGENSGIXPROC) (GLenum mode); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glPixelTexGenSGIX (GLenum mode); +#endif +#endif /* GL_SGIX_pixel_texture */ + +#ifndef GL_SGIX_pixel_tiles +#define GL_SGIX_pixel_tiles 1 +#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 /* GL_SGIX_pixel_tiles */ + +#ifndef GL_SGIX_polynomial_ffd +#define GL_SGIX_polynomial_ffd 1 +#define GL_TEXTURE_DEFORMATION_BIT_SGIX 0x00000001 +#define GL_GEOMETRY_DEFORMATION_BIT_SGIX 0x00000002 +#define GL_GEOMETRY_DEFORMATION_SGIX 0x8194 +#define GL_TEXTURE_DEFORMATION_SGIX 0x8195 +#define GL_DEFORMATIONS_MASK_SGIX 0x8196 +#define GL_MAX_DEFORMATION_ORDER_SGIX 0x8197 +typedef void (APIENTRYP PFNGLDEFORMATIONMAP3DSGIXPROC) (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, GLdouble w1, GLdouble w2, GLint wstride, GLint worder, const GLdouble *points); +typedef void (APIENTRYP PFNGLDEFORMATIONMAP3FSGIXPROC) (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, GLfloat w1, GLfloat w2, GLint wstride, GLint worder, const GLfloat *points); +typedef void (APIENTRYP PFNGLDEFORMSGIXPROC) (GLbitfield mask); +typedef void (APIENTRYP PFNGLLOADIDENTITYDEFORMATIONMAPSGIXPROC) (GLbitfield mask); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDeformationMap3dSGIX (GLenum target, GLdouble u1, GLdouble u2, GLint ustride, GLint uorder, GLdouble v1, GLdouble v2, GLint vstride, GLint vorder, GLdouble w1, GLdouble w2, GLint wstride, GLint worder, const GLdouble *points); +GLAPI void APIENTRY glDeformationMap3fSGIX (GLenum target, GLfloat u1, GLfloat u2, GLint ustride, GLint uorder, GLfloat v1, GLfloat v2, GLint vstride, GLint vorder, GLfloat w1, GLfloat w2, GLint wstride, GLint worder, const GLfloat *points); +GLAPI void APIENTRY glDeformSGIX (GLbitfield mask); +GLAPI void APIENTRY glLoadIdentityDeformationMapSGIX (GLbitfield mask); +#endif +#endif /* GL_SGIX_polynomial_ffd */ + +#ifndef GL_SGIX_reference_plane +#define GL_SGIX_reference_plane 1 +#define GL_REFERENCE_PLANE_SGIX 0x817D +#define GL_REFERENCE_PLANE_EQUATION_SGIX 0x817E +typedef void (APIENTRYP PFNGLREFERENCEPLANESGIXPROC) (const GLdouble *equation); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glReferencePlaneSGIX (const GLdouble *equation); +#endif +#endif /* GL_SGIX_reference_plane */ + +#ifndef GL_SGIX_resample +#define GL_SGIX_resample 1 +#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 /* GL_SGIX_resample */ + +#ifndef GL_SGIX_scalebias_hint +#define GL_SGIX_scalebias_hint 1 +#define GL_SCALEBIAS_HINT_SGIX 0x8322 +#endif /* GL_SGIX_scalebias_hint */ + +#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 +#endif /* GL_SGIX_shadow */ + +#ifndef GL_SGIX_shadow_ambient +#define GL_SGIX_shadow_ambient 1 +#define GL_SHADOW_AMBIENT_SGIX 0x80BF +#endif /* GL_SGIX_shadow_ambient */ + +#ifndef GL_SGIX_sprite +#define GL_SGIX_sprite 1 +#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 +typedef void (APIENTRYP PFNGLSPRITEPARAMETERFSGIXPROC) (GLenum pname, GLfloat param); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERFVSGIXPROC) (GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERISGIXPROC) (GLenum pname, GLint param); +typedef void (APIENTRYP PFNGLSPRITEPARAMETERIVSGIXPROC) (GLenum pname, const GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glSpriteParameterfSGIX (GLenum pname, GLfloat param); +GLAPI void APIENTRY glSpriteParameterfvSGIX (GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glSpriteParameteriSGIX (GLenum pname, GLint param); +GLAPI void APIENTRY glSpriteParameterivSGIX (GLenum pname, const GLint *params); +#endif +#endif /* GL_SGIX_sprite */ + +#ifndef GL_SGIX_subsample +#define GL_SGIX_subsample 1 +#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 /* GL_SGIX_subsample */ + +#ifndef GL_SGIX_tag_sample_buffer +#define GL_SGIX_tag_sample_buffer 1 +typedef void (APIENTRYP PFNGLTAGSAMPLEBUFFERSGIXPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glTagSampleBufferSGIX (void); +#endif +#endif /* GL_SGIX_tag_sample_buffer */ + +#ifndef GL_SGIX_texture_add_env +#define GL_SGIX_texture_add_env 1 +#define GL_TEXTURE_ENV_BIAS_SGIX 0x80BE +#endif /* GL_SGIX_texture_add_env */ + +#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 +#endif /* GL_SGIX_texture_coordinate_clamp */ + +#ifndef GL_SGIX_texture_lod_bias +#define GL_SGIX_texture_lod_bias 1 +#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 /* GL_SGIX_texture_lod_bias */ + +#ifndef GL_SGIX_texture_multi_buffer +#define GL_SGIX_texture_multi_buffer 1 +#define GL_TEXTURE_MULTI_BUFFER_HINT_SGIX 0x812E +#endif /* GL_SGIX_texture_multi_buffer */ + +#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 +#endif /* GL_SGIX_texture_scale_bias */ + +#ifndef GL_SGIX_vertex_preclip +#define GL_SGIX_vertex_preclip 1 +#define GL_VERTEX_PRECLIP_SGIX 0x83EE +#define GL_VERTEX_PRECLIP_HINT_SGIX 0x83EF +#endif /* GL_SGIX_vertex_preclip */ + +#ifndef GL_SGIX_ycrcb +#define GL_SGIX_ycrcb 1 +#define GL_YCRCB_422_SGIX 0x81BB +#define GL_YCRCB_444_SGIX 0x81BC +#endif /* GL_SGIX_ycrcb */ + +#ifndef GL_SGIX_ycrcb_subsample +#define GL_SGIX_ycrcb_subsample 1 +#endif /* GL_SGIX_ycrcb_subsample */ + +#ifndef GL_SGIX_ycrcba +#define GL_SGIX_ycrcba 1 +#define GL_YCRCB_SGIX 0x8318 +#define GL_YCRCBA_SGIX 0x8319 +#endif /* GL_SGIX_ycrcba */ + +#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 +#endif /* GL_SGI_color_matrix */ + +#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 (APIENTRYP PFNGLCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *table); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, const GLfloat *params); +typedef void (APIENTRYP PFNGLCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, const GLint *params); +typedef void (APIENTRYP PFNGLCOPYCOLORTABLESGIPROC) (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +typedef void (APIENTRYP PFNGLGETCOLORTABLESGIPROC) (GLenum target, GLenum format, GLenum type, void *table); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERFVSGIPROC) (GLenum target, GLenum pname, GLfloat *params); +typedef void (APIENTRYP PFNGLGETCOLORTABLEPARAMETERIVSGIPROC) (GLenum target, GLenum pname, GLint *params); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColorTableSGI (GLenum target, GLenum internalformat, GLsizei width, GLenum format, GLenum type, const void *table); +GLAPI void APIENTRY glColorTableParameterfvSGI (GLenum target, GLenum pname, const GLfloat *params); +GLAPI void APIENTRY glColorTableParameterivSGI (GLenum target, GLenum pname, const GLint *params); +GLAPI void APIENTRY glCopyColorTableSGI (GLenum target, GLenum internalformat, GLint x, GLint y, GLsizei width); +GLAPI void APIENTRY glGetColorTableSGI (GLenum target, GLenum format, GLenum type, void *table); +GLAPI void APIENTRY glGetColorTableParameterfvSGI (GLenum target, GLenum pname, GLfloat *params); +GLAPI void APIENTRY glGetColorTableParameterivSGI (GLenum target, GLenum pname, GLint *params); +#endif +#endif /* GL_SGI_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 +#endif /* GL_SGI_texture_color_table */ + +#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 (APIENTRYP PFNGLFINISHTEXTURESUNXPROC) (void); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glFinishTextureSUNX (void); +#endif +#endif /* GL_SUNX_constant_data */ + +#ifndef GL_SUN_convolution_border_modes +#define GL_SUN_convolution_border_modes 1 +#define GL_WRAP_BORDER_SUN 0x81D4 +#endif /* GL_SUN_convolution_border_modes */ + +#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 (APIENTRYP PFNGLGLOBALALPHAFACTORBSUNPROC) (GLbyte factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORSSUNPROC) (GLshort factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORISUNPROC) (GLint factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORFSUNPROC) (GLfloat factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORDSUNPROC) (GLdouble factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUBSUNPROC) (GLubyte factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUSSUNPROC) (GLushort factor); +typedef void (APIENTRYP PFNGLGLOBALALPHAFACTORUISUNPROC) (GLuint factor); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glGlobalAlphaFactorbSUN (GLbyte factor); +GLAPI void APIENTRY glGlobalAlphaFactorsSUN (GLshort factor); +GLAPI void APIENTRY glGlobalAlphaFactoriSUN (GLint factor); +GLAPI void APIENTRY glGlobalAlphaFactorfSUN (GLfloat factor); +GLAPI void APIENTRY glGlobalAlphaFactordSUN (GLdouble factor); +GLAPI void APIENTRY glGlobalAlphaFactorubSUN (GLubyte factor); +GLAPI void APIENTRY glGlobalAlphaFactorusSUN (GLushort factor); +GLAPI void APIENTRY glGlobalAlphaFactoruiSUN (GLuint factor); +#endif +#endif /* GL_SUN_global_alpha */ + +#ifndef GL_SUN_mesh_array +#define GL_SUN_mesh_array 1 +#define GL_QUAD_MESH_SUN 0x8614 +#define GL_TRIANGLE_MESH_SUN 0x8615 +typedef void (APIENTRYP PFNGLDRAWMESHARRAYSSUNPROC) (GLenum mode, GLint first, GLsizei count, GLsizei width); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glDrawMeshArraysSUN (GLenum mode, GLint first, GLsizei count, GLsizei width); +#endif +#endif /* GL_SUN_mesh_array */ + +#ifndef GL_SUN_slice_accum +#define GL_SUN_slice_accum 1 +#define GL_SLICE_ACCUM_SUN 0x85CC +#endif /* GL_SUN_slice_accum */ + +#ifndef GL_SUN_triangle_list +#define GL_SUN_triangle_list 1 +#define GL_RESTART_SUN 0x0001 +#define GL_REPLACE_MIDDLE_SUN 0x0002 +#define GL_REPLACE_OLDEST_SUN 0x0003 +#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 (APIENTRYP PFNGLREPLACEMENTCODEUISUNPROC) (GLuint code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUSSUNPROC) (GLushort code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUBSUNPROC) (GLubyte code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVSUNPROC) (const GLuint *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUSVSUNPROC) (const GLushort *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUBVSUNPROC) (const GLubyte *code); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEPOINTERSUNPROC) (GLenum type, GLsizei stride, const void **pointer); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glReplacementCodeuiSUN (GLuint code); +GLAPI void APIENTRY glReplacementCodeusSUN (GLushort code); +GLAPI void APIENTRY glReplacementCodeubSUN (GLubyte code); +GLAPI void APIENTRY glReplacementCodeuivSUN (const GLuint *code); +GLAPI void APIENTRY glReplacementCodeusvSUN (const GLushort *code); +GLAPI void APIENTRY glReplacementCodeubvSUN (const GLubyte *code); +GLAPI void APIENTRY glReplacementCodePointerSUN (GLenum type, GLsizei stride, const void **pointer); +#endif +#endif /* GL_SUN_triangle_list */ + +#ifndef GL_SUN_vertex +#define GL_SUN_vertex 1 +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX2FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX2FVSUNPROC) (const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX3FSUNPROC) (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR4UBVERTEX3FVSUNPROC) (const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLNORMAL3FVERTEX3FSUNPROC) (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLCOLOR4FNORMAL3FVERTEX3FSUNPROC) (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD4FVERTEX4FSUNPROC) (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (APIENTRYP PFNGLTEXCOORD4FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4UBVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR4UBVERTEX3FVSUNPROC) (const GLfloat *tc, const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FCOLOR3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLTEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLTEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLTEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLTEXCOORD4FCOLOR4FNORMAL3FVERTEX4FVSUNPROC) (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVERTEX3FSUNPROC) (GLuint rc, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUIVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FSUNPROC) (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4UBVERTEX3FVSUNPROC) (const GLuint *rc, const GLubyte *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FSUNPROC) (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *c, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUINORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLREPLACEMENTCODEUICOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *v); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FSUNPROC) (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +typedef void (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); +typedef void (APIENTRYP 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 (APIENTRYP PFNGLREPLACEMENTCODEUITEXCOORD2FCOLOR4FNORMAL3FVERTEX3FVSUNPROC) (const GLuint *rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +#ifdef GL_GLEXT_PROTOTYPES +GLAPI void APIENTRY glColor4ubVertex2fSUN (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y); +GLAPI void APIENTRY glColor4ubVertex2fvSUN (const GLubyte *c, const GLfloat *v); +GLAPI void APIENTRY glColor4ubVertex3fSUN (GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glColor4ubVertex3fvSUN (const GLubyte *c, const GLfloat *v); +GLAPI void APIENTRY glColor3fVertex3fSUN (GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glColor3fVertex3fvSUN (const GLfloat *c, const GLfloat *v); +GLAPI void APIENTRY glNormal3fVertex3fSUN (GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glNormal3fVertex3fvSUN (const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glColor4fNormal3fVertex3fSUN (GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glColor4fNormal3fVertex3fvSUN (const GLfloat *c, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glTexCoord2fVertex3fSUN (GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glTexCoord2fVertex3fvSUN (const GLfloat *tc, const GLfloat *v); +GLAPI void APIENTRY glTexCoord4fVertex4fSUN (GLfloat s, GLfloat t, GLfloat p, GLfloat q, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GLAPI void APIENTRY glTexCoord4fVertex4fvSUN (const GLfloat *tc, const GLfloat *v); +GLAPI void APIENTRY glTexCoord2fColor4ubVertex3fSUN (GLfloat s, GLfloat t, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glTexCoord2fColor4ubVertex3fvSUN (const GLfloat *tc, const GLubyte *c, const GLfloat *v); +GLAPI void APIENTRY glTexCoord2fColor3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glTexCoord2fColor3fVertex3fvSUN (const GLfloat *tc, const GLfloat *c, const GLfloat *v); +GLAPI void APIENTRY glTexCoord2fNormal3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glTexCoord2fNormal3fVertex3fvSUN (const GLfloat *tc, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glTexCoord2fColor4fNormal3fVertex3fSUN (GLfloat s, GLfloat t, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glTexCoord2fColor4fNormal3fVertex3fvSUN (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glTexCoord4fColor4fNormal3fVertex4fSUN (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); +GLAPI void APIENTRY glTexCoord4fColor4fNormal3fVertex4fvSUN (const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiVertex3fSUN (GLuint rc, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiVertex3fvSUN (const GLuint *rc, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiColor4ubVertex3fSUN (GLuint rc, GLubyte r, GLubyte g, GLubyte b, GLubyte a, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiColor4ubVertex3fvSUN (const GLuint *rc, const GLubyte *c, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiColor3fVertex3fSUN (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiColor3fVertex3fvSUN (const GLuint *rc, const GLfloat *c, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiNormal3fVertex3fSUN (GLuint rc, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiNormal3fVertex3fvSUN (const GLuint *rc, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fSUN (GLuint rc, GLfloat r, GLfloat g, GLfloat b, GLfloat a, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiColor4fNormal3fVertex3fvSUN (const GLuint *rc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fVertex3fSUN (GLuint rc, GLfloat s, GLfloat t, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fVertex3fvSUN (const GLuint *rc, const GLfloat *tc, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fSUN (GLuint rc, GLfloat s, GLfloat t, GLfloat nx, GLfloat ny, GLfloat nz, GLfloat x, GLfloat y, GLfloat z); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fNormal3fVertex3fvSUN (const GLuint *rc, const GLfloat *tc, const GLfloat *n, const GLfloat *v); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fSUN (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); +GLAPI void APIENTRY glReplacementCodeuiTexCoord2fColor4fNormal3fVertex3fvSUN (const GLuint *rc, const GLfloat *tc, const GLfloat *c, const GLfloat *n, const GLfloat *v); +#endif +#endif /* GL_SUN_vertex */ + +#ifndef GL_WIN_phong_shading +#define GL_WIN_phong_shading 1 +#define GL_PHONG_WIN 0x80EA +#define GL_PHONG_HINT_WIN 0x80EB +#endif /* GL_WIN_phong_shading */ + +#ifndef GL_WIN_specular_fog +#define GL_WIN_specular_fog 1 +#define GL_FOG_SPECULAR_TEXTURE_WIN 0x80EC +#endif /* GL_WIN_specular_fog */ + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles.h new file mode 100644 index 0000000..1e0660c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles.h @@ -0,0 +1,39 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_opengles.h + * + * This is a simple file to encapsulate the OpenGL ES 1.X API headers. + */ +#include "SDL_config.h" + +#ifdef __IPHONEOS__ +#include +#include +#else +#include +#include +#endif + +#ifndef APIENTRY +#define APIENTRY +#endif diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2.h new file mode 100644 index 0000000..df29d38 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2.h @@ -0,0 +1,52 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_opengles2.h + * + * This is a simple file to encapsulate the OpenGL ES 2.0 API headers. + */ +#include "SDL_config.h" + +#ifndef _MSC_VER + +#ifdef __IPHONEOS__ +#include +#include +#else +#include +#include +#include +#endif + +#else /* _MSC_VER */ + +/* OpenGL ES2 headers for Visual Studio */ +#include "SDL_opengles2_khrplatform.h" +#include "SDL_opengles2_gl2platform.h" +#include "SDL_opengles2_gl2.h" +#include "SDL_opengles2_gl2ext.h" + +#endif /* _MSC_VER */ + +#ifndef APIENTRY +#define APIENTRY GL_APIENTRY +#endif diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2.h new file mode 100644 index 0000000..c62fb0a --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2.h @@ -0,0 +1,621 @@ +#ifndef __gl2_h_ +#define __gl2_h_ + +/* $Revision: 20555 $ on $Date:: 2013-02-12 14:32:47 -0800 #$ */ + +/*#include */ + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * This document is licensed under the SGI Free Software B License Version + * 2.0. For details, see http://oss.sgi.com/projects/FreeB/ . + */ + +/*------------------------------------------------------------------------- + * Data type definitions + *-----------------------------------------------------------------------*/ + +typedef void GLvoid; +typedef char GLchar; +typedef unsigned int GLenum; +typedef unsigned char GLboolean; +typedef unsigned int GLbitfield; +typedef khronos_int8_t GLbyte; +typedef short GLshort; +typedef int GLint; +typedef int GLsizei; +typedef khronos_uint8_t GLubyte; +typedef unsigned short GLushort; +typedef unsigned int GLuint; +typedef khronos_float_t GLfloat; +typedef khronos_float_t GLclampf; +typedef khronos_int32_t GLfixed; + +/* GL types for handling large vertex buffer objects */ +typedef khronos_intptr_t GLintptr; +typedef khronos_ssize_t GLsizeiptr; + +/* OpenGL ES core versions */ +#define GL_ES_VERSION_2_0 1 + +/* ClearBufferMask */ +#define GL_DEPTH_BUFFER_BIT 0x00000100 +#define GL_STENCIL_BUFFER_BIT 0x00000400 +#define GL_COLOR_BUFFER_BIT 0x00004000 + +/* Boolean */ +#define GL_FALSE 0 +#define GL_TRUE 1 + +/* BeginMode */ +#define GL_POINTS 0x0000 +#define GL_LINES 0x0001 +#define GL_LINE_LOOP 0x0002 +#define GL_LINE_STRIP 0x0003 +#define GL_TRIANGLES 0x0004 +#define GL_TRIANGLE_STRIP 0x0005 +#define GL_TRIANGLE_FAN 0x0006 + +/* AlphaFunction (not supported in ES20) */ +/* GL_NEVER */ +/* GL_LESS */ +/* GL_EQUAL */ +/* GL_LEQUAL */ +/* GL_GREATER */ +/* GL_NOTEQUAL */ +/* GL_GEQUAL */ +/* GL_ALWAYS */ + +/* BlendingFactorDest */ +#define GL_ZERO 0 +#define GL_ONE 1 +#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 + +/* BlendingFactorSrc */ +/* GL_ZERO */ +/* GL_ONE */ +#define GL_DST_COLOR 0x0306 +#define GL_ONE_MINUS_DST_COLOR 0x0307 +#define GL_SRC_ALPHA_SATURATE 0x0308 +/* GL_SRC_ALPHA */ +/* GL_ONE_MINUS_SRC_ALPHA */ +/* GL_DST_ALPHA */ +/* GL_ONE_MINUS_DST_ALPHA */ + +/* BlendEquationSeparate */ +#define GL_FUNC_ADD 0x8006 +#define GL_BLEND_EQUATION 0x8009 +#define GL_BLEND_EQUATION_RGB 0x8009 /* same as BLEND_EQUATION */ +#define GL_BLEND_EQUATION_ALPHA 0x883D + +/* BlendSubtract */ +#define GL_FUNC_SUBTRACT 0x800A +#define GL_FUNC_REVERSE_SUBTRACT 0x800B + +/* Separate Blend Functions */ +#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_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 + +/* Buffer Objects */ +#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_STREAM_DRAW 0x88E0 +#define GL_STATIC_DRAW 0x88E4 +#define GL_DYNAMIC_DRAW 0x88E8 + +#define GL_BUFFER_SIZE 0x8764 +#define GL_BUFFER_USAGE 0x8765 + +#define GL_CURRENT_VERTEX_ATTRIB 0x8626 + +/* CullFaceMode */ +#define GL_FRONT 0x0404 +#define GL_BACK 0x0405 +#define GL_FRONT_AND_BACK 0x0408 + +/* DepthFunction */ +/* GL_NEVER */ +/* GL_LESS */ +/* GL_EQUAL */ +/* GL_LEQUAL */ +/* GL_GREATER */ +/* GL_NOTEQUAL */ +/* GL_GEQUAL */ +/* GL_ALWAYS */ + +/* EnableCap */ +#define GL_TEXTURE_2D 0x0DE1 +#define GL_CULL_FACE 0x0B44 +#define GL_BLEND 0x0BE2 +#define GL_DITHER 0x0BD0 +#define GL_STENCIL_TEST 0x0B90 +#define GL_DEPTH_TEST 0x0B71 +#define GL_SCISSOR_TEST 0x0C11 +#define GL_POLYGON_OFFSET_FILL 0x8037 +#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E +#define GL_SAMPLE_COVERAGE 0x80A0 + +/* ErrorCode */ +#define GL_NO_ERROR 0 +#define GL_INVALID_ENUM 0x0500 +#define GL_INVALID_VALUE 0x0501 +#define GL_INVALID_OPERATION 0x0502 +#define GL_OUT_OF_MEMORY 0x0505 + +/* FrontFaceDirection */ +#define GL_CW 0x0900 +#define GL_CCW 0x0901 + +/* GetPName */ +#define GL_LINE_WIDTH 0x0B21 +#define GL_ALIASED_POINT_SIZE_RANGE 0x846D +#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E +#define GL_CULL_FACE_MODE 0x0B45 +#define GL_FRONT_FACE 0x0B46 +#define GL_DEPTH_RANGE 0x0B70 +#define GL_DEPTH_WRITEMASK 0x0B72 +#define GL_DEPTH_CLEAR_VALUE 0x0B73 +#define GL_DEPTH_FUNC 0x0B74 +#define GL_STENCIL_CLEAR_VALUE 0x0B91 +#define GL_STENCIL_FUNC 0x0B92 +#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_VALUE_MASK 0x0B93 +#define GL_STENCIL_WRITEMASK 0x0B98 +#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_STENCIL_BACK_REF 0x8CA3 +#define GL_STENCIL_BACK_VALUE_MASK 0x8CA4 +#define GL_STENCIL_BACK_WRITEMASK 0x8CA5 +#define GL_VIEWPORT 0x0BA2 +#define GL_SCISSOR_BOX 0x0C10 +/* GL_SCISSOR_TEST */ +#define GL_COLOR_CLEAR_VALUE 0x0C22 +#define GL_COLOR_WRITEMASK 0x0C23 +#define GL_UNPACK_ALIGNMENT 0x0CF5 +#define GL_PACK_ALIGNMENT 0x0D05 +#define GL_MAX_TEXTURE_SIZE 0x0D33 +#define GL_MAX_VIEWPORT_DIMS 0x0D3A +#define GL_SUBPIXEL_BITS 0x0D50 +#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_POLYGON_OFFSET_UNITS 0x2A00 +/* GL_POLYGON_OFFSET_FILL */ +#define GL_POLYGON_OFFSET_FACTOR 0x8038 +#define GL_TEXTURE_BINDING_2D 0x8069 +#define GL_SAMPLE_BUFFERS 0x80A8 +#define GL_SAMPLES 0x80A9 +#define GL_SAMPLE_COVERAGE_VALUE 0x80AA +#define GL_SAMPLE_COVERAGE_INVERT 0x80AB + +/* GetTextureParameter */ +/* GL_TEXTURE_MAG_FILTER */ +/* GL_TEXTURE_MIN_FILTER */ +/* GL_TEXTURE_WRAP_S */ +/* GL_TEXTURE_WRAP_T */ + +#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2 +#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3 + +/* HintMode */ +#define GL_DONT_CARE 0x1100 +#define GL_FASTEST 0x1101 +#define GL_NICEST 0x1102 + +/* HintTarget */ +#define GL_GENERATE_MIPMAP_HINT 0x8192 + +/* DataType */ +#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_FIXED 0x140C + +/* PixelFormat */ +#define GL_DEPTH_COMPONENT 0x1902 +#define GL_ALPHA 0x1906 +#define GL_RGB 0x1907 +#define GL_RGBA 0x1908 +#define GL_LUMINANCE 0x1909 +#define GL_LUMINANCE_ALPHA 0x190A + +/* PixelType */ +/* GL_UNSIGNED_BYTE */ +#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033 +#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034 +#define GL_UNSIGNED_SHORT_5_6_5 0x8363 + +/* Shaders */ +#define GL_FRAGMENT_SHADER 0x8B30 +#define GL_VERTEX_SHADER 0x8B31 +#define GL_MAX_VERTEX_ATTRIBS 0x8869 +#define GL_MAX_VERTEX_UNIFORM_VECTORS 0x8DFB +#define GL_MAX_VARYING_VECTORS 0x8DFC +#define GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS 0x8B4D +#define GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS 0x8B4C +#define GL_MAX_TEXTURE_IMAGE_UNITS 0x8872 +#define GL_MAX_FRAGMENT_UNIFORM_VECTORS 0x8DFD +#define GL_SHADER_TYPE 0x8B4F +#define GL_DELETE_STATUS 0x8B80 +#define GL_LINK_STATUS 0x8B82 +#define GL_VALIDATE_STATUS 0x8B83 +#define GL_ATTACHED_SHADERS 0x8B85 +#define GL_ACTIVE_UNIFORMS 0x8B86 +#define GL_ACTIVE_UNIFORM_MAX_LENGTH 0x8B87 +#define GL_ACTIVE_ATTRIBUTES 0x8B89 +#define GL_ACTIVE_ATTRIBUTE_MAX_LENGTH 0x8B8A +#define GL_SHADING_LANGUAGE_VERSION 0x8B8C +#define GL_CURRENT_PROGRAM 0x8B8D + +/* StencilFunction */ +#define GL_NEVER 0x0200 +#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 + +/* StencilOp */ +/* GL_ZERO */ +#define GL_KEEP 0x1E00 +#define GL_REPLACE 0x1E01 +#define GL_INCR 0x1E02 +#define GL_DECR 0x1E03 +#define GL_INVERT 0x150A +#define GL_INCR_WRAP 0x8507 +#define GL_DECR_WRAP 0x8508 + +/* StringName */ +#define GL_VENDOR 0x1F00 +#define GL_RENDERER 0x1F01 +#define GL_VERSION 0x1F02 +#define GL_EXTENSIONS 0x1F03 + +/* TextureMagFilter */ +#define GL_NEAREST 0x2600 +#define GL_LINEAR 0x2601 + +/* TextureMinFilter */ +/* GL_NEAREST */ +/* GL_LINEAR */ +#define GL_NEAREST_MIPMAP_NEAREST 0x2700 +#define GL_LINEAR_MIPMAP_NEAREST 0x2701 +#define GL_NEAREST_MIPMAP_LINEAR 0x2702 +#define GL_LINEAR_MIPMAP_LINEAR 0x2703 + +/* TextureParameterName */ +#define GL_TEXTURE_MAG_FILTER 0x2800 +#define GL_TEXTURE_MIN_FILTER 0x2801 +#define GL_TEXTURE_WRAP_S 0x2802 +#define GL_TEXTURE_WRAP_T 0x2803 + +/* TextureTarget */ +/* GL_TEXTURE_2D */ +#define GL_TEXTURE 0x1702 + +#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_MAX_CUBE_MAP_TEXTURE_SIZE 0x851C + +/* TextureUnit */ +#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 + +/* TextureWrapMode */ +#define GL_REPEAT 0x2901 +#define GL_CLAMP_TO_EDGE 0x812F +#define GL_MIRRORED_REPEAT 0x8370 + +/* Uniform Types */ +#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_2D 0x8B5E +#define GL_SAMPLER_CUBE 0x8B60 + +/* Vertex Arrays */ +#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_VERTEX_ATTRIB_ARRAY_NORMALIZED 0x886A +#define GL_VERTEX_ATTRIB_ARRAY_POINTER 0x8645 +#define GL_VERTEX_ATTRIB_ARRAY_BUFFER_BINDING 0x889F + +/* Read Format */ +#define GL_IMPLEMENTATION_COLOR_READ_TYPE 0x8B9A +#define GL_IMPLEMENTATION_COLOR_READ_FORMAT 0x8B9B + +/* Shader Source */ +#define GL_COMPILE_STATUS 0x8B81 +#define GL_INFO_LOG_LENGTH 0x8B84 +#define GL_SHADER_SOURCE_LENGTH 0x8B88 +#define GL_SHADER_COMPILER 0x8DFA + +/* Shader Binary */ +#define GL_SHADER_BINARY_FORMATS 0x8DF8 +#define GL_NUM_SHADER_BINARY_FORMATS 0x8DF9 + +/* Shader Precision-Specified Types */ +#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 + +/* Framebuffer Object. */ +#define GL_FRAMEBUFFER 0x8D40 +#define GL_RENDERBUFFER 0x8D41 + +#define GL_RGBA4 0x8056 +#define GL_RGB5_A1 0x8057 +#define GL_RGB565 0x8D62 +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_STENCIL_INDEX8 0x8D48 + +#define GL_RENDERBUFFER_WIDTH 0x8D42 +#define GL_RENDERBUFFER_HEIGHT 0x8D43 +#define GL_RENDERBUFFER_INTERNAL_FORMAT 0x8D44 +#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_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_COLOR_ATTACHMENT0 0x8CE0 +#define GL_DEPTH_ATTACHMENT 0x8D00 +#define GL_STENCIL_ATTACHMENT 0x8D20 + +#define GL_NONE 0 + +#define GL_FRAMEBUFFER_COMPLETE 0x8CD5 +#define GL_FRAMEBUFFER_INCOMPLETE_ATTACHMENT 0x8CD6 +#define GL_FRAMEBUFFER_INCOMPLETE_MISSING_ATTACHMENT 0x8CD7 +#define GL_FRAMEBUFFER_INCOMPLETE_DIMENSIONS 0x8CD9 +#define GL_FRAMEBUFFER_UNSUPPORTED 0x8CDD + +#define GL_FRAMEBUFFER_BINDING 0x8CA6 +#define GL_RENDERBUFFER_BINDING 0x8CA7 +#define GL_MAX_RENDERBUFFER_SIZE 0x84E8 + +#define GL_INVALID_FRAMEBUFFER_OPERATION 0x0506 + +/*------------------------------------------------------------------------- + * GL core functions. + *-----------------------------------------------------------------------*/ + +GL_APICALL void GL_APIENTRY glActiveTexture (GLenum texture); +GL_APICALL void GL_APIENTRY glAttachShader (GLuint program, GLuint shader); +GL_APICALL void GL_APIENTRY glBindAttribLocation (GLuint program, GLuint index, const GLchar* name); +GL_APICALL void GL_APIENTRY glBindBuffer (GLenum target, GLuint buffer); +GL_APICALL void GL_APIENTRY glBindFramebuffer (GLenum target, GLuint framebuffer); +GL_APICALL void GL_APIENTRY glBindRenderbuffer (GLenum target, GLuint renderbuffer); +GL_APICALL void GL_APIENTRY glBindTexture (GLenum target, GLuint texture); +GL_APICALL void GL_APIENTRY glBlendColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GL_APICALL void GL_APIENTRY glBlendEquation ( GLenum mode ); +GL_APICALL void GL_APIENTRY glBlendEquationSeparate (GLenum modeRGB, GLenum modeAlpha); +GL_APICALL void GL_APIENTRY glBlendFunc (GLenum sfactor, GLenum dfactor); +GL_APICALL void GL_APIENTRY glBlendFuncSeparate (GLenum srcRGB, GLenum dstRGB, GLenum srcAlpha, GLenum dstAlpha); +GL_APICALL void GL_APIENTRY glBufferData (GLenum target, GLsizeiptr size, const GLvoid* data, GLenum usage); +GL_APICALL void GL_APIENTRY glBufferSubData (GLenum target, GLintptr offset, GLsizeiptr size, const GLvoid* data); +GL_APICALL GLenum GL_APIENTRY glCheckFramebufferStatus (GLenum target); +GL_APICALL void GL_APIENTRY glClear (GLbitfield mask); +GL_APICALL void GL_APIENTRY glClearColor (GLclampf red, GLclampf green, GLclampf blue, GLclampf alpha); +GL_APICALL void GL_APIENTRY glClearDepthf (GLclampf depth); +GL_APICALL void GL_APIENTRY glClearStencil (GLint s); +GL_APICALL void GL_APIENTRY glColorMask (GLboolean red, GLboolean green, GLboolean blue, GLboolean alpha); +GL_APICALL void GL_APIENTRY glCompileShader (GLuint shader); +GL_APICALL void GL_APIENTRY glCompressedTexImage2D (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLint border, GLsizei imageSize, const GLvoid* data); +GL_APICALL void GL_APIENTRY glCompressedTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLsizei imageSize, const GLvoid* data); +GL_APICALL void GL_APIENTRY glCopyTexImage2D (GLenum target, GLint level, GLenum internalformat, GLint x, GLint y, GLsizei width, GLsizei height, GLint border); +GL_APICALL void GL_APIENTRY glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GL_APICALL GLuint GL_APIENTRY glCreateProgram (void); +GL_APICALL GLuint GL_APIENTRY glCreateShader (GLenum type); +GL_APICALL void GL_APIENTRY glCullFace (GLenum mode); +GL_APICALL void GL_APIENTRY glDeleteBuffers (GLsizei n, const GLuint* buffers); +GL_APICALL void GL_APIENTRY glDeleteFramebuffers (GLsizei n, const GLuint* framebuffers); +GL_APICALL void GL_APIENTRY glDeleteProgram (GLuint program); +GL_APICALL void GL_APIENTRY glDeleteRenderbuffers (GLsizei n, const GLuint* renderbuffers); +GL_APICALL void GL_APIENTRY glDeleteShader (GLuint shader); +GL_APICALL void GL_APIENTRY glDeleteTextures (GLsizei n, const GLuint* textures); +GL_APICALL void GL_APIENTRY glDepthFunc (GLenum func); +GL_APICALL void GL_APIENTRY glDepthMask (GLboolean flag); +GL_APICALL void GL_APIENTRY glDepthRangef (GLclampf zNear, GLclampf zFar); +GL_APICALL void GL_APIENTRY glDetachShader (GLuint program, GLuint shader); +GL_APICALL void GL_APIENTRY glDisable (GLenum cap); +GL_APICALL void GL_APIENTRY glDisableVertexAttribArray (GLuint index); +GL_APICALL void GL_APIENTRY glDrawArrays (GLenum mode, GLint first, GLsizei count); +GL_APICALL void GL_APIENTRY glDrawElements (GLenum mode, GLsizei count, GLenum type, const GLvoid* indices); +GL_APICALL void GL_APIENTRY glEnable (GLenum cap); +GL_APICALL void GL_APIENTRY glEnableVertexAttribArray (GLuint index); +GL_APICALL void GL_APIENTRY glFinish (void); +GL_APICALL void GL_APIENTRY glFlush (void); +GL_APICALL void GL_APIENTRY glFramebufferRenderbuffer (GLenum target, GLenum attachment, GLenum renderbuffertarget, GLuint renderbuffer); +GL_APICALL void GL_APIENTRY glFramebufferTexture2D (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level); +GL_APICALL void GL_APIENTRY glFrontFace (GLenum mode); +GL_APICALL void GL_APIENTRY glGenBuffers (GLsizei n, GLuint* buffers); +GL_APICALL void GL_APIENTRY glGenerateMipmap (GLenum target); +GL_APICALL void GL_APIENTRY glGenFramebuffers (GLsizei n, GLuint* framebuffers); +GL_APICALL void GL_APIENTRY glGenRenderbuffers (GLsizei n, GLuint* renderbuffers); +GL_APICALL void GL_APIENTRY glGenTextures (GLsizei n, GLuint* textures); +GL_APICALL void GL_APIENTRY glGetActiveAttrib (GLuint program, GLuint index, GLsizei bufsize, GLsizei* length, GLint* size, GLenum* type, GLchar* name); +GL_APICALL void GL_APIENTRY glGetActiveUniform (GLuint program, GLuint index, GLsizei bufsize, GLsizei* length, GLint* size, GLenum* type, GLchar* name); +GL_APICALL void GL_APIENTRY glGetAttachedShaders (GLuint program, GLsizei maxcount, GLsizei* count, GLuint* shaders); +GL_APICALL GLint GL_APIENTRY glGetAttribLocation (GLuint program, const GLchar* name); +GL_APICALL void GL_APIENTRY glGetBooleanv (GLenum pname, GLboolean* params); +GL_APICALL void GL_APIENTRY glGetBufferParameteriv (GLenum target, GLenum pname, GLint* params); +GL_APICALL GLenum GL_APIENTRY glGetError (void); +GL_APICALL void GL_APIENTRY glGetFloatv (GLenum pname, GLfloat* params); +GL_APICALL void GL_APIENTRY glGetFramebufferAttachmentParameteriv (GLenum target, GLenum attachment, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetIntegerv (GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetProgramiv (GLuint program, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetProgramInfoLog (GLuint program, GLsizei bufsize, GLsizei* length, GLchar* infolog); +GL_APICALL void GL_APIENTRY glGetRenderbufferParameteriv (GLenum target, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetShaderiv (GLuint shader, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetShaderInfoLog (GLuint shader, GLsizei bufsize, GLsizei* length, GLchar* infolog); +GL_APICALL void GL_APIENTRY glGetShaderPrecisionFormat (GLenum shadertype, GLenum precisiontype, GLint* range, GLint* precision); +GL_APICALL void GL_APIENTRY glGetShaderSource (GLuint shader, GLsizei bufsize, GLsizei* length, GLchar* source); +GL_APICALL const GLubyte* GL_APIENTRY glGetString (GLenum name); +GL_APICALL void GL_APIENTRY glGetTexParameterfv (GLenum target, GLenum pname, GLfloat* params); +GL_APICALL void GL_APIENTRY glGetTexParameteriv (GLenum target, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetUniformfv (GLuint program, GLint location, GLfloat* params); +GL_APICALL void GL_APIENTRY glGetUniformiv (GLuint program, GLint location, GLint* params); +GL_APICALL GLint GL_APIENTRY glGetUniformLocation (GLuint program, const GLchar* name); +GL_APICALL void GL_APIENTRY glGetVertexAttribfv (GLuint index, GLenum pname, GLfloat* params); +GL_APICALL void GL_APIENTRY glGetVertexAttribiv (GLuint index, GLenum pname, GLint* params); +GL_APICALL void GL_APIENTRY glGetVertexAttribPointerv (GLuint index, GLenum pname, GLvoid** pointer); +GL_APICALL void GL_APIENTRY glHint (GLenum target, GLenum mode); +GL_APICALL GLboolean GL_APIENTRY glIsBuffer (GLuint buffer); +GL_APICALL GLboolean GL_APIENTRY glIsEnabled (GLenum cap); +GL_APICALL GLboolean GL_APIENTRY glIsFramebuffer (GLuint framebuffer); +GL_APICALL GLboolean GL_APIENTRY glIsProgram (GLuint program); +GL_APICALL GLboolean GL_APIENTRY glIsRenderbuffer (GLuint renderbuffer); +GL_APICALL GLboolean GL_APIENTRY glIsShader (GLuint shader); +GL_APICALL GLboolean GL_APIENTRY glIsTexture (GLuint texture); +GL_APICALL void GL_APIENTRY glLineWidth (GLfloat width); +GL_APICALL void GL_APIENTRY glLinkProgram (GLuint program); +GL_APICALL void GL_APIENTRY glPixelStorei (GLenum pname, GLint param); +GL_APICALL void GL_APIENTRY glPolygonOffset (GLfloat factor, GLfloat units); +GL_APICALL void GL_APIENTRY glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid* pixels); +GL_APICALL void GL_APIENTRY glReleaseShaderCompiler (void); +GL_APICALL void GL_APIENTRY glRenderbufferStorage (GLenum target, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glSampleCoverage (GLclampf value, GLboolean invert); +GL_APICALL void GL_APIENTRY glScissor (GLint x, GLint y, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glShaderBinary (GLsizei n, const GLuint* shaders, GLenum binaryformat, const GLvoid* binary, GLsizei length); +GL_APICALL void GL_APIENTRY glShaderSource (GLuint shader, GLsizei count, const GLchar* const* string, const GLint* length); +GL_APICALL void GL_APIENTRY glStencilFunc (GLenum func, GLint ref, GLuint mask); +GL_APICALL void GL_APIENTRY glStencilFuncSeparate (GLenum face, GLenum func, GLint ref, GLuint mask); +GL_APICALL void GL_APIENTRY glStencilMask (GLuint mask); +GL_APICALL void GL_APIENTRY glStencilMaskSeparate (GLenum face, GLuint mask); +GL_APICALL void GL_APIENTRY glStencilOp (GLenum fail, GLenum zfail, GLenum zpass); +GL_APICALL void GL_APIENTRY glStencilOpSeparate (GLenum face, GLenum fail, GLenum zfail, GLenum zpass); +GL_APICALL void GL_APIENTRY glTexImage2D (GLenum target, GLint level, GLint internalformat, GLsizei width, GLsizei height, GLint border, GLenum format, GLenum type, const GLvoid* pixels); +GL_APICALL void GL_APIENTRY glTexParameterf (GLenum target, GLenum pname, GLfloat param); +GL_APICALL void GL_APIENTRY glTexParameterfv (GLenum target, GLenum pname, const GLfloat* params); +GL_APICALL void GL_APIENTRY glTexParameteri (GLenum target, GLenum pname, GLint param); +GL_APICALL void GL_APIENTRY glTexParameteriv (GLenum target, GLenum pname, const GLint* params); +GL_APICALL void GL_APIENTRY glTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLsizei width, GLsizei height, GLenum format, GLenum type, const GLvoid* pixels); +GL_APICALL void GL_APIENTRY glUniform1f (GLint location, GLfloat x); +GL_APICALL void GL_APIENTRY glUniform1fv (GLint location, GLsizei count, const GLfloat* v); +GL_APICALL void GL_APIENTRY glUniform1i (GLint location, GLint x); +GL_APICALL void GL_APIENTRY glUniform1iv (GLint location, GLsizei count, const GLint* v); +GL_APICALL void GL_APIENTRY glUniform2f (GLint location, GLfloat x, GLfloat y); +GL_APICALL void GL_APIENTRY glUniform2fv (GLint location, GLsizei count, const GLfloat* v); +GL_APICALL void GL_APIENTRY glUniform2i (GLint location, GLint x, GLint y); +GL_APICALL void GL_APIENTRY glUniform2iv (GLint location, GLsizei count, const GLint* v); +GL_APICALL void GL_APIENTRY glUniform3f (GLint location, GLfloat x, GLfloat y, GLfloat z); +GL_APICALL void GL_APIENTRY glUniform3fv (GLint location, GLsizei count, const GLfloat* v); +GL_APICALL void GL_APIENTRY glUniform3i (GLint location, GLint x, GLint y, GLint z); +GL_APICALL void GL_APIENTRY glUniform3iv (GLint location, GLsizei count, const GLint* v); +GL_APICALL void GL_APIENTRY glUniform4f (GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GL_APICALL void GL_APIENTRY glUniform4fv (GLint location, GLsizei count, const GLfloat* v); +GL_APICALL void GL_APIENTRY glUniform4i (GLint location, GLint x, GLint y, GLint z, GLint w); +GL_APICALL void GL_APIENTRY glUniform4iv (GLint location, GLsizei count, const GLint* v); +GL_APICALL void GL_APIENTRY glUniformMatrix2fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +GL_APICALL void GL_APIENTRY glUniformMatrix3fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +GL_APICALL void GL_APIENTRY glUniformMatrix4fv (GLint location, GLsizei count, GLboolean transpose, const GLfloat* value); +GL_APICALL void GL_APIENTRY glUseProgram (GLuint program); +GL_APICALL void GL_APIENTRY glValidateProgram (GLuint program); +GL_APICALL void GL_APIENTRY glVertexAttrib1f (GLuint indx, GLfloat x); +GL_APICALL void GL_APIENTRY glVertexAttrib1fv (GLuint indx, const GLfloat* values); +GL_APICALL void GL_APIENTRY glVertexAttrib2f (GLuint indx, GLfloat x, GLfloat y); +GL_APICALL void GL_APIENTRY glVertexAttrib2fv (GLuint indx, const GLfloat* values); +GL_APICALL void GL_APIENTRY glVertexAttrib3f (GLuint indx, GLfloat x, GLfloat y, GLfloat z); +GL_APICALL void GL_APIENTRY glVertexAttrib3fv (GLuint indx, const GLfloat* values); +GL_APICALL void GL_APIENTRY glVertexAttrib4f (GLuint indx, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GL_APICALL void GL_APIENTRY glVertexAttrib4fv (GLuint indx, const GLfloat* values); +GL_APICALL void GL_APIENTRY glVertexAttribPointer (GLuint indx, GLint size, GLenum type, GLboolean normalized, GLsizei stride, const GLvoid* ptr); +GL_APICALL void GL_APIENTRY glViewport (GLint x, GLint y, GLsizei width, GLsizei height); + +#ifdef __cplusplus +} +#endif + +#endif /* __gl2_h_ */ + diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2ext.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2ext.h new file mode 100644 index 0000000..e8ca8b1 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2ext.h @@ -0,0 +1,2050 @@ +#ifndef __gl2ext_h_ +#define __gl2ext_h_ + +/* $Revision: 22801 $ on $Date:: 2013-08-21 03:20:48 -0700 #$ */ + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * This document is licensed under the SGI Free Software B License Version + * 2.0. For details, see http://oss.sgi.com/projects/FreeB/ . + */ + +#ifndef GL_APIENTRYP +# define GL_APIENTRYP GL_APIENTRY* +#endif + +/* New types shared by several extensions */ + +#ifndef __gl3_h_ +/* These are defined with respect to in the + * Apple extension spec, but they are also used by non-APPLE + * extensions, and in the Khronos header we use the Khronos + * portable types in khrplatform.h, which must be defined. + */ +typedef khronos_int64_t GLint64; +typedef khronos_uint64_t GLuint64; +typedef struct __GLsync *GLsync; +#endif + + +/*------------------------------------------------------------------------* + * OES extension tokens + *------------------------------------------------------------------------*/ + +/* GL_OES_compressed_ETC1_RGB8_texture */ +#ifndef GL_OES_compressed_ETC1_RGB8_texture +#define GL_ETC1_RGB8_OES 0x8D64 +#endif + +/* GL_OES_compressed_paletted_texture */ +#ifndef GL_OES_compressed_paletted_texture +#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 +#endif + +/* GL_OES_depth24 */ +#ifndef GL_OES_depth24 +#define GL_DEPTH_COMPONENT24_OES 0x81A6 +#endif + +/* GL_OES_depth32 */ +#ifndef GL_OES_depth32 +#define GL_DEPTH_COMPONENT32_OES 0x81A7 +#endif + +/* GL_OES_depth_texture */ +/* No new tokens introduced by this extension. */ + +/* GL_OES_EGL_image */ +#ifndef GL_OES_EGL_image +typedef void* GLeglImageOES; +#endif + +/* GL_OES_EGL_image_external */ +#ifndef GL_OES_EGL_image_external +/* GLeglImageOES defined in GL_OES_EGL_image already. */ +#define GL_TEXTURE_EXTERNAL_OES 0x8D65 +#define GL_SAMPLER_EXTERNAL_OES 0x8D66 +#define GL_TEXTURE_BINDING_EXTERNAL_OES 0x8D67 +#define GL_REQUIRED_TEXTURE_IMAGE_UNITS_OES 0x8D68 +#endif + +/* GL_OES_element_index_uint */ +#ifndef GL_OES_element_index_uint +#define GL_UNSIGNED_INT 0x1405 +#endif + +/* GL_OES_get_program_binary */ +#ifndef GL_OES_get_program_binary +#define GL_PROGRAM_BINARY_LENGTH_OES 0x8741 +#define GL_NUM_PROGRAM_BINARY_FORMATS_OES 0x87FE +#define GL_PROGRAM_BINARY_FORMATS_OES 0x87FF +#endif + +/* GL_OES_mapbuffer */ +#ifndef GL_OES_mapbuffer +#define GL_WRITE_ONLY_OES 0x88B9 +#define GL_BUFFER_ACCESS_OES 0x88BB +#define GL_BUFFER_MAPPED_OES 0x88BC +#define GL_BUFFER_MAP_POINTER_OES 0x88BD +#endif + +/* GL_OES_packed_depth_stencil */ +#ifndef GL_OES_packed_depth_stencil +#define GL_DEPTH_STENCIL_OES 0x84F9 +#define GL_UNSIGNED_INT_24_8_OES 0x84FA +#define GL_DEPTH24_STENCIL8_OES 0x88F0 +#endif + +/* GL_OES_required_internalformat */ +#ifndef GL_OES_required_internalformat +#define GL_ALPHA8_OES 0x803C +#define GL_DEPTH_COMPONENT16_OES 0x81A5 +/* reuse GL_DEPTH_COMPONENT24_OES */ +/* reuse GL_DEPTH24_STENCIL8_OES */ +/* reuse GL_DEPTH_COMPONENT32_OES */ +#define GL_LUMINANCE4_ALPHA4_OES 0x8043 +#define GL_LUMINANCE8_ALPHA8_OES 0x8045 +#define GL_LUMINANCE8_OES 0x8040 +#define GL_RGBA4_OES 0x8056 +#define GL_RGB5_A1_OES 0x8057 +#define GL_RGB565_OES 0x8D62 +/* reuse GL_RGB8_OES */ +/* reuse GL_RGBA8_OES */ +/* reuse GL_RGB10_EXT */ +/* reuse GL_RGB10_A2_EXT */ +#endif + +/* GL_OES_rgb8_rgba8 */ +#ifndef GL_OES_rgb8_rgba8 +#define GL_RGB8_OES 0x8051 +#define GL_RGBA8_OES 0x8058 +#endif + +/* GL_OES_standard_derivatives */ +#ifndef GL_OES_standard_derivatives +#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT_OES 0x8B8B +#endif + +/* GL_OES_stencil1 */ +#ifndef GL_OES_stencil1 +#define GL_STENCIL_INDEX1_OES 0x8D46 +#endif + +/* GL_OES_stencil4 */ +#ifndef GL_OES_stencil4 +#define GL_STENCIL_INDEX4_OES 0x8D47 +#endif + +#ifndef GL_OES_surfaceless_context +#define GL_FRAMEBUFFER_UNDEFINED_OES 0x8219 +#endif + +/* GL_OES_texture_3D */ +#ifndef GL_OES_texture_3D +#define GL_TEXTURE_WRAP_R_OES 0x8072 +#define GL_TEXTURE_3D_OES 0x806F +#define GL_TEXTURE_BINDING_3D_OES 0x806A +#define GL_MAX_3D_TEXTURE_SIZE_OES 0x8073 +#define GL_SAMPLER_3D_OES 0x8B5F +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET_OES 0x8CD4 +#endif + +/* GL_OES_texture_float */ +/* No new tokens introduced by this extension. */ + +/* GL_OES_texture_float_linear */ +/* No new tokens introduced by this extension. */ + +/* GL_OES_texture_half_float */ +#ifndef GL_OES_texture_half_float +#define GL_HALF_FLOAT_OES 0x8D61 +#endif + +/* GL_OES_texture_half_float_linear */ +/* No new tokens introduced by this extension. */ + +/* GL_OES_texture_npot */ +/* No new tokens introduced by this extension. */ + +/* GL_OES_vertex_array_object */ +#ifndef GL_OES_vertex_array_object +#define GL_VERTEX_ARRAY_BINDING_OES 0x85B5 +#endif + +/* GL_OES_vertex_half_float */ +/* GL_HALF_FLOAT_OES defined in GL_OES_texture_half_float already. */ + +/* GL_OES_vertex_type_10_10_10_2 */ +#ifndef GL_OES_vertex_type_10_10_10_2 +#define GL_UNSIGNED_INT_10_10_10_2_OES 0x8DF6 +#define GL_INT_10_10_10_2_OES 0x8DF7 +#endif + +/*------------------------------------------------------------------------* + * KHR extension tokens + *------------------------------------------------------------------------*/ + +#ifndef GL_KHR_debug +typedef void (GL_APIENTRYP GLDEBUGPROCKHR)(GLenum source,GLenum type,GLuint id,GLenum severity,GLsizei length,const GLchar *message,const void *userParam); +#define GL_DEBUG_OUTPUT_SYNCHRONOUS_KHR 0x8242 +#define GL_DEBUG_NEXT_LOGGED_MESSAGE_LENGTH_KHR 0x8243 +#define GL_DEBUG_CALLBACK_FUNCTION_KHR 0x8244 +#define GL_DEBUG_CALLBACK_USER_PARAM_KHR 0x8245 +#define GL_DEBUG_SOURCE_API_KHR 0x8246 +#define GL_DEBUG_SOURCE_WINDOW_SYSTEM_KHR 0x8247 +#define GL_DEBUG_SOURCE_SHADER_COMPILER_KHR 0x8248 +#define GL_DEBUG_SOURCE_THIRD_PARTY_KHR 0x8249 +#define GL_DEBUG_SOURCE_APPLICATION_KHR 0x824A +#define GL_DEBUG_SOURCE_OTHER_KHR 0x824B +#define GL_DEBUG_TYPE_ERROR_KHR 0x824C +#define GL_DEBUG_TYPE_DEPRECATED_BEHAVIOR_KHR 0x824D +#define GL_DEBUG_TYPE_UNDEFINED_BEHAVIOR_KHR 0x824E +#define GL_DEBUG_TYPE_PORTABILITY_KHR 0x824F +#define GL_DEBUG_TYPE_PERFORMANCE_KHR 0x8250 +#define GL_DEBUG_TYPE_OTHER_KHR 0x8251 +#define GL_DEBUG_TYPE_MARKER_KHR 0x8268 +#define GL_DEBUG_TYPE_PUSH_GROUP_KHR 0x8269 +#define GL_DEBUG_TYPE_POP_GROUP_KHR 0x826A +#define GL_DEBUG_SEVERITY_NOTIFICATION_KHR 0x826B +#define GL_MAX_DEBUG_GROUP_STACK_DEPTH_KHR 0x826C +#define GL_DEBUG_GROUP_STACK_DEPTH_KHR 0x826D +#define GL_BUFFER_KHR 0x82E0 +#define GL_SHADER_KHR 0x82E1 +#define GL_PROGRAM_KHR 0x82E2 +#define GL_QUERY_KHR 0x82E3 +/* PROGRAM_PIPELINE only in GL */ +#define GL_SAMPLER_KHR 0x82E6 +/* DISPLAY_LIST only in GL */ +#define GL_MAX_LABEL_LENGTH_KHR 0x82E8 +#define GL_MAX_DEBUG_MESSAGE_LENGTH_KHR 0x9143 +#define GL_MAX_DEBUG_LOGGED_MESSAGES_KHR 0x9144 +#define GL_DEBUG_LOGGED_MESSAGES_KHR 0x9145 +#define GL_DEBUG_SEVERITY_HIGH_KHR 0x9146 +#define GL_DEBUG_SEVERITY_MEDIUM_KHR 0x9147 +#define GL_DEBUG_SEVERITY_LOW_KHR 0x9148 +#define GL_DEBUG_OUTPUT_KHR 0x92E0 +#define GL_CONTEXT_FLAG_DEBUG_BIT_KHR 0x00000002 +#define GL_STACK_OVERFLOW_KHR 0x0503 +#define GL_STACK_UNDERFLOW_KHR 0x0504 +#endif + +#ifndef GL_KHR_texture_compression_astc_ldr +#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 +#endif + +/*------------------------------------------------------------------------* + * AMD extension tokens + *------------------------------------------------------------------------*/ + +/* GL_AMD_compressed_3DC_texture */ +#ifndef GL_AMD_compressed_3DC_texture +#define GL_3DC_X_AMD 0x87F9 +#define GL_3DC_XY_AMD 0x87FA +#endif + +/* GL_AMD_compressed_ATC_texture */ +#ifndef GL_AMD_compressed_ATC_texture +#define GL_ATC_RGB_AMD 0x8C92 +#define GL_ATC_RGBA_EXPLICIT_ALPHA_AMD 0x8C93 +#define GL_ATC_RGBA_INTERPOLATED_ALPHA_AMD 0x87EE +#endif + +/* GL_AMD_performance_monitor */ +#ifndef GL_AMD_performance_monitor +#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 +#endif + +/* GL_AMD_program_binary_Z400 */ +#ifndef GL_AMD_program_binary_Z400 +#define GL_Z400_BINARY_AMD 0x8740 +#endif + +/*------------------------------------------------------------------------* + * ANGLE extension tokens + *------------------------------------------------------------------------*/ + +/* GL_ANGLE_depth_texture */ +#ifndef GL_ANGLE_depth_texture +#define GL_DEPTH_COMPONENT 0x1902 +#define GL_DEPTH_STENCIL_OES 0x84F9 +#define GL_UNSIGNED_SHORT 0x1403 +#define GL_UNSIGNED_INT 0x1405 +#define GL_UNSIGNED_INT_24_8_OES 0x84FA +#define GL_DEPTH_COMPONENT16 0x81A5 +#define GL_DEPTH_COMPONENT32_OES 0x81A7 +#define GL_DEPTH24_STENCIL8_OES 0x88F0 +#endif + +/* GL_ANGLE_framebuffer_blit */ +#ifndef GL_ANGLE_framebuffer_blit +#define GL_READ_FRAMEBUFFER_ANGLE 0x8CA8 +#define GL_DRAW_FRAMEBUFFER_ANGLE 0x8CA9 +#define GL_DRAW_FRAMEBUFFER_BINDING_ANGLE 0x8CA6 +#define GL_READ_FRAMEBUFFER_BINDING_ANGLE 0x8CAA +#endif + +/* GL_ANGLE_framebuffer_multisample */ +#ifndef GL_ANGLE_framebuffer_multisample +#define GL_RENDERBUFFER_SAMPLES_ANGLE 0x8CAB +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_ANGLE 0x8D56 +#define GL_MAX_SAMPLES_ANGLE 0x8D57 +#endif + +/* GL_ANGLE_instanced_arrays */ +#ifndef GL_ANGLE_instanced_arrays +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_ANGLE 0x88FE +#endif + +/* GL_ANGLE_pack_reverse_row_order */ +#ifndef GL_ANGLE_pack_reverse_row_order +#define GL_PACK_REVERSE_ROW_ORDER_ANGLE 0x93A4 +#endif + +/* GL_ANGLE_program_binary */ +#ifndef GL_ANGLE_program_binary +#define GL_PROGRAM_BINARY_ANGLE 0x93A6 +#endif + +/* GL_ANGLE_texture_compression_dxt3 */ +#ifndef GL_ANGLE_texture_compression_dxt3 +#define GL_COMPRESSED_RGBA_S3TC_DXT3_ANGLE 0x83F2 +#endif + +/* GL_ANGLE_texture_compression_dxt5 */ +#ifndef GL_ANGLE_texture_compression_dxt5 +#define GL_COMPRESSED_RGBA_S3TC_DXT5_ANGLE 0x83F3 +#endif + +/* GL_ANGLE_texture_usage */ +#ifndef GL_ANGLE_texture_usage +#define GL_TEXTURE_USAGE_ANGLE 0x93A2 +#define GL_FRAMEBUFFER_ATTACHMENT_ANGLE 0x93A3 +#endif + +/* GL_ANGLE_translated_shader_source */ +#ifndef GL_ANGLE_translated_shader_source +#define GL_TRANSLATED_SHADER_SOURCE_LENGTH_ANGLE 0x93A0 +#endif + +/*------------------------------------------------------------------------* + * APPLE extension tokens + *------------------------------------------------------------------------*/ + +/* GL_APPLE_copy_texture_levels */ +/* No new tokens introduced by this extension. */ + +/* GL_APPLE_framebuffer_multisample */ +#ifndef GL_APPLE_framebuffer_multisample +#define GL_RENDERBUFFER_SAMPLES_APPLE 0x8CAB +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_APPLE 0x8D56 +#define GL_MAX_SAMPLES_APPLE 0x8D57 +#define GL_READ_FRAMEBUFFER_APPLE 0x8CA8 +#define GL_DRAW_FRAMEBUFFER_APPLE 0x8CA9 +#define GL_DRAW_FRAMEBUFFER_BINDING_APPLE 0x8CA6 +#define GL_READ_FRAMEBUFFER_BINDING_APPLE 0x8CAA +#endif + +/* GL_APPLE_rgb_422 */ +#ifndef GL_APPLE_rgb_422 +#define GL_RGB_422_APPLE 0x8A1F +#define GL_UNSIGNED_SHORT_8_8_APPLE 0x85BA +#define GL_UNSIGNED_SHORT_8_8_REV_APPLE 0x85BB +#endif + +/* GL_APPLE_sync */ +#ifndef GL_APPLE_sync + +#define GL_SYNC_OBJECT_APPLE 0x8A53 +#define GL_MAX_SERVER_WAIT_TIMEOUT_APPLE 0x9111 +#define GL_OBJECT_TYPE_APPLE 0x9112 +#define GL_SYNC_CONDITION_APPLE 0x9113 +#define GL_SYNC_STATUS_APPLE 0x9114 +#define GL_SYNC_FLAGS_APPLE 0x9115 +#define GL_SYNC_FENCE_APPLE 0x9116 +#define GL_SYNC_GPU_COMMANDS_COMPLETE_APPLE 0x9117 +#define GL_UNSIGNALED_APPLE 0x9118 +#define GL_SIGNALED_APPLE 0x9119 +#define GL_ALREADY_SIGNALED_APPLE 0x911A +#define GL_TIMEOUT_EXPIRED_APPLE 0x911B +#define GL_CONDITION_SATISFIED_APPLE 0x911C +#define GL_WAIT_FAILED_APPLE 0x911D +#define GL_SYNC_FLUSH_COMMANDS_BIT_APPLE 0x00000001 +#define GL_TIMEOUT_IGNORED_APPLE 0xFFFFFFFFFFFFFFFFull +#endif + +/* GL_APPLE_texture_format_BGRA8888 */ +#ifndef GL_APPLE_texture_format_BGRA8888 +#define GL_BGRA_EXT 0x80E1 +#endif + +/* GL_APPLE_texture_max_level */ +#ifndef GL_APPLE_texture_max_level +#define GL_TEXTURE_MAX_LEVEL_APPLE 0x813D +#endif + +/*------------------------------------------------------------------------* + * ARM extension tokens + *------------------------------------------------------------------------*/ + +/* GL_ARM_mali_program_binary */ +#ifndef GL_ARM_mali_program_binary +#define GL_MALI_PROGRAM_BINARY_ARM 0x8F61 +#endif + +/* GL_ARM_mali_shader_binary */ +#ifndef GL_ARM_mali_shader_binary +#define GL_MALI_SHADER_BINARY_ARM 0x8F60 +#endif + +/* GL_ARM_rgba8 */ +/* No new tokens introduced by this extension. */ + +/*------------------------------------------------------------------------* + * EXT extension tokens + *------------------------------------------------------------------------*/ + +/* GL_EXT_blend_minmax */ +#ifndef GL_EXT_blend_minmax +#define GL_MIN_EXT 0x8007 +#define GL_MAX_EXT 0x8008 +#endif + +/* GL_EXT_color_buffer_half_float */ +#ifndef GL_EXT_color_buffer_half_float +#define GL_RGBA16F_EXT 0x881A +#define GL_RGB16F_EXT 0x881B +#define GL_RG16F_EXT 0x822F +#define GL_R16F_EXT 0x822D +#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE_EXT 0x8211 +#define GL_UNSIGNED_NORMALIZED_EXT 0x8C17 +#endif + +/* GL_EXT_debug_label */ +#ifndef GL_EXT_debug_label +#define GL_PROGRAM_PIPELINE_OBJECT_EXT 0x8A4F +#define GL_PROGRAM_OBJECT_EXT 0x8B40 +#define GL_SHADER_OBJECT_EXT 0x8B48 +#define GL_BUFFER_OBJECT_EXT 0x9151 +#define GL_QUERY_OBJECT_EXT 0x9153 +#define GL_VERTEX_ARRAY_OBJECT_EXT 0x9154 +#endif + +/* GL_EXT_debug_marker */ +/* No new tokens introduced by this extension. */ + +/* GL_EXT_discard_framebuffer */ +#ifndef GL_EXT_discard_framebuffer +#define GL_COLOR_EXT 0x1800 +#define GL_DEPTH_EXT 0x1801 +#define GL_STENCIL_EXT 0x1802 +#endif + +#ifndef GL_EXT_disjoint_timer_query +#define GL_QUERY_COUNTER_BITS_EXT 0x8864 +#define GL_CURRENT_QUERY_EXT 0x8865 +#define GL_QUERY_RESULT_EXT 0x8866 +#define GL_QUERY_RESULT_AVAILABLE_EXT 0x8867 +#define GL_TIME_ELAPSED_EXT 0x88BF +#define GL_TIMESTAMP_EXT 0x8E28 +#define GL_GPU_DISJOINT_EXT 0x8FBB +#endif + +#ifndef GL_EXT_draw_buffers +#define GL_EXT_draw_buffers 1 +#define GL_MAX_COLOR_ATTACHMENTS_EXT 0x8CDF +#define GL_MAX_DRAW_BUFFERS_EXT 0x8824 +#define GL_DRAW_BUFFER0_EXT 0x8825 +#define GL_DRAW_BUFFER1_EXT 0x8826 +#define GL_DRAW_BUFFER2_EXT 0x8827 +#define GL_DRAW_BUFFER3_EXT 0x8828 +#define GL_DRAW_BUFFER4_EXT 0x8829 +#define GL_DRAW_BUFFER5_EXT 0x882A +#define GL_DRAW_BUFFER6_EXT 0x882B +#define GL_DRAW_BUFFER7_EXT 0x882C +#define GL_DRAW_BUFFER8_EXT 0x882D +#define GL_DRAW_BUFFER9_EXT 0x882E +#define GL_DRAW_BUFFER10_EXT 0x882F +#define GL_DRAW_BUFFER11_EXT 0x8830 +#define GL_DRAW_BUFFER12_EXT 0x8831 +#define GL_DRAW_BUFFER13_EXT 0x8832 +#define GL_DRAW_BUFFER14_EXT 0x8833 +#define GL_DRAW_BUFFER15_EXT 0x8834 +#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 +#endif + +/* GL_EXT_map_buffer_range */ +#ifndef GL_EXT_map_buffer_range +#define GL_MAP_READ_BIT_EXT 0x0001 +#define GL_MAP_WRITE_BIT_EXT 0x0002 +#define GL_MAP_INVALIDATE_RANGE_BIT_EXT 0x0004 +#define GL_MAP_INVALIDATE_BUFFER_BIT_EXT 0x0008 +#define GL_MAP_FLUSH_EXPLICIT_BIT_EXT 0x0010 +#define GL_MAP_UNSYNCHRONIZED_BIT_EXT 0x0020 +#endif + +/* GL_EXT_multisampled_render_to_texture */ +#ifndef GL_EXT_multisampled_render_to_texture +#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_SAMPLES_EXT 0x8D6C +/* reuse values from GL_EXT_framebuffer_multisample (desktop extension) */ +#define GL_RENDERBUFFER_SAMPLES_EXT 0x8CAB +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_EXT 0x8D56 +#define GL_MAX_SAMPLES_EXT 0x8D57 +#endif + +/* GL_EXT_multiview_draw_buffers */ +#ifndef GL_EXT_multiview_draw_buffers +#define GL_COLOR_ATTACHMENT_EXT 0x90F0 +#define GL_MULTIVIEW_EXT 0x90F1 +#define GL_DRAW_BUFFER_EXT 0x0C01 +#define GL_READ_BUFFER_EXT 0x0C02 +#define GL_MAX_MULTIVIEW_BUFFERS_EXT 0x90F2 +#endif + +/* GL_EXT_multi_draw_arrays */ +/* No new tokens introduced by this extension. */ + +/* GL_EXT_occlusion_query_boolean */ +#ifndef GL_EXT_occlusion_query_boolean +#define GL_ANY_SAMPLES_PASSED_EXT 0x8C2F +#define GL_ANY_SAMPLES_PASSED_CONSERVATIVE_EXT 0x8D6A +#define GL_CURRENT_QUERY_EXT 0x8865 +#define GL_QUERY_RESULT_EXT 0x8866 +#define GL_QUERY_RESULT_AVAILABLE_EXT 0x8867 +#endif + +/* GL_EXT_read_format_bgra */ +#ifndef GL_EXT_read_format_bgra +#define GL_BGRA_EXT 0x80E1 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV_EXT 0x8365 +#define GL_UNSIGNED_SHORT_1_5_5_5_REV_EXT 0x8366 +#endif + +/* GL_EXT_robustness */ +#ifndef GL_EXT_robustness +/* reuse GL_NO_ERROR */ +#define GL_GUILTY_CONTEXT_RESET_EXT 0x8253 +#define GL_INNOCENT_CONTEXT_RESET_EXT 0x8254 +#define GL_UNKNOWN_CONTEXT_RESET_EXT 0x8255 +#define GL_CONTEXT_ROBUST_ACCESS_EXT 0x90F3 +#define GL_RESET_NOTIFICATION_STRATEGY_EXT 0x8256 +#define GL_LOSE_CONTEXT_ON_RESET_EXT 0x8252 +#define GL_NO_RESET_NOTIFICATION_EXT 0x8261 +#endif + +/* GL_EXT_separate_shader_objects */ +#ifndef GL_EXT_separate_shader_objects +#define GL_VERTEX_SHADER_BIT_EXT 0x00000001 +#define GL_FRAGMENT_SHADER_BIT_EXT 0x00000002 +#define GL_ALL_SHADER_BITS_EXT 0xFFFFFFFF +#define GL_PROGRAM_SEPARABLE_EXT 0x8258 +#define GL_ACTIVE_PROGRAM_EXT 0x8259 +#define GL_PROGRAM_PIPELINE_BINDING_EXT 0x825A +#endif + +/* GL_EXT_shader_framebuffer_fetch */ +#ifndef GL_EXT_shader_framebuffer_fetch +#define GL_FRAGMENT_SHADER_DISCARDS_SAMPLES_EXT 0x8A52 +#endif + +/* GL_EXT_shader_texture_lod */ +/* No new tokens introduced by this extension. */ + +/* GL_EXT_shadow_samplers */ +#ifndef GL_EXT_shadow_samplers +#define GL_TEXTURE_COMPARE_MODE_EXT 0x884C +#define GL_TEXTURE_COMPARE_FUNC_EXT 0x884D +#define GL_COMPARE_REF_TO_TEXTURE_EXT 0x884E +#define GL_SAMPLER_2D_SHADOW_EXT 0x8B62 +#endif + +/* GL_EXT_sRGB */ +#ifndef GL_EXT_sRGB +#define GL_SRGB_EXT 0x8C40 +#define GL_SRGB_ALPHA_EXT 0x8C42 +#define GL_SRGB8_ALPHA8_EXT 0x8C43 +#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING_EXT 0x8210 +#endif + +/* GL_EXT_sRGB_write_control */ +#ifndef GL_EXT_sRGB_write_control +#define GL_EXT_sRGB_write_control 1 +#define GL_FRAMEBUFFER_SRGB_EXT 0x8DB9 +#endif + +/* GL_EXT_texture_compression_dxt1 */ +#ifndef GL_EXT_texture_compression_dxt1 +#define GL_COMPRESSED_RGB_S3TC_DXT1_EXT 0x83F0 +#define GL_COMPRESSED_RGBA_S3TC_DXT1_EXT 0x83F1 +#endif + +/* GL_EXT_texture_filter_anisotropic */ +#ifndef GL_EXT_texture_filter_anisotropic +#define GL_TEXTURE_MAX_ANISOTROPY_EXT 0x84FE +#define GL_MAX_TEXTURE_MAX_ANISOTROPY_EXT 0x84FF +#endif + +/* GL_EXT_texture_format_BGRA8888 */ +#ifndef GL_EXT_texture_format_BGRA8888 +#define GL_BGRA_EXT 0x80E1 +#endif + +/* GL_EXT_texture_rg */ +#ifndef GL_EXT_texture_rg +#define GL_RED_EXT 0x1903 +#define GL_RG_EXT 0x8227 +#define GL_R8_EXT 0x8229 +#define GL_RG8_EXT 0x822B +#endif + +/* 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 +#endif + +/* GL_EXT_texture_storage */ +#ifndef GL_EXT_texture_storage +#define GL_TEXTURE_IMMUTABLE_FORMAT_EXT 0x912F +#define GL_ALPHA8_EXT 0x803C +#define GL_LUMINANCE8_EXT 0x8040 +#define GL_LUMINANCE8_ALPHA8_EXT 0x8045 +#define GL_RGBA32F_EXT 0x8814 +#define GL_RGB32F_EXT 0x8815 +#define GL_ALPHA32F_EXT 0x8816 +#define GL_LUMINANCE32F_EXT 0x8818 +#define GL_LUMINANCE_ALPHA32F_EXT 0x8819 +/* reuse GL_RGBA16F_EXT */ +/* reuse GL_RGB16F_EXT */ +#define GL_ALPHA16F_EXT 0x881C +#define GL_LUMINANCE16F_EXT 0x881E +#define GL_LUMINANCE_ALPHA16F_EXT 0x881F +#define GL_RGB10_A2_EXT 0x8059 +#define GL_RGB10_EXT 0x8052 +#define GL_BGRA8_EXT 0x93A1 +#define GL_R8_EXT 0x8229 +#define GL_RG8_EXT 0x822B +#define GL_R32F_EXT 0x822E +#define GL_RG32F_EXT 0x8230 +#define GL_R16F_EXT 0x822D +#define GL_RG16F_EXT 0x822F +#endif + +/* GL_EXT_texture_type_2_10_10_10_REV */ +#ifndef GL_EXT_texture_type_2_10_10_10_REV +#define GL_UNSIGNED_INT_2_10_10_10_REV_EXT 0x8368 +#endif + +/* GL_EXT_unpack_subimage */ +#ifndef GL_EXT_unpack_subimage +#define GL_UNPACK_ROW_LENGTH_EXT 0x0CF2 +#define GL_UNPACK_SKIP_ROWS_EXT 0x0CF3 +#define GL_UNPACK_SKIP_PIXELS_EXT 0x0CF4 +#endif + +/*------------------------------------------------------------------------* + * DMP extension tokens + *------------------------------------------------------------------------*/ + +/* GL_DMP_shader_binary */ +#ifndef GL_DMP_shader_binary +#define GL_SHADER_BINARY_DMP 0x9250 +#endif + +/*------------------------------------------------------------------------* + * FJ extension tokens + *------------------------------------------------------------------------*/ + +/* GL_FJ_shader_binary_GCCSO */ +#ifndef GL_FJ_shader_binary_GCCSO +#define GL_GCCSO_SHADER_BINARY_FJ 0x9260 +#endif + +/*------------------------------------------------------------------------* + * IMG extension tokens + *------------------------------------------------------------------------*/ + +/* GL_IMG_program_binary */ +#ifndef GL_IMG_program_binary +#define GL_SGX_PROGRAM_BINARY_IMG 0x9130 +#endif + +/* GL_IMG_read_format */ +#ifndef GL_IMG_read_format +#define GL_BGRA_IMG 0x80E1 +#define GL_UNSIGNED_SHORT_4_4_4_4_REV_IMG 0x8365 +#endif + +/* GL_IMG_shader_binary */ +#ifndef GL_IMG_shader_binary +#define GL_SGX_BINARY_IMG 0x8C0A +#endif + +/* GL_IMG_texture_compression_pvrtc */ +#ifndef GL_IMG_texture_compression_pvrtc +#define GL_COMPRESSED_RGB_PVRTC_4BPPV1_IMG 0x8C00 +#define GL_COMPRESSED_RGB_PVRTC_2BPPV1_IMG 0x8C01 +#define GL_COMPRESSED_RGBA_PVRTC_4BPPV1_IMG 0x8C02 +#define GL_COMPRESSED_RGBA_PVRTC_2BPPV1_IMG 0x8C03 +#endif + +/* GL_IMG_texture_compression_pvrtc2 */ +#ifndef GL_IMG_texture_compression_pvrtc2 +#define GL_COMPRESSED_RGBA_PVRTC_2BPPV2_IMG 0x9137 +#define GL_COMPRESSED_RGBA_PVRTC_4BPPV2_IMG 0x9138 +#endif + +/* GL_IMG_multisampled_render_to_texture */ +#ifndef GL_IMG_multisampled_render_to_texture +#define GL_RENDERBUFFER_SAMPLES_IMG 0x9133 +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_IMG 0x9134 +#define GL_MAX_SAMPLES_IMG 0x9135 +#define GL_TEXTURE_SAMPLES_IMG 0x9136 +#endif + +/*------------------------------------------------------------------------* + * NV extension tokens + *------------------------------------------------------------------------*/ + +/* GL_NV_coverage_sample */ +#ifndef GL_NV_coverage_sample +#define GL_COVERAGE_COMPONENT_NV 0x8ED0 +#define GL_COVERAGE_COMPONENT4_NV 0x8ED1 +#define GL_COVERAGE_ATTACHMENT_NV 0x8ED2 +#define GL_COVERAGE_BUFFERS_NV 0x8ED3 +#define GL_COVERAGE_SAMPLES_NV 0x8ED4 +#define GL_COVERAGE_ALL_FRAGMENTS_NV 0x8ED5 +#define GL_COVERAGE_EDGE_FRAGMENTS_NV 0x8ED6 +#define GL_COVERAGE_AUTOMATIC_NV 0x8ED7 +#define GL_COVERAGE_BUFFER_BIT_NV 0x00008000 +#endif + +/* GL_NV_depth_nonlinear */ +#ifndef GL_NV_depth_nonlinear +#define GL_DEPTH_COMPONENT16_NONLINEAR_NV 0x8E2C +#endif + +/* GL_NV_draw_buffers */ +#ifndef GL_NV_draw_buffers +#define GL_MAX_DRAW_BUFFERS_NV 0x8824 +#define GL_DRAW_BUFFER0_NV 0x8825 +#define GL_DRAW_BUFFER1_NV 0x8826 +#define GL_DRAW_BUFFER2_NV 0x8827 +#define GL_DRAW_BUFFER3_NV 0x8828 +#define GL_DRAW_BUFFER4_NV 0x8829 +#define GL_DRAW_BUFFER5_NV 0x882A +#define GL_DRAW_BUFFER6_NV 0x882B +#define GL_DRAW_BUFFER7_NV 0x882C +#define GL_DRAW_BUFFER8_NV 0x882D +#define GL_DRAW_BUFFER9_NV 0x882E +#define GL_DRAW_BUFFER10_NV 0x882F +#define GL_DRAW_BUFFER11_NV 0x8830 +#define GL_DRAW_BUFFER12_NV 0x8831 +#define GL_DRAW_BUFFER13_NV 0x8832 +#define GL_DRAW_BUFFER14_NV 0x8833 +#define GL_DRAW_BUFFER15_NV 0x8834 +#define GL_COLOR_ATTACHMENT0_NV 0x8CE0 +#define GL_COLOR_ATTACHMENT1_NV 0x8CE1 +#define GL_COLOR_ATTACHMENT2_NV 0x8CE2 +#define GL_COLOR_ATTACHMENT3_NV 0x8CE3 +#define GL_COLOR_ATTACHMENT4_NV 0x8CE4 +#define GL_COLOR_ATTACHMENT5_NV 0x8CE5 +#define GL_COLOR_ATTACHMENT6_NV 0x8CE6 +#define GL_COLOR_ATTACHMENT7_NV 0x8CE7 +#define GL_COLOR_ATTACHMENT8_NV 0x8CE8 +#define GL_COLOR_ATTACHMENT9_NV 0x8CE9 +#define GL_COLOR_ATTACHMENT10_NV 0x8CEA +#define GL_COLOR_ATTACHMENT11_NV 0x8CEB +#define GL_COLOR_ATTACHMENT12_NV 0x8CEC +#define GL_COLOR_ATTACHMENT13_NV 0x8CED +#define GL_COLOR_ATTACHMENT14_NV 0x8CEE +#define GL_COLOR_ATTACHMENT15_NV 0x8CEF +#endif + +/* GL_NV_draw_instanced */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_fbo_color_attachments */ +#ifndef GL_NV_fbo_color_attachments +#define GL_MAX_COLOR_ATTACHMENTS_NV 0x8CDF +/* GL_COLOR_ATTACHMENT{0-15}_NV defined in GL_NV_draw_buffers already. */ +#endif + +/* GL_NV_fence */ +#ifndef GL_NV_fence +#define GL_ALL_COMPLETED_NV 0x84F2 +#define GL_FENCE_STATUS_NV 0x84F3 +#define GL_FENCE_CONDITION_NV 0x84F4 +#endif + +/* GL_NV_framebuffer_blit */ +#ifndef GL_NV_framebuffer_blit +#define GL_READ_FRAMEBUFFER_NV 0x8CA8 +#define GL_DRAW_FRAMEBUFFER_NV 0x8CA9 +#define GL_DRAW_FRAMEBUFFER_BINDING_NV 0x8CA6 +#define GL_READ_FRAMEBUFFER_BINDING_NV 0x8CAA +#endif + +/* GL_NV_framebuffer_multisample */ +#ifndef GL_NV_framebuffer_multisample +#define GL_RENDERBUFFER_SAMPLES_NV 0x8CAB +#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE_NV 0x8D56 +#define GL_MAX_SAMPLES_NV 0x8D57 +#endif + +/* GL_NV_generate_mipmap_sRGB */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_instanced_arrays */ +#ifndef GL_NV_instanced_arrays +#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR_NV 0x88FE +#endif + +/* GL_NV_read_buffer */ +#ifndef GL_NV_read_buffer +#define GL_READ_BUFFER_NV 0x0C02 +#endif + +/* GL_NV_read_buffer_front */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_read_depth */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_read_depth_stencil */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_read_stencil */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_shadow_samplers_array */ +#ifndef GL_NV_shadow_samplers_array +#define GL_SAMPLER_2D_ARRAY_SHADOW_NV 0x8DC4 +#endif + +/* GL_NV_shadow_samplers_cube */ +#ifndef GL_NV_shadow_samplers_cube +#define GL_SAMPLER_CUBE_SHADOW_NV 0x8DC5 +#endif + +/* GL_NV_sRGB_formats */ +#ifndef GL_NV_sRGB_formats +#define GL_SLUMINANCE_NV 0x8C46 +#define GL_SLUMINANCE_ALPHA_NV 0x8C44 +#define GL_SRGB8_NV 0x8C41 +#define GL_SLUMINANCE8_NV 0x8C47 +#define GL_SLUMINANCE8_ALPHA8_NV 0x8C45 +#define GL_COMPRESSED_SRGB_S3TC_DXT1_NV 0x8C4C +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT1_NV 0x8C4D +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT3_NV 0x8C4E +#define GL_COMPRESSED_SRGB_ALPHA_S3TC_DXT5_NV 0x8C4F +#define GL_ETC1_SRGB8_NV 0x88EE +#endif + +/* GL_NV_texture_border_clamp */ +#ifndef GL_NV_texture_border_clamp +#define GL_TEXTURE_BORDER_COLOR_NV 0x1004 +#define GL_CLAMP_TO_BORDER_NV 0x812D +#endif + +/* GL_NV_texture_compression_s3tc_update */ +/* No new tokens introduced by this extension. */ + +/* GL_NV_texture_npot_2D_mipmap */ +/* No new tokens introduced by this extension. */ + +/*------------------------------------------------------------------------* + * QCOM extension tokens + *------------------------------------------------------------------------*/ + +/* GL_QCOM_alpha_test */ +#ifndef GL_QCOM_alpha_test +#define GL_ALPHA_TEST_QCOM 0x0BC0 +#define GL_ALPHA_TEST_FUNC_QCOM 0x0BC1 +#define GL_ALPHA_TEST_REF_QCOM 0x0BC2 +#endif + +/* GL_QCOM_binning_control */ +#ifndef GL_QCOM_binning_control +#define GL_BINNING_CONTROL_HINT_QCOM 0x8FB0 +#define GL_CPU_OPTIMIZED_QCOM 0x8FB1 +#define GL_GPU_OPTIMIZED_QCOM 0x8FB2 +#define GL_RENDER_DIRECT_TO_FRAMEBUFFER_QCOM 0x8FB3 +#endif + +/* GL_QCOM_driver_control */ +/* No new tokens introduced by this extension. */ + +/* GL_QCOM_extended_get */ +#ifndef GL_QCOM_extended_get +#define GL_TEXTURE_WIDTH_QCOM 0x8BD2 +#define GL_TEXTURE_HEIGHT_QCOM 0x8BD3 +#define GL_TEXTURE_DEPTH_QCOM 0x8BD4 +#define GL_TEXTURE_INTERNAL_FORMAT_QCOM 0x8BD5 +#define GL_TEXTURE_FORMAT_QCOM 0x8BD6 +#define GL_TEXTURE_TYPE_QCOM 0x8BD7 +#define GL_TEXTURE_IMAGE_VALID_QCOM 0x8BD8 +#define GL_TEXTURE_NUM_LEVELS_QCOM 0x8BD9 +#define GL_TEXTURE_TARGET_QCOM 0x8BDA +#define GL_TEXTURE_OBJECT_VALID_QCOM 0x8BDB +#define GL_STATE_RESTORE 0x8BDC +#endif + +/* GL_QCOM_extended_get2 */ +/* No new tokens introduced by this extension. */ + +/* GL_QCOM_perfmon_global_mode */ +#ifndef GL_QCOM_perfmon_global_mode +#define GL_PERFMON_GLOBAL_MODE_QCOM 0x8FA0 +#endif + +/* GL_QCOM_writeonly_rendering */ +#ifndef GL_QCOM_writeonly_rendering +#define GL_WRITEONLY_RENDERING_QCOM 0x8823 +#endif + +/* GL_QCOM_tiled_rendering */ +#ifndef GL_QCOM_tiled_rendering +#define GL_COLOR_BUFFER_BIT0_QCOM 0x00000001 +#define GL_COLOR_BUFFER_BIT1_QCOM 0x00000002 +#define GL_COLOR_BUFFER_BIT2_QCOM 0x00000004 +#define GL_COLOR_BUFFER_BIT3_QCOM 0x00000008 +#define GL_COLOR_BUFFER_BIT4_QCOM 0x00000010 +#define GL_COLOR_BUFFER_BIT5_QCOM 0x00000020 +#define GL_COLOR_BUFFER_BIT6_QCOM 0x00000040 +#define GL_COLOR_BUFFER_BIT7_QCOM 0x00000080 +#define GL_DEPTH_BUFFER_BIT0_QCOM 0x00000100 +#define GL_DEPTH_BUFFER_BIT1_QCOM 0x00000200 +#define GL_DEPTH_BUFFER_BIT2_QCOM 0x00000400 +#define GL_DEPTH_BUFFER_BIT3_QCOM 0x00000800 +#define GL_DEPTH_BUFFER_BIT4_QCOM 0x00001000 +#define GL_DEPTH_BUFFER_BIT5_QCOM 0x00002000 +#define GL_DEPTH_BUFFER_BIT6_QCOM 0x00004000 +#define GL_DEPTH_BUFFER_BIT7_QCOM 0x00008000 +#define GL_STENCIL_BUFFER_BIT0_QCOM 0x00010000 +#define GL_STENCIL_BUFFER_BIT1_QCOM 0x00020000 +#define GL_STENCIL_BUFFER_BIT2_QCOM 0x00040000 +#define GL_STENCIL_BUFFER_BIT3_QCOM 0x00080000 +#define GL_STENCIL_BUFFER_BIT4_QCOM 0x00100000 +#define GL_STENCIL_BUFFER_BIT5_QCOM 0x00200000 +#define GL_STENCIL_BUFFER_BIT6_QCOM 0x00400000 +#define GL_STENCIL_BUFFER_BIT7_QCOM 0x00800000 +#define GL_MULTISAMPLE_BUFFER_BIT0_QCOM 0x01000000 +#define GL_MULTISAMPLE_BUFFER_BIT1_QCOM 0x02000000 +#define GL_MULTISAMPLE_BUFFER_BIT2_QCOM 0x04000000 +#define GL_MULTISAMPLE_BUFFER_BIT3_QCOM 0x08000000 +#define GL_MULTISAMPLE_BUFFER_BIT4_QCOM 0x10000000 +#define GL_MULTISAMPLE_BUFFER_BIT5_QCOM 0x20000000 +#define GL_MULTISAMPLE_BUFFER_BIT6_QCOM 0x40000000 +#define GL_MULTISAMPLE_BUFFER_BIT7_QCOM 0x80000000 +#endif + +/*------------------------------------------------------------------------* + * VIV extension tokens + *------------------------------------------------------------------------*/ + +/* GL_VIV_shader_binary */ +#ifndef GL_VIV_shader_binary +#define GL_SHADER_BINARY_VIV 0x8FC4 +#endif + +/*------------------------------------------------------------------------* + * End of extension tokens, start of corresponding extension functions + *------------------------------------------------------------------------*/ + +/*------------------------------------------------------------------------* + * OES extension functions + *------------------------------------------------------------------------*/ + +/* GL_OES_compressed_ETC1_RGB8_texture */ +#ifndef GL_OES_compressed_ETC1_RGB8_texture +#define GL_OES_compressed_ETC1_RGB8_texture 1 +#endif + +/* GL_OES_compressed_paletted_texture */ +#ifndef GL_OES_compressed_paletted_texture +#define GL_OES_compressed_paletted_texture 1 +#endif + +/* GL_OES_depth24 */ +#ifndef GL_OES_depth24 +#define GL_OES_depth24 1 +#endif + +/* GL_OES_depth32 */ +#ifndef GL_OES_depth32 +#define GL_OES_depth32 1 +#endif + +/* GL_OES_depth_texture */ +#ifndef GL_OES_depth_texture +#define GL_OES_depth_texture 1 +#endif + +/* GL_OES_EGL_image */ +#ifndef GL_OES_EGL_image +#define GL_OES_EGL_image 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glEGLImageTargetTexture2DOES (GLenum target, GLeglImageOES image); +GL_APICALL void GL_APIENTRY glEGLImageTargetRenderbufferStorageOES (GLenum target, GLeglImageOES image); +#endif +typedef void (GL_APIENTRYP PFNGLEGLIMAGETARGETTEXTURE2DOESPROC) (GLenum target, GLeglImageOES image); +typedef void (GL_APIENTRYP PFNGLEGLIMAGETARGETRENDERBUFFERSTORAGEOESPROC) (GLenum target, GLeglImageOES image); +#endif + +/* GL_OES_EGL_image_external */ +#ifndef GL_OES_EGL_image_external +#define GL_OES_EGL_image_external 1 +/* glEGLImageTargetTexture2DOES defined in GL_OES_EGL_image already. */ +#endif + +/* GL_OES_element_index_uint */ +#ifndef GL_OES_element_index_uint +#define GL_OES_element_index_uint 1 +#endif + +/* GL_OES_fbo_render_mipmap */ +#ifndef GL_OES_fbo_render_mipmap +#define GL_OES_fbo_render_mipmap 1 +#endif + +/* GL_OES_fragment_precision_high */ +#ifndef GL_OES_fragment_precision_high +#define GL_OES_fragment_precision_high 1 +#endif + +/* GL_OES_get_program_binary */ +#ifndef GL_OES_get_program_binary +#define GL_OES_get_program_binary 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glGetProgramBinaryOES (GLuint program, GLsizei bufSize, GLsizei *length, GLenum *binaryFormat, GLvoid *binary); +GL_APICALL void GL_APIENTRY glProgramBinaryOES (GLuint program, GLenum binaryFormat, const GLvoid *binary, GLint length); +#endif +typedef void (GL_APIENTRYP PFNGLGETPROGRAMBINARYOESPROC) (GLuint program, GLsizei bufSize, GLsizei *length, GLenum *binaryFormat, GLvoid *binary); +typedef void (GL_APIENTRYP PFNGLPROGRAMBINARYOESPROC) (GLuint program, GLenum binaryFormat, const GLvoid *binary, GLint length); +#endif + +/* GL_OES_mapbuffer */ +#ifndef GL_OES_mapbuffer +#define GL_OES_mapbuffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void* GL_APIENTRY glMapBufferOES (GLenum target, GLenum access); +GL_APICALL GLboolean GL_APIENTRY glUnmapBufferOES (GLenum target); +GL_APICALL void GL_APIENTRY glGetBufferPointervOES (GLenum target, GLenum pname, GLvoid **params); +#endif +typedef void* (GL_APIENTRYP PFNGLMAPBUFFEROESPROC) (GLenum target, GLenum access); +typedef GLboolean (GL_APIENTRYP PFNGLUNMAPBUFFEROESPROC) (GLenum target); +typedef void (GL_APIENTRYP PFNGLGETBUFFERPOINTERVOESPROC) (GLenum target, GLenum pname, GLvoid **params); +#endif + +/* GL_OES_packed_depth_stencil */ +#ifndef GL_OES_packed_depth_stencil +#define GL_OES_packed_depth_stencil 1 +#endif + +/* GL_OES_required_internalformat */ +#ifndef GL_OES_required_internalformat +#define GL_OES_required_internalformat 1 +#endif + +/* GL_OES_rgb8_rgba8 */ +#ifndef GL_OES_rgb8_rgba8 +#define GL_OES_rgb8_rgba8 1 +#endif + +/* GL_OES_standard_derivatives */ +#ifndef GL_OES_standard_derivatives +#define GL_OES_standard_derivatives 1 +#endif + +/* GL_OES_stencil1 */ +#ifndef GL_OES_stencil1 +#define GL_OES_stencil1 1 +#endif + +/* GL_OES_stencil4 */ +#ifndef GL_OES_stencil4 +#define GL_OES_stencil4 1 +#endif + +#ifndef GL_OES_surfaceless_context +#define GL_OES_surfaceless_context 1 +#endif + +/* GL_OES_texture_3D */ +#ifndef GL_OES_texture_3D +#define GL_OES_texture_3D 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glTexImage3DOES (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid* pixels); +GL_APICALL void GL_APIENTRY glTexSubImage3DOES (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, const GLvoid* pixels); +GL_APICALL void GL_APIENTRY glCopyTexSubImage3DOES (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glCompressedTexImage3DOES (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid* data); +GL_APICALL void GL_APIENTRY glCompressedTexSubImage3DOES (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLsizei imageSize, const GLvoid* data); +GL_APICALL void GL_APIENTRY glFramebufferTexture3DOES (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +#endif +typedef void (GL_APIENTRYP PFNGLTEXIMAGE3DOESPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type, const GLvoid* pixels); +typedef void (GL_APIENTRYP PFNGLTEXSUBIMAGE3DOESPROC) (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 (GL_APIENTRYP PFNGLCOPYTEXSUBIMAGE3DOESPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLint x, GLint y, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLCOMPRESSEDTEXIMAGE3DOESPROC) (GLenum target, GLint level, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth, GLint border, GLsizei imageSize, const GLvoid* data); +typedef void (GL_APIENTRYP PFNGLCOMPRESSEDTEXSUBIMAGE3DOESPROC) (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 (GL_APIENTRYP PFNGLFRAMEBUFFERTEXTURE3DOESPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLint zoffset); +#endif + +/* GL_OES_texture_float */ +#ifndef GL_OES_texture_float +#define GL_OES_texture_float 1 +#endif + +/* GL_OES_texture_float_linear */ +#ifndef GL_OES_texture_float_linear +#define GL_OES_texture_float_linear 1 +#endif + +/* GL_OES_texture_half_float */ +#ifndef GL_OES_texture_half_float +#define GL_OES_texture_half_float 1 +#endif + +/* GL_OES_texture_half_float_linear */ +#ifndef GL_OES_texture_half_float_linear +#define GL_OES_texture_half_float_linear 1 +#endif + +/* GL_OES_texture_npot */ +#ifndef GL_OES_texture_npot +#define GL_OES_texture_npot 1 +#endif + +/* GL_OES_vertex_array_object */ +#ifndef GL_OES_vertex_array_object +#define GL_OES_vertex_array_object 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glBindVertexArrayOES (GLuint array); +GL_APICALL void GL_APIENTRY glDeleteVertexArraysOES (GLsizei n, const GLuint *arrays); +GL_APICALL void GL_APIENTRY glGenVertexArraysOES (GLsizei n, GLuint *arrays); +GL_APICALL GLboolean GL_APIENTRY glIsVertexArrayOES (GLuint array); +#endif +typedef void (GL_APIENTRYP PFNGLBINDVERTEXARRAYOESPROC) (GLuint array); +typedef void (GL_APIENTRYP PFNGLDELETEVERTEXARRAYSOESPROC) (GLsizei n, const GLuint *arrays); +typedef void (GL_APIENTRYP PFNGLGENVERTEXARRAYSOESPROC) (GLsizei n, GLuint *arrays); +typedef GLboolean (GL_APIENTRYP PFNGLISVERTEXARRAYOESPROC) (GLuint array); +#endif + +/* GL_OES_vertex_half_float */ +#ifndef GL_OES_vertex_half_float +#define GL_OES_vertex_half_float 1 +#endif + +/* GL_OES_vertex_type_10_10_10_2 */ +#ifndef GL_OES_vertex_type_10_10_10_2 +#define GL_OES_vertex_type_10_10_10_2 1 +#endif + +/*------------------------------------------------------------------------* + * KHR extension functions + *------------------------------------------------------------------------*/ + +#ifndef GL_KHR_debug +#define GL_KHR_debug 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDebugMessageControlKHR (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +GL_APICALL void GL_APIENTRY glDebugMessageInsertKHR (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +GL_APICALL void GL_APIENTRY glDebugMessageCallbackKHR (GLDEBUGPROCKHR callback, const void *userParam); +GL_APICALL GLuint GL_APIENTRY glGetDebugMessageLogKHR (GLuint count, GLsizei bufsize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +GL_APICALL void GL_APIENTRY glPushDebugGroupKHR (GLenum source, GLuint id, GLsizei length, const GLchar *message); +GL_APICALL void GL_APIENTRY glPopDebugGroupKHR (void); +GL_APICALL void GL_APIENTRY glObjectLabelKHR (GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +GL_APICALL void GL_APIENTRY glGetObjectLabelKHR (GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +GL_APICALL void GL_APIENTRY glObjectPtrLabelKHR (const void *ptr, GLsizei length, const GLchar *label); +GL_APICALL void GL_APIENTRY glGetObjectPtrLabelKHR (const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +GL_APICALL void GL_APIENTRY glGetPointervKHR (GLenum pname, GLvoid **params); +#endif +typedef void (GL_APIENTRYP PFNGLDEBUGMESSAGECONTROLKHRPROC) (GLenum source, GLenum type, GLenum severity, GLsizei count, const GLuint *ids, GLboolean enabled); +typedef void (GL_APIENTRYP PFNGLDEBUGMESSAGEINSERTKHRPROC) (GLenum source, GLenum type, GLuint id, GLenum severity, GLsizei length, const GLchar *buf); +typedef void (GL_APIENTRYP PFNGLDEBUGMESSAGECALLBACKKHRPROC) (GLDEBUGPROCKHR callback, const void *userParam); +typedef GLuint (GL_APIENTRYP PFNGLGETDEBUGMESSAGELOGKHRPROC) (GLuint count, GLsizei bufsize, GLenum *sources, GLenum *types, GLuint *ids, GLenum *severities, GLsizei *lengths, GLchar *messageLog); +typedef void (GL_APIENTRYP PFNGLPUSHDEBUGGROUPKHRPROC) (GLenum source, GLuint id, GLsizei length, const GLchar *message); +typedef void (GL_APIENTRYP PFNGLPOPDEBUGGROUPKHRPROC) (void); +typedef void (GL_APIENTRYP PFNGLOBJECTLABELKHRPROC) (GLenum identifier, GLuint name, GLsizei length, const GLchar *label); +typedef void (GL_APIENTRYP PFNGLGETOBJECTLABELKHRPROC) (GLenum identifier, GLuint name, GLsizei bufSize, GLsizei *length, GLchar *label); +typedef void (GL_APIENTRYP PFNGLOBJECTPTRLABELKHRPROC) (const void *ptr, GLsizei length, const GLchar *label); +typedef void (GL_APIENTRYP PFNGLGETOBJECTPTRLABELKHRPROC) (const void *ptr, GLsizei bufSize, GLsizei *length, GLchar *label); +typedef void (GL_APIENTRYP PFNGLGETPOINTERVKHRPROC) (GLenum pname, GLvoid **params); +#endif + +#ifndef GL_KHR_texture_compression_astc_ldr +#define GL_KHR_texture_compression_astc_ldr 1 +#endif + + +/*------------------------------------------------------------------------* + * AMD extension functions + *------------------------------------------------------------------------*/ + +/* GL_AMD_compressed_3DC_texture */ +#ifndef GL_AMD_compressed_3DC_texture +#define GL_AMD_compressed_3DC_texture 1 +#endif + +/* GL_AMD_compressed_ATC_texture */ +#ifndef GL_AMD_compressed_ATC_texture +#define GL_AMD_compressed_ATC_texture 1 +#endif + +/* AMD_performance_monitor */ +#ifndef GL_AMD_performance_monitor +#define GL_AMD_performance_monitor 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glGetPerfMonitorGroupsAMD (GLint *numGroups, GLsizei groupsSize, GLuint *groups); +GL_APICALL void GL_APIENTRY glGetPerfMonitorCountersAMD (GLuint group, GLint *numCounters, GLint *maxActiveCounters, GLsizei counterSize, GLuint *counters); +GL_APICALL void GL_APIENTRY glGetPerfMonitorGroupStringAMD (GLuint group, GLsizei bufSize, GLsizei *length, GLchar *groupString); +GL_APICALL void GL_APIENTRY glGetPerfMonitorCounterStringAMD (GLuint group, GLuint counter, GLsizei bufSize, GLsizei *length, GLchar *counterString); +GL_APICALL void GL_APIENTRY glGetPerfMonitorCounterInfoAMD (GLuint group, GLuint counter, GLenum pname, GLvoid *data); +GL_APICALL void GL_APIENTRY glGenPerfMonitorsAMD (GLsizei n, GLuint *monitors); +GL_APICALL void GL_APIENTRY glDeletePerfMonitorsAMD (GLsizei n, GLuint *monitors); +GL_APICALL void GL_APIENTRY glSelectPerfMonitorCountersAMD (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint *countersList); +GL_APICALL void GL_APIENTRY glBeginPerfMonitorAMD (GLuint monitor); +GL_APICALL void GL_APIENTRY glEndPerfMonitorAMD (GLuint monitor); +GL_APICALL void GL_APIENTRY glGetPerfMonitorCounterDataAMD (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint *data, GLint *bytesWritten); +#endif +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORGROUPSAMDPROC) (GLint *numGroups, GLsizei groupsSize, GLuint *groups); +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORCOUNTERSAMDPROC) (GLuint group, GLint *numCounters, GLint *maxActiveCounters, GLsizei counterSize, GLuint *counters); +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORGROUPSTRINGAMDPROC) (GLuint group, GLsizei bufSize, GLsizei *length, GLchar *groupString); +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORCOUNTERSTRINGAMDPROC) (GLuint group, GLuint counter, GLsizei bufSize, GLsizei *length, GLchar *counterString); +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORCOUNTERINFOAMDPROC) (GLuint group, GLuint counter, GLenum pname, GLvoid *data); +typedef void (GL_APIENTRYP PFNGLGENPERFMONITORSAMDPROC) (GLsizei n, GLuint *monitors); +typedef void (GL_APIENTRYP PFNGLDELETEPERFMONITORSAMDPROC) (GLsizei n, GLuint *monitors); +typedef void (GL_APIENTRYP PFNGLSELECTPERFMONITORCOUNTERSAMDPROC) (GLuint monitor, GLboolean enable, GLuint group, GLint numCounters, GLuint *countersList); +typedef void (GL_APIENTRYP PFNGLBEGINPERFMONITORAMDPROC) (GLuint monitor); +typedef void (GL_APIENTRYP PFNGLENDPERFMONITORAMDPROC) (GLuint monitor); +typedef void (GL_APIENTRYP PFNGLGETPERFMONITORCOUNTERDATAAMDPROC) (GLuint monitor, GLenum pname, GLsizei dataSize, GLuint *data, GLint *bytesWritten); +#endif + +/* GL_AMD_program_binary_Z400 */ +#ifndef GL_AMD_program_binary_Z400 +#define GL_AMD_program_binary_Z400 1 +#endif + +/*------------------------------------------------------------------------* + * ANGLE extension functions + *------------------------------------------------------------------------*/ + +/* GL_ANGLE_depth_texture */ +#ifndef GL_ANGLE_depth_texture +#define GL_ANGLE_depth_texture 1 +#endif + +/* GL_ANGLE_framebuffer_blit */ +#ifndef GL_ANGLE_framebuffer_blit +#define GL_ANGLE_framebuffer_blit 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glBlitFramebufferANGLE (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#endif +typedef void (GL_APIENTRYP PFNGLBLITFRAMEBUFFERANGLEPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#endif + +/* GL_ANGLE_framebuffer_multisample */ +#ifndef GL_ANGLE_framebuffer_multisample +#define GL_ANGLE_framebuffer_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glRenderbufferStorageMultisampleANGLE (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#endif +typedef void (GL_APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEANGLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#endif + +#ifndef GL_ANGLE_instanced_arrays +#define GL_ANGLE_instanced_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDrawArraysInstancedANGLE (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +GL_APICALL void GL_APIENTRY glDrawElementsInstancedANGLE (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +GL_APICALL void GL_APIENTRY glVertexAttribDivisorANGLE (GLuint index, GLuint divisor); +#endif +typedef void (GL_APIENTRYP PFNGLDRAWARRAYSINSTANCEDANGLEPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +typedef void (GL_APIENTRYP PFNGLDRAWELEMENTSINSTANCEDANGLEPROC) (GLenum mode, GLsizei count, GLenum type, const void *indices, GLsizei primcount); +typedef void (GL_APIENTRYP PFNGLVERTEXATTRIBDIVISORANGLEPROC) (GLuint index, GLuint divisor); +#endif + +/* GL_ANGLE_pack_reverse_row_order */ +#ifndef GL_ANGLE_pack_reverse_row_order +#define GL_ANGLE_pack_reverse_row_order 1 +#endif + +/* GL_ANGLE_program_binary */ +#ifndef GL_ANGLE_program_binary +#define GL_ANGLE_program_binary 1 +#endif + +/* GL_ANGLE_texture_compression_dxt3 */ +#ifndef GL_ANGLE_texture_compression_dxt3 +#define GL_ANGLE_texture_compression_dxt3 1 +#endif + +/* GL_ANGLE_texture_compression_dxt5 */ +#ifndef GL_ANGLE_texture_compression_dxt5 +#define GL_ANGLE_texture_compression_dxt5 1 +#endif + +/* GL_ANGLE_texture_usage */ +#ifndef GL_ANGLE_texture_usage +#define GL_ANGLE_texture_usage 1 +#endif + +#ifndef GL_ANGLE_translated_shader_source +#define GL_ANGLE_translated_shader_source 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glGetTranslatedShaderSourceANGLE (GLuint shader, GLsizei bufsize, GLsizei *length, GLchar *source); +#endif +typedef void (GL_APIENTRYP PFNGLGETTRANSLATEDSHADERSOURCEANGLEPROC) (GLuint shader, GLsizei bufsize, GLsizei *length, GLchar *source); +#endif + +/*------------------------------------------------------------------------* + * APPLE extension functions + *------------------------------------------------------------------------*/ + +/* GL_APPLE_copy_texture_levels */ +#ifndef GL_APPLE_copy_texture_levels +#define GL_APPLE_copy_texture_levels 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glCopyTextureLevelsAPPLE (GLuint destinationTexture, GLuint sourceTexture, GLint sourceBaseLevel, GLsizei sourceLevelCount); +#endif +typedef void (GL_APIENTRYP PFNGLCOPYTEXTURELEVELSAPPLEPROC) (GLuint destinationTexture, GLuint sourceTexture, GLint sourceBaseLevel, GLsizei sourceLevelCount); +#endif + +/* GL_APPLE_framebuffer_multisample */ +#ifndef GL_APPLE_framebuffer_multisample +#define GL_APPLE_framebuffer_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glRenderbufferStorageMultisampleAPPLE (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glResolveMultisampleFramebufferAPPLE (void); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (GL_APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEAPPLEPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLRESOLVEMULTISAMPLEFRAMEBUFFERAPPLEPROC) (void); +#endif + +/* GL_APPLE_rgb_422 */ +#ifndef GL_APPLE_rgb_422 +#define GL_APPLE_rgb_422 1 +#endif + +/* GL_APPLE_sync */ +#ifndef GL_APPLE_sync +#define GL_APPLE_sync 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL GLsync GL_APIENTRY glFenceSyncAPPLE (GLenum condition, GLbitfield flags); +GL_APICALL GLboolean GL_APIENTRY glIsSyncAPPLE (GLsync sync); +GL_APICALL void GL_APIENTRY glDeleteSyncAPPLE (GLsync sync); +GL_APICALL GLenum GL_APIENTRY glClientWaitSyncAPPLE (GLsync sync, GLbitfield flags, GLuint64 timeout); +GL_APICALL void GL_APIENTRY glWaitSyncAPPLE (GLsync sync, GLbitfield flags, GLuint64 timeout); +GL_APICALL void GL_APIENTRY glGetInteger64vAPPLE (GLenum pname, GLint64 *params); +GL_APICALL void GL_APIENTRY glGetSyncivAPPLE (GLsync sync, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +#endif +typedef GLsync (GL_APIENTRYP PFNGLFENCESYNCAPPLEPROC) (GLenum condition, GLbitfield flags); +typedef GLboolean (GL_APIENTRYP PFNGLISSYNCAPPLEPROC) (GLsync sync); +typedef void (GL_APIENTRYP PFNGLDELETESYNCAPPLEPROC) (GLsync sync); +typedef GLenum (GL_APIENTRYP PFNGLCLIENTWAITSYNCAPPLEPROC) (GLsync sync, GLbitfield flags, GLuint64 timeout); +typedef void (GL_APIENTRYP PFNGLWAITSYNCAPPLEPROC) (GLsync sync, GLbitfield flags, GLuint64 timeout); +typedef void (GL_APIENTRYP PFNGLGETINTEGER64VAPPLEPROC) (GLenum pname, GLint64 *params); +typedef void (GL_APIENTRYP PFNGLGETSYNCIVAPPLEPROC) (GLsync sync, GLenum pname, GLsizei bufSize, GLsizei *length, GLint *values); +#endif + +/* GL_APPLE_texture_format_BGRA8888 */ +#ifndef GL_APPLE_texture_format_BGRA8888 +#define GL_APPLE_texture_format_BGRA8888 1 +#endif + +/* GL_APPLE_texture_max_level */ +#ifndef GL_APPLE_texture_max_level +#define GL_APPLE_texture_max_level 1 +#endif + +/*------------------------------------------------------------------------* + * ARM extension functions + *------------------------------------------------------------------------*/ + +/* GL_ARM_mali_program_binary */ +#ifndef GL_ARM_mali_program_binary +#define GL_ARM_mali_program_binary 1 +#endif + +/* GL_ARM_mali_shader_binary */ +#ifndef GL_ARM_mali_shader_binary +#define GL_ARM_mali_shader_binary 1 +#endif + +/* GL_ARM_rgba8 */ +#ifndef GL_ARM_rgba8 +#define GL_ARM_rgba8 1 +#endif + +/*------------------------------------------------------------------------* + * EXT extension functions + *------------------------------------------------------------------------*/ + +/* GL_EXT_blend_minmax */ +#ifndef GL_EXT_blend_minmax +#define GL_EXT_blend_minmax 1 +#endif + +/* GL_EXT_color_buffer_half_float */ +#ifndef GL_EXT_color_buffer_half_float +#define GL_EXT_color_buffer_half_float 1 +#endif + +/* GL_EXT_debug_label */ +#ifndef GL_EXT_debug_label +#define GL_EXT_debug_label 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glLabelObjectEXT (GLenum type, GLuint object, GLsizei length, const GLchar *label); +GL_APICALL void GL_APIENTRY glGetObjectLabelEXT (GLenum type, GLuint object, GLsizei bufSize, GLsizei *length, GLchar *label); +#endif +typedef void (GL_APIENTRYP PFNGLLABELOBJECTEXTPROC) (GLenum type, GLuint object, GLsizei length, const GLchar *label); +typedef void (GL_APIENTRYP PFNGLGETOBJECTLABELEXTPROC) (GLenum type, GLuint object, GLsizei bufSize, GLsizei *length, GLchar *label); +#endif + +/* GL_EXT_debug_marker */ +#ifndef GL_EXT_debug_marker +#define GL_EXT_debug_marker 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glInsertEventMarkerEXT (GLsizei length, const GLchar *marker); +GL_APICALL void GL_APIENTRY glPushGroupMarkerEXT (GLsizei length, const GLchar *marker); +GL_APICALL void GL_APIENTRY glPopGroupMarkerEXT (void); +#endif +typedef void (GL_APIENTRYP PFNGLINSERTEVENTMARKEREXTPROC) (GLsizei length, const GLchar *marker); +typedef void (GL_APIENTRYP PFNGLPUSHGROUPMARKEREXTPROC) (GLsizei length, const GLchar *marker); +typedef void (GL_APIENTRYP PFNGLPOPGROUPMARKEREXTPROC) (void); +#endif + +/* GL_EXT_discard_framebuffer */ +#ifndef GL_EXT_discard_framebuffer +#define GL_EXT_discard_framebuffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDiscardFramebufferEXT (GLenum target, GLsizei numAttachments, const GLenum *attachments); +#endif +typedef void (GL_APIENTRYP PFNGLDISCARDFRAMEBUFFEREXTPROC) (GLenum target, GLsizei numAttachments, const GLenum *attachments); +#endif + +#ifndef GL_EXT_disjoint_timer_query +#define GL_EXT_disjoint_timer_query 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glGenQueriesEXT (GLsizei n, GLuint *ids); +GL_APICALL void GL_APIENTRY glDeleteQueriesEXT (GLsizei n, const GLuint *ids); +GL_APICALL GLboolean GL_APIENTRY glIsQueryEXT (GLuint id); +GL_APICALL void GL_APIENTRY glBeginQueryEXT (GLenum target, GLuint id); +GL_APICALL void GL_APIENTRY glEndQueryEXT (GLenum target); +GL_APICALL void GL_APIENTRY glQueryCounterEXT (GLuint id, GLenum target); +GL_APICALL void GL_APIENTRY glGetQueryivEXT (GLenum target, GLenum pname, GLint *params); +GL_APICALL void GL_APIENTRY glGetQueryObjectivEXT (GLuint id, GLenum pname, GLint *params); +GL_APICALL void GL_APIENTRY glGetQueryObjectuivEXT (GLuint id, GLenum pname, GLuint *params); +GL_APICALL void GL_APIENTRY glGetQueryObjecti64vEXT (GLuint id, GLenum pname, GLint64 *params); +GL_APICALL void GL_APIENTRY glGetQueryObjectui64vEXT (GLuint id, GLenum pname, GLuint64 *params); +#endif +typedef void (GL_APIENTRYP PFNGLGENQUERIESEXTPROC) (GLsizei n, GLuint *ids); +typedef void (GL_APIENTRYP PFNGLDELETEQUERIESEXTPROC) (GLsizei n, const GLuint *ids); +typedef GLboolean (GL_APIENTRYP PFNGLISQUERYEXTPROC) (GLuint id); +typedef void (GL_APIENTRYP PFNGLBEGINQUERYEXTPROC) (GLenum target, GLuint id); +typedef void (GL_APIENTRYP PFNGLENDQUERYEXTPROC) (GLenum target); +typedef void (GL_APIENTRYP PFNGLQUERYCOUNTEREXTPROC) (GLuint id, GLenum target); +typedef void (GL_APIENTRYP PFNGLGETQUERYIVEXTPROC) (GLenum target, GLenum pname, GLint *params); +typedef void (GL_APIENTRYP PFNGLGETQUERYOBJECTIVEXTPROC) (GLuint id, GLenum pname, GLint *params); +typedef void (GL_APIENTRYP PFNGLGETQUERYOBJECTUIVEXTPROC) (GLuint id, GLenum pname, GLuint *params); +typedef void (GL_APIENTRYP PFNGLGETQUERYOBJECTI64VEXTPROC) (GLuint id, GLenum pname, GLint64 *params); +typedef void (GL_APIENTRYP PFNGLGETQUERYOBJECTUI64VEXTPROC) (GLuint id, GLenum pname, GLuint64 *params); +#endif /* GL_EXT_disjoint_timer_query */ + +#ifndef GL_EXT_draw_buffers +#define GL_EXT_draw_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDrawBuffersEXT (GLsizei n, const GLenum *bufs); +#endif +typedef void (GL_APIENTRYP PFNGLDRAWBUFFERSEXTPROC) (GLsizei n, const GLenum *bufs); +#endif /* GL_EXT_draw_buffers */ + +/* GL_EXT_map_buffer_range */ +#ifndef GL_EXT_map_buffer_range +#define GL_EXT_map_buffer_range 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void* GL_APIENTRY glMapBufferRangeEXT (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); +GL_APICALL void GL_APIENTRY glFlushMappedBufferRangeEXT (GLenum target, GLintptr offset, GLsizeiptr length); +#endif +typedef void* (GL_APIENTRYP PFNGLMAPBUFFERRANGEEXTPROC) (GLenum target, GLintptr offset, GLsizeiptr length, GLbitfield access); +typedef void (GL_APIENTRYP PFNGLFLUSHMAPPEDBUFFERRANGEEXTPROC) (GLenum target, GLintptr offset, GLsizeiptr length); +#endif + +/* GL_EXT_multisampled_render_to_texture */ +#ifndef GL_EXT_multisampled_render_to_texture +#define GL_EXT_multisampled_render_to_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glRenderbufferStorageMultisampleEXT (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glFramebufferTexture2DMultisampleEXT (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLsizei samples); +#endif +typedef void (GL_APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEEXTPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DMULTISAMPLEEXTPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLsizei samples); +#endif + +/* GL_EXT_multiview_draw_buffers */ +#ifndef GL_EXT_multiview_draw_buffers +#define GL_EXT_multiview_draw_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glReadBufferIndexedEXT (GLenum src, GLint index); +GL_APICALL void GL_APIENTRY glDrawBuffersIndexedEXT (GLint n, const GLenum *location, const GLint *indices); +GL_APICALL void GL_APIENTRY glGetIntegeri_vEXT (GLenum target, GLuint index, GLint *data); +#endif +typedef void (GL_APIENTRYP PFNGLREADBUFFERINDEXEDEXTPROC) (GLenum src, GLint index); +typedef void (GL_APIENTRYP PFNGLDRAWBUFFERSINDEXEDEXTPROC) (GLint n, const GLenum *location, const GLint *indices); +typedef void (GL_APIENTRYP PFNGLGETINTEGERI_VEXTPROC) (GLenum target, GLuint index, GLint *data); +#endif + +#ifndef GL_EXT_multi_draw_arrays +#define GL_EXT_multi_draw_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glMultiDrawArraysEXT (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +GL_APICALL void GL_APIENTRY glMultiDrawElementsEXT (GLenum mode, const GLsizei *count, GLenum type, const GLvoid **indices, GLsizei primcount); +#endif /* GL_GLEXT_PROTOTYPES */ +typedef void (GL_APIENTRYP PFNGLMULTIDRAWARRAYSEXTPROC) (GLenum mode, const GLint *first, const GLsizei *count, GLsizei primcount); +typedef void (GL_APIENTRYP PFNGLMULTIDRAWELEMENTSEXTPROC) (GLenum mode, const GLsizei *count, GLenum type, const GLvoid **indices, GLsizei primcount); +#endif + +/* GL_EXT_occlusion_query_boolean */ +#ifndef GL_EXT_occlusion_query_boolean +#define GL_EXT_occlusion_query_boolean 1 +/* All entry points also exist in GL_EXT_disjoint_timer_query */ +#endif + +/* GL_EXT_read_format_bgra */ +#ifndef GL_EXT_read_format_bgra +#define GL_EXT_read_format_bgra 1 +#endif + +/* GL_EXT_robustness */ +#ifndef GL_EXT_robustness +#define GL_EXT_robustness 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL GLenum GL_APIENTRY glGetGraphicsResetStatusEXT (void); +GL_APICALL void GL_APIENTRY glReadnPixelsEXT (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, GLvoid *data); +GL_APICALL void GL_APIENTRY glGetnUniformfvEXT (GLuint program, GLint location, GLsizei bufSize, GLfloat *params); +GL_APICALL void GL_APIENTRY glGetnUniformivEXT (GLuint program, GLint location, GLsizei bufSize, GLint *params); +#endif +typedef GLenum (GL_APIENTRYP PFNGLGETGRAPHICSRESETSTATUSEXTPROC) (void); +typedef void (GL_APIENTRYP PFNGLREADNPIXELSEXTPROC) (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLsizei bufSize, GLvoid *data); +typedef void (GL_APIENTRYP PFNGLGETNUNIFORMFVEXTPROC) (GLuint program, GLint location, GLsizei bufSize, GLfloat *params); +typedef void (GL_APIENTRYP PFNGLGETNUNIFORMIVEXTPROC) (GLuint program, GLint location, GLsizei bufSize, GLint *params); +#endif + +/* GL_EXT_separate_shader_objects */ +#ifndef GL_EXT_separate_shader_objects +#define GL_EXT_separate_shader_objects 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glUseProgramStagesEXT (GLuint pipeline, GLbitfield stages, GLuint program); +GL_APICALL void GL_APIENTRY glActiveShaderProgramEXT (GLuint pipeline, GLuint program); +GL_APICALL GLuint GL_APIENTRY glCreateShaderProgramvEXT (GLenum type, GLsizei count, const GLchar **strings); +GL_APICALL void GL_APIENTRY glBindProgramPipelineEXT (GLuint pipeline); +GL_APICALL void GL_APIENTRY glDeleteProgramPipelinesEXT (GLsizei n, const GLuint *pipelines); +GL_APICALL void GL_APIENTRY glGenProgramPipelinesEXT (GLsizei n, GLuint *pipelines); +GL_APICALL GLboolean GL_APIENTRY glIsProgramPipelineEXT (GLuint pipeline); +GL_APICALL void GL_APIENTRY glProgramParameteriEXT (GLuint program, GLenum pname, GLint value); +GL_APICALL void GL_APIENTRY glGetProgramPipelineivEXT (GLuint pipeline, GLenum pname, GLint *params); +GL_APICALL void GL_APIENTRY glProgramUniform1iEXT (GLuint program, GLint location, GLint x); +GL_APICALL void GL_APIENTRY glProgramUniform2iEXT (GLuint program, GLint location, GLint x, GLint y); +GL_APICALL void GL_APIENTRY glProgramUniform3iEXT (GLuint program, GLint location, GLint x, GLint y, GLint z); +GL_APICALL void GL_APIENTRY glProgramUniform4iEXT (GLuint program, GLint location, GLint x, GLint y, GLint z, GLint w); +GL_APICALL void GL_APIENTRY glProgramUniform1fEXT (GLuint program, GLint location, GLfloat x); +GL_APICALL void GL_APIENTRY glProgramUniform2fEXT (GLuint program, GLint location, GLfloat x, GLfloat y); +GL_APICALL void GL_APIENTRY glProgramUniform3fEXT (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z); +GL_APICALL void GL_APIENTRY glProgramUniform4fEXT (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +GL_APICALL void GL_APIENTRY glProgramUniform1ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GL_APICALL void GL_APIENTRY glProgramUniform2ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GL_APICALL void GL_APIENTRY glProgramUniform3ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GL_APICALL void GL_APIENTRY glProgramUniform4ivEXT (GLuint program, GLint location, GLsizei count, const GLint *value); +GL_APICALL void GL_APIENTRY glProgramUniform1fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniform2fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniform3fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniform4fvEXT (GLuint program, GLint location, GLsizei count, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniformMatrix2fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniformMatrix3fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GL_APICALL void GL_APIENTRY glProgramUniformMatrix4fvEXT (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +GL_APICALL void GL_APIENTRY glValidateProgramPipelineEXT (GLuint pipeline); +GL_APICALL void GL_APIENTRY glGetProgramPipelineInfoLogEXT (GLuint pipeline, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +#endif +typedef void (GL_APIENTRYP PFNGLUSEPROGRAMSTAGESEXTPROC) (GLuint pipeline, GLbitfield stages, GLuint program); +typedef void (GL_APIENTRYP PFNGLACTIVESHADERPROGRAMEXTPROC) (GLuint pipeline, GLuint program); +typedef GLuint (GL_APIENTRYP PFNGLCREATESHADERPROGRAMVEXTPROC) (GLenum type, GLsizei count, const GLchar **strings); +typedef void (GL_APIENTRYP PFNGLBINDPROGRAMPIPELINEEXTPROC) (GLuint pipeline); +typedef void (GL_APIENTRYP PFNGLDELETEPROGRAMPIPELINESEXTPROC) (GLsizei n, const GLuint *pipelines); +typedef void (GL_APIENTRYP PFNGLGENPROGRAMPIPELINESEXTPROC) (GLsizei n, GLuint *pipelines); +typedef GLboolean (GL_APIENTRYP PFNGLISPROGRAMPIPELINEEXTPROC) (GLuint pipeline); +typedef void (GL_APIENTRYP PFNGLPROGRAMPARAMETERIEXTPROC) (GLuint program, GLenum pname, GLint value); +typedef void (GL_APIENTRYP PFNGLGETPROGRAMPIPELINEIVEXTPROC) (GLuint pipeline, GLenum pname, GLint *params); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM1IEXTPROC) (GLuint program, GLint location, GLint x); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM2IEXTPROC) (GLuint program, GLint location, GLint x, GLint y); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM3IEXTPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM4IEXTPROC) (GLuint program, GLint location, GLint x, GLint y, GLint z, GLint w); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM1FEXTPROC) (GLuint program, GLint location, GLfloat x); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM2FEXTPROC) (GLuint program, GLint location, GLfloat x, GLfloat y); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM3FEXTPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM4FEXTPROC) (GLuint program, GLint location, GLfloat x, GLfloat y, GLfloat z, GLfloat w); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM1IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM2IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM3IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM4IVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLint *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM1FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM2FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM3FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORM4FVEXTPROC) (GLuint program, GLint location, GLsizei count, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORMMATRIX2FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORMMATRIX3FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLPROGRAMUNIFORMMATRIX4FVEXTPROC) (GLuint program, GLint location, GLsizei count, GLboolean transpose, const GLfloat *value); +typedef void (GL_APIENTRYP PFNGLVALIDATEPROGRAMPIPELINEEXTPROC) (GLuint pipeline); +typedef void (GL_APIENTRYP PFNGLGETPROGRAMPIPELINEINFOLOGEXTPROC) (GLuint pipeline, GLsizei bufSize, GLsizei *length, GLchar *infoLog); +#endif + +/* GL_EXT_shader_framebuffer_fetch */ +#ifndef GL_EXT_shader_framebuffer_fetch +#define GL_EXT_shader_framebuffer_fetch 1 +#endif + +/* GL_EXT_shader_texture_lod */ +#ifndef GL_EXT_shader_texture_lod +#define GL_EXT_shader_texture_lod 1 +#endif + +/* GL_EXT_shadow_samplers */ +#ifndef GL_EXT_shadow_samplers +#define GL_EXT_shadow_samplers 1 +#endif + +/* GL_EXT_sRGB */ +#ifndef GL_EXT_sRGB +#define GL_EXT_sRGB 1 +#endif + +/* GL_EXT_texture_compression_dxt1 */ +#ifndef GL_EXT_texture_compression_dxt1 +#define GL_EXT_texture_compression_dxt1 1 +#endif + +/* GL_EXT_texture_filter_anisotropic */ +#ifndef GL_EXT_texture_filter_anisotropic +#define GL_EXT_texture_filter_anisotropic 1 +#endif + +/* GL_EXT_texture_format_BGRA8888 */ +#ifndef GL_EXT_texture_format_BGRA8888 +#define GL_EXT_texture_format_BGRA8888 1 +#endif + +/* GL_EXT_texture_rg */ +#ifndef GL_EXT_texture_rg +#define GL_EXT_texture_rg 1 +#endif + +/* GL_EXT_texture_storage */ +#ifndef GL_EXT_texture_storage +#define GL_EXT_texture_storage 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glTexStorage1DEXT (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +GL_APICALL void GL_APIENTRY glTexStorage2DEXT (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glTexStorage3DEXT (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +GL_APICALL void GL_APIENTRY glTextureStorage1DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +GL_APICALL void GL_APIENTRY glTextureStorage2DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glTextureStorage3DEXT (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +#endif +typedef void (GL_APIENTRYP PFNGLTEXSTORAGE1DEXTPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +typedef void (GL_APIENTRYP PFNGLTEXSTORAGE2DEXTPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLTEXSTORAGE3DEXTPROC) (GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +typedef void (GL_APIENTRYP PFNGLTEXTURESTORAGE1DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width); +typedef void (GL_APIENTRYP PFNGLTEXTURESTORAGE2DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLTEXTURESTORAGE3DEXTPROC) (GLuint texture, GLenum target, GLsizei levels, GLenum internalformat, GLsizei width, GLsizei height, GLsizei depth); +#endif + +/* GL_EXT_texture_type_2_10_10_10_REV */ +#ifndef GL_EXT_texture_type_2_10_10_10_REV +#define GL_EXT_texture_type_2_10_10_10_REV 1 +#endif + +/* GL_EXT_unpack_subimage */ +#ifndef GL_EXT_unpack_subimage +#define GL_EXT_unpack_subimage 1 +#endif + +/*------------------------------------------------------------------------* + * DMP extension functions + *------------------------------------------------------------------------*/ + +/* GL_DMP_shader_binary */ +#ifndef GL_DMP_shader_binary +#define GL_DMP_shader_binary 1 +#endif + +/*------------------------------------------------------------------------* + * FJ extension functions + *------------------------------------------------------------------------*/ + +/* GL_FJ_shader_binary_GCCSO */ +#ifndef GL_FJ_shader_binary_GCCSO +#define GL_FJ_shader_binary_GCCSO 1 +#endif + +/*------------------------------------------------------------------------* + * IMG extension functions + *------------------------------------------------------------------------*/ + +/* GL_IMG_program_binary */ +#ifndef GL_IMG_program_binary +#define GL_IMG_program_binary 1 +#endif + +/* GL_IMG_read_format */ +#ifndef GL_IMG_read_format +#define GL_IMG_read_format 1 +#endif + +/* GL_IMG_shader_binary */ +#ifndef GL_IMG_shader_binary +#define GL_IMG_shader_binary 1 +#endif + +/* GL_IMG_texture_compression_pvrtc */ +#ifndef GL_IMG_texture_compression_pvrtc +#define GL_IMG_texture_compression_pvrtc 1 +#endif + +/* GL_IMG_texture_compression_pvrtc2 */ +#ifndef GL_IMG_texture_compression_pvrtc2 +#define GL_IMG_texture_compression_pvrtc2 1 +#endif + +/* GL_IMG_multisampled_render_to_texture */ +#ifndef GL_IMG_multisampled_render_to_texture +#define GL_IMG_multisampled_render_to_texture 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glRenderbufferStorageMultisampleIMG (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +GL_APICALL void GL_APIENTRY glFramebufferTexture2DMultisampleIMG (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLsizei samples); +#endif +typedef void (GL_APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLEIMGPROC) (GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +typedef void (GL_APIENTRYP PFNGLFRAMEBUFFERTEXTURE2DMULTISAMPLEIMGPROC) (GLenum target, GLenum attachment, GLenum textarget, GLuint texture, GLint level, GLsizei samples); +#endif + +/*------------------------------------------------------------------------* + * NV extension functions + *------------------------------------------------------------------------*/ + +/* GL_NV_coverage_sample */ +#ifndef GL_NV_coverage_sample +#define GL_NV_coverage_sample 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glCoverageMaskNV (GLboolean mask); +GL_APICALL void GL_APIENTRY glCoverageOperationNV (GLenum operation); +#endif +typedef void (GL_APIENTRYP PFNGLCOVERAGEMASKNVPROC) (GLboolean mask); +typedef void (GL_APIENTRYP PFNGLCOVERAGEOPERATIONNVPROC) (GLenum operation); +#endif + +/* GL_NV_depth_nonlinear */ +#ifndef GL_NV_depth_nonlinear +#define GL_NV_depth_nonlinear 1 +#endif + +/* GL_NV_draw_buffers */ +#ifndef GL_NV_draw_buffers +#define GL_NV_draw_buffers 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDrawBuffersNV (GLsizei n, const GLenum *bufs); +#endif +typedef void (GL_APIENTRYP PFNGLDRAWBUFFERSNVPROC) (GLsizei n, const GLenum *bufs); +#endif + +/* GL_NV_draw_instanced */ +#ifndef GL_NV_draw_instanced +#define GL_NV_draw_instanced 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDrawArraysInstancedNV (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +GL_APICALL void GL_APIENTRY glDrawElementsInstancedNV (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); +#endif +typedef void (GL_APIENTRYP PFNGLDRAWARRAYSINSTANCEDNVPROC) (GLenum mode, GLint first, GLsizei count, GLsizei primcount); +typedef void (GL_APIENTRYP PFNGLDRAWELEMENTSINSTANCEDNVPROC) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices, GLsizei primcount); +#endif + +/* GL_NV_fbo_color_attachments */ +#ifndef GL_NV_fbo_color_attachments +#define GL_NV_fbo_color_attachments 1 +#endif + +/* GL_NV_fence */ +#ifndef GL_NV_fence +#define GL_NV_fence 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glDeleteFencesNV (GLsizei n, const GLuint *fences); +GL_APICALL void GL_APIENTRY glGenFencesNV (GLsizei n, GLuint *fences); +GL_APICALL GLboolean GL_APIENTRY glIsFenceNV (GLuint fence); +GL_APICALL GLboolean GL_APIENTRY glTestFenceNV (GLuint fence); +GL_APICALL void GL_APIENTRY glGetFenceivNV (GLuint fence, GLenum pname, GLint *params); +GL_APICALL void GL_APIENTRY glFinishFenceNV (GLuint fence); +GL_APICALL void GL_APIENTRY glSetFenceNV (GLuint fence, GLenum condition); +#endif +typedef void (GL_APIENTRYP PFNGLDELETEFENCESNVPROC) (GLsizei n, const GLuint *fences); +typedef void (GL_APIENTRYP PFNGLGENFENCESNVPROC) (GLsizei n, GLuint *fences); +typedef GLboolean (GL_APIENTRYP PFNGLISFENCENVPROC) (GLuint fence); +typedef GLboolean (GL_APIENTRYP PFNGLTESTFENCENVPROC) (GLuint fence); +typedef void (GL_APIENTRYP PFNGLGETFENCEIVNVPROC) (GLuint fence, GLenum pname, GLint *params); +typedef void (GL_APIENTRYP PFNGLFINISHFENCENVPROC) (GLuint fence); +typedef void (GL_APIENTRYP PFNGLSETFENCENVPROC) (GLuint fence, GLenum condition); +#endif + +/* GL_NV_framebuffer_blit */ +#ifndef GL_NV_framebuffer_blit +#define GL_NV_framebuffer_blit 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glBlitFramebufferNV (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#endif +typedef void (GL_APIENTRYP PFNGLBLITFRAMEBUFFERNVPROC) (GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0, GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter); +#endif + +/* GL_NV_framebuffer_multisample */ +#ifndef GL_NV_framebuffer_multisample +#define GL_NV_framebuffer_multisample 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glRenderbufferStorageMultisampleNV ( GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#endif +typedef void (GL_APIENTRYP PFNGLRENDERBUFFERSTORAGEMULTISAMPLENVPROC) ( GLenum target, GLsizei samples, GLenum internalformat, GLsizei width, GLsizei height); +#endif + +/* GL_NV_generate_mipmap_sRGB */ +#ifndef GL_NV_generate_mipmap_sRGB +#define GL_NV_generate_mipmap_sRGB 1 +#endif + +/* GL_NV_instanced_arrays */ +#ifndef GL_NV_instanced_arrays +#define GL_NV_instanced_arrays 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glVertexAttribDivisorNV (GLuint index, GLuint divisor); +#endif +typedef void (GL_APIENTRYP PFNGLVERTEXATTRIBDIVISORNVPROC) (GLuint index, GLuint divisor); +#endif + +/* GL_NV_read_buffer */ +#ifndef GL_NV_read_buffer +#define GL_NV_read_buffer 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glReadBufferNV (GLenum mode); +#endif +typedef void (GL_APIENTRYP PFNGLREADBUFFERNVPROC) (GLenum mode); +#endif + +/* GL_NV_read_buffer_front */ +#ifndef GL_NV_read_buffer_front +#define GL_NV_read_buffer_front 1 +#endif + +/* GL_NV_read_depth */ +#ifndef GL_NV_read_depth +#define GL_NV_read_depth 1 +#endif + +/* GL_NV_read_depth_stencil */ +#ifndef GL_NV_read_depth_stencil +#define GL_NV_read_depth_stencil 1 +#endif + +/* GL_NV_read_stencil */ +#ifndef GL_NV_read_stencil +#define GL_NV_read_stencil 1 +#endif + +/* GL_NV_shadow_samplers_array */ +#ifndef GL_NV_shadow_samplers_array +#define GL_NV_shadow_samplers_array 1 +#endif + +/* GL_NV_shadow_samplers_cube */ +#ifndef GL_NV_shadow_samplers_cube +#define GL_NV_shadow_samplers_cube 1 +#endif + +/* GL_NV_sRGB_formats */ +#ifndef GL_NV_sRGB_formats +#define GL_NV_sRGB_formats 1 +#endif + +/* GL_NV_texture_border_clamp */ +#ifndef GL_NV_texture_border_clamp +#define GL_NV_texture_border_clamp 1 +#endif + +/* GL_NV_texture_compression_s3tc_update */ +#ifndef GL_NV_texture_compression_s3tc_update +#define GL_NV_texture_compression_s3tc_update 1 +#endif + +/* GL_NV_texture_npot_2D_mipmap */ +#ifndef GL_NV_texture_npot_2D_mipmap +#define GL_NV_texture_npot_2D_mipmap 1 +#endif + +/*------------------------------------------------------------------------* + * QCOM extension functions + *------------------------------------------------------------------------*/ + +/* GL_QCOM_alpha_test */ +#ifndef GL_QCOM_alpha_test +#define GL_QCOM_alpha_test 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glAlphaFuncQCOM (GLenum func, GLclampf ref); +#endif +typedef void (GL_APIENTRYP PFNGLALPHAFUNCQCOMPROC) (GLenum func, GLclampf ref); +#endif + +/* GL_QCOM_binning_control */ +#ifndef GL_QCOM_binning_control +#define GL_QCOM_binning_control 1 +#endif + +/* GL_QCOM_driver_control */ +#ifndef GL_QCOM_driver_control +#define GL_QCOM_driver_control 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glGetDriverControlsQCOM (GLint *num, GLsizei size, GLuint *driverControls); +GL_APICALL void GL_APIENTRY glGetDriverControlStringQCOM (GLuint driverControl, GLsizei bufSize, GLsizei *length, GLchar *driverControlString); +GL_APICALL void GL_APIENTRY glEnableDriverControlQCOM (GLuint driverControl); +GL_APICALL void GL_APIENTRY glDisableDriverControlQCOM (GLuint driverControl); +#endif +typedef void (GL_APIENTRYP PFNGLGETDRIVERCONTROLSQCOMPROC) (GLint *num, GLsizei size, GLuint *driverControls); +typedef void (GL_APIENTRYP PFNGLGETDRIVERCONTROLSTRINGQCOMPROC) (GLuint driverControl, GLsizei bufSize, GLsizei *length, GLchar *driverControlString); +typedef void (GL_APIENTRYP PFNGLENABLEDRIVERCONTROLQCOMPROC) (GLuint driverControl); +typedef void (GL_APIENTRYP PFNGLDISABLEDRIVERCONTROLQCOMPROC) (GLuint driverControl); +#endif + +/* GL_QCOM_extended_get */ +#ifndef GL_QCOM_extended_get +#define GL_QCOM_extended_get 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glExtGetTexturesQCOM (GLuint *textures, GLint maxTextures, GLint *numTextures); +GL_APICALL void GL_APIENTRY glExtGetBuffersQCOM (GLuint *buffers, GLint maxBuffers, GLint *numBuffers); +GL_APICALL void GL_APIENTRY glExtGetRenderbuffersQCOM (GLuint *renderbuffers, GLint maxRenderbuffers, GLint *numRenderbuffers); +GL_APICALL void GL_APIENTRY glExtGetFramebuffersQCOM (GLuint *framebuffers, GLint maxFramebuffers, GLint *numFramebuffers); +GL_APICALL void GL_APIENTRY glExtGetTexLevelParameterivQCOM (GLuint texture, GLenum face, GLint level, GLenum pname, GLint *params); +GL_APICALL void GL_APIENTRY glExtTexObjectStateOverrideiQCOM (GLenum target, GLenum pname, GLint param); +GL_APICALL void GL_APIENTRY glExtGetTexSubImageQCOM (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, GLvoid *texels); +GL_APICALL void GL_APIENTRY glExtGetBufferPointervQCOM (GLenum target, GLvoid **params); +#endif +typedef void (GL_APIENTRYP PFNGLEXTGETTEXTURESQCOMPROC) (GLuint *textures, GLint maxTextures, GLint *numTextures); +typedef void (GL_APIENTRYP PFNGLEXTGETBUFFERSQCOMPROC) (GLuint *buffers, GLint maxBuffers, GLint *numBuffers); +typedef void (GL_APIENTRYP PFNGLEXTGETRENDERBUFFERSQCOMPROC) (GLuint *renderbuffers, GLint maxRenderbuffers, GLint *numRenderbuffers); +typedef void (GL_APIENTRYP PFNGLEXTGETFRAMEBUFFERSQCOMPROC) (GLuint *framebuffers, GLint maxFramebuffers, GLint *numFramebuffers); +typedef void (GL_APIENTRYP PFNGLEXTGETTEXLEVELPARAMETERIVQCOMPROC) (GLuint texture, GLenum face, GLint level, GLenum pname, GLint *params); +typedef void (GL_APIENTRYP PFNGLEXTTEXOBJECTSTATEOVERRIDEIQCOMPROC) (GLenum target, GLenum pname, GLint param); +typedef void (GL_APIENTRYP PFNGLEXTGETTEXSUBIMAGEQCOMPROC) (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset, GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type, GLvoid *texels); +typedef void (GL_APIENTRYP PFNGLEXTGETBUFFERPOINTERVQCOMPROC) (GLenum target, GLvoid **params); +#endif + +/* GL_QCOM_extended_get2 */ +#ifndef GL_QCOM_extended_get2 +#define GL_QCOM_extended_get2 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glExtGetShadersQCOM (GLuint *shaders, GLint maxShaders, GLint *numShaders); +GL_APICALL void GL_APIENTRY glExtGetProgramsQCOM (GLuint *programs, GLint maxPrograms, GLint *numPrograms); +GL_APICALL GLboolean GL_APIENTRY glExtIsProgramBinaryQCOM (GLuint program); +GL_APICALL void GL_APIENTRY glExtGetProgramBinarySourceQCOM (GLuint program, GLenum shadertype, GLchar *source, GLint *length); +#endif +typedef void (GL_APIENTRYP PFNGLEXTGETSHADERSQCOMPROC) (GLuint *shaders, GLint maxShaders, GLint *numShaders); +typedef void (GL_APIENTRYP PFNGLEXTGETPROGRAMSQCOMPROC) (GLuint *programs, GLint maxPrograms, GLint *numPrograms); +typedef GLboolean (GL_APIENTRYP PFNGLEXTISPROGRAMBINARYQCOMPROC) (GLuint program); +typedef void (GL_APIENTRYP PFNGLEXTGETPROGRAMBINARYSOURCEQCOMPROC) (GLuint program, GLenum shadertype, GLchar *source, GLint *length); +#endif + +/* GL_QCOM_perfmon_global_mode */ +#ifndef GL_QCOM_perfmon_global_mode +#define GL_QCOM_perfmon_global_mode 1 +#endif + +/* GL_QCOM_writeonly_rendering */ +#ifndef GL_QCOM_writeonly_rendering +#define GL_QCOM_writeonly_rendering 1 +#endif + +/* GL_QCOM_tiled_rendering */ +#ifndef GL_QCOM_tiled_rendering +#define GL_QCOM_tiled_rendering 1 +#ifdef GL_GLEXT_PROTOTYPES +GL_APICALL void GL_APIENTRY glStartTilingQCOM (GLuint x, GLuint y, GLuint width, GLuint height, GLbitfield preserveMask); +GL_APICALL void GL_APIENTRY glEndTilingQCOM (GLbitfield preserveMask); +#endif +typedef void (GL_APIENTRYP PFNGLSTARTTILINGQCOMPROC) (GLuint x, GLuint y, GLuint width, GLuint height, GLbitfield preserveMask); +typedef void (GL_APIENTRYP PFNGLENDTILINGQCOMPROC) (GLbitfield preserveMask); +#endif + +/*------------------------------------------------------------------------* + * VIV extension tokens + *------------------------------------------------------------------------*/ + +/* GL_VIV_shader_binary */ +#ifndef GL_VIV_shader_binary +#define GL_VIV_shader_binary 1 +#endif + +#ifdef __cplusplus +} +#endif + +#endif /* __gl2ext_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2platform.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2platform.h new file mode 100644 index 0000000..c325686 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_gl2platform.h @@ -0,0 +1,30 @@ +#ifndef __gl2platform_h_ +#define __gl2platform_h_ + +/* $Revision: 10602 $ on $Date:: 2010-03-04 22:35:34 -0800 #$ */ + +/* + * This document is licensed under the SGI Free Software B License Version + * 2.0. For details, see http://oss.sgi.com/projects/FreeB/ . + */ + +/* Platform-specific types and definitions for OpenGL ES 2.X gl2.h + * + * Adopters may modify khrplatform.h and this file to suit their platform. + * You are encouraged to submit all modifications to the Khronos group so that + * they can be included in future versions of this file. Please submit changes + * by sending them to the public Khronos Bugzilla (http://khronos.org/bugzilla) + * by filing a bug against product "OpenGL-ES" component "Registry". + */ + +/*#include */ + +#ifndef GL_APICALL +#define GL_APICALL KHRONOS_APICALL +#endif + +#ifndef GL_APIENTRY +#define GL_APIENTRY KHRONOS_APIENTRY +#endif + +#endif /* __gl2platform_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_khrplatform.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_khrplatform.h new file mode 100644 index 0000000..c9e6f17 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_opengles2_khrplatform.h @@ -0,0 +1,282 @@ +#ifndef __khrplatform_h_ +#define __khrplatform_h_ + +/* +** Copyright (c) 2008-2009 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. +*/ + +/* Khronos platform-specific types and definitions. + * + * $Revision: 23298 $ on $Date: 2013-09-30 17:07:13 -0700 (Mon, 30 Sep 2013) $ + * + * Adopters may modify this file to suit their platform. Adopters are + * encouraged to submit platform specific modifications to the Khronos + * group so that they can be included in future versions of this file. + * Please submit changes by sending them to the public Khronos Bugzilla + * (http://khronos.org/bugzilla) by filing a bug against product + * "Khronos (general)" component "Registry". + * + * A predefined template which fills in some of the bug fields can be + * reached using http://tinyurl.com/khrplatform-h-bugreport, but you + * must create a Bugzilla login first. + * + * + * See the Implementer's Guidelines for information about where this file + * should be located on your system and for more details of its use: + * http://www.khronos.org/registry/implementers_guide.pdf + * + * This file should be included as + * #include + * by Khronos client API header files that use its types and defines. + * + * The types in khrplatform.h should only be used to define API-specific types. + * + * Types defined in khrplatform.h: + * khronos_int8_t signed 8 bit + * khronos_uint8_t unsigned 8 bit + * khronos_int16_t signed 16 bit + * khronos_uint16_t unsigned 16 bit + * khronos_int32_t signed 32 bit + * khronos_uint32_t unsigned 32 bit + * khronos_int64_t signed 64 bit + * khronos_uint64_t unsigned 64 bit + * khronos_intptr_t signed same number of bits as a pointer + * khronos_uintptr_t unsigned same number of bits as a pointer + * khronos_ssize_t signed size + * khronos_usize_t unsigned size + * khronos_float_t signed 32 bit floating point + * khronos_time_ns_t unsigned 64 bit time in nanoseconds + * khronos_utime_nanoseconds_t unsigned time interval or absolute time in + * nanoseconds + * khronos_stime_nanoseconds_t signed time interval in nanoseconds + * khronos_boolean_enum_t enumerated boolean type. This should + * only be used as a base type when a client API's boolean type is + * an enum. Client APIs which use an integer or other type for + * booleans cannot use this as the base type for their boolean. + * + * Tokens defined in khrplatform.h: + * + * KHRONOS_FALSE, KHRONOS_TRUE Enumerated boolean false/true values. + * + * KHRONOS_SUPPORT_INT64 is 1 if 64 bit integers are supported; otherwise 0. + * KHRONOS_SUPPORT_FLOAT is 1 if floats are supported; otherwise 0. + * + * Calling convention macros defined in this file: + * KHRONOS_APICALL + * KHRONOS_APIENTRY + * KHRONOS_APIATTRIBUTES + * + * These may be used in function prototypes as: + * + * KHRONOS_APICALL void KHRONOS_APIENTRY funcname( + * int arg1, + * int arg2) KHRONOS_APIATTRIBUTES; + */ + +/*------------------------------------------------------------------------- + * Definition of KHRONOS_APICALL + *------------------------------------------------------------------------- + * This precedes the return type of the function in the function prototype. + */ +#if defined(_WIN32) && !defined(__SCITECH_SNAP__) +# define KHRONOS_APICALL __declspec(dllimport) +#elif defined (__SYMBIAN32__) +# define KHRONOS_APICALL IMPORT_C +#else +# define KHRONOS_APICALL +#endif + +/*------------------------------------------------------------------------- + * Definition of KHRONOS_APIENTRY + *------------------------------------------------------------------------- + * This follows the return type of the function and precedes the function + * name in the function prototype. + */ +#if defined(_WIN32) && !defined(_WIN32_WCE) && !defined(__SCITECH_SNAP__) + /* Win32 but not WinCE */ +# define KHRONOS_APIENTRY __stdcall +#else +# define KHRONOS_APIENTRY +#endif + +/*------------------------------------------------------------------------- + * Definition of KHRONOS_APIATTRIBUTES + *------------------------------------------------------------------------- + * This follows the closing parenthesis of the function prototype arguments. + */ +#if defined (__ARMCC_2__) +#define KHRONOS_APIATTRIBUTES __softfp +#else +#define KHRONOS_APIATTRIBUTES +#endif + +/*------------------------------------------------------------------------- + * basic type definitions + *-----------------------------------------------------------------------*/ +#if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) || defined(__GNUC__) || defined(__SCO__) || defined(__USLC__) + + +/* + * Using + */ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(__VMS ) || defined(__sgi) + +/* + * Using + */ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(_WIN32) && !defined(__SCITECH_SNAP__) + +/* + * Win32 + */ +typedef __int32 khronos_int32_t; +typedef unsigned __int32 khronos_uint32_t; +typedef __int64 khronos_int64_t; +typedef unsigned __int64 khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif defined(__sun__) || defined(__digital__) + +/* + * Sun or Digital + */ +typedef int khronos_int32_t; +typedef unsigned int khronos_uint32_t; +#if defined(__arch64__) || defined(_LP64) +typedef long int khronos_int64_t; +typedef unsigned long int khronos_uint64_t; +#else +typedef long long int khronos_int64_t; +typedef unsigned long long int khronos_uint64_t; +#endif /* __arch64__ */ +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#elif 0 + +/* + * Hypothetical platform with no float or int64 support + */ +typedef int khronos_int32_t; +typedef unsigned int khronos_uint32_t; +#define KHRONOS_SUPPORT_INT64 0 +#define KHRONOS_SUPPORT_FLOAT 0 + +#else + +/* + * Generic fallback + */ +#include +typedef int32_t khronos_int32_t; +typedef uint32_t khronos_uint32_t; +typedef int64_t khronos_int64_t; +typedef uint64_t khronos_uint64_t; +#define KHRONOS_SUPPORT_INT64 1 +#define KHRONOS_SUPPORT_FLOAT 1 + +#endif + + +/* + * Types that are (so far) the same on all platforms + */ +typedef signed char khronos_int8_t; +typedef unsigned char khronos_uint8_t; +typedef signed short int khronos_int16_t; +typedef unsigned short int khronos_uint16_t; + +/* + * Types that differ between LLP64 and LP64 architectures - in LLP64, + * pointers are 64 bits, but 'long' is still 32 bits. Win64 appears + * to be the only LLP64 architecture in current use. + */ +#ifdef _WIN64 +typedef signed long long int khronos_intptr_t; +typedef unsigned long long int khronos_uintptr_t; +typedef signed long long int khronos_ssize_t; +typedef unsigned long long int khronos_usize_t; +#else +typedef signed long int khronos_intptr_t; +typedef unsigned long int khronos_uintptr_t; +typedef signed long int khronos_ssize_t; +typedef unsigned long int khronos_usize_t; +#endif + +#if KHRONOS_SUPPORT_FLOAT +/* + * Float type + */ +typedef float khronos_float_t; +#endif + +#if KHRONOS_SUPPORT_INT64 +/* Time types + * + * These types can be used to represent a time interval in nanoseconds or + * an absolute Unadjusted System Time. Unadjusted System Time is the number + * of nanoseconds since some arbitrary system event (e.g. since the last + * time the system booted). The Unadjusted System Time is an unsigned + * 64 bit value that wraps back to 0 every 584 years. Time intervals + * may be either signed or unsigned. + */ +typedef khronos_uint64_t khronos_utime_nanoseconds_t; +typedef khronos_int64_t khronos_stime_nanoseconds_t; +#endif + +/* + * Dummy value used to pad enum types to 32 bits. + */ +#ifndef KHRONOS_MAX_ENUM +#define KHRONOS_MAX_ENUM 0x7FFFFFFF +#endif + +/* + * Enumerated boolean type + * + * Values other than zero should be considered to be true. Therefore + * comparisons should not be made against KHRONOS_TRUE. + */ +typedef enum { + KHRONOS_FALSE = 0, + KHRONOS_TRUE = 1, + KHRONOS_BOOLEAN_ENUM_FORCE_SIZE = KHRONOS_MAX_ENUM +} khronos_boolean_enum_t; + +#endif /* __khrplatform_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_pixels.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_pixels.h new file mode 100644 index 0000000..dcb7a98 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_pixels.h @@ -0,0 +1,470 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_pixels.h + * + * Header for the enumerated pixel format definitions. + */ + +#ifndef SDL_pixels_h_ +#define SDL_pixels_h_ + +#include "SDL_stdinc.h" +#include "SDL_endian.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \name Transparency definitions + * + * These define alpha as the opacity of a surface. + */ +/* @{ */ +#define SDL_ALPHA_OPAQUE 255 +#define SDL_ALPHA_TRANSPARENT 0 +/* @} */ + +/** Pixel type. */ +enum +{ + SDL_PIXELTYPE_UNKNOWN, + SDL_PIXELTYPE_INDEX1, + SDL_PIXELTYPE_INDEX4, + SDL_PIXELTYPE_INDEX8, + SDL_PIXELTYPE_PACKED8, + SDL_PIXELTYPE_PACKED16, + SDL_PIXELTYPE_PACKED32, + SDL_PIXELTYPE_ARRAYU8, + SDL_PIXELTYPE_ARRAYU16, + SDL_PIXELTYPE_ARRAYU32, + SDL_PIXELTYPE_ARRAYF16, + SDL_PIXELTYPE_ARRAYF32 +}; + +/** Bitmap pixel order, high bit -> low bit. */ +enum +{ + SDL_BITMAPORDER_NONE, + SDL_BITMAPORDER_4321, + SDL_BITMAPORDER_1234 +}; + +/** Packed component order, high bit -> low bit. */ +enum +{ + SDL_PACKEDORDER_NONE, + SDL_PACKEDORDER_XRGB, + SDL_PACKEDORDER_RGBX, + SDL_PACKEDORDER_ARGB, + SDL_PACKEDORDER_RGBA, + SDL_PACKEDORDER_XBGR, + SDL_PACKEDORDER_BGRX, + SDL_PACKEDORDER_ABGR, + SDL_PACKEDORDER_BGRA +}; + +/** Array component order, low byte -> high byte. */ +/* !!! FIXME: in 2.1, make these not overlap differently with + !!! FIXME: SDL_PACKEDORDER_*, so we can simplify SDL_ISPIXELFORMAT_ALPHA */ +enum +{ + SDL_ARRAYORDER_NONE, + SDL_ARRAYORDER_RGB, + SDL_ARRAYORDER_RGBA, + SDL_ARRAYORDER_ARGB, + SDL_ARRAYORDER_BGR, + SDL_ARRAYORDER_BGRA, + SDL_ARRAYORDER_ABGR +}; + +/** Packed component layout. */ +enum +{ + SDL_PACKEDLAYOUT_NONE, + SDL_PACKEDLAYOUT_332, + SDL_PACKEDLAYOUT_4444, + SDL_PACKEDLAYOUT_1555, + SDL_PACKEDLAYOUT_5551, + SDL_PACKEDLAYOUT_565, + SDL_PACKEDLAYOUT_8888, + SDL_PACKEDLAYOUT_2101010, + SDL_PACKEDLAYOUT_1010102 +}; + +#define SDL_DEFINE_PIXELFOURCC(A, B, C, D) SDL_FOURCC(A, B, C, D) + +#define SDL_DEFINE_PIXELFORMAT(type, order, layout, bits, bytes) \ + ((1 << 28) | ((type) << 24) | ((order) << 20) | ((layout) << 16) | \ + ((bits) << 8) | ((bytes) << 0)) + +#define SDL_PIXELFLAG(X) (((X) >> 28) & 0x0F) +#define SDL_PIXELTYPE(X) (((X) >> 24) & 0x0F) +#define SDL_PIXELORDER(X) (((X) >> 20) & 0x0F) +#define SDL_PIXELLAYOUT(X) (((X) >> 16) & 0x0F) +#define SDL_BITSPERPIXEL(X) (((X) >> 8) & 0xFF) +#define SDL_BYTESPERPIXEL(X) \ + (SDL_ISPIXELFORMAT_FOURCC(X) ? \ + ((((X) == SDL_PIXELFORMAT_YUY2) || \ + ((X) == SDL_PIXELFORMAT_UYVY) || \ + ((X) == SDL_PIXELFORMAT_YVYU)) ? 2 : 1) : (((X) >> 0) & 0xFF)) + +#define SDL_ISPIXELFORMAT_INDEXED(format) \ + (!SDL_ISPIXELFORMAT_FOURCC(format) && \ + ((SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX1) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX4) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX8))) + +#define SDL_ISPIXELFORMAT_PACKED(format) \ + (!SDL_ISPIXELFORMAT_FOURCC(format) && \ + ((SDL_PIXELTYPE(format) == SDL_PIXELTYPE_PACKED8) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_PACKED16) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_PACKED32))) + +#define SDL_ISPIXELFORMAT_ARRAY(format) \ + (!SDL_ISPIXELFORMAT_FOURCC(format) && \ + ((SDL_PIXELTYPE(format) == SDL_PIXELTYPE_ARRAYU8) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_ARRAYU16) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_ARRAYU32) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_ARRAYF16) || \ + (SDL_PIXELTYPE(format) == SDL_PIXELTYPE_ARRAYF32))) + +#define SDL_ISPIXELFORMAT_ALPHA(format) \ + ((SDL_ISPIXELFORMAT_PACKED(format) && \ + ((SDL_PIXELORDER(format) == SDL_PACKEDORDER_ARGB) || \ + (SDL_PIXELORDER(format) == SDL_PACKEDORDER_RGBA) || \ + (SDL_PIXELORDER(format) == SDL_PACKEDORDER_ABGR) || \ + (SDL_PIXELORDER(format) == SDL_PACKEDORDER_BGRA))) || \ + (SDL_ISPIXELFORMAT_ARRAY(format) && \ + ((SDL_PIXELORDER(format) == SDL_ARRAYORDER_ARGB) || \ + (SDL_PIXELORDER(format) == SDL_ARRAYORDER_RGBA) || \ + (SDL_PIXELORDER(format) == SDL_ARRAYORDER_ABGR) || \ + (SDL_PIXELORDER(format) == SDL_ARRAYORDER_BGRA)))) + +/* The flag is set to 1 because 0x1? is not in the printable ASCII range */ +#define SDL_ISPIXELFORMAT_FOURCC(format) \ + ((format) && (SDL_PIXELFLAG(format) != 1)) + +/* Note: If you modify this list, update SDL_GetPixelFormatName() */ +typedef enum +{ + SDL_PIXELFORMAT_UNKNOWN, + SDL_PIXELFORMAT_INDEX1LSB = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX1, SDL_BITMAPORDER_4321, 0, + 1, 0), + SDL_PIXELFORMAT_INDEX1MSB = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX1, SDL_BITMAPORDER_1234, 0, + 1, 0), + SDL_PIXELFORMAT_INDEX4LSB = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX4, SDL_BITMAPORDER_4321, 0, + 4, 0), + SDL_PIXELFORMAT_INDEX4MSB = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX4, SDL_BITMAPORDER_1234, 0, + 4, 0), + SDL_PIXELFORMAT_INDEX8 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX8, 0, 0, 8, 1), + SDL_PIXELFORMAT_RGB332 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED8, SDL_PACKEDORDER_XRGB, + SDL_PACKEDLAYOUT_332, 8, 1), + SDL_PIXELFORMAT_RGB444 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB, + SDL_PACKEDLAYOUT_4444, 12, 2), + SDL_PIXELFORMAT_RGB555 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB, + SDL_PACKEDLAYOUT_1555, 15, 2), + SDL_PIXELFORMAT_BGR555 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XBGR, + SDL_PACKEDLAYOUT_1555, 15, 2), + SDL_PIXELFORMAT_ARGB4444 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ARGB, + SDL_PACKEDLAYOUT_4444, 16, 2), + SDL_PIXELFORMAT_RGBA4444 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_RGBA, + SDL_PACKEDLAYOUT_4444, 16, 2), + SDL_PIXELFORMAT_ABGR4444 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ABGR, + SDL_PACKEDLAYOUT_4444, 16, 2), + SDL_PIXELFORMAT_BGRA4444 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_BGRA, + SDL_PACKEDLAYOUT_4444, 16, 2), + SDL_PIXELFORMAT_ARGB1555 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ARGB, + SDL_PACKEDLAYOUT_1555, 16, 2), + SDL_PIXELFORMAT_RGBA5551 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_RGBA, + SDL_PACKEDLAYOUT_5551, 16, 2), + SDL_PIXELFORMAT_ABGR1555 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ABGR, + SDL_PACKEDLAYOUT_1555, 16, 2), + SDL_PIXELFORMAT_BGRA5551 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_BGRA, + SDL_PACKEDLAYOUT_5551, 16, 2), + SDL_PIXELFORMAT_RGB565 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB, + SDL_PACKEDLAYOUT_565, 16, 2), + SDL_PIXELFORMAT_BGR565 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XBGR, + SDL_PACKEDLAYOUT_565, 16, 2), + SDL_PIXELFORMAT_RGB24 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_ARRAYU8, SDL_ARRAYORDER_RGB, 0, + 24, 3), + SDL_PIXELFORMAT_BGR24 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_ARRAYU8, SDL_ARRAYORDER_BGR, 0, + 24, 3), + SDL_PIXELFORMAT_RGB888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_XRGB, + SDL_PACKEDLAYOUT_8888, 24, 4), + SDL_PIXELFORMAT_RGBX8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_RGBX, + SDL_PACKEDLAYOUT_8888, 24, 4), + SDL_PIXELFORMAT_BGR888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_XBGR, + SDL_PACKEDLAYOUT_8888, 24, 4), + SDL_PIXELFORMAT_BGRX8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_BGRX, + SDL_PACKEDLAYOUT_8888, 24, 4), + SDL_PIXELFORMAT_ARGB8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ARGB, + SDL_PACKEDLAYOUT_8888, 32, 4), + SDL_PIXELFORMAT_RGBA8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_RGBA, + SDL_PACKEDLAYOUT_8888, 32, 4), + SDL_PIXELFORMAT_ABGR8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ABGR, + SDL_PACKEDLAYOUT_8888, 32, 4), + SDL_PIXELFORMAT_BGRA8888 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_BGRA, + SDL_PACKEDLAYOUT_8888, 32, 4), + SDL_PIXELFORMAT_ARGB2101010 = + SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ARGB, + SDL_PACKEDLAYOUT_2101010, 32, 4), + + /* Aliases for RGBA byte arrays of color data, for the current platform */ +#if SDL_BYTEORDER == SDL_BIG_ENDIAN + SDL_PIXELFORMAT_RGBA32 = SDL_PIXELFORMAT_RGBA8888, + SDL_PIXELFORMAT_ARGB32 = SDL_PIXELFORMAT_ARGB8888, + SDL_PIXELFORMAT_BGRA32 = SDL_PIXELFORMAT_BGRA8888, + SDL_PIXELFORMAT_ABGR32 = SDL_PIXELFORMAT_ABGR8888, +#else + SDL_PIXELFORMAT_RGBA32 = SDL_PIXELFORMAT_ABGR8888, + SDL_PIXELFORMAT_ARGB32 = SDL_PIXELFORMAT_BGRA8888, + SDL_PIXELFORMAT_BGRA32 = SDL_PIXELFORMAT_ARGB8888, + SDL_PIXELFORMAT_ABGR32 = SDL_PIXELFORMAT_RGBA8888, +#endif + + SDL_PIXELFORMAT_YV12 = /**< Planar mode: Y + V + U (3 planes) */ + SDL_DEFINE_PIXELFOURCC('Y', 'V', '1', '2'), + SDL_PIXELFORMAT_IYUV = /**< Planar mode: Y + U + V (3 planes) */ + SDL_DEFINE_PIXELFOURCC('I', 'Y', 'U', 'V'), + SDL_PIXELFORMAT_YUY2 = /**< Packed mode: Y0+U0+Y1+V0 (1 plane) */ + SDL_DEFINE_PIXELFOURCC('Y', 'U', 'Y', '2'), + SDL_PIXELFORMAT_UYVY = /**< Packed mode: U0+Y0+V0+Y1 (1 plane) */ + SDL_DEFINE_PIXELFOURCC('U', 'Y', 'V', 'Y'), + SDL_PIXELFORMAT_YVYU = /**< Packed mode: Y0+V0+Y1+U0 (1 plane) */ + SDL_DEFINE_PIXELFOURCC('Y', 'V', 'Y', 'U'), + SDL_PIXELFORMAT_NV12 = /**< Planar mode: Y + U/V interleaved (2 planes) */ + SDL_DEFINE_PIXELFOURCC('N', 'V', '1', '2'), + SDL_PIXELFORMAT_NV21 = /**< Planar mode: Y + V/U interleaved (2 planes) */ + SDL_DEFINE_PIXELFOURCC('N', 'V', '2', '1'), + SDL_PIXELFORMAT_EXTERNAL_OES = /**< Android video texture format */ + SDL_DEFINE_PIXELFOURCC('O', 'E', 'S', ' ') +} SDL_PixelFormatEnum; + +typedef struct SDL_Color +{ + Uint8 r; + Uint8 g; + Uint8 b; + Uint8 a; +} SDL_Color; +#define SDL_Colour SDL_Color + +typedef struct SDL_Palette +{ + int ncolors; + SDL_Color *colors; + Uint32 version; + int refcount; +} SDL_Palette; + +/** + * \note Everything in the pixel format structure is read-only. + */ +typedef struct SDL_PixelFormat +{ + Uint32 format; + SDL_Palette *palette; + Uint8 BitsPerPixel; + Uint8 BytesPerPixel; + Uint8 padding[2]; + Uint32 Rmask; + Uint32 Gmask; + Uint32 Bmask; + Uint32 Amask; + Uint8 Rloss; + Uint8 Gloss; + Uint8 Bloss; + Uint8 Aloss; + Uint8 Rshift; + Uint8 Gshift; + Uint8 Bshift; + Uint8 Ashift; + int refcount; + struct SDL_PixelFormat *next; +} SDL_PixelFormat; + +/** + * \brief Get the human readable name of a pixel format + */ +extern DECLSPEC const char* SDLCALL SDL_GetPixelFormatName(Uint32 format); + +/** + * \brief Convert one of the enumerated pixel formats to a bpp and RGBA masks. + * + * \return SDL_TRUE, or SDL_FALSE if the conversion wasn't possible. + * + * \sa SDL_MasksToPixelFormatEnum() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_PixelFormatEnumToMasks(Uint32 format, + int *bpp, + Uint32 * Rmask, + Uint32 * Gmask, + Uint32 * Bmask, + Uint32 * Amask); + +/** + * \brief Convert a bpp and RGBA masks to an enumerated pixel format. + * + * \return The pixel format, or ::SDL_PIXELFORMAT_UNKNOWN if the conversion + * wasn't possible. + * + * \sa SDL_PixelFormatEnumToMasks() + */ +extern DECLSPEC Uint32 SDLCALL SDL_MasksToPixelFormatEnum(int bpp, + Uint32 Rmask, + Uint32 Gmask, + Uint32 Bmask, + Uint32 Amask); + +/** + * \brief Create an SDL_PixelFormat structure from a pixel format enum. + */ +extern DECLSPEC SDL_PixelFormat * SDLCALL SDL_AllocFormat(Uint32 pixel_format); + +/** + * \brief Free an SDL_PixelFormat structure. + */ +extern DECLSPEC void SDLCALL SDL_FreeFormat(SDL_PixelFormat *format); + +/** + * \brief Create a palette structure with the specified number of color + * entries. + * + * \return A new palette, or NULL if there wasn't enough memory. + * + * \note The palette entries are initialized to white. + * + * \sa SDL_FreePalette() + */ +extern DECLSPEC SDL_Palette *SDLCALL SDL_AllocPalette(int ncolors); + +/** + * \brief Set the palette for a pixel format structure. + */ +extern DECLSPEC int SDLCALL SDL_SetPixelFormatPalette(SDL_PixelFormat * format, + SDL_Palette *palette); + +/** + * \brief Set a range of colors in a palette. + * + * \param palette The palette to modify. + * \param colors An array of colors to copy into the palette. + * \param firstcolor The index of the first palette entry to modify. + * \param ncolors The number of entries to modify. + * + * \return 0 on success, or -1 if not all of the colors could be set. + */ +extern DECLSPEC int SDLCALL SDL_SetPaletteColors(SDL_Palette * palette, + const SDL_Color * colors, + int firstcolor, int ncolors); + +/** + * \brief Free a palette created with SDL_AllocPalette(). + * + * \sa SDL_AllocPalette() + */ +extern DECLSPEC void SDLCALL SDL_FreePalette(SDL_Palette * palette); + +/** + * \brief Maps an RGB triple to an opaque pixel value for a given pixel format. + * + * \sa SDL_MapRGBA + */ +extern DECLSPEC Uint32 SDLCALL SDL_MapRGB(const SDL_PixelFormat * format, + Uint8 r, Uint8 g, Uint8 b); + +/** + * \brief Maps an RGBA quadruple to a pixel value for a given pixel format. + * + * \sa SDL_MapRGB + */ +extern DECLSPEC Uint32 SDLCALL SDL_MapRGBA(const SDL_PixelFormat * format, + Uint8 r, Uint8 g, Uint8 b, + Uint8 a); + +/** + * \brief Get the RGB components from a pixel of the specified format. + * + * \sa SDL_GetRGBA + */ +extern DECLSPEC void SDLCALL SDL_GetRGB(Uint32 pixel, + const SDL_PixelFormat * format, + Uint8 * r, Uint8 * g, Uint8 * b); + +/** + * \brief Get the RGBA components from a pixel of the specified format. + * + * \sa SDL_GetRGB + */ +extern DECLSPEC void SDLCALL SDL_GetRGBA(Uint32 pixel, + const SDL_PixelFormat * format, + Uint8 * r, Uint8 * g, Uint8 * b, + Uint8 * a); + +/** + * \brief Calculate a 256 entry gamma ramp for a gamma value. + */ +extern DECLSPEC void SDLCALL SDL_CalculateGammaRamp(float gamma, Uint16 * ramp); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_pixels_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_platform.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_platform.h new file mode 100644 index 0000000..c2cbc6b --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_platform.h @@ -0,0 +1,198 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_platform.h + * + * Try to get a standard set of platform defines. + */ + +#ifndef SDL_platform_h_ +#define SDL_platform_h_ + +#if defined(_AIX) +#undef __AIX__ +#define __AIX__ 1 +#endif +#if defined(__HAIKU__) +#undef __HAIKU__ +#define __HAIKU__ 1 +#endif +#if defined(bsdi) || defined(__bsdi) || defined(__bsdi__) +#undef __BSDI__ +#define __BSDI__ 1 +#endif +#if defined(_arch_dreamcast) +#undef __DREAMCAST__ +#define __DREAMCAST__ 1 +#endif +#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__) +#undef __FREEBSD__ +#define __FREEBSD__ 1 +#endif +#if defined(hpux) || defined(__hpux) || defined(__hpux__) +#undef __HPUX__ +#define __HPUX__ 1 +#endif +#if defined(sgi) || defined(__sgi) || defined(__sgi__) || defined(_SGI_SOURCE) +#undef __IRIX__ +#define __IRIX__ 1 +#endif +#if (defined(linux) || defined(__linux) || defined(__linux__)) +#undef __LINUX__ +#define __LINUX__ 1 +#endif +#if defined(ANDROID) || defined(__ANDROID__) +#undef __ANDROID__ +#undef __LINUX__ /* do we need to do this? */ +#define __ANDROID__ 1 +#endif + +#if defined(__APPLE__) +/* lets us know what version of Mac OS X we're compiling on */ +#include "AvailabilityMacros.h" +#include "TargetConditionals.h" +#if TARGET_OS_TV +#undef __TVOS__ +#define __TVOS__ 1 +#endif +#if TARGET_OS_IPHONE +/* if compiling for iOS */ +#undef __IPHONEOS__ +#define __IPHONEOS__ 1 +#undef __MACOSX__ +#else +/* if not compiling for iOS */ +#undef __MACOSX__ +#define __MACOSX__ 1 +#if MAC_OS_X_VERSION_MIN_REQUIRED < 1060 +# error SDL for Mac OS X only supports deploying on 10.6 and above. +#endif /* MAC_OS_X_VERSION_MIN_REQUIRED < 1060 */ +#endif /* TARGET_OS_IPHONE */ +#endif /* defined(__APPLE__) */ + +#if defined(__NetBSD__) +#undef __NETBSD__ +#define __NETBSD__ 1 +#endif +#if defined(__OpenBSD__) +#undef __OPENBSD__ +#define __OPENBSD__ 1 +#endif +#if defined(__OS2__) || defined(__EMX__) +#undef __OS2__ +#define __OS2__ 1 +#endif +#if defined(osf) || defined(__osf) || defined(__osf__) || defined(_OSF_SOURCE) +#undef __OSF__ +#define __OSF__ 1 +#endif +#if defined(__QNXNTO__) +#undef __QNXNTO__ +#define __QNXNTO__ 1 +#endif +#if defined(riscos) || defined(__riscos) || defined(__riscos__) +#undef __RISCOS__ +#define __RISCOS__ 1 +#endif +#if defined(__sun) && defined(__SVR4) +#undef __SOLARIS__ +#define __SOLARIS__ 1 +#endif + +#if defined(WIN32) || defined(_WIN32) || defined(__CYGWIN__) || defined(__MINGW32__) +/* Try to find out if we're compiling for WinRT or non-WinRT */ +#if defined(_MSC_VER) && defined(__has_include) +#if __has_include() +#define HAVE_WINAPIFAMILY_H 1 +#else +#define HAVE_WINAPIFAMILY_H 0 +#endif + +/* If _USING_V110_SDK71_ is defined it means we are using the Windows XP toolset. */ +#elif defined(_MSC_VER) && (_MSC_VER >= 1700 && !_USING_V110_SDK71_) /* _MSC_VER == 1700 for Visual Studio 2012 */ +#define HAVE_WINAPIFAMILY_H 1 +#else +#define HAVE_WINAPIFAMILY_H 0 +#endif + +#if HAVE_WINAPIFAMILY_H +#include +#define WINAPI_FAMILY_WINRT (!WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) && WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP)) +#else +#define WINAPI_FAMILY_WINRT 0 +#endif /* HAVE_WINAPIFAMILY_H */ + +#if WINAPI_FAMILY_WINRT +#undef __WINRT__ +#define __WINRT__ 1 +#else +#undef __WINDOWS__ +#define __WINDOWS__ 1 +#endif +#endif /* defined(WIN32) || defined(_WIN32) || defined(__CYGWIN__) */ + +#if defined(__WINDOWS__) +#undef __WIN32__ +#define __WIN32__ 1 +#endif +#if defined(__PSP__) +#undef __PSP__ +#define __PSP__ 1 +#endif + +/* The NACL compiler defines __native_client__ and __pnacl__ + * Ref: http://www.chromium.org/nativeclient/pnacl/stability-of-the-pnacl-bitcode-abi + */ +#if defined(__native_client__) +#undef __LINUX__ +#undef __NACL__ +#define __NACL__ 1 +#endif +#if defined(__pnacl__) +#undef __LINUX__ +#undef __PNACL__ +#define __PNACL__ 1 +/* PNACL with newlib supports static linking only */ +#define __SDL_NOGETPROCADDR__ +#endif + + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Gets the name of the platform. + */ +extern DECLSPEC const char * SDLCALL SDL_GetPlatform (void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_platform_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_power.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_power.h new file mode 100644 index 0000000..4831cb7 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_power.h @@ -0,0 +1,75 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_power_h_ +#define SDL_power_h_ + +/** + * \file SDL_power.h + * + * Header for the SDL power management routines. + */ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief The basic state for the system's power supply. + */ +typedef enum +{ + SDL_POWERSTATE_UNKNOWN, /**< cannot determine power status */ + SDL_POWERSTATE_ON_BATTERY, /**< Not plugged in, running on the battery */ + SDL_POWERSTATE_NO_BATTERY, /**< Plugged in, no battery available */ + SDL_POWERSTATE_CHARGING, /**< Plugged in, charging battery */ + SDL_POWERSTATE_CHARGED /**< Plugged in, battery charged */ +} SDL_PowerState; + + +/** + * \brief Get the current power supply details. + * + * \param secs Seconds of battery life left. You can pass a NULL here if + * you don't care. Will return -1 if we can't determine a + * value, or we're not running on a battery. + * + * \param pct Percentage of battery life left, between 0 and 100. You can + * pass a NULL here if you don't care. Will return -1 if we + * can't determine a value, or we're not running on a battery. + * + * \return The state of the battery (if any). + */ +extern DECLSPEC SDL_PowerState SDLCALL SDL_GetPowerInfo(int *secs, int *pct); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_power_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_quit.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_quit.h new file mode 100644 index 0000000..c979983 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_quit.h @@ -0,0 +1,58 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_quit.h + * + * Include file for SDL quit event handling. + */ + +#ifndef SDL_quit_h_ +#define SDL_quit_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +/** + * \file SDL_quit.h + * + * An ::SDL_QUIT event is generated when the user tries to close the application + * window. If it is ignored or filtered out, the window will remain open. + * If it is not ignored or filtered, it is queued normally and the window + * is allowed to close. When the window is closed, screen updates will + * complete, but have no effect. + * + * SDL_Init() installs signal handlers for SIGINT (keyboard interrupt) + * and SIGTERM (system termination request), if handlers do not already + * exist, that generate ::SDL_QUIT events as well. There is no way + * to determine the cause of an ::SDL_QUIT event, but setting a signal + * handler in your application will override the default generation of + * quit events for that signal. + * + * \sa SDL_Quit() + */ + +/* There are no functions directly affecting the quit event */ + +#define SDL_QuitRequested() \ + (SDL_PumpEvents(), (SDL_PeepEvents(NULL,0,SDL_PEEKEVENT,SDL_QUIT,SDL_QUIT) > 0)) + +#endif /* SDL_quit_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rect.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rect.h new file mode 100644 index 0000000..71a4115 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rect.h @@ -0,0 +1,174 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_rect.h + * + * Header file for SDL_rect definition and management functions. + */ + +#ifndef SDL_rect_h_ +#define SDL_rect_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_pixels.h" +#include "SDL_rwops.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief The structure that defines a point (integer) + * + * \sa SDL_EnclosePoints + * \sa SDL_PointInRect + */ +typedef struct SDL_Point +{ + int x; + int y; +} SDL_Point; + +/** + * \brief The structure that defines a point (floating point) + * + * \sa SDL_EnclosePoints + * \sa SDL_PointInRect + */ +typedef struct SDL_FPoint +{ + float x; + float y; +} SDL_FPoint; + + +/** + * \brief A rectangle, with the origin at the upper left (integer). + * + * \sa SDL_RectEmpty + * \sa SDL_RectEquals + * \sa SDL_HasIntersection + * \sa SDL_IntersectRect + * \sa SDL_UnionRect + * \sa SDL_EnclosePoints + */ +typedef struct SDL_Rect +{ + int x, y; + int w, h; +} SDL_Rect; + + +/** + * \brief A rectangle, with the origin at the upper left (floating point). + */ +typedef struct SDL_FRect +{ + float x; + float y; + float w; + float h; +} SDL_FRect; + + +/** + * \brief Returns true if point resides inside a rectangle. + */ +SDL_FORCE_INLINE SDL_bool SDL_PointInRect(const SDL_Point *p, const SDL_Rect *r) +{ + return ( (p->x >= r->x) && (p->x < (r->x + r->w)) && + (p->y >= r->y) && (p->y < (r->y + r->h)) ) ? SDL_TRUE : SDL_FALSE; +} + +/** + * \brief Returns true if the rectangle has no area. + */ +SDL_FORCE_INLINE SDL_bool SDL_RectEmpty(const SDL_Rect *r) +{ + return ((!r) || (r->w <= 0) || (r->h <= 0)) ? SDL_TRUE : SDL_FALSE; +} + +/** + * \brief Returns true if the two rectangles are equal. + */ +SDL_FORCE_INLINE SDL_bool SDL_RectEquals(const SDL_Rect *a, const SDL_Rect *b) +{ + return (a && b && (a->x == b->x) && (a->y == b->y) && + (a->w == b->w) && (a->h == b->h)) ? SDL_TRUE : SDL_FALSE; +} + +/** + * \brief Determine whether two rectangles intersect. + * + * \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasIntersection(const SDL_Rect * A, + const SDL_Rect * B); + +/** + * \brief Calculate the intersection of two rectangles. + * + * \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IntersectRect(const SDL_Rect * A, + const SDL_Rect * B, + SDL_Rect * result); + +/** + * \brief Calculate the union of two rectangles. + */ +extern DECLSPEC void SDLCALL SDL_UnionRect(const SDL_Rect * A, + const SDL_Rect * B, + SDL_Rect * result); + +/** + * \brief Calculate a minimal rectangle enclosing a set of points + * + * \return SDL_TRUE if any points were within the clipping rect + */ +extern DECLSPEC SDL_bool SDLCALL SDL_EnclosePoints(const SDL_Point * points, + int count, + const SDL_Rect * clip, + SDL_Rect * result); + +/** + * \brief Calculate the intersection of a rectangle and line segment. + * + * \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IntersectRectAndLine(const SDL_Rect * + rect, int *X1, + int *Y1, int *X2, + int *Y2); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_rect_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_render.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_render.h new file mode 100644 index 0000000..096b4a5 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_render.h @@ -0,0 +1,1098 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_render.h + * + * Header file for SDL 2D rendering functions. + * + * This API supports the following features: + * * single pixel points + * * single pixel lines + * * filled rectangles + * * texture images + * + * The primitives may be drawn in opaque, blended, or additive modes. + * + * The texture images may be drawn in opaque, blended, or additive modes. + * They can have an additional color tint or alpha modulation applied to + * them, and may also be stretched with linear interpolation. + * + * This API is designed to accelerate simple 2D operations. You may + * want more functionality such as polygons and particle effects and + * in that case you should use SDL's OpenGL/Direct3D support or one + * of the many good 3D engines. + * + * These functions must be called from the main thread. + * See this bug for details: http://bugzilla.libsdl.org/show_bug.cgi?id=1995 + */ + +#ifndef SDL_render_h_ +#define SDL_render_h_ + +#include "SDL_stdinc.h" +#include "SDL_rect.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Flags used when creating a rendering context + */ +typedef enum +{ + SDL_RENDERER_SOFTWARE = 0x00000001, /**< The renderer is a software fallback */ + SDL_RENDERER_ACCELERATED = 0x00000002, /**< The renderer uses hardware + acceleration */ + SDL_RENDERER_PRESENTVSYNC = 0x00000004, /**< Present is synchronized + with the refresh rate */ + SDL_RENDERER_TARGETTEXTURE = 0x00000008 /**< The renderer supports + rendering to texture */ +} SDL_RendererFlags; + +/** + * \brief Information on the capabilities of a render driver or context. + */ +typedef struct SDL_RendererInfo +{ + const char *name; /**< The name of the renderer */ + Uint32 flags; /**< Supported ::SDL_RendererFlags */ + Uint32 num_texture_formats; /**< The number of available texture formats */ + Uint32 texture_formats[16]; /**< The available texture formats */ + int max_texture_width; /**< The maximum texture width */ + int max_texture_height; /**< The maximum texture height */ +} SDL_RendererInfo; + +/** + * \brief The access pattern allowed for a texture. + */ +typedef enum +{ + SDL_TEXTUREACCESS_STATIC, /**< Changes rarely, not lockable */ + SDL_TEXTUREACCESS_STREAMING, /**< Changes frequently, lockable */ + SDL_TEXTUREACCESS_TARGET /**< Texture can be used as a render target */ +} SDL_TextureAccess; + +/** + * \brief The texture channel modulation used in SDL_RenderCopy(). + */ +typedef enum +{ + SDL_TEXTUREMODULATE_NONE = 0x00000000, /**< No modulation */ + SDL_TEXTUREMODULATE_COLOR = 0x00000001, /**< srcC = srcC * color */ + SDL_TEXTUREMODULATE_ALPHA = 0x00000002 /**< srcA = srcA * alpha */ +} SDL_TextureModulate; + +/** + * \brief Flip constants for SDL_RenderCopyEx + */ +typedef enum +{ + SDL_FLIP_NONE = 0x00000000, /**< Do not flip */ + SDL_FLIP_HORIZONTAL = 0x00000001, /**< flip horizontally */ + SDL_FLIP_VERTICAL = 0x00000002 /**< flip vertically */ +} SDL_RendererFlip; + +/** + * \brief A structure representing rendering state + */ +struct SDL_Renderer; +typedef struct SDL_Renderer SDL_Renderer; + +/** + * \brief An efficient driver-specific representation of pixel data + */ +struct SDL_Texture; +typedef struct SDL_Texture SDL_Texture; + + +/* Function prototypes */ + +/** + * \brief Get the number of 2D rendering drivers available for the current + * display. + * + * A render driver is a set of code that handles rendering and texture + * management on a particular display. Normally there is only one, but + * some drivers may have several available with different capabilities. + * + * \sa SDL_GetRenderDriverInfo() + * \sa SDL_CreateRenderer() + */ +extern DECLSPEC int SDLCALL SDL_GetNumRenderDrivers(void); + +/** + * \brief Get information about a specific 2D rendering driver for the current + * display. + * + * \param index The index of the driver to query information about. + * \param info A pointer to an SDL_RendererInfo struct to be filled with + * information on the rendering driver. + * + * \return 0 on success, -1 if the index was out of range. + * + * \sa SDL_CreateRenderer() + */ +extern DECLSPEC int SDLCALL SDL_GetRenderDriverInfo(int index, + SDL_RendererInfo * info); + +/** + * \brief Create a window and default renderer + * + * \param width The width of the window + * \param height The height of the window + * \param window_flags The flags used to create the window + * \param window A pointer filled with the window, or NULL on error + * \param renderer A pointer filled with the renderer, or NULL on error + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_CreateWindowAndRenderer( + int width, int height, Uint32 window_flags, + SDL_Window **window, SDL_Renderer **renderer); + + +/** + * \brief Create a 2D rendering context for a window. + * + * \param window The window where rendering is displayed. + * \param index The index of the rendering driver to initialize, or -1 to + * initialize the first one supporting the requested flags. + * \param flags ::SDL_RendererFlags. + * + * \return A valid rendering context or NULL if there was an error. + * + * \sa SDL_CreateSoftwareRenderer() + * \sa SDL_GetRendererInfo() + * \sa SDL_DestroyRenderer() + */ +extern DECLSPEC SDL_Renderer * SDLCALL SDL_CreateRenderer(SDL_Window * window, + int index, Uint32 flags); + +/** + * \brief Create a 2D software rendering context for a surface. + * + * \param surface The surface where rendering is done. + * + * \return A valid rendering context or NULL if there was an error. + * + * \sa SDL_CreateRenderer() + * \sa SDL_DestroyRenderer() + */ +extern DECLSPEC SDL_Renderer * SDLCALL SDL_CreateSoftwareRenderer(SDL_Surface * surface); + +/** + * \brief Get the renderer associated with a window. + */ +extern DECLSPEC SDL_Renderer * SDLCALL SDL_GetRenderer(SDL_Window * window); + +/** + * \brief Get information about a rendering context. + */ +extern DECLSPEC int SDLCALL SDL_GetRendererInfo(SDL_Renderer * renderer, + SDL_RendererInfo * info); + +/** + * \brief Get the output size in pixels of a rendering context. + */ +extern DECLSPEC int SDLCALL SDL_GetRendererOutputSize(SDL_Renderer * renderer, + int *w, int *h); + +/** + * \brief Create a texture for a rendering context. + * + * \param renderer The renderer. + * \param format The format of the texture. + * \param access One of the enumerated values in ::SDL_TextureAccess. + * \param w The width of the texture in pixels. + * \param h The height of the texture in pixels. + * + * \return The created texture is returned, or NULL if no rendering context was + * active, the format was unsupported, or the width or height were out + * of range. + * + * \note The contents of the texture are not defined at creation. + * + * \sa SDL_QueryTexture() + * \sa SDL_UpdateTexture() + * \sa SDL_DestroyTexture() + */ +extern DECLSPEC SDL_Texture * SDLCALL SDL_CreateTexture(SDL_Renderer * renderer, + Uint32 format, + int access, int w, + int h); + +/** + * \brief Create a texture from an existing surface. + * + * \param renderer The renderer. + * \param surface The surface containing pixel data used to fill the texture. + * + * \return The created texture is returned, or NULL on error. + * + * \note The surface is not modified or freed by this function. + * + * \sa SDL_QueryTexture() + * \sa SDL_DestroyTexture() + */ +extern DECLSPEC SDL_Texture * SDLCALL SDL_CreateTextureFromSurface(SDL_Renderer * renderer, SDL_Surface * surface); + +/** + * \brief Query the attributes of a texture + * + * \param texture A texture to be queried. + * \param format A pointer filled in with the raw format of the texture. The + * actual format may differ, but pixel transfers will use this + * format. + * \param access A pointer filled in with the actual access to the texture. + * \param w A pointer filled in with the width of the texture in pixels. + * \param h A pointer filled in with the height of the texture in pixels. + * + * \return 0 on success, or -1 if the texture is not valid. + */ +extern DECLSPEC int SDLCALL SDL_QueryTexture(SDL_Texture * texture, + Uint32 * format, int *access, + int *w, int *h); + +/** + * \brief Set an additional color value used in render copy operations. + * + * \param texture The texture to update. + * \param r The red color value multiplied into copy operations. + * \param g The green color value multiplied into copy operations. + * \param b The blue color value multiplied into copy operations. + * + * \return 0 on success, or -1 if the texture is not valid or color modulation + * is not supported. + * + * \sa SDL_GetTextureColorMod() + */ +extern DECLSPEC int SDLCALL SDL_SetTextureColorMod(SDL_Texture * texture, + Uint8 r, Uint8 g, Uint8 b); + + +/** + * \brief Get the additional color value used in render copy operations. + * + * \param texture The texture to query. + * \param r A pointer filled in with the current red color value. + * \param g A pointer filled in with the current green color value. + * \param b A pointer filled in with the current blue color value. + * + * \return 0 on success, or -1 if the texture is not valid. + * + * \sa SDL_SetTextureColorMod() + */ +extern DECLSPEC int SDLCALL SDL_GetTextureColorMod(SDL_Texture * texture, + Uint8 * r, Uint8 * g, + Uint8 * b); + +/** + * \brief Set an additional alpha value used in render copy operations. + * + * \param texture The texture to update. + * \param alpha The alpha value multiplied into copy operations. + * + * \return 0 on success, or -1 if the texture is not valid or alpha modulation + * is not supported. + * + * \sa SDL_GetTextureAlphaMod() + */ +extern DECLSPEC int SDLCALL SDL_SetTextureAlphaMod(SDL_Texture * texture, + Uint8 alpha); + +/** + * \brief Get the additional alpha value used in render copy operations. + * + * \param texture The texture to query. + * \param alpha A pointer filled in with the current alpha value. + * + * \return 0 on success, or -1 if the texture is not valid. + * + * \sa SDL_SetTextureAlphaMod() + */ +extern DECLSPEC int SDLCALL SDL_GetTextureAlphaMod(SDL_Texture * texture, + Uint8 * alpha); + +/** + * \brief Set the blend mode used for texture copy operations. + * + * \param texture The texture to update. + * \param blendMode ::SDL_BlendMode to use for texture blending. + * + * \return 0 on success, or -1 if the texture is not valid or the blend mode is + * not supported. + * + * \note If the blend mode is not supported, the closest supported mode is + * chosen. + * + * \sa SDL_GetTextureBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_SetTextureBlendMode(SDL_Texture * texture, + SDL_BlendMode blendMode); + +/** + * \brief Get the blend mode used for texture copy operations. + * + * \param texture The texture to query. + * \param blendMode A pointer filled in with the current blend mode. + * + * \return 0 on success, or -1 if the texture is not valid. + * + * \sa SDL_SetTextureBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_GetTextureBlendMode(SDL_Texture * texture, + SDL_BlendMode *blendMode); + +/** + * \brief Update the given texture rectangle with new pixel data. + * + * \param texture The texture to update + * \param rect A pointer to the rectangle of pixels to update, or NULL to + * update the entire texture. + * \param pixels The raw pixel data in the format of the texture. + * \param pitch The number of bytes in a row of pixel data, including padding between lines. + * + * The pixel data must be in the format of the texture. The pixel format can be + * queried with SDL_QueryTexture. + * + * \return 0 on success, or -1 if the texture is not valid. + * + * \note This is a fairly slow function. + */ +extern DECLSPEC int SDLCALL SDL_UpdateTexture(SDL_Texture * texture, + const SDL_Rect * rect, + const void *pixels, int pitch); + +/** + * \brief Update a rectangle within a planar YV12 or IYUV texture with new pixel data. + * + * \param texture The texture to update + * \param rect A pointer to the rectangle of pixels to update, or NULL to + * update the entire texture. + * \param Yplane The raw pixel data for the Y plane. + * \param Ypitch The number of bytes between rows of pixel data for the Y plane. + * \param Uplane The raw pixel data for the U plane. + * \param Upitch The number of bytes between rows of pixel data for the U plane. + * \param Vplane The raw pixel data for the V plane. + * \param Vpitch The number of bytes between rows of pixel data for the V plane. + * + * \return 0 on success, or -1 if the texture is not valid. + * + * \note You can use SDL_UpdateTexture() as long as your pixel data is + * a contiguous block of Y and U/V planes in the proper order, but + * this function is available if your pixel data is not contiguous. + */ +extern DECLSPEC int SDLCALL SDL_UpdateYUVTexture(SDL_Texture * texture, + const SDL_Rect * rect, + const Uint8 *Yplane, int Ypitch, + const Uint8 *Uplane, int Upitch, + const Uint8 *Vplane, int Vpitch); + +/** + * \brief Lock a portion of the texture for write-only pixel access. + * + * \param texture The texture to lock for access, which was created with + * ::SDL_TEXTUREACCESS_STREAMING. + * \param rect A pointer to the rectangle to lock for access. If the rect + * is NULL, the entire texture will be locked. + * \param pixels This is filled in with a pointer to the locked pixels, + * appropriately offset by the locked area. + * \param pitch This is filled in with the pitch of the locked pixels. + * + * \return 0 on success, or -1 if the texture is not valid or was not created with ::SDL_TEXTUREACCESS_STREAMING. + * + * \sa SDL_UnlockTexture() + */ +extern DECLSPEC int SDLCALL SDL_LockTexture(SDL_Texture * texture, + const SDL_Rect * rect, + void **pixels, int *pitch); + +/** + * \brief Unlock a texture, uploading the changes to video memory, if needed. + * + * \sa SDL_LockTexture() + */ +extern DECLSPEC void SDLCALL SDL_UnlockTexture(SDL_Texture * texture); + +/** + * \brief Determines whether a window supports the use of render targets + * + * \param renderer The renderer that will be checked + * + * \return SDL_TRUE if supported, SDL_FALSE if not. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_RenderTargetSupported(SDL_Renderer *renderer); + +/** + * \brief Set a texture as the current rendering target. + * + * \param renderer The renderer. + * \param texture The targeted texture, which must be created with the SDL_TEXTUREACCESS_TARGET flag, or NULL for the default render target + * + * \return 0 on success, or -1 on error + * + * \sa SDL_GetRenderTarget() + */ +extern DECLSPEC int SDLCALL SDL_SetRenderTarget(SDL_Renderer *renderer, + SDL_Texture *texture); + +/** + * \brief Get the current render target or NULL for the default render target. + * + * \return The current render target + * + * \sa SDL_SetRenderTarget() + */ +extern DECLSPEC SDL_Texture * SDLCALL SDL_GetRenderTarget(SDL_Renderer *renderer); + +/** + * \brief Set device independent resolution for rendering + * + * \param renderer The renderer for which resolution should be set. + * \param w The width of the logical resolution + * \param h The height of the logical resolution + * + * This function uses the viewport and scaling functionality to allow a fixed logical + * resolution for rendering, regardless of the actual output resolution. If the actual + * output resolution doesn't have the same aspect ratio the output rendering will be + * centered within the output display. + * + * If the output display is a window, mouse events in the window will be filtered + * and scaled so they seem to arrive within the logical resolution. + * + * \note If this function results in scaling or subpixel drawing by the + * rendering backend, it will be handled using the appropriate + * quality hints. + * + * \sa SDL_RenderGetLogicalSize() + * \sa SDL_RenderSetScale() + * \sa SDL_RenderSetViewport() + */ +extern DECLSPEC int SDLCALL SDL_RenderSetLogicalSize(SDL_Renderer * renderer, int w, int h); + +/** + * \brief Get device independent resolution for rendering + * + * \param renderer The renderer from which resolution should be queried. + * \param w A pointer filled with the width of the logical resolution + * \param h A pointer filled with the height of the logical resolution + * + * \sa SDL_RenderSetLogicalSize() + */ +extern DECLSPEC void SDLCALL SDL_RenderGetLogicalSize(SDL_Renderer * renderer, int *w, int *h); + +/** + * \brief Set whether to force integer scales for resolution-independent rendering + * + * \param renderer The renderer for which integer scaling should be set. + * \param enable Enable or disable integer scaling + * + * This function restricts the logical viewport to integer values - that is, when + * a resolution is between two multiples of a logical size, the viewport size is + * rounded down to the lower multiple. + * + * \sa SDL_RenderSetLogicalSize() + */ +extern DECLSPEC int SDLCALL SDL_RenderSetIntegerScale(SDL_Renderer * renderer, + SDL_bool enable); + +/** + * \brief Get whether integer scales are forced for resolution-independent rendering + * + * \param renderer The renderer from which integer scaling should be queried. + * + * \sa SDL_RenderSetIntegerScale() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_RenderGetIntegerScale(SDL_Renderer * renderer); + +/** + * \brief Set the drawing area for rendering on the current target. + * + * \param renderer The renderer for which the drawing area should be set. + * \param rect The rectangle representing the drawing area, or NULL to set the viewport to the entire target. + * + * The x,y of the viewport rect represents the origin for rendering. + * + * \return 0 on success, or -1 on error + * + * \note If the window associated with the renderer is resized, the viewport is automatically reset. + * + * \sa SDL_RenderGetViewport() + * \sa SDL_RenderSetLogicalSize() + */ +extern DECLSPEC int SDLCALL SDL_RenderSetViewport(SDL_Renderer * renderer, + const SDL_Rect * rect); + +/** + * \brief Get the drawing area for the current target. + * + * \sa SDL_RenderSetViewport() + */ +extern DECLSPEC void SDLCALL SDL_RenderGetViewport(SDL_Renderer * renderer, + SDL_Rect * rect); + +/** + * \brief Set the clip rectangle for the current target. + * + * \param renderer The renderer for which clip rectangle should be set. + * \param rect A pointer to the rectangle to set as the clip rectangle, or + * NULL to disable clipping. + * + * \return 0 on success, or -1 on error + * + * \sa SDL_RenderGetClipRect() + */ +extern DECLSPEC int SDLCALL SDL_RenderSetClipRect(SDL_Renderer * renderer, + const SDL_Rect * rect); + +/** + * \brief Get the clip rectangle for the current target. + * + * \param renderer The renderer from which clip rectangle should be queried. + * \param rect A pointer filled in with the current clip rectangle, or + * an empty rectangle if clipping is disabled. + * + * \sa SDL_RenderSetClipRect() + */ +extern DECLSPEC void SDLCALL SDL_RenderGetClipRect(SDL_Renderer * renderer, + SDL_Rect * rect); + +/** + * \brief Get whether clipping is enabled on the given renderer. + * + * \param renderer The renderer from which clip state should be queried. + * + * \sa SDL_RenderGetClipRect() + */ +extern DECLSPEC SDL_bool SDLCALL SDL_RenderIsClipEnabled(SDL_Renderer * renderer); + + +/** + * \brief Set the drawing scale for rendering on the current target. + * + * \param renderer The renderer for which the drawing scale should be set. + * \param scaleX The horizontal scaling factor + * \param scaleY The vertical scaling factor + * + * The drawing coordinates are scaled by the x/y scaling factors + * before they are used by the renderer. This allows resolution + * independent drawing with a single coordinate system. + * + * \note If this results in scaling or subpixel drawing by the + * rendering backend, it will be handled using the appropriate + * quality hints. For best results use integer scaling factors. + * + * \sa SDL_RenderGetScale() + * \sa SDL_RenderSetLogicalSize() + */ +extern DECLSPEC int SDLCALL SDL_RenderSetScale(SDL_Renderer * renderer, + float scaleX, float scaleY); + +/** + * \brief Get the drawing scale for the current target. + * + * \param renderer The renderer from which drawing scale should be queried. + * \param scaleX A pointer filled in with the horizontal scaling factor + * \param scaleY A pointer filled in with the vertical scaling factor + * + * \sa SDL_RenderSetScale() + */ +extern DECLSPEC void SDLCALL SDL_RenderGetScale(SDL_Renderer * renderer, + float *scaleX, float *scaleY); + +/** + * \brief Set the color used for drawing operations (Rect, Line and Clear). + * + * \param renderer The renderer for which drawing color should be set. + * \param r The red value used to draw on the rendering target. + * \param g The green value used to draw on the rendering target. + * \param b The blue value used to draw on the rendering target. + * \param a The alpha value used to draw on the rendering target, usually + * ::SDL_ALPHA_OPAQUE (255). + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_SetRenderDrawColor(SDL_Renderer * renderer, + Uint8 r, Uint8 g, Uint8 b, + Uint8 a); + +/** + * \brief Get the color used for drawing operations (Rect, Line and Clear). + * + * \param renderer The renderer from which drawing color should be queried. + * \param r A pointer to the red value used to draw on the rendering target. + * \param g A pointer to the green value used to draw on the rendering target. + * \param b A pointer to the blue value used to draw on the rendering target. + * \param a A pointer to the alpha value used to draw on the rendering target, + * usually ::SDL_ALPHA_OPAQUE (255). + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_GetRenderDrawColor(SDL_Renderer * renderer, + Uint8 * r, Uint8 * g, Uint8 * b, + Uint8 * a); + +/** + * \brief Set the blend mode used for drawing operations (Fill and Line). + * + * \param renderer The renderer for which blend mode should be set. + * \param blendMode ::SDL_BlendMode to use for blending. + * + * \return 0 on success, or -1 on error + * + * \note If the blend mode is not supported, the closest supported mode is + * chosen. + * + * \sa SDL_GetRenderDrawBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_SetRenderDrawBlendMode(SDL_Renderer * renderer, + SDL_BlendMode blendMode); + +/** + * \brief Get the blend mode used for drawing operations. + * + * \param renderer The renderer from which blend mode should be queried. + * \param blendMode A pointer filled in with the current blend mode. + * + * \return 0 on success, or -1 on error + * + * \sa SDL_SetRenderDrawBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_GetRenderDrawBlendMode(SDL_Renderer * renderer, + SDL_BlendMode *blendMode); + +/** + * \brief Clear the current rendering target with the drawing color + * + * This function clears the entire rendering target, ignoring the viewport and + * the clip rectangle. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderClear(SDL_Renderer * renderer); + +/** + * \brief Draw a point on the current rendering target. + * + * \param renderer The renderer which should draw a point. + * \param x The x coordinate of the point. + * \param y The y coordinate of the point. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawPoint(SDL_Renderer * renderer, + int x, int y); + +/** + * \brief Draw multiple points on the current rendering target. + * + * \param renderer The renderer which should draw multiple points. + * \param points The points to draw + * \param count The number of points to draw + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawPoints(SDL_Renderer * renderer, + const SDL_Point * points, + int count); + +/** + * \brief Draw a line on the current rendering target. + * + * \param renderer The renderer which should draw a line. + * \param x1 The x coordinate of the start point. + * \param y1 The y coordinate of the start point. + * \param x2 The x coordinate of the end point. + * \param y2 The y coordinate of the end point. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawLine(SDL_Renderer * renderer, + int x1, int y1, int x2, int y2); + +/** + * \brief Draw a series of connected lines on the current rendering target. + * + * \param renderer The renderer which should draw multiple lines. + * \param points The points along the lines + * \param count The number of points, drawing count-1 lines + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawLines(SDL_Renderer * renderer, + const SDL_Point * points, + int count); + +/** + * \brief Draw a rectangle on the current rendering target. + * + * \param renderer The renderer which should draw a rectangle. + * \param rect A pointer to the destination rectangle, or NULL to outline the entire rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawRect(SDL_Renderer * renderer, + const SDL_Rect * rect); + +/** + * \brief Draw some number of rectangles on the current rendering target. + * + * \param renderer The renderer which should draw multiple rectangles. + * \param rects A pointer to an array of destination rectangles. + * \param count The number of rectangles. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawRects(SDL_Renderer * renderer, + const SDL_Rect * rects, + int count); + +/** + * \brief Fill a rectangle on the current rendering target with the drawing color. + * + * \param renderer The renderer which should fill a rectangle. + * \param rect A pointer to the destination rectangle, or NULL for the entire + * rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderFillRect(SDL_Renderer * renderer, + const SDL_Rect * rect); + +/** + * \brief Fill some number of rectangles on the current rendering target with the drawing color. + * + * \param renderer The renderer which should fill multiple rectangles. + * \param rects A pointer to an array of destination rectangles. + * \param count The number of rectangles. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderFillRects(SDL_Renderer * renderer, + const SDL_Rect * rects, + int count); + +/** + * \brief Copy a portion of the texture to the current rendering target. + * + * \param renderer The renderer which should copy parts of a texture. + * \param texture The source texture. + * \param srcrect A pointer to the source rectangle, or NULL for the entire + * texture. + * \param dstrect A pointer to the destination rectangle, or NULL for the + * entire rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderCopy(SDL_Renderer * renderer, + SDL_Texture * texture, + const SDL_Rect * srcrect, + const SDL_Rect * dstrect); + +/** + * \brief Copy a portion of the source texture to the current rendering target, rotating it by angle around the given center + * + * \param renderer The renderer which should copy parts of a texture. + * \param texture The source texture. + * \param srcrect A pointer to the source rectangle, or NULL for the entire + * texture. + * \param dstrect A pointer to the destination rectangle, or NULL for the + * entire rendering target. + * \param angle An angle in degrees that indicates the rotation that will be applied to dstrect, rotating it in a clockwise direction + * \param center A pointer to a point indicating the point around which dstrect will be rotated (if NULL, rotation will be done around dstrect.w/2, dstrect.h/2). + * \param flip An SDL_RendererFlip value stating which flipping actions should be performed on the texture + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderCopyEx(SDL_Renderer * renderer, + SDL_Texture * texture, + const SDL_Rect * srcrect, + const SDL_Rect * dstrect, + const double angle, + const SDL_Point *center, + const SDL_RendererFlip flip); + + +/** + * \brief Draw a point on the current rendering target. + * + * \param renderer The renderer which should draw a point. + * \param x The x coordinate of the point. + * \param y The y coordinate of the point. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawPointF(SDL_Renderer * renderer, + float x, float y); + +/** + * \brief Draw multiple points on the current rendering target. + * + * \param renderer The renderer which should draw multiple points. + * \param points The points to draw + * \param count The number of points to draw + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawPointsF(SDL_Renderer * renderer, + const SDL_FPoint * points, + int count); + +/** + * \brief Draw a line on the current rendering target. + * + * \param renderer The renderer which should draw a line. + * \param x1 The x coordinate of the start point. + * \param y1 The y coordinate of the start point. + * \param x2 The x coordinate of the end point. + * \param y2 The y coordinate of the end point. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawLineF(SDL_Renderer * renderer, + float x1, float y1, float x2, float y2); + +/** + * \brief Draw a series of connected lines on the current rendering target. + * + * \param renderer The renderer which should draw multiple lines. + * \param points The points along the lines + * \param count The number of points, drawing count-1 lines + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawLinesF(SDL_Renderer * renderer, + const SDL_FPoint * points, + int count); + +/** + * \brief Draw a rectangle on the current rendering target. + * + * \param renderer The renderer which should draw a rectangle. + * \param rect A pointer to the destination rectangle, or NULL to outline the entire rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawRectF(SDL_Renderer * renderer, + const SDL_FRect * rect); + +/** + * \brief Draw some number of rectangles on the current rendering target. + * + * \param renderer The renderer which should draw multiple rectangles. + * \param rects A pointer to an array of destination rectangles. + * \param count The number of rectangles. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderDrawRectsF(SDL_Renderer * renderer, + const SDL_FRect * rects, + int count); + +/** + * \brief Fill a rectangle on the current rendering target with the drawing color. + * + * \param renderer The renderer which should fill a rectangle. + * \param rect A pointer to the destination rectangle, or NULL for the entire + * rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderFillRectF(SDL_Renderer * renderer, + const SDL_FRect * rect); + +/** + * \brief Fill some number of rectangles on the current rendering target with the drawing color. + * + * \param renderer The renderer which should fill multiple rectangles. + * \param rects A pointer to an array of destination rectangles. + * \param count The number of rectangles. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderFillRectsF(SDL_Renderer * renderer, + const SDL_FRect * rects, + int count); + +/** + * \brief Copy a portion of the texture to the current rendering target. + * + * \param renderer The renderer which should copy parts of a texture. + * \param texture The source texture. + * \param srcrect A pointer to the source rectangle, or NULL for the entire + * texture. + * \param dstrect A pointer to the destination rectangle, or NULL for the + * entire rendering target. + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderCopyF(SDL_Renderer * renderer, + SDL_Texture * texture, + const SDL_Rect * srcrect, + const SDL_FRect * dstrect); + +/** + * \brief Copy a portion of the source texture to the current rendering target, rotating it by angle around the given center + * + * \param renderer The renderer which should copy parts of a texture. + * \param texture The source texture. + * \param srcrect A pointer to the source rectangle, or NULL for the entire + * texture. + * \param dstrect A pointer to the destination rectangle, or NULL for the + * entire rendering target. + * \param angle An angle in degrees that indicates the rotation that will be applied to dstrect, rotating it in a clockwise direction + * \param center A pointer to a point indicating the point around which dstrect will be rotated (if NULL, rotation will be done around dstrect.w/2, dstrect.h/2). + * \param flip An SDL_RendererFlip value stating which flipping actions should be performed on the texture + * + * \return 0 on success, or -1 on error + */ +extern DECLSPEC int SDLCALL SDL_RenderCopyExF(SDL_Renderer * renderer, + SDL_Texture * texture, + const SDL_Rect * srcrect, + const SDL_FRect * dstrect, + const double angle, + const SDL_FPoint *center, + const SDL_RendererFlip flip); + +/** + * \brief Read pixels from the current rendering target. + * + * \param renderer The renderer from which pixels should be read. + * \param rect A pointer to the rectangle to read, or NULL for the entire + * render target. + * \param format The desired format of the pixel data, or 0 to use the format + * of the rendering target + * \param pixels A pointer to be filled in with the pixel data + * \param pitch The pitch of the pixels parameter. + * + * \return 0 on success, or -1 if pixel reading is not supported. + * + * \warning This is a very slow operation, and should not be used frequently. + */ +extern DECLSPEC int SDLCALL SDL_RenderReadPixels(SDL_Renderer * renderer, + const SDL_Rect * rect, + Uint32 format, + void *pixels, int pitch); + +/** + * \brief Update the screen with rendering performed. + */ +extern DECLSPEC void SDLCALL SDL_RenderPresent(SDL_Renderer * renderer); + +/** + * \brief Destroy the specified texture. + * + * \sa SDL_CreateTexture() + * \sa SDL_CreateTextureFromSurface() + */ +extern DECLSPEC void SDLCALL SDL_DestroyTexture(SDL_Texture * texture); + +/** + * \brief Destroy the rendering context for a window and free associated + * textures. + * + * \sa SDL_CreateRenderer() + */ +extern DECLSPEC void SDLCALL SDL_DestroyRenderer(SDL_Renderer * renderer); + +/** + * \brief Force the rendering context to flush any pending commands to the + * underlying rendering API. + * + * You do not need to (and in fact, shouldn't) call this function unless + * you are planning to call into OpenGL/Direct3D/Metal/whatever directly + * in addition to using an SDL_Renderer. + * + * This is for a very-specific case: if you are using SDL's render API, + * you asked for a specific renderer backend (OpenGL, Direct3D, etc), + * you set SDL_HINT_RENDER_BATCHING to "1", and you plan to make + * OpenGL/D3D/whatever calls in addition to SDL render API calls. If all of + * this applies, you should call SDL_RenderFlush() between calls to SDL's + * render API and the low-level API you're using in cooperation. + * + * In all other cases, you can ignore this function. This is only here to + * get maximum performance out of a specific situation. In all other cases, + * SDL will do the right thing, perhaps at a performance loss. + * + * This function is first available in SDL 2.0.10, and is not needed in + * 2.0.9 and earlier, as earlier versions did not queue rendering commands + * at all, instead flushing them to the OS immediately. + */ +extern DECLSPEC int SDLCALL SDL_RenderFlush(SDL_Renderer * renderer); + + +/** + * \brief Bind the texture to the current OpenGL/ES/ES2 context for use with + * OpenGL instructions. + * + * \param texture The SDL texture to bind + * \param texw A pointer to a float that will be filled with the texture width + * \param texh A pointer to a float that will be filled with the texture height + * + * \return 0 on success, or -1 if the operation is not supported + */ +extern DECLSPEC int SDLCALL SDL_GL_BindTexture(SDL_Texture *texture, float *texw, float *texh); + +/** + * \brief Unbind a texture from the current OpenGL/ES/ES2 context. + * + * \param texture The SDL texture to unbind + * + * \return 0 on success, or -1 if the operation is not supported + */ +extern DECLSPEC int SDLCALL SDL_GL_UnbindTexture(SDL_Texture *texture); + +/** + * \brief Get the CAMetalLayer associated with the given Metal renderer + * + * \param renderer The renderer to query + * + * \return CAMetalLayer* on success, or NULL if the renderer isn't a Metal renderer + * + * \sa SDL_RenderGetMetalCommandEncoder() + */ +extern DECLSPEC void *SDLCALL SDL_RenderGetMetalLayer(SDL_Renderer * renderer); + +/** + * \brief Get the Metal command encoder for the current frame + * + * \param renderer The renderer to query + * + * \return id on success, or NULL if the renderer isn't a Metal renderer + * + * \sa SDL_RenderGetMetalLayer() + */ +extern DECLSPEC void *SDLCALL SDL_RenderGetMetalCommandEncoder(SDL_Renderer * renderer); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_render_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_revision.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_revision.h new file mode 100644 index 0000000..3b3fc85 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_revision.h @@ -0,0 +1,2 @@ +#define SDL_REVISION "hg-12952:bc90ce38f1e2" +#define SDL_REVISION_NUMBER 12952 diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rwops.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rwops.h new file mode 100644 index 0000000..f66119f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_rwops.h @@ -0,0 +1,291 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_rwops.h + * + * This file provides a general interface for SDL to read and write + * data streams. It can easily be extended to files, memory, etc. + */ + +#ifndef SDL_rwops_h_ +#define SDL_rwops_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* RWops Types */ +#define SDL_RWOPS_UNKNOWN 0U /**< Unknown stream type */ +#define SDL_RWOPS_WINFILE 1U /**< Win32 file */ +#define SDL_RWOPS_STDFILE 2U /**< Stdio file */ +#define SDL_RWOPS_JNIFILE 3U /**< Android asset */ +#define SDL_RWOPS_MEMORY 4U /**< Memory stream */ +#define SDL_RWOPS_MEMORY_RO 5U /**< Read-Only memory stream */ + +/** + * This is the read/write operation structure -- very basic. + */ +typedef struct SDL_RWops +{ + /** + * Return the size of the file in this rwops, or -1 if unknown + */ + Sint64 (SDLCALL * size) (struct SDL_RWops * context); + + /** + * Seek to \c offset relative to \c whence, one of stdio's whence values: + * RW_SEEK_SET, RW_SEEK_CUR, RW_SEEK_END + * + * \return the final offset in the data stream, or -1 on error. + */ + Sint64 (SDLCALL * seek) (struct SDL_RWops * context, Sint64 offset, + int whence); + + /** + * Read up to \c maxnum objects each of size \c size from the data + * stream to the area pointed at by \c ptr. + * + * \return the number of objects read, or 0 at error or end of file. + */ + size_t (SDLCALL * read) (struct SDL_RWops * context, void *ptr, + size_t size, size_t maxnum); + + /** + * Write exactly \c num objects each of size \c size from the area + * pointed at by \c ptr to data stream. + * + * \return the number of objects written, or 0 at error or end of file. + */ + size_t (SDLCALL * write) (struct SDL_RWops * context, const void *ptr, + size_t size, size_t num); + + /** + * Close and free an allocated SDL_RWops structure. + * + * \return 0 if successful or -1 on write error when flushing data. + */ + int (SDLCALL * close) (struct SDL_RWops * context); + + Uint32 type; + union + { +#if defined(__ANDROID__) + struct + { + void *fileNameRef; + void *inputStreamRef; + void *readableByteChannelRef; + void *readMethod; + void *assetFileDescriptorRef; + long position; + long size; + long offset; + int fd; + } androidio; +#elif defined(__WIN32__) + struct + { + SDL_bool append; + void *h; + struct + { + void *data; + size_t size; + size_t left; + } buffer; + } windowsio; +#endif + +#ifdef HAVE_STDIO_H + struct + { + SDL_bool autoclose; + FILE *fp; + } stdio; +#endif + struct + { + Uint8 *base; + Uint8 *here; + Uint8 *stop; + } mem; + struct + { + void *data1; + void *data2; + } unknown; + } hidden; + +} SDL_RWops; + + +/** + * \name RWFrom functions + * + * Functions to create SDL_RWops structures from various data streams. + */ +/* @{ */ + +extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromFile(const char *file, + const char *mode); + +#ifdef HAVE_STDIO_H +extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromFP(FILE * fp, + SDL_bool autoclose); +#else +extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromFP(void * fp, + SDL_bool autoclose); +#endif + +extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromMem(void *mem, int size); +extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromConstMem(const void *mem, + int size); + +/* @} *//* RWFrom functions */ + + +extern DECLSPEC SDL_RWops *SDLCALL SDL_AllocRW(void); +extern DECLSPEC void SDLCALL SDL_FreeRW(SDL_RWops * area); + +#define RW_SEEK_SET 0 /**< Seek from the beginning of data */ +#define RW_SEEK_CUR 1 /**< Seek relative to current read point */ +#define RW_SEEK_END 2 /**< Seek relative to the end of data */ + +/** + * Return the size of the file in this rwops, or -1 if unknown + */ +extern DECLSPEC Sint64 SDLCALL SDL_RWsize(SDL_RWops *context); + +/** + * Seek to \c offset relative to \c whence, one of stdio's whence values: + * RW_SEEK_SET, RW_SEEK_CUR, RW_SEEK_END + * + * \return the final offset in the data stream, or -1 on error. + */ +extern DECLSPEC Sint64 SDLCALL SDL_RWseek(SDL_RWops *context, + Sint64 offset, int whence); + +/** + * Return the current offset in the data stream, or -1 on error. + */ +extern DECLSPEC Sint64 SDLCALL SDL_RWtell(SDL_RWops *context); + +/** + * Read up to \c maxnum objects each of size \c size from the data + * stream to the area pointed at by \c ptr. + * + * \return the number of objects read, or 0 at error or end of file. + */ +extern DECLSPEC size_t SDLCALL SDL_RWread(SDL_RWops *context, + void *ptr, size_t size, size_t maxnum); + +/** + * Write exactly \c num objects each of size \c size from the area + * pointed at by \c ptr to data stream. + * + * \return the number of objects written, or 0 at error or end of file. + */ +extern DECLSPEC size_t SDLCALL SDL_RWwrite(SDL_RWops *context, + const void *ptr, size_t size, size_t num); + +/** + * Close and free an allocated SDL_RWops structure. + * + * \return 0 if successful or -1 on write error when flushing data. + */ +extern DECLSPEC int SDLCALL SDL_RWclose(SDL_RWops *context); + +/** + * Load all the data from an SDL data stream. + * + * The data is allocated with a zero byte at the end (null terminated) + * + * If \c datasize is not NULL, it is filled with the size of the data read. + * + * If \c freesrc is non-zero, the stream will be closed after being read. + * + * The data should be freed with SDL_free(). + * + * \return the data, or NULL if there was an error. + */ +extern DECLSPEC void *SDLCALL SDL_LoadFile_RW(SDL_RWops * src, size_t *datasize, + int freesrc); + +/** + * Load an entire file. + * + * The data is allocated with a zero byte at the end (null terminated) + * + * If \c datasize is not NULL, it is filled with the size of the data read. + * + * If \c freesrc is non-zero, the stream will be closed after being read. + * + * The data should be freed with SDL_free(). + * + * \return the data, or NULL if there was an error. + */ +extern DECLSPEC void *SDLCALL SDL_LoadFile(const char *file, size_t *datasize); + +/** + * \name Read endian functions + * + * Read an item of the specified endianness and return in native format. + */ +/* @{ */ +extern DECLSPEC Uint8 SDLCALL SDL_ReadU8(SDL_RWops * src); +extern DECLSPEC Uint16 SDLCALL SDL_ReadLE16(SDL_RWops * src); +extern DECLSPEC Uint16 SDLCALL SDL_ReadBE16(SDL_RWops * src); +extern DECLSPEC Uint32 SDLCALL SDL_ReadLE32(SDL_RWops * src); +extern DECLSPEC Uint32 SDLCALL SDL_ReadBE32(SDL_RWops * src); +extern DECLSPEC Uint64 SDLCALL SDL_ReadLE64(SDL_RWops * src); +extern DECLSPEC Uint64 SDLCALL SDL_ReadBE64(SDL_RWops * src); +/* @} *//* Read endian functions */ + +/** + * \name Write endian functions + * + * Write an item of native format to the specified endianness. + */ +/* @{ */ +extern DECLSPEC size_t SDLCALL SDL_WriteU8(SDL_RWops * dst, Uint8 value); +extern DECLSPEC size_t SDLCALL SDL_WriteLE16(SDL_RWops * dst, Uint16 value); +extern DECLSPEC size_t SDLCALL SDL_WriteBE16(SDL_RWops * dst, Uint16 value); +extern DECLSPEC size_t SDLCALL SDL_WriteLE32(SDL_RWops * dst, Uint32 value); +extern DECLSPEC size_t SDLCALL SDL_WriteBE32(SDL_RWops * dst, Uint32 value); +extern DECLSPEC size_t SDLCALL SDL_WriteLE64(SDL_RWops * dst, Uint64 value); +extern DECLSPEC size_t SDLCALL SDL_WriteBE64(SDL_RWops * dst, Uint64 value); +/* @} *//* Write endian functions */ + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_rwops_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_scancode.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_scancode.h new file mode 100644 index 0000000..a50305f --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_scancode.h @@ -0,0 +1,413 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_scancode.h + * + * Defines keyboard scancodes. + */ + +#ifndef SDL_scancode_h_ +#define SDL_scancode_h_ + +#include "SDL_stdinc.h" + +/** + * \brief The SDL keyboard scancode representation. + * + * Values of this type are used to represent keyboard keys, among other places + * in the \link SDL_Keysym::scancode key.keysym.scancode \endlink field of the + * SDL_Event structure. + * + * The values in this enumeration are based on the USB usage page standard: + * https://www.usb.org/sites/default/files/documents/hut1_12v2.pdf + */ +typedef enum +{ + SDL_SCANCODE_UNKNOWN = 0, + + /** + * \name Usage page 0x07 + * + * These values are from usage page 0x07 (USB keyboard page). + */ + /* @{ */ + + SDL_SCANCODE_A = 4, + SDL_SCANCODE_B = 5, + SDL_SCANCODE_C = 6, + SDL_SCANCODE_D = 7, + SDL_SCANCODE_E = 8, + SDL_SCANCODE_F = 9, + SDL_SCANCODE_G = 10, + SDL_SCANCODE_H = 11, + SDL_SCANCODE_I = 12, + SDL_SCANCODE_J = 13, + SDL_SCANCODE_K = 14, + SDL_SCANCODE_L = 15, + SDL_SCANCODE_M = 16, + SDL_SCANCODE_N = 17, + SDL_SCANCODE_O = 18, + SDL_SCANCODE_P = 19, + SDL_SCANCODE_Q = 20, + SDL_SCANCODE_R = 21, + SDL_SCANCODE_S = 22, + SDL_SCANCODE_T = 23, + SDL_SCANCODE_U = 24, + SDL_SCANCODE_V = 25, + SDL_SCANCODE_W = 26, + SDL_SCANCODE_X = 27, + SDL_SCANCODE_Y = 28, + SDL_SCANCODE_Z = 29, + + SDL_SCANCODE_1 = 30, + SDL_SCANCODE_2 = 31, + SDL_SCANCODE_3 = 32, + SDL_SCANCODE_4 = 33, + SDL_SCANCODE_5 = 34, + SDL_SCANCODE_6 = 35, + SDL_SCANCODE_7 = 36, + SDL_SCANCODE_8 = 37, + SDL_SCANCODE_9 = 38, + SDL_SCANCODE_0 = 39, + + SDL_SCANCODE_RETURN = 40, + SDL_SCANCODE_ESCAPE = 41, + SDL_SCANCODE_BACKSPACE = 42, + SDL_SCANCODE_TAB = 43, + SDL_SCANCODE_SPACE = 44, + + SDL_SCANCODE_MINUS = 45, + SDL_SCANCODE_EQUALS = 46, + SDL_SCANCODE_LEFTBRACKET = 47, + SDL_SCANCODE_RIGHTBRACKET = 48, + SDL_SCANCODE_BACKSLASH = 49, /**< Located at the lower left of the return + * key on ISO keyboards and at the right end + * of the QWERTY row on ANSI keyboards. + * Produces REVERSE SOLIDUS (backslash) and + * VERTICAL LINE in a US layout, REVERSE + * SOLIDUS and VERTICAL LINE in a UK Mac + * layout, NUMBER SIGN and TILDE in a UK + * Windows layout, DOLLAR SIGN and POUND SIGN + * in a Swiss German layout, NUMBER SIGN and + * APOSTROPHE in a German layout, GRAVE + * ACCENT and POUND SIGN in a French Mac + * layout, and ASTERISK and MICRO SIGN in a + * French Windows layout. + */ + SDL_SCANCODE_NONUSHASH = 50, /**< ISO USB keyboards actually use this code + * instead of 49 for the same key, but all + * OSes I've seen treat the two codes + * identically. So, as an implementor, unless + * your keyboard generates both of those + * codes and your OS treats them differently, + * you should generate SDL_SCANCODE_BACKSLASH + * instead of this code. As a user, you + * should not rely on this code because SDL + * will never generate it with most (all?) + * keyboards. + */ + SDL_SCANCODE_SEMICOLON = 51, + SDL_SCANCODE_APOSTROPHE = 52, + SDL_SCANCODE_GRAVE = 53, /**< Located in the top left corner (on both ANSI + * and ISO keyboards). Produces GRAVE ACCENT and + * TILDE in a US Windows layout and in US and UK + * Mac layouts on ANSI keyboards, GRAVE ACCENT + * and NOT SIGN in a UK Windows layout, SECTION + * SIGN and PLUS-MINUS SIGN in US and UK Mac + * layouts on ISO keyboards, SECTION SIGN and + * DEGREE SIGN in a Swiss German layout (Mac: + * only on ISO keyboards), CIRCUMFLEX ACCENT and + * DEGREE SIGN in a German layout (Mac: only on + * ISO keyboards), SUPERSCRIPT TWO and TILDE in a + * French Windows layout, COMMERCIAL AT and + * NUMBER SIGN in a French Mac layout on ISO + * keyboards, and LESS-THAN SIGN and GREATER-THAN + * SIGN in a Swiss German, German, or French Mac + * layout on ANSI keyboards. + */ + SDL_SCANCODE_COMMA = 54, + SDL_SCANCODE_PERIOD = 55, + SDL_SCANCODE_SLASH = 56, + + SDL_SCANCODE_CAPSLOCK = 57, + + SDL_SCANCODE_F1 = 58, + SDL_SCANCODE_F2 = 59, + SDL_SCANCODE_F3 = 60, + SDL_SCANCODE_F4 = 61, + SDL_SCANCODE_F5 = 62, + SDL_SCANCODE_F6 = 63, + SDL_SCANCODE_F7 = 64, + SDL_SCANCODE_F8 = 65, + SDL_SCANCODE_F9 = 66, + SDL_SCANCODE_F10 = 67, + SDL_SCANCODE_F11 = 68, + SDL_SCANCODE_F12 = 69, + + SDL_SCANCODE_PRINTSCREEN = 70, + SDL_SCANCODE_SCROLLLOCK = 71, + SDL_SCANCODE_PAUSE = 72, + SDL_SCANCODE_INSERT = 73, /**< insert on PC, help on some Mac keyboards (but + does send code 73, not 117) */ + SDL_SCANCODE_HOME = 74, + SDL_SCANCODE_PAGEUP = 75, + SDL_SCANCODE_DELETE = 76, + SDL_SCANCODE_END = 77, + SDL_SCANCODE_PAGEDOWN = 78, + SDL_SCANCODE_RIGHT = 79, + SDL_SCANCODE_LEFT = 80, + SDL_SCANCODE_DOWN = 81, + SDL_SCANCODE_UP = 82, + + SDL_SCANCODE_NUMLOCKCLEAR = 83, /**< num lock on PC, clear on Mac keyboards + */ + SDL_SCANCODE_KP_DIVIDE = 84, + SDL_SCANCODE_KP_MULTIPLY = 85, + SDL_SCANCODE_KP_MINUS = 86, + SDL_SCANCODE_KP_PLUS = 87, + SDL_SCANCODE_KP_ENTER = 88, + SDL_SCANCODE_KP_1 = 89, + SDL_SCANCODE_KP_2 = 90, + SDL_SCANCODE_KP_3 = 91, + SDL_SCANCODE_KP_4 = 92, + SDL_SCANCODE_KP_5 = 93, + SDL_SCANCODE_KP_6 = 94, + SDL_SCANCODE_KP_7 = 95, + SDL_SCANCODE_KP_8 = 96, + SDL_SCANCODE_KP_9 = 97, + SDL_SCANCODE_KP_0 = 98, + SDL_SCANCODE_KP_PERIOD = 99, + + SDL_SCANCODE_NONUSBACKSLASH = 100, /**< This is the additional key that ISO + * keyboards have over ANSI ones, + * located between left shift and Y. + * Produces GRAVE ACCENT and TILDE in a + * US or UK Mac layout, REVERSE SOLIDUS + * (backslash) and VERTICAL LINE in a + * US or UK Windows layout, and + * LESS-THAN SIGN and GREATER-THAN SIGN + * in a Swiss German, German, or French + * layout. */ + SDL_SCANCODE_APPLICATION = 101, /**< windows contextual menu, compose */ + SDL_SCANCODE_POWER = 102, /**< The USB document says this is a status flag, + * not a physical key - but some Mac keyboards + * do have a power key. */ + SDL_SCANCODE_KP_EQUALS = 103, + SDL_SCANCODE_F13 = 104, + SDL_SCANCODE_F14 = 105, + SDL_SCANCODE_F15 = 106, + SDL_SCANCODE_F16 = 107, + SDL_SCANCODE_F17 = 108, + SDL_SCANCODE_F18 = 109, + SDL_SCANCODE_F19 = 110, + SDL_SCANCODE_F20 = 111, + SDL_SCANCODE_F21 = 112, + SDL_SCANCODE_F22 = 113, + SDL_SCANCODE_F23 = 114, + SDL_SCANCODE_F24 = 115, + SDL_SCANCODE_EXECUTE = 116, + SDL_SCANCODE_HELP = 117, + SDL_SCANCODE_MENU = 118, + SDL_SCANCODE_SELECT = 119, + SDL_SCANCODE_STOP = 120, + SDL_SCANCODE_AGAIN = 121, /**< redo */ + SDL_SCANCODE_UNDO = 122, + SDL_SCANCODE_CUT = 123, + SDL_SCANCODE_COPY = 124, + SDL_SCANCODE_PASTE = 125, + SDL_SCANCODE_FIND = 126, + SDL_SCANCODE_MUTE = 127, + SDL_SCANCODE_VOLUMEUP = 128, + SDL_SCANCODE_VOLUMEDOWN = 129, +/* not sure whether there's a reason to enable these */ +/* SDL_SCANCODE_LOCKINGCAPSLOCK = 130, */ +/* SDL_SCANCODE_LOCKINGNUMLOCK = 131, */ +/* SDL_SCANCODE_LOCKINGSCROLLLOCK = 132, */ + SDL_SCANCODE_KP_COMMA = 133, + SDL_SCANCODE_KP_EQUALSAS400 = 134, + + SDL_SCANCODE_INTERNATIONAL1 = 135, /**< used on Asian keyboards, see + footnotes in USB doc */ + SDL_SCANCODE_INTERNATIONAL2 = 136, + SDL_SCANCODE_INTERNATIONAL3 = 137, /**< Yen */ + SDL_SCANCODE_INTERNATIONAL4 = 138, + SDL_SCANCODE_INTERNATIONAL5 = 139, + SDL_SCANCODE_INTERNATIONAL6 = 140, + SDL_SCANCODE_INTERNATIONAL7 = 141, + SDL_SCANCODE_INTERNATIONAL8 = 142, + SDL_SCANCODE_INTERNATIONAL9 = 143, + SDL_SCANCODE_LANG1 = 144, /**< Hangul/English toggle */ + SDL_SCANCODE_LANG2 = 145, /**< Hanja conversion */ + SDL_SCANCODE_LANG3 = 146, /**< Katakana */ + SDL_SCANCODE_LANG4 = 147, /**< Hiragana */ + SDL_SCANCODE_LANG5 = 148, /**< Zenkaku/Hankaku */ + SDL_SCANCODE_LANG6 = 149, /**< reserved */ + SDL_SCANCODE_LANG7 = 150, /**< reserved */ + SDL_SCANCODE_LANG8 = 151, /**< reserved */ + SDL_SCANCODE_LANG9 = 152, /**< reserved */ + + SDL_SCANCODE_ALTERASE = 153, /**< Erase-Eaze */ + SDL_SCANCODE_SYSREQ = 154, + SDL_SCANCODE_CANCEL = 155, + SDL_SCANCODE_CLEAR = 156, + SDL_SCANCODE_PRIOR = 157, + SDL_SCANCODE_RETURN2 = 158, + SDL_SCANCODE_SEPARATOR = 159, + SDL_SCANCODE_OUT = 160, + SDL_SCANCODE_OPER = 161, + SDL_SCANCODE_CLEARAGAIN = 162, + SDL_SCANCODE_CRSEL = 163, + SDL_SCANCODE_EXSEL = 164, + + SDL_SCANCODE_KP_00 = 176, + SDL_SCANCODE_KP_000 = 177, + SDL_SCANCODE_THOUSANDSSEPARATOR = 178, + SDL_SCANCODE_DECIMALSEPARATOR = 179, + SDL_SCANCODE_CURRENCYUNIT = 180, + SDL_SCANCODE_CURRENCYSUBUNIT = 181, + SDL_SCANCODE_KP_LEFTPAREN = 182, + SDL_SCANCODE_KP_RIGHTPAREN = 183, + SDL_SCANCODE_KP_LEFTBRACE = 184, + SDL_SCANCODE_KP_RIGHTBRACE = 185, + SDL_SCANCODE_KP_TAB = 186, + SDL_SCANCODE_KP_BACKSPACE = 187, + SDL_SCANCODE_KP_A = 188, + SDL_SCANCODE_KP_B = 189, + SDL_SCANCODE_KP_C = 190, + SDL_SCANCODE_KP_D = 191, + SDL_SCANCODE_KP_E = 192, + SDL_SCANCODE_KP_F = 193, + SDL_SCANCODE_KP_XOR = 194, + SDL_SCANCODE_KP_POWER = 195, + SDL_SCANCODE_KP_PERCENT = 196, + SDL_SCANCODE_KP_LESS = 197, + SDL_SCANCODE_KP_GREATER = 198, + SDL_SCANCODE_KP_AMPERSAND = 199, + SDL_SCANCODE_KP_DBLAMPERSAND = 200, + SDL_SCANCODE_KP_VERTICALBAR = 201, + SDL_SCANCODE_KP_DBLVERTICALBAR = 202, + SDL_SCANCODE_KP_COLON = 203, + SDL_SCANCODE_KP_HASH = 204, + SDL_SCANCODE_KP_SPACE = 205, + SDL_SCANCODE_KP_AT = 206, + SDL_SCANCODE_KP_EXCLAM = 207, + SDL_SCANCODE_KP_MEMSTORE = 208, + SDL_SCANCODE_KP_MEMRECALL = 209, + SDL_SCANCODE_KP_MEMCLEAR = 210, + SDL_SCANCODE_KP_MEMADD = 211, + SDL_SCANCODE_KP_MEMSUBTRACT = 212, + SDL_SCANCODE_KP_MEMMULTIPLY = 213, + SDL_SCANCODE_KP_MEMDIVIDE = 214, + SDL_SCANCODE_KP_PLUSMINUS = 215, + SDL_SCANCODE_KP_CLEAR = 216, + SDL_SCANCODE_KP_CLEARENTRY = 217, + SDL_SCANCODE_KP_BINARY = 218, + SDL_SCANCODE_KP_OCTAL = 219, + SDL_SCANCODE_KP_DECIMAL = 220, + SDL_SCANCODE_KP_HEXADECIMAL = 221, + + SDL_SCANCODE_LCTRL = 224, + SDL_SCANCODE_LSHIFT = 225, + SDL_SCANCODE_LALT = 226, /**< alt, option */ + SDL_SCANCODE_LGUI = 227, /**< windows, command (apple), meta */ + SDL_SCANCODE_RCTRL = 228, + SDL_SCANCODE_RSHIFT = 229, + SDL_SCANCODE_RALT = 230, /**< alt gr, option */ + SDL_SCANCODE_RGUI = 231, /**< windows, command (apple), meta */ + + SDL_SCANCODE_MODE = 257, /**< I'm not sure if this is really not covered + * by any of the above, but since there's a + * special KMOD_MODE for it I'm adding it here + */ + + /* @} *//* Usage page 0x07 */ + + /** + * \name Usage page 0x0C + * + * These values are mapped from usage page 0x0C (USB consumer page). + */ + /* @{ */ + + SDL_SCANCODE_AUDIONEXT = 258, + SDL_SCANCODE_AUDIOPREV = 259, + SDL_SCANCODE_AUDIOSTOP = 260, + SDL_SCANCODE_AUDIOPLAY = 261, + SDL_SCANCODE_AUDIOMUTE = 262, + SDL_SCANCODE_MEDIASELECT = 263, + SDL_SCANCODE_WWW = 264, + SDL_SCANCODE_MAIL = 265, + SDL_SCANCODE_CALCULATOR = 266, + SDL_SCANCODE_COMPUTER = 267, + SDL_SCANCODE_AC_SEARCH = 268, + SDL_SCANCODE_AC_HOME = 269, + SDL_SCANCODE_AC_BACK = 270, + SDL_SCANCODE_AC_FORWARD = 271, + SDL_SCANCODE_AC_STOP = 272, + SDL_SCANCODE_AC_REFRESH = 273, + SDL_SCANCODE_AC_BOOKMARKS = 274, + + /* @} *//* Usage page 0x0C */ + + /** + * \name Walther keys + * + * These are values that Christian Walther added (for mac keyboard?). + */ + /* @{ */ + + SDL_SCANCODE_BRIGHTNESSDOWN = 275, + SDL_SCANCODE_BRIGHTNESSUP = 276, + SDL_SCANCODE_DISPLAYSWITCH = 277, /**< display mirroring/dual display + switch, video mode switch */ + SDL_SCANCODE_KBDILLUMTOGGLE = 278, + SDL_SCANCODE_KBDILLUMDOWN = 279, + SDL_SCANCODE_KBDILLUMUP = 280, + SDL_SCANCODE_EJECT = 281, + SDL_SCANCODE_SLEEP = 282, + + SDL_SCANCODE_APP1 = 283, + SDL_SCANCODE_APP2 = 284, + + /* @} *//* Walther keys */ + + /** + * \name Usage page 0x0C (additional media keys) + * + * These values are mapped from usage page 0x0C (USB consumer page). + */ + /* @{ */ + + SDL_SCANCODE_AUDIOREWIND = 285, + SDL_SCANCODE_AUDIOFASTFORWARD = 286, + + /* @} *//* Usage page 0x0C (additional media keys) */ + + /* Add any other keys here. */ + + SDL_NUM_SCANCODES = 512 /**< not a key, just marks the number of scancodes + for array bounds */ +} SDL_Scancode; + +#endif /* SDL_scancode_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_sensor.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_sensor.h new file mode 100644 index 0000000..966adbf --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_sensor.h @@ -0,0 +1,251 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_sensor.h + * + * Include file for SDL sensor event handling + * + */ + +#ifndef SDL_sensor_h_ +#define SDL_sensor_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +/* *INDENT-OFF* */ +extern "C" { +/* *INDENT-ON* */ +#endif + +/** + * \brief SDL_sensor.h + * + * In order to use these functions, SDL_Init() must have been called + * with the ::SDL_INIT_SENSOR flag. This causes SDL to scan the system + * for sensors, and load appropriate drivers. + */ + +struct _SDL_Sensor; +typedef struct _SDL_Sensor SDL_Sensor; + +/** + * This is a unique ID for a sensor for the time it is connected to the system, + * and is never reused for the lifetime of the application. + * + * The ID value starts at 0 and increments from there. The value -1 is an invalid ID. + */ +typedef Sint32 SDL_SensorID; + +/* The different sensors defined by SDL + * + * Additional sensors may be available, using platform dependent semantics. + * + * Hare are the additional Android sensors: + * https://developer.android.com/reference/android/hardware/SensorEvent.html#values + */ +typedef enum +{ + SDL_SENSOR_INVALID = -1, /**< Returned for an invalid sensor */ + SDL_SENSOR_UNKNOWN, /**< Unknown sensor type */ + SDL_SENSOR_ACCEL, /**< Accelerometer */ + SDL_SENSOR_GYRO /**< Gyroscope */ +} SDL_SensorType; + +/** + * Accelerometer sensor + * + * The accelerometer returns the current acceleration in SI meters per + * second squared. This includes gravity, so a device at rest will have + * an acceleration of SDL_STANDARD_GRAVITY straight down. + * + * values[0]: Acceleration on the x axis + * values[1]: Acceleration on the y axis + * values[2]: Acceleration on the z axis + * + * For phones held in portrait mode, the axes are defined as follows: + * -X ... +X : left ... right + * -Y ... +Y : bottom ... top + * -Z ... +Z : farther ... closer + * + * The axis data is not changed when the phone is rotated. + * + * \sa SDL_GetDisplayOrientation() + */ +#define SDL_STANDARD_GRAVITY 9.80665f + +/** + * Gyroscope sensor + * + * The gyroscope returns the current rate of rotation in radians per second. + * The rotation is positive in the counter-clockwise direction. That is, + * an observer looking from a positive location on one of the axes would + * see positive rotation on that axis when it appeared to be rotating + * counter-clockwise. + * + * values[0]: Angular speed around the x axis + * values[1]: Angular speed around the y axis + * values[2]: Angular speed around the z axis + * + * For phones held in portrait mode, the axes are defined as follows: + * -X ... +X : left ... right + * -Y ... +Y : bottom ... top + * -Z ... +Z : farther ... closer + * + * The axis data is not changed when the phone is rotated. + * + * \sa SDL_GetDisplayOrientation() + */ + +/* Function prototypes */ + +/** + * \brief Count the number of sensors attached to the system right now + */ +extern DECLSPEC int SDLCALL SDL_NumSensors(void); + +/** + * \brief Get the implementation dependent name of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor name, or NULL if device_index is out of range. + */ +extern DECLSPEC const char *SDLCALL SDL_SensorGetDeviceName(int device_index); + +/** + * \brief Get the type of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor type, or SDL_SENSOR_INVALID if device_index is out of range. + */ +extern DECLSPEC SDL_SensorType SDLCALL SDL_SensorGetDeviceType(int device_index); + +/** + * \brief Get the platform dependent type of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor platform dependent type, or -1 if device_index is out of range. + */ +extern DECLSPEC int SDLCALL SDL_SensorGetDeviceNonPortableType(int device_index); + +/** + * \brief Get the instance ID of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor instance ID, or -1 if device_index is out of range. + */ +extern DECLSPEC SDL_SensorID SDLCALL SDL_SensorGetDeviceInstanceID(int device_index); + +/** + * \brief Open a sensor for use. + * + * The index passed as an argument refers to the N'th sensor on the system. + * + * \return A sensor identifier, or NULL if an error occurred. + */ +extern DECLSPEC SDL_Sensor *SDLCALL SDL_SensorOpen(int device_index); + +/** + * Return the SDL_Sensor associated with an instance id. + */ +extern DECLSPEC SDL_Sensor *SDLCALL SDL_SensorFromInstanceID(SDL_SensorID instance_id); + +/** + * \brief Get the implementation dependent name of a sensor. + * + * \return The sensor name, or NULL if the sensor is NULL. + */ +extern DECLSPEC const char *SDLCALL SDL_SensorGetName(SDL_Sensor *sensor); + +/** + * \brief Get the type of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor type, or SDL_SENSOR_INVALID if the sensor is NULL. + */ +extern DECLSPEC SDL_SensorType SDLCALL SDL_SensorGetType(SDL_Sensor *sensor); + +/** + * \brief Get the platform dependent type of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor platform dependent type, or -1 if the sensor is NULL. + */ +extern DECLSPEC int SDLCALL SDL_SensorGetNonPortableType(SDL_Sensor *sensor); + +/** + * \brief Get the instance ID of a sensor. + * + * This can be called before any sensors are opened. + * + * \return The sensor instance ID, or -1 if the sensor is NULL. + */ +extern DECLSPEC SDL_SensorID SDLCALL SDL_SensorGetInstanceID(SDL_Sensor *sensor); + +/** + * Get the current state of an opened sensor. + * + * The number of values and interpretation of the data is sensor dependent. + * + * \param sensor The sensor to query + * \param data A pointer filled with the current sensor state + * \param num_values The number of values to write to data + * + * \return 0 or -1 if an error occurred. + */ +extern DECLSPEC int SDLCALL SDL_SensorGetData(SDL_Sensor * sensor, float *data, int num_values); + +/** + * Close a sensor previously opened with SDL_SensorOpen() + */ +extern DECLSPEC void SDLCALL SDL_SensorClose(SDL_Sensor * sensor); + +/** + * Update the current state of the open sensors. + * + * This is called automatically by the event loop if sensor events are enabled. + * + * This needs to be called from the thread that initialized the sensor subsystem. + */ +extern DECLSPEC void SDLCALL SDL_SensorUpdate(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +/* *INDENT-OFF* */ +} +/* *INDENT-ON* */ +#endif +#include "close_code.h" + +#endif /* SDL_sensor_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_shape.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_shape.h new file mode 100644 index 0000000..2ab43fc --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_shape.h @@ -0,0 +1,144 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_shape_h_ +#define SDL_shape_h_ + +#include "SDL_stdinc.h" +#include "SDL_pixels.h" +#include "SDL_rect.h" +#include "SDL_surface.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** \file SDL_shape.h + * + * Header file for the shaped window API. + */ + +#define SDL_NONSHAPEABLE_WINDOW -1 +#define SDL_INVALID_SHAPE_ARGUMENT -2 +#define SDL_WINDOW_LACKS_SHAPE -3 + +/** + * \brief Create a window that can be shaped with the specified position, dimensions, and flags. + * + * \param title The title of the window, in UTF-8 encoding. + * \param x The x position of the window, ::SDL_WINDOWPOS_CENTERED, or + * ::SDL_WINDOWPOS_UNDEFINED. + * \param y The y position of the window, ::SDL_WINDOWPOS_CENTERED, or + * ::SDL_WINDOWPOS_UNDEFINED. + * \param w The width of the window. + * \param h The height of the window. + * \param flags The flags for the window, a mask of SDL_WINDOW_BORDERLESS with any of the following: + * ::SDL_WINDOW_OPENGL, ::SDL_WINDOW_INPUT_GRABBED, + * ::SDL_WINDOW_HIDDEN, ::SDL_WINDOW_RESIZABLE, + * ::SDL_WINDOW_MAXIMIZED, ::SDL_WINDOW_MINIMIZED, + * ::SDL_WINDOW_BORDERLESS is always set, and ::SDL_WINDOW_FULLSCREEN is always unset. + * + * \return The window created, or NULL if window creation failed. + * + * \sa SDL_DestroyWindow() + */ +extern DECLSPEC SDL_Window * SDLCALL SDL_CreateShapedWindow(const char *title,unsigned int x,unsigned int y,unsigned int w,unsigned int h,Uint32 flags); + +/** + * \brief Return whether the given window is a shaped window. + * + * \param window The window to query for being shaped. + * + * \return SDL_TRUE if the window is a window that can be shaped, SDL_FALSE if the window is unshaped or NULL. + * + * \sa SDL_CreateShapedWindow + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsShapedWindow(const SDL_Window *window); + +/** \brief An enum denoting the specific type of contents present in an SDL_WindowShapeParams union. */ +typedef enum { + /** \brief The default mode, a binarized alpha cutoff of 1. */ + ShapeModeDefault, + /** \brief A binarized alpha cutoff with a given integer value. */ + ShapeModeBinarizeAlpha, + /** \brief A binarized alpha cutoff with a given integer value, but with the opposite comparison. */ + ShapeModeReverseBinarizeAlpha, + /** \brief A color key is applied. */ + ShapeModeColorKey +} WindowShapeMode; + +#define SDL_SHAPEMODEALPHA(mode) (mode == ShapeModeDefault || mode == ShapeModeBinarizeAlpha || mode == ShapeModeReverseBinarizeAlpha) + +/** \brief A union containing parameters for shaped windows. */ +typedef union { + /** \brief A cutoff alpha value for binarization of the window shape's alpha channel. */ + Uint8 binarizationCutoff; + SDL_Color colorKey; +} SDL_WindowShapeParams; + +/** \brief A struct that tags the SDL_WindowShapeParams union with an enum describing the type of its contents. */ +typedef struct SDL_WindowShapeMode { + /** \brief The mode of these window-shape parameters. */ + WindowShapeMode mode; + /** \brief Window-shape parameters. */ + SDL_WindowShapeParams parameters; +} SDL_WindowShapeMode; + +/** + * \brief Set the shape and parameters of a shaped window. + * + * \param window The shaped window whose parameters should be set. + * \param shape A surface encoding the desired shape for the window. + * \param shape_mode The parameters to set for the shaped window. + * + * \return 0 on success, SDL_INVALID_SHAPE_ARGUMENT on an invalid shape argument, or SDL_NONSHAPEABLE_WINDOW + * if the SDL_Window given does not reference a valid shaped window. + * + * \sa SDL_WindowShapeMode + * \sa SDL_GetShapedWindowMode. + */ +extern DECLSPEC int SDLCALL SDL_SetWindowShape(SDL_Window *window,SDL_Surface *shape,SDL_WindowShapeMode *shape_mode); + +/** + * \brief Get the shape parameters of a shaped window. + * + * \param window The shaped window whose parameters should be retrieved. + * \param shape_mode An empty shape-mode structure to fill, or NULL to check whether the window has a shape. + * + * \return 0 if the window has a shape and, provided shape_mode was not NULL, shape_mode has been filled with the mode + * data, SDL_NONSHAPEABLE_WINDOW if the SDL_Window given is not a shaped window, or SDL_WINDOW_LACKS_SHAPE if + * the SDL_Window given is a shapeable window currently lacking a shape. + * + * \sa SDL_WindowShapeMode + * \sa SDL_SetWindowShape + */ +extern DECLSPEC int SDLCALL SDL_GetShapedWindowMode(SDL_Window *window,SDL_WindowShapeMode *shape_mode); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_shape_h_ */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_stdinc.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_stdinc.h new file mode 100644 index 0000000..28bb7b9 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_stdinc.h @@ -0,0 +1,607 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_stdinc.h + * + * This is a general header that includes C language support. + */ + +#ifndef SDL_stdinc_h_ +#define SDL_stdinc_h_ + +#include "SDL_config.h" + +#ifdef HAVE_SYS_TYPES_H +#include +#endif +#ifdef HAVE_STDIO_H +#include +#endif +#if defined(STDC_HEADERS) +# include +# include +# include +#else +# if defined(HAVE_STDLIB_H) +# include +# elif defined(HAVE_MALLOC_H) +# include +# endif +# if defined(HAVE_STDDEF_H) +# include +# endif +# if defined(HAVE_STDARG_H) +# include +# endif +#endif +#ifdef HAVE_STRING_H +# if !defined(STDC_HEADERS) && defined(HAVE_MEMORY_H) +# include +# endif +# include +#endif +#ifdef HAVE_STRINGS_H +# include +#endif +#ifdef HAVE_WCHAR_H +# include +#endif +#if defined(HAVE_INTTYPES_H) +# include +#elif defined(HAVE_STDINT_H) +# include +#endif +#ifdef HAVE_CTYPE_H +# include +#endif +#ifdef HAVE_MATH_H +# if defined(__WINRT__) +/* Defining _USE_MATH_DEFINES is required to get M_PI to be defined on + WinRT. See http://msdn.microsoft.com/en-us/library/4hwaceh6.aspx + for more information. +*/ +# define _USE_MATH_DEFINES +# endif +# include +#endif +#ifdef HAVE_FLOAT_H +# include +#endif +#if defined(HAVE_ALLOCA) && !defined(alloca) +# if defined(HAVE_ALLOCA_H) +# include +# elif defined(__GNUC__) +# define alloca __builtin_alloca +# elif defined(_MSC_VER) +# include +# define alloca _alloca +# elif defined(__WATCOMC__) +# include +# elif defined(__BORLANDC__) +# include +# elif defined(__DMC__) +# include +# elif defined(__AIX__) +#pragma alloca +# elif defined(__MRC__) +void *alloca(unsigned); +# else +char *alloca(); +# endif +#endif + +/** + * The number of elements in an array. + */ +#define SDL_arraysize(array) (sizeof(array)/sizeof(array[0])) +#define SDL_TABLESIZE(table) SDL_arraysize(table) + +/** + * Macro useful for building other macros with strings in them + * + * e.g. #define LOG_ERROR(X) OutputDebugString(SDL_STRINGIFY_ARG(__FUNCTION__) ": " X "\n") + */ +#define SDL_STRINGIFY_ARG(arg) #arg + +/** + * \name Cast operators + * + * Use proper C++ casts when compiled as C++ to be compatible with the option + * -Wold-style-cast of GCC (and -Werror=old-style-cast in GCC 4.2 and above). + */ +/* @{ */ +#ifdef __cplusplus +#define SDL_reinterpret_cast(type, expression) reinterpret_cast(expression) +#define SDL_static_cast(type, expression) static_cast(expression) +#define SDL_const_cast(type, expression) const_cast(expression) +#else +#define SDL_reinterpret_cast(type, expression) ((type)(expression)) +#define SDL_static_cast(type, expression) ((type)(expression)) +#define SDL_const_cast(type, expression) ((type)(expression)) +#endif +/* @} *//* Cast operators */ + +/* Define a four character code as a Uint32 */ +#define SDL_FOURCC(A, B, C, D) \ + ((SDL_static_cast(Uint32, SDL_static_cast(Uint8, (A))) << 0) | \ + (SDL_static_cast(Uint32, SDL_static_cast(Uint8, (B))) << 8) | \ + (SDL_static_cast(Uint32, SDL_static_cast(Uint8, (C))) << 16) | \ + (SDL_static_cast(Uint32, SDL_static_cast(Uint8, (D))) << 24)) + +/** + * \name Basic data types + */ +/* @{ */ + +#ifdef __CC_ARM +/* ARM's compiler throws warnings if we use an enum: like "SDL_bool x = a < b;" */ +#define SDL_FALSE 0 +#define SDL_TRUE 1 +typedef int SDL_bool; +#else +typedef enum +{ + SDL_FALSE = 0, + SDL_TRUE = 1 +} SDL_bool; +#endif + +/** + * \brief A signed 8-bit integer type. + */ +#define SDL_MAX_SINT8 ((Sint8)0x7F) /* 127 */ +#define SDL_MIN_SINT8 ((Sint8)(~0x7F)) /* -128 */ +typedef int8_t Sint8; +/** + * \brief An unsigned 8-bit integer type. + */ +#define SDL_MAX_UINT8 ((Uint8)0xFF) /* 255 */ +#define SDL_MIN_UINT8 ((Uint8)0x00) /* 0 */ +typedef uint8_t Uint8; +/** + * \brief A signed 16-bit integer type. + */ +#define SDL_MAX_SINT16 ((Sint16)0x7FFF) /* 32767 */ +#define SDL_MIN_SINT16 ((Sint16)(~0x7FFF)) /* -32768 */ +typedef int16_t Sint16; +/** + * \brief An unsigned 16-bit integer type. + */ +#define SDL_MAX_UINT16 ((Uint16)0xFFFF) /* 65535 */ +#define SDL_MIN_UINT16 ((Uint16)0x0000) /* 0 */ +typedef uint16_t Uint16; +/** + * \brief A signed 32-bit integer type. + */ +#define SDL_MAX_SINT32 ((Sint32)0x7FFFFFFF) /* 2147483647 */ +#define SDL_MIN_SINT32 ((Sint32)(~0x7FFFFFFF)) /* -2147483648 */ +typedef int32_t Sint32; +/** + * \brief An unsigned 32-bit integer type. + */ +#define SDL_MAX_UINT32 ((Uint32)0xFFFFFFFFu) /* 4294967295 */ +#define SDL_MIN_UINT32 ((Uint32)0x00000000) /* 0 */ +typedef uint32_t Uint32; + +/** + * \brief A signed 64-bit integer type. + */ +#define SDL_MAX_SINT64 ((Sint64)0x7FFFFFFFFFFFFFFFll) /* 9223372036854775807 */ +#define SDL_MIN_SINT64 ((Sint64)(~0x7FFFFFFFFFFFFFFFll)) /* -9223372036854775808 */ +typedef int64_t Sint64; +/** + * \brief An unsigned 64-bit integer type. + */ +#define SDL_MAX_UINT64 ((Uint64)0xFFFFFFFFFFFFFFFFull) /* 18446744073709551615 */ +#define SDL_MIN_UINT64 ((Uint64)(0x0000000000000000ull)) /* 0 */ +typedef uint64_t Uint64; + +/* @} *//* Basic data types */ + +/* Make sure we have macros for printing 64 bit values. + * should define these but this is not true all platforms. + * (for example win32) */ +#ifndef SDL_PRIs64 +#ifdef PRIs64 +#define SDL_PRIs64 PRIs64 +#elif defined(__WIN32__) +#define SDL_PRIs64 "I64d" +#elif defined(__LINUX__) && defined(__LP64__) +#define SDL_PRIs64 "ld" +#else +#define SDL_PRIs64 "lld" +#endif +#endif +#ifndef SDL_PRIu64 +#ifdef PRIu64 +#define SDL_PRIu64 PRIu64 +#elif defined(__WIN32__) +#define SDL_PRIu64 "I64u" +#elif defined(__LINUX__) && defined(__LP64__) +#define SDL_PRIu64 "lu" +#else +#define SDL_PRIu64 "llu" +#endif +#endif +#ifndef SDL_PRIx64 +#ifdef PRIx64 +#define SDL_PRIx64 PRIx64 +#elif defined(__WIN32__) +#define SDL_PRIx64 "I64x" +#elif defined(__LINUX__) && defined(__LP64__) +#define SDL_PRIx64 "lx" +#else +#define SDL_PRIx64 "llx" +#endif +#endif +#ifndef SDL_PRIX64 +#ifdef PRIX64 +#define SDL_PRIX64 PRIX64 +#elif defined(__WIN32__) +#define SDL_PRIX64 "I64X" +#elif defined(__LINUX__) && defined(__LP64__) +#define SDL_PRIX64 "lX" +#else +#define SDL_PRIX64 "llX" +#endif +#endif + +/* Annotations to help code analysis tools */ +#ifdef SDL_DISABLE_ANALYZE_MACROS +#define SDL_IN_BYTECAP(x) +#define SDL_INOUT_Z_CAP(x) +#define SDL_OUT_Z_CAP(x) +#define SDL_OUT_CAP(x) +#define SDL_OUT_BYTECAP(x) +#define SDL_OUT_Z_BYTECAP(x) +#define SDL_PRINTF_FORMAT_STRING +#define SDL_SCANF_FORMAT_STRING +#define SDL_PRINTF_VARARG_FUNC( fmtargnumber ) +#define SDL_SCANF_VARARG_FUNC( fmtargnumber ) +#else +#if defined(_MSC_VER) && (_MSC_VER >= 1600) /* VS 2010 and above */ +#include + +#define SDL_IN_BYTECAP(x) _In_bytecount_(x) +#define SDL_INOUT_Z_CAP(x) _Inout_z_cap_(x) +#define SDL_OUT_Z_CAP(x) _Out_z_cap_(x) +#define SDL_OUT_CAP(x) _Out_cap_(x) +#define SDL_OUT_BYTECAP(x) _Out_bytecap_(x) +#define SDL_OUT_Z_BYTECAP(x) _Out_z_bytecap_(x) + +#define SDL_PRINTF_FORMAT_STRING _Printf_format_string_ +#define SDL_SCANF_FORMAT_STRING _Scanf_format_string_impl_ +#else +#define SDL_IN_BYTECAP(x) +#define SDL_INOUT_Z_CAP(x) +#define SDL_OUT_Z_CAP(x) +#define SDL_OUT_CAP(x) +#define SDL_OUT_BYTECAP(x) +#define SDL_OUT_Z_BYTECAP(x) +#define SDL_PRINTF_FORMAT_STRING +#define SDL_SCANF_FORMAT_STRING +#endif +#if defined(__GNUC__) +#define SDL_PRINTF_VARARG_FUNC( fmtargnumber ) __attribute__ (( format( __printf__, fmtargnumber, fmtargnumber+1 ))) +#define SDL_SCANF_VARARG_FUNC( fmtargnumber ) __attribute__ (( format( __scanf__, fmtargnumber, fmtargnumber+1 ))) +#else +#define SDL_PRINTF_VARARG_FUNC( fmtargnumber ) +#define SDL_SCANF_VARARG_FUNC( fmtargnumber ) +#endif +#endif /* SDL_DISABLE_ANALYZE_MACROS */ + +#define SDL_COMPILE_TIME_ASSERT(name, x) \ + typedef int SDL_compile_time_assert_ ## name[(x) * 2 - 1] +/** \cond */ +#ifndef DOXYGEN_SHOULD_IGNORE_THIS +SDL_COMPILE_TIME_ASSERT(uint8, sizeof(Uint8) == 1); +SDL_COMPILE_TIME_ASSERT(sint8, sizeof(Sint8) == 1); +SDL_COMPILE_TIME_ASSERT(uint16, sizeof(Uint16) == 2); +SDL_COMPILE_TIME_ASSERT(sint16, sizeof(Sint16) == 2); +SDL_COMPILE_TIME_ASSERT(uint32, sizeof(Uint32) == 4); +SDL_COMPILE_TIME_ASSERT(sint32, sizeof(Sint32) == 4); +SDL_COMPILE_TIME_ASSERT(uint64, sizeof(Uint64) == 8); +SDL_COMPILE_TIME_ASSERT(sint64, sizeof(Sint64) == 8); +#endif /* DOXYGEN_SHOULD_IGNORE_THIS */ +/** \endcond */ + +/* Check to make sure enums are the size of ints, for structure packing. + For both Watcom C/C++ and Borland C/C++ the compiler option that makes + enums having the size of an int must be enabled. + This is "-b" for Borland C/C++ and "-ei" for Watcom C/C++ (v11). +*/ + +/** \cond */ +#ifndef DOXYGEN_SHOULD_IGNORE_THIS +#if !defined(__ANDROID__) + /* TODO: include/SDL_stdinc.h:174: error: size of array 'SDL_dummy_enum' is negative */ +typedef enum +{ + DUMMY_ENUM_VALUE +} SDL_DUMMY_ENUM; + +SDL_COMPILE_TIME_ASSERT(enum, sizeof(SDL_DUMMY_ENUM) == sizeof(int)); +#endif +#endif /* DOXYGEN_SHOULD_IGNORE_THIS */ +/** \endcond */ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +#ifdef HAVE_ALLOCA +#define SDL_stack_alloc(type, count) (type*)alloca(sizeof(type)*(count)) +#define SDL_stack_free(data) +#else +#define SDL_stack_alloc(type, count) (type*)SDL_malloc(sizeof(type)*(count)) +#define SDL_stack_free(data) SDL_free(data) +#endif + +extern DECLSPEC void *SDLCALL SDL_malloc(size_t size); +extern DECLSPEC void *SDLCALL SDL_calloc(size_t nmemb, size_t size); +extern DECLSPEC void *SDLCALL SDL_realloc(void *mem, size_t size); +extern DECLSPEC void SDLCALL SDL_free(void *mem); + +typedef void *(SDLCALL *SDL_malloc_func)(size_t size); +typedef void *(SDLCALL *SDL_calloc_func)(size_t nmemb, size_t size); +typedef void *(SDLCALL *SDL_realloc_func)(void *mem, size_t size); +typedef void (SDLCALL *SDL_free_func)(void *mem); + +/** + * \brief Get the current set of SDL memory functions + */ +extern DECLSPEC void SDLCALL SDL_GetMemoryFunctions(SDL_malloc_func *malloc_func, + SDL_calloc_func *calloc_func, + SDL_realloc_func *realloc_func, + SDL_free_func *free_func); + +/** + * \brief Replace SDL's memory allocation functions with a custom set + * + * \note If you are replacing SDL's memory functions, you should call + * SDL_GetNumAllocations() and be very careful if it returns non-zero. + * That means that your free function will be called with memory + * allocated by the previous memory allocation functions. + */ +extern DECLSPEC int SDLCALL SDL_SetMemoryFunctions(SDL_malloc_func malloc_func, + SDL_calloc_func calloc_func, + SDL_realloc_func realloc_func, + SDL_free_func free_func); + +/** + * \brief Get the number of outstanding (unfreed) allocations + */ +extern DECLSPEC int SDLCALL SDL_GetNumAllocations(void); + +extern DECLSPEC char *SDLCALL SDL_getenv(const char *name); +extern DECLSPEC int SDLCALL SDL_setenv(const char *name, const char *value, int overwrite); + +extern DECLSPEC void SDLCALL SDL_qsort(void *base, size_t nmemb, size_t size, int (*compare) (const void *, const void *)); + +extern DECLSPEC int SDLCALL SDL_abs(int x); + +/* !!! FIXME: these have side effects. You probably shouldn't use them. */ +/* !!! FIXME: Maybe we do forceinline functions of SDL_mini, SDL_minf, etc? */ +#define SDL_min(x, y) (((x) < (y)) ? (x) : (y)) +#define SDL_max(x, y) (((x) > (y)) ? (x) : (y)) + +extern DECLSPEC int SDLCALL SDL_isdigit(int x); +extern DECLSPEC int SDLCALL SDL_isspace(int x); +extern DECLSPEC int SDLCALL SDL_toupper(int x); +extern DECLSPEC int SDLCALL SDL_tolower(int x); + +extern DECLSPEC void *SDLCALL SDL_memset(SDL_OUT_BYTECAP(len) void *dst, int c, size_t len); + +#define SDL_zero(x) SDL_memset(&(x), 0, sizeof((x))) +#define SDL_zerop(x) SDL_memset((x), 0, sizeof(*(x))) + +/* Note that memset() is a byte assignment and this is a 32-bit assignment, so they're not directly equivalent. */ +SDL_FORCE_INLINE void SDL_memset4(void *dst, Uint32 val, size_t dwords) +{ +#if defined(__GNUC__) && defined(i386) + int u0, u1, u2; + __asm__ __volatile__ ( + "cld \n\t" + "rep ; stosl \n\t" + : "=&D" (u0), "=&a" (u1), "=&c" (u2) + : "0" (dst), "1" (val), "2" (SDL_static_cast(Uint32, dwords)) + : "memory" + ); +#else + size_t _n = (dwords + 3) / 4; + Uint32 *_p = SDL_static_cast(Uint32 *, dst); + Uint32 _val = (val); + if (dwords == 0) + return; + switch (dwords % 4) + { + case 0: do { *_p++ = _val; /* fallthrough */ + case 3: *_p++ = _val; /* fallthrough */ + case 2: *_p++ = _val; /* fallthrough */ + case 1: *_p++ = _val; /* fallthrough */ + } while ( --_n ); + } +#endif +} + +extern DECLSPEC void *SDLCALL SDL_memcpy(SDL_OUT_BYTECAP(len) void *dst, SDL_IN_BYTECAP(len) const void *src, size_t len); + +extern DECLSPEC void *SDLCALL SDL_memmove(SDL_OUT_BYTECAP(len) void *dst, SDL_IN_BYTECAP(len) const void *src, size_t len); +extern DECLSPEC int SDLCALL SDL_memcmp(const void *s1, const void *s2, size_t len); + +extern DECLSPEC wchar_t *SDLCALL SDL_wcsdup(const wchar_t *wstr); +extern DECLSPEC size_t SDLCALL SDL_wcslen(const wchar_t *wstr); +extern DECLSPEC size_t SDLCALL SDL_wcslcpy(SDL_OUT_Z_CAP(maxlen) wchar_t *dst, const wchar_t *src, size_t maxlen); +extern DECLSPEC size_t SDLCALL SDL_wcslcat(SDL_INOUT_Z_CAP(maxlen) wchar_t *dst, const wchar_t *src, size_t maxlen); +extern DECLSPEC int SDLCALL SDL_wcscmp(const wchar_t *str1, const wchar_t *str2); + +extern DECLSPEC size_t SDLCALL SDL_strlen(const char *str); +extern DECLSPEC size_t SDLCALL SDL_strlcpy(SDL_OUT_Z_CAP(maxlen) char *dst, const char *src, size_t maxlen); +extern DECLSPEC size_t SDLCALL SDL_utf8strlcpy(SDL_OUT_Z_CAP(dst_bytes) char *dst, const char *src, size_t dst_bytes); +extern DECLSPEC size_t SDLCALL SDL_strlcat(SDL_INOUT_Z_CAP(maxlen) char *dst, const char *src, size_t maxlen); +extern DECLSPEC char *SDLCALL SDL_strdup(const char *str); +extern DECLSPEC char *SDLCALL SDL_strrev(char *str); +extern DECLSPEC char *SDLCALL SDL_strupr(char *str); +extern DECLSPEC char *SDLCALL SDL_strlwr(char *str); +extern DECLSPEC char *SDLCALL SDL_strchr(const char *str, int c); +extern DECLSPEC char *SDLCALL SDL_strrchr(const char *str, int c); +extern DECLSPEC char *SDLCALL SDL_strstr(const char *haystack, const char *needle); +extern DECLSPEC size_t SDLCALL SDL_utf8strlen(const char *str); + +extern DECLSPEC char *SDLCALL SDL_itoa(int value, char *str, int radix); +extern DECLSPEC char *SDLCALL SDL_uitoa(unsigned int value, char *str, int radix); +extern DECLSPEC char *SDLCALL SDL_ltoa(long value, char *str, int radix); +extern DECLSPEC char *SDLCALL SDL_ultoa(unsigned long value, char *str, int radix); +extern DECLSPEC char *SDLCALL SDL_lltoa(Sint64 value, char *str, int radix); +extern DECLSPEC char *SDLCALL SDL_ulltoa(Uint64 value, char *str, int radix); + +extern DECLSPEC int SDLCALL SDL_atoi(const char *str); +extern DECLSPEC double SDLCALL SDL_atof(const char *str); +extern DECLSPEC long SDLCALL SDL_strtol(const char *str, char **endp, int base); +extern DECLSPEC unsigned long SDLCALL SDL_strtoul(const char *str, char **endp, int base); +extern DECLSPEC Sint64 SDLCALL SDL_strtoll(const char *str, char **endp, int base); +extern DECLSPEC Uint64 SDLCALL SDL_strtoull(const char *str, char **endp, int base); +extern DECLSPEC double SDLCALL SDL_strtod(const char *str, char **endp); + +extern DECLSPEC int SDLCALL SDL_strcmp(const char *str1, const char *str2); +extern DECLSPEC int SDLCALL SDL_strncmp(const char *str1, const char *str2, size_t maxlen); +extern DECLSPEC int SDLCALL SDL_strcasecmp(const char *str1, const char *str2); +extern DECLSPEC int SDLCALL SDL_strncasecmp(const char *str1, const char *str2, size_t len); + +extern DECLSPEC int SDLCALL SDL_sscanf(const char *text, SDL_SCANF_FORMAT_STRING const char *fmt, ...) SDL_SCANF_VARARG_FUNC(2); +extern DECLSPEC int SDLCALL SDL_vsscanf(const char *text, const char *fmt, va_list ap); +extern DECLSPEC int SDLCALL SDL_snprintf(SDL_OUT_Z_CAP(maxlen) char *text, size_t maxlen, SDL_PRINTF_FORMAT_STRING const char *fmt, ... ) SDL_PRINTF_VARARG_FUNC(3); +extern DECLSPEC int SDLCALL SDL_vsnprintf(SDL_OUT_Z_CAP(maxlen) char *text, size_t maxlen, const char *fmt, va_list ap); + +#ifndef HAVE_M_PI +#ifndef M_PI +#define M_PI 3.14159265358979323846264338327950288 /**< pi */ +#endif +#endif + +extern DECLSPEC double SDLCALL SDL_acos(double x); +extern DECLSPEC float SDLCALL SDL_acosf(float x); +extern DECLSPEC double SDLCALL SDL_asin(double x); +extern DECLSPEC float SDLCALL SDL_asinf(float x); +extern DECLSPEC double SDLCALL SDL_atan(double x); +extern DECLSPEC float SDLCALL SDL_atanf(float x); +extern DECLSPEC double SDLCALL SDL_atan2(double x, double y); +extern DECLSPEC float SDLCALL SDL_atan2f(float x, float y); +extern DECLSPEC double SDLCALL SDL_ceil(double x); +extern DECLSPEC float SDLCALL SDL_ceilf(float x); +extern DECLSPEC double SDLCALL SDL_copysign(double x, double y); +extern DECLSPEC float SDLCALL SDL_copysignf(float x, float y); +extern DECLSPEC double SDLCALL SDL_cos(double x); +extern DECLSPEC float SDLCALL SDL_cosf(float x); +extern DECLSPEC double SDLCALL SDL_exp(double x); +extern DECLSPEC float SDLCALL SDL_expf(float x); +extern DECLSPEC double SDLCALL SDL_fabs(double x); +extern DECLSPEC float SDLCALL SDL_fabsf(float x); +extern DECLSPEC double SDLCALL SDL_floor(double x); +extern DECLSPEC float SDLCALL SDL_floorf(float x); +extern DECLSPEC double SDLCALL SDL_fmod(double x, double y); +extern DECLSPEC float SDLCALL SDL_fmodf(float x, float y); +extern DECLSPEC double SDLCALL SDL_log(double x); +extern DECLSPEC float SDLCALL SDL_logf(float x); +extern DECLSPEC double SDLCALL SDL_log10(double x); +extern DECLSPEC float SDLCALL SDL_log10f(float x); +extern DECLSPEC double SDLCALL SDL_pow(double x, double y); +extern DECLSPEC float SDLCALL SDL_powf(float x, float y); +extern DECLSPEC double SDLCALL SDL_scalbn(double x, int n); +extern DECLSPEC float SDLCALL SDL_scalbnf(float x, int n); +extern DECLSPEC double SDLCALL SDL_sin(double x); +extern DECLSPEC float SDLCALL SDL_sinf(float x); +extern DECLSPEC double SDLCALL SDL_sqrt(double x); +extern DECLSPEC float SDLCALL SDL_sqrtf(float x); +extern DECLSPEC double SDLCALL SDL_tan(double x); +extern DECLSPEC float SDLCALL SDL_tanf(float x); + +/* The SDL implementation of iconv() returns these error codes */ +#define SDL_ICONV_ERROR (size_t)-1 +#define SDL_ICONV_E2BIG (size_t)-2 +#define SDL_ICONV_EILSEQ (size_t)-3 +#define SDL_ICONV_EINVAL (size_t)-4 + +/* SDL_iconv_* are now always real symbols/types, not macros or inlined. */ +typedef struct _SDL_iconv_t *SDL_iconv_t; +extern DECLSPEC SDL_iconv_t SDLCALL SDL_iconv_open(const char *tocode, + const char *fromcode); +extern DECLSPEC int SDLCALL SDL_iconv_close(SDL_iconv_t cd); +extern DECLSPEC size_t SDLCALL SDL_iconv(SDL_iconv_t cd, const char **inbuf, + size_t * inbytesleft, char **outbuf, + size_t * outbytesleft); +/** + * This function converts a string between encodings in one pass, returning a + * string that must be freed with SDL_free() or NULL on error. + */ +extern DECLSPEC char *SDLCALL SDL_iconv_string(const char *tocode, + const char *fromcode, + const char *inbuf, + size_t inbytesleft); +#define SDL_iconv_utf8_locale(S) SDL_iconv_string("", "UTF-8", S, SDL_strlen(S)+1) +#define SDL_iconv_utf8_ucs2(S) (Uint16 *)SDL_iconv_string("UCS-2-INTERNAL", "UTF-8", S, SDL_strlen(S)+1) +#define SDL_iconv_utf8_ucs4(S) (Uint32 *)SDL_iconv_string("UCS-4-INTERNAL", "UTF-8", S, SDL_strlen(S)+1) + +/* force builds using Clang's static analysis tools to use literal C runtime + here, since there are possibly tests that are ineffective otherwise. */ +#if defined(__clang_analyzer__) && !defined(SDL_DISABLE_ANALYZE_MACROS) +#define SDL_malloc malloc +#define SDL_calloc calloc +#define SDL_realloc realloc +#define SDL_free free +#define SDL_memset memset +#define SDL_memcpy memcpy +#define SDL_memmove memmove +#define SDL_memcmp memcmp +#define SDL_strlen strlen +#define SDL_strlcpy strlcpy +#define SDL_strlcat strlcat +#define SDL_strdup strdup +#define SDL_strchr strchr +#define SDL_strrchr strrchr +#define SDL_strstr strstr +#define SDL_strcmp strcmp +#define SDL_strncmp strncmp +#define SDL_strcasecmp strcasecmp +#define SDL_strncasecmp strncasecmp +#define SDL_sscanf sscanf +#define SDL_vsscanf vsscanf +#define SDL_snprintf snprintf +#define SDL_vsnprintf vsnprintf +#endif + +SDL_FORCE_INLINE void *SDL_memcpy4(SDL_OUT_BYTECAP(dwords*4) void *dst, SDL_IN_BYTECAP(dwords*4) const void *src, size_t dwords) +{ + return SDL_memcpy(dst, src, dwords * 4); +} + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_stdinc_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_surface.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_surface.h new file mode 100644 index 0000000..51a1283 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_surface.h @@ -0,0 +1,554 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_surface.h + * + * Header file for ::SDL_Surface definition and management functions. + */ + +#ifndef SDL_surface_h_ +#define SDL_surface_h_ + +#include "SDL_stdinc.h" +#include "SDL_pixels.h" +#include "SDL_rect.h" +#include "SDL_blendmode.h" +#include "SDL_rwops.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \name Surface flags + * + * These are the currently supported flags for the ::SDL_Surface. + * + * \internal + * Used internally (read-only). + */ +/* @{ */ +#define SDL_SWSURFACE 0 /**< Just here for compatibility */ +#define SDL_PREALLOC 0x00000001 /**< Surface uses preallocated memory */ +#define SDL_RLEACCEL 0x00000002 /**< Surface is RLE encoded */ +#define SDL_DONTFREE 0x00000004 /**< Surface is referenced internally */ +#define SDL_SIMD_ALIGNED 0x00000008 /**< Surface uses aligned memory */ +/* @} *//* Surface flags */ + +/** + * Evaluates to true if the surface needs to be locked before access. + */ +#define SDL_MUSTLOCK(S) (((S)->flags & SDL_RLEACCEL) != 0) + +/** + * \brief A collection of pixels used in software blitting. + * + * \note This structure should be treated as read-only, except for \c pixels, + * which, if not NULL, contains the raw pixel data for the surface. + */ +typedef struct SDL_Surface +{ + Uint32 flags; /**< Read-only */ + SDL_PixelFormat *format; /**< Read-only */ + int w, h; /**< Read-only */ + int pitch; /**< Read-only */ + void *pixels; /**< Read-write */ + + /** Application data associated with the surface */ + void *userdata; /**< Read-write */ + + /** information needed for surfaces requiring locks */ + int locked; /**< Read-only */ + void *lock_data; /**< Read-only */ + + /** clipping information */ + SDL_Rect clip_rect; /**< Read-only */ + + /** info for fast blit mapping to other surfaces */ + struct SDL_BlitMap *map; /**< Private */ + + /** Reference count -- used when freeing surface */ + int refcount; /**< Read-mostly */ +} SDL_Surface; + +/** + * \brief The type of function used for surface blitting functions. + */ +typedef int (SDLCALL *SDL_blit) (struct SDL_Surface * src, SDL_Rect * srcrect, + struct SDL_Surface * dst, SDL_Rect * dstrect); + +/** + * \brief The formula used for converting between YUV and RGB + */ +typedef enum +{ + SDL_YUV_CONVERSION_JPEG, /**< Full range JPEG */ + SDL_YUV_CONVERSION_BT601, /**< BT.601 (the default) */ + SDL_YUV_CONVERSION_BT709, /**< BT.709 */ + SDL_YUV_CONVERSION_AUTOMATIC /**< BT.601 for SD content, BT.709 for HD content */ +} SDL_YUV_CONVERSION_MODE; + +/** + * Allocate and free an RGB surface. + * + * If the depth is 4 or 8 bits, an empty palette is allocated for the surface. + * If the depth is greater than 8 bits, the pixel format is set using the + * flags '[RGB]mask'. + * + * If the function runs out of memory, it will return NULL. + * + * \param flags The \c flags are obsolete and should be set to 0. + * \param width The width in pixels of the surface to create. + * \param height The height in pixels of the surface to create. + * \param depth The depth in bits of the surface to create. + * \param Rmask The red mask of the surface to create. + * \param Gmask The green mask of the surface to create. + * \param Bmask The blue mask of the surface to create. + * \param Amask The alpha mask of the surface to create. + */ +extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurface + (Uint32 flags, int width, int height, int depth, + Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask); + +/* !!! FIXME for 2.1: why does this ask for depth? Format provides that. */ +extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurfaceWithFormat + (Uint32 flags, int width, int height, int depth, Uint32 format); + +extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurfaceFrom(void *pixels, + int width, + int height, + int depth, + int pitch, + Uint32 Rmask, + Uint32 Gmask, + Uint32 Bmask, + Uint32 Amask); +extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurfaceWithFormatFrom + (void *pixels, int width, int height, int depth, int pitch, Uint32 format); +extern DECLSPEC void SDLCALL SDL_FreeSurface(SDL_Surface * surface); + +/** + * \brief Set the palette used by a surface. + * + * \return 0, or -1 if the surface format doesn't use a palette. + * + * \note A single palette can be shared with many surfaces. + */ +extern DECLSPEC int SDLCALL SDL_SetSurfacePalette(SDL_Surface * surface, + SDL_Palette * palette); + +/** + * \brief Sets up a surface for directly accessing the pixels. + * + * Between calls to SDL_LockSurface() / SDL_UnlockSurface(), you can write + * to and read from \c surface->pixels, using the pixel format stored in + * \c surface->format. Once you are done accessing the surface, you should + * use SDL_UnlockSurface() to release it. + * + * Not all surfaces require locking. If SDL_MUSTLOCK(surface) evaluates + * to 0, then you can read and write to the surface at any time, and the + * pixel format of the surface will not change. + * + * No operating system or library calls should be made between lock/unlock + * pairs, as critical system locks may be held during this time. + * + * SDL_LockSurface() returns 0, or -1 if the surface couldn't be locked. + * + * \sa SDL_UnlockSurface() + */ +extern DECLSPEC int SDLCALL SDL_LockSurface(SDL_Surface * surface); +/** \sa SDL_LockSurface() */ +extern DECLSPEC void SDLCALL SDL_UnlockSurface(SDL_Surface * surface); + +/** + * Load a surface from a seekable SDL data stream (memory or file). + * + * If \c freesrc is non-zero, the stream will be closed after being read. + * + * The new surface should be freed with SDL_FreeSurface(). + * + * \return the new surface, or NULL if there was an error. + */ +extern DECLSPEC SDL_Surface *SDLCALL SDL_LoadBMP_RW(SDL_RWops * src, + int freesrc); + +/** + * Load a surface from a file. + * + * Convenience macro. + */ +#define SDL_LoadBMP(file) SDL_LoadBMP_RW(SDL_RWFromFile(file, "rb"), 1) + +/** + * Save a surface to a seekable SDL data stream (memory or file). + * + * Surfaces with a 24-bit, 32-bit and paletted 8-bit format get saved in the + * BMP directly. Other RGB formats with 8-bit or higher get converted to a + * 24-bit surface or, if they have an alpha mask or a colorkey, to a 32-bit + * surface before they are saved. YUV and paletted 1-bit and 4-bit formats are + * not supported. + * + * If \c freedst is non-zero, the stream will be closed after being written. + * + * \return 0 if successful or -1 if there was an error. + */ +extern DECLSPEC int SDLCALL SDL_SaveBMP_RW + (SDL_Surface * surface, SDL_RWops * dst, int freedst); + +/** + * Save a surface to a file. + * + * Convenience macro. + */ +#define SDL_SaveBMP(surface, file) \ + SDL_SaveBMP_RW(surface, SDL_RWFromFile(file, "wb"), 1) + +/** + * \brief Sets the RLE acceleration hint for a surface. + * + * \return 0 on success, or -1 if the surface is not valid + * + * \note If RLE is enabled, colorkey and alpha blending blits are much faster, + * but the surface must be locked before directly accessing the pixels. + */ +extern DECLSPEC int SDLCALL SDL_SetSurfaceRLE(SDL_Surface * surface, + int flag); + +/** + * \brief Sets the color key (transparent pixel) in a blittable surface. + * + * \param surface The surface to update + * \param flag Non-zero to enable colorkey and 0 to disable colorkey + * \param key The transparent pixel in the native surface format + * + * \return 0 on success, or -1 if the surface is not valid + * + * You can pass SDL_RLEACCEL to enable RLE accelerated blits. + */ +extern DECLSPEC int SDLCALL SDL_SetColorKey(SDL_Surface * surface, + int flag, Uint32 key); + +/** + * \brief Returns whether the surface has a color key + * + * \return SDL_TRUE if the surface has a color key, or SDL_FALSE if the surface is NULL or has no color key + */ +extern DECLSPEC SDL_bool SDLCALL SDL_HasColorKey(SDL_Surface * surface); + +/** + * \brief Gets the color key (transparent pixel) in a blittable surface. + * + * \param surface The surface to update + * \param key A pointer filled in with the transparent pixel in the native + * surface format + * + * \return 0 on success, or -1 if the surface is not valid or colorkey is not + * enabled. + */ +extern DECLSPEC int SDLCALL SDL_GetColorKey(SDL_Surface * surface, + Uint32 * key); + +/** + * \brief Set an additional color value used in blit operations. + * + * \param surface The surface to update. + * \param r The red color value multiplied into blit operations. + * \param g The green color value multiplied into blit operations. + * \param b The blue color value multiplied into blit operations. + * + * \return 0 on success, or -1 if the surface is not valid. + * + * \sa SDL_GetSurfaceColorMod() + */ +extern DECLSPEC int SDLCALL SDL_SetSurfaceColorMod(SDL_Surface * surface, + Uint8 r, Uint8 g, Uint8 b); + + +/** + * \brief Get the additional color value used in blit operations. + * + * \param surface The surface to query. + * \param r A pointer filled in with the current red color value. + * \param g A pointer filled in with the current green color value. + * \param b A pointer filled in with the current blue color value. + * + * \return 0 on success, or -1 if the surface is not valid. + * + * \sa SDL_SetSurfaceColorMod() + */ +extern DECLSPEC int SDLCALL SDL_GetSurfaceColorMod(SDL_Surface * surface, + Uint8 * r, Uint8 * g, + Uint8 * b); + +/** + * \brief Set an additional alpha value used in blit operations. + * + * \param surface The surface to update. + * \param alpha The alpha value multiplied into blit operations. + * + * \return 0 on success, or -1 if the surface is not valid. + * + * \sa SDL_GetSurfaceAlphaMod() + */ +extern DECLSPEC int SDLCALL SDL_SetSurfaceAlphaMod(SDL_Surface * surface, + Uint8 alpha); + +/** + * \brief Get the additional alpha value used in blit operations. + * + * \param surface The surface to query. + * \param alpha A pointer filled in with the current alpha value. + * + * \return 0 on success, or -1 if the surface is not valid. + * + * \sa SDL_SetSurfaceAlphaMod() + */ +extern DECLSPEC int SDLCALL SDL_GetSurfaceAlphaMod(SDL_Surface * surface, + Uint8 * alpha); + +/** + * \brief Set the blend mode used for blit operations. + * + * \param surface The surface to update. + * \param blendMode ::SDL_BlendMode to use for blit blending. + * + * \return 0 on success, or -1 if the parameters are not valid. + * + * \sa SDL_GetSurfaceBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_SetSurfaceBlendMode(SDL_Surface * surface, + SDL_BlendMode blendMode); + +/** + * \brief Get the blend mode used for blit operations. + * + * \param surface The surface to query. + * \param blendMode A pointer filled in with the current blend mode. + * + * \return 0 on success, or -1 if the surface is not valid. + * + * \sa SDL_SetSurfaceBlendMode() + */ +extern DECLSPEC int SDLCALL SDL_GetSurfaceBlendMode(SDL_Surface * surface, + SDL_BlendMode *blendMode); + +/** + * Sets the clipping rectangle for the destination surface in a blit. + * + * If the clip rectangle is NULL, clipping will be disabled. + * + * If the clip rectangle doesn't intersect the surface, the function will + * return SDL_FALSE and blits will be completely clipped. Otherwise the + * function returns SDL_TRUE and blits to the surface will be clipped to + * the intersection of the surface area and the clipping rectangle. + * + * Note that blits are automatically clipped to the edges of the source + * and destination surfaces. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_SetClipRect(SDL_Surface * surface, + const SDL_Rect * rect); + +/** + * Gets the clipping rectangle for the destination surface in a blit. + * + * \c rect must be a pointer to a valid rectangle which will be filled + * with the correct values. + */ +extern DECLSPEC void SDLCALL SDL_GetClipRect(SDL_Surface * surface, + SDL_Rect * rect); + +/* + * Creates a new surface identical to the existing surface + */ +extern DECLSPEC SDL_Surface *SDLCALL SDL_DuplicateSurface(SDL_Surface * surface); + +/** + * Creates a new surface of the specified format, and then copies and maps + * the given surface to it so the blit of the converted surface will be as + * fast as possible. If this function fails, it returns NULL. + * + * The \c flags parameter is passed to SDL_CreateRGBSurface() and has those + * semantics. You can also pass ::SDL_RLEACCEL in the flags parameter and + * SDL will try to RLE accelerate colorkey and alpha blits in the resulting + * surface. + */ +extern DECLSPEC SDL_Surface *SDLCALL SDL_ConvertSurface + (SDL_Surface * src, const SDL_PixelFormat * fmt, Uint32 flags); +extern DECLSPEC SDL_Surface *SDLCALL SDL_ConvertSurfaceFormat + (SDL_Surface * src, Uint32 pixel_format, Uint32 flags); + +/** + * \brief Copy a block of pixels of one format to another format + * + * \return 0 on success, or -1 if there was an error + */ +extern DECLSPEC int SDLCALL SDL_ConvertPixels(int width, int height, + Uint32 src_format, + const void * src, int src_pitch, + Uint32 dst_format, + void * dst, int dst_pitch); + +/** + * Performs a fast fill of the given rectangle with \c color. + * + * If \c rect is NULL, the whole surface will be filled with \c color. + * + * The color should be a pixel of the format used by the surface, and + * can be generated by the SDL_MapRGB() function. + * + * \return 0 on success, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_FillRect + (SDL_Surface * dst, const SDL_Rect * rect, Uint32 color); +extern DECLSPEC int SDLCALL SDL_FillRects + (SDL_Surface * dst, const SDL_Rect * rects, int count, Uint32 color); + +/** + * Performs a fast blit from the source surface to the destination surface. + * + * This assumes that the source and destination rectangles are + * the same size. If either \c srcrect or \c dstrect are NULL, the entire + * surface (\c src or \c dst) is copied. The final blit rectangles are saved + * in \c srcrect and \c dstrect after all clipping is performed. + * + * \return If the blit is successful, it returns 0, otherwise it returns -1. + * + * The blit function should not be called on a locked surface. + * + * The blit semantics for surfaces with and without blending and colorkey + * are defined as follows: + * \verbatim + RGBA->RGB: + Source surface blend mode set to SDL_BLENDMODE_BLEND: + alpha-blend (using the source alpha-channel and per-surface alpha) + SDL_SRCCOLORKEY ignored. + Source surface blend mode set to SDL_BLENDMODE_NONE: + copy RGB. + if SDL_SRCCOLORKEY set, only copy the pixels matching the + RGB values of the source color key, ignoring alpha in the + comparison. + + RGB->RGBA: + Source surface blend mode set to SDL_BLENDMODE_BLEND: + alpha-blend (using the source per-surface alpha) + Source surface blend mode set to SDL_BLENDMODE_NONE: + copy RGB, set destination alpha to source per-surface alpha value. + both: + if SDL_SRCCOLORKEY set, only copy the pixels matching the + source color key. + + RGBA->RGBA: + Source surface blend mode set to SDL_BLENDMODE_BLEND: + alpha-blend (using the source alpha-channel and per-surface alpha) + SDL_SRCCOLORKEY ignored. + Source surface blend mode set to SDL_BLENDMODE_NONE: + copy all of RGBA to the destination. + if SDL_SRCCOLORKEY set, only copy the pixels matching the + RGB values of the source color key, ignoring alpha in the + comparison. + + RGB->RGB: + Source surface blend mode set to SDL_BLENDMODE_BLEND: + alpha-blend (using the source per-surface alpha) + Source surface blend mode set to SDL_BLENDMODE_NONE: + copy RGB. + both: + if SDL_SRCCOLORKEY set, only copy the pixels matching the + source color key. + \endverbatim + * + * You should call SDL_BlitSurface() unless you know exactly how SDL + * blitting works internally and how to use the other blit functions. + */ +#define SDL_BlitSurface SDL_UpperBlit + +/** + * This is the public blit function, SDL_BlitSurface(), and it performs + * rectangle validation and clipping before passing it to SDL_LowerBlit() + */ +extern DECLSPEC int SDLCALL SDL_UpperBlit + (SDL_Surface * src, const SDL_Rect * srcrect, + SDL_Surface * dst, SDL_Rect * dstrect); + +/** + * This is a semi-private blit function and it performs low-level surface + * blitting only. + */ +extern DECLSPEC int SDLCALL SDL_LowerBlit + (SDL_Surface * src, SDL_Rect * srcrect, + SDL_Surface * dst, SDL_Rect * dstrect); + +/** + * \brief Perform a fast, low quality, stretch blit between two surfaces of the + * same pixel format. + * + * \note This function uses a static buffer, and is not thread-safe. + */ +extern DECLSPEC int SDLCALL SDL_SoftStretch(SDL_Surface * src, + const SDL_Rect * srcrect, + SDL_Surface * dst, + const SDL_Rect * dstrect); + +#define SDL_BlitScaled SDL_UpperBlitScaled + +/** + * This is the public scaled blit function, SDL_BlitScaled(), and it performs + * rectangle validation and clipping before passing it to SDL_LowerBlitScaled() + */ +extern DECLSPEC int SDLCALL SDL_UpperBlitScaled + (SDL_Surface * src, const SDL_Rect * srcrect, + SDL_Surface * dst, SDL_Rect * dstrect); + +/** + * This is a semi-private blit function and it performs low-level surface + * scaled blitting only. + */ +extern DECLSPEC int SDLCALL SDL_LowerBlitScaled + (SDL_Surface * src, SDL_Rect * srcrect, + SDL_Surface * dst, SDL_Rect * dstrect); + +/** + * \brief Set the YUV conversion mode + */ +extern DECLSPEC void SDLCALL SDL_SetYUVConversionMode(SDL_YUV_CONVERSION_MODE mode); + +/** + * \brief Get the YUV conversion mode + */ +extern DECLSPEC SDL_YUV_CONVERSION_MODE SDLCALL SDL_GetYUVConversionMode(void); + +/** + * \brief Get the YUV conversion mode, returning the correct mode for the resolution when the current conversion mode is SDL_YUV_CONVERSION_AUTOMATIC + */ +extern DECLSPEC SDL_YUV_CONVERSION_MODE SDLCALL SDL_GetYUVConversionModeForResolution(int width, int height); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_surface_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_system.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_system.h new file mode 100644 index 0000000..3b08407 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_system.h @@ -0,0 +1,279 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_system.h + * + * Include file for platform specific SDL API functions + */ + +#ifndef SDL_system_h_ +#define SDL_system_h_ + +#include "SDL_stdinc.h" +#include "SDL_keyboard.h" +#include "SDL_render.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/* Platform specific functions for Windows */ +#ifdef __WIN32__ + +/** + \brief Set a function that is called for every windows message, before TranslateMessage() +*/ +typedef void (SDLCALL * SDL_WindowsMessageHook)(void *userdata, void *hWnd, unsigned int message, Uint64 wParam, Sint64 lParam); +extern DECLSPEC void SDLCALL SDL_SetWindowsMessageHook(SDL_WindowsMessageHook callback, void *userdata); + +/** + \brief Returns the D3D9 adapter index that matches the specified display index. + + This adapter index can be passed to IDirect3D9::CreateDevice and controls + on which monitor a full screen application will appear. +*/ +extern DECLSPEC int SDLCALL SDL_Direct3D9GetAdapterIndex( int displayIndex ); + +typedef struct IDirect3DDevice9 IDirect3DDevice9; +/** + \brief Returns the D3D device associated with a renderer, or NULL if it's not a D3D renderer. + + Once you are done using the device, you should release it to avoid a resource leak. + */ +extern DECLSPEC IDirect3DDevice9* SDLCALL SDL_RenderGetD3D9Device(SDL_Renderer * renderer); + +/** + \brief Returns the DXGI Adapter and Output indices for the specified display index. + + These can be passed to EnumAdapters and EnumOutputs respectively to get the objects + required to create a DX10 or DX11 device and swap chain. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_DXGIGetOutputInfo( int displayIndex, int *adapterIndex, int *outputIndex ); + +#endif /* __WIN32__ */ + + +/* Platform specific functions for Linux */ +#ifdef __LINUX__ + +/** + \brief Sets the UNIX nice value for a thread, using setpriority() if possible, and RealtimeKit if available. + + \return 0 on success, or -1 on error. + */ +extern DECLSPEC int SDLCALL SDL_LinuxSetThreadPriority(Sint64 threadID, int priority); + +#endif /* __LINUX__ */ + +/* Platform specific functions for iOS */ +#if defined(__IPHONEOS__) && __IPHONEOS__ + +#define SDL_iOSSetAnimationCallback(window, interval, callback, callbackParam) SDL_iPhoneSetAnimationCallback(window, interval, callback, callbackParam) +extern DECLSPEC int SDLCALL SDL_iPhoneSetAnimationCallback(SDL_Window * window, int interval, void (*callback)(void*), void *callbackParam); + +#define SDL_iOSSetEventPump(enabled) SDL_iPhoneSetEventPump(enabled) +extern DECLSPEC void SDLCALL SDL_iPhoneSetEventPump(SDL_bool enabled); + +#endif /* __IPHONEOS__ */ + + +/* Platform specific functions for Android */ +#if defined(__ANDROID__) && __ANDROID__ + +/** + \brief Get the JNI environment for the current thread + + This returns JNIEnv*, but the prototype is void* so we don't need jni.h + */ +extern DECLSPEC void * SDLCALL SDL_AndroidGetJNIEnv(void); + +/** + \brief Get the SDL Activity object for the application + + This returns jobject, but the prototype is void* so we don't need jni.h + The jobject returned by SDL_AndroidGetActivity is a local reference. + It is the caller's responsibility to properly release it + (using env->Push/PopLocalFrame or manually with env->DeleteLocalRef) + */ +extern DECLSPEC void * SDLCALL SDL_AndroidGetActivity(void); + +/** + \brief Return true if the application is running on Android TV + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsAndroidTV(void); + +/** + \brief Return true if the application is running on a Chromebook + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsChromebook(void); + +/** + \brief Return true is the application is running on a Samsung DeX docking station + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsDeXMode(void); + +/** + \brief Trigger the Android system back button behavior. + */ +extern DECLSPEC void SDLCALL SDL_AndroidBackButton(void); + +/** + See the official Android developer guide for more information: + http://developer.android.com/guide/topics/data/data-storage.html +*/ +#define SDL_ANDROID_EXTERNAL_STORAGE_READ 0x01 +#define SDL_ANDROID_EXTERNAL_STORAGE_WRITE 0x02 + +/** + \brief Get the path used for internal storage for this application. + + This path is unique to your application and cannot be written to + by other applications. + */ +extern DECLSPEC const char * SDLCALL SDL_AndroidGetInternalStoragePath(void); + +/** + \brief Get the current state of external storage, a bitmask of these values: + SDL_ANDROID_EXTERNAL_STORAGE_READ + SDL_ANDROID_EXTERNAL_STORAGE_WRITE + + If external storage is currently unavailable, this will return 0. +*/ +extern DECLSPEC int SDLCALL SDL_AndroidGetExternalStorageState(void); + +/** + \brief Get the path used for external storage for this application. + + This path is unique to your application, but is public and can be + written to by other applications. + */ +extern DECLSPEC const char * SDLCALL SDL_AndroidGetExternalStoragePath(void); + +#endif /* __ANDROID__ */ + +/* Platform specific functions for WinRT */ +#if defined(__WINRT__) && __WINRT__ + +/** + * \brief WinRT / Windows Phone path types + */ +typedef enum +{ + /** \brief The installed app's root directory. + Files here are likely to be read-only. */ + SDL_WINRT_PATH_INSTALLED_LOCATION, + + /** \brief The app's local data store. Files may be written here */ + SDL_WINRT_PATH_LOCAL_FOLDER, + + /** \brief The app's roaming data store. Unsupported on Windows Phone. + Files written here may be copied to other machines via a network + connection. + */ + SDL_WINRT_PATH_ROAMING_FOLDER, + + /** \brief The app's temporary data store. Unsupported on Windows Phone. + Files written here may be deleted at any time. */ + SDL_WINRT_PATH_TEMP_FOLDER +} SDL_WinRT_Path; + + +/** + * \brief WinRT Device Family + */ +typedef enum +{ + /** \brief Unknown family */ + SDL_WINRT_DEVICEFAMILY_UNKNOWN, + + /** \brief Desktop family*/ + SDL_WINRT_DEVICEFAMILY_DESKTOP, + + /** \brief Mobile family (for example smartphone) */ + SDL_WINRT_DEVICEFAMILY_MOBILE, + + /** \brief XBox family */ + SDL_WINRT_DEVICEFAMILY_XBOX, +} SDL_WinRT_DeviceFamily; + + +/** + * \brief Retrieves a WinRT defined path on the local file system + * + * \note Documentation on most app-specific path types on WinRT + * can be found on MSDN, at the URL: + * http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx + * + * \param pathType The type of path to retrieve. + * \return A UCS-2 string (16-bit, wide-char) containing the path, or NULL + * if the path is not available for any reason. Not all paths are + * available on all versions of Windows. This is especially true on + * Windows Phone. Check the documentation for the given + * SDL_WinRT_Path for more information on which path types are + * supported where. + */ +extern DECLSPEC const wchar_t * SDLCALL SDL_WinRTGetFSPathUNICODE(SDL_WinRT_Path pathType); + +/** + * \brief Retrieves a WinRT defined path on the local file system + * + * \note Documentation on most app-specific path types on WinRT + * can be found on MSDN, at the URL: + * http://msdn.microsoft.com/en-us/library/windows/apps/hh464917.aspx + * + * \param pathType The type of path to retrieve. + * \return A UTF-8 string (8-bit, multi-byte) containing the path, or NULL + * if the path is not available for any reason. Not all paths are + * available on all versions of Windows. This is especially true on + * Windows Phone. Check the documentation for the given + * SDL_WinRT_Path for more information on which path types are + * supported where. + */ +extern DECLSPEC const char * SDLCALL SDL_WinRTGetFSPathUTF8(SDL_WinRT_Path pathType); + +/** + * \brief Detects the device family of WinRT plattform on runtime + * + * \return Device family + */ +extern DECLSPEC SDL_WinRT_DeviceFamily SDLCALL SDL_WinRTGetDeviceFamily(); + +#endif /* __WINRT__ */ + +/** + \brief Return true if the current device is a tablet. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_IsTablet(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_system_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_syswm.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_syswm.h new file mode 100644 index 0000000..7aa8c68 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_syswm.h @@ -0,0 +1,327 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_syswm.h + * + * Include file for SDL custom system window manager hooks. + */ + +#ifndef SDL_syswm_h_ +#define SDL_syswm_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" +#include "SDL_version.h" + +/** + * \brief SDL_syswm.h + * + * Your application has access to a special type of event ::SDL_SYSWMEVENT, + * which contains window-manager specific information and arrives whenever + * an unhandled window event occurs. This event is ignored by default, but + * you can enable it with SDL_EventState(). + */ +struct SDL_SysWMinfo; + +#if !defined(SDL_PROTOTYPES_ONLY) + +#if defined(SDL_VIDEO_DRIVER_WINDOWS) +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN +#endif +#include +#endif + +#if defined(SDL_VIDEO_DRIVER_WINRT) +#include +#endif + +/* This is the structure for custom window manager events */ +#if defined(SDL_VIDEO_DRIVER_X11) +#if defined(__APPLE__) && defined(__MACH__) +/* conflicts with Quickdraw.h */ +#define Cursor X11Cursor +#endif + +#include +#include + +#if defined(__APPLE__) && defined(__MACH__) +/* matches the re-define above */ +#undef Cursor +#endif + +#endif /* defined(SDL_VIDEO_DRIVER_X11) */ + +#if defined(SDL_VIDEO_DRIVER_DIRECTFB) +#include +#endif + +#if defined(SDL_VIDEO_DRIVER_COCOA) +#ifdef __OBJC__ +@class NSWindow; +#else +typedef struct _NSWindow NSWindow; +#endif +#endif + +#if defined(SDL_VIDEO_DRIVER_UIKIT) +#ifdef __OBJC__ +#include +#else +typedef struct _UIWindow UIWindow; +typedef struct _UIViewController UIViewController; +#endif +typedef Uint32 GLuint; +#endif + +#if defined(SDL_VIDEO_DRIVER_ANDROID) +typedef struct ANativeWindow ANativeWindow; +typedef void *EGLSurface; +#endif + +#if defined(SDL_VIDEO_DRIVER_VIVANTE) +#include "SDL_egl.h" +#endif +#endif /* SDL_PROTOTYPES_ONLY */ + + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +#if !defined(SDL_PROTOTYPES_ONLY) +/** + * These are the various supported windowing subsystems + */ +typedef enum +{ + SDL_SYSWM_UNKNOWN, + SDL_SYSWM_WINDOWS, + SDL_SYSWM_X11, + SDL_SYSWM_DIRECTFB, + SDL_SYSWM_COCOA, + SDL_SYSWM_UIKIT, + SDL_SYSWM_WAYLAND, + SDL_SYSWM_MIR, /* no longer available, left for API/ABI compatibility. Remove in 2.1! */ + SDL_SYSWM_WINRT, + SDL_SYSWM_ANDROID, + SDL_SYSWM_VIVANTE, + SDL_SYSWM_OS2 +} SDL_SYSWM_TYPE; + +/** + * The custom event structure. + */ +struct SDL_SysWMmsg +{ + SDL_version version; + SDL_SYSWM_TYPE subsystem; + union + { +#if defined(SDL_VIDEO_DRIVER_WINDOWS) + struct { + HWND hwnd; /**< The window for the message */ + UINT msg; /**< The type of message */ + WPARAM wParam; /**< WORD message parameter */ + LPARAM lParam; /**< LONG message parameter */ + } win; +#endif +#if defined(SDL_VIDEO_DRIVER_X11) + struct { + XEvent event; + } x11; +#endif +#if defined(SDL_VIDEO_DRIVER_DIRECTFB) + struct { + DFBEvent event; + } dfb; +#endif +#if defined(SDL_VIDEO_DRIVER_COCOA) + struct + { + /* Latest version of Xcode clang complains about empty structs in C v. C++: + error: empty struct has size 0 in C, size 1 in C++ + */ + int dummy; + /* No Cocoa window events yet */ + } cocoa; +#endif +#if defined(SDL_VIDEO_DRIVER_UIKIT) + struct + { + int dummy; + /* No UIKit window events yet */ + } uikit; +#endif +#if defined(SDL_VIDEO_DRIVER_VIVANTE) + struct + { + int dummy; + /* No Vivante window events yet */ + } vivante; +#endif + /* Can't have an empty union */ + int dummy; + } msg; +}; + +/** + * The custom window manager information structure. + * + * When this structure is returned, it holds information about which + * low level system it is using, and will be one of SDL_SYSWM_TYPE. + */ +struct SDL_SysWMinfo +{ + SDL_version version; + SDL_SYSWM_TYPE subsystem; + union + { +#if defined(SDL_VIDEO_DRIVER_WINDOWS) + struct + { + HWND window; /**< The window handle */ + HDC hdc; /**< The window device context */ + HINSTANCE hinstance; /**< The instance handle */ + } win; +#endif +#if defined(SDL_VIDEO_DRIVER_WINRT) + struct + { + IInspectable * window; /**< The WinRT CoreWindow */ + } winrt; +#endif +#if defined(SDL_VIDEO_DRIVER_X11) + struct + { + Display *display; /**< The X11 display */ + Window window; /**< The X11 window */ + } x11; +#endif +#if defined(SDL_VIDEO_DRIVER_DIRECTFB) + struct + { + IDirectFB *dfb; /**< The directfb main interface */ + IDirectFBWindow *window; /**< The directfb window handle */ + IDirectFBSurface *surface; /**< The directfb client surface */ + } dfb; +#endif +#if defined(SDL_VIDEO_DRIVER_COCOA) + struct + { +#if defined(__OBJC__) && defined(__has_feature) && __has_feature(objc_arc) + NSWindow __unsafe_unretained *window; /**< The Cocoa window */ +#else + NSWindow *window; /**< The Cocoa window */ +#endif + } cocoa; +#endif +#if defined(SDL_VIDEO_DRIVER_UIKIT) + struct + { +#if defined(__OBJC__) && defined(__has_feature) && __has_feature(objc_arc) + UIWindow __unsafe_unretained *window; /**< The UIKit window */ +#else + UIWindow *window; /**< The UIKit window */ +#endif + GLuint framebuffer; /**< The GL view's Framebuffer Object. It must be bound when rendering to the screen using GL. */ + GLuint colorbuffer; /**< The GL view's color Renderbuffer Object. It must be bound when SDL_GL_SwapWindow is called. */ + GLuint resolveFramebuffer; /**< The Framebuffer Object which holds the resolve color Renderbuffer, when MSAA is used. */ + } uikit; +#endif +#if defined(SDL_VIDEO_DRIVER_WAYLAND) + struct + { + struct wl_display *display; /**< Wayland display */ + struct wl_surface *surface; /**< Wayland surface */ + struct wl_shell_surface *shell_surface; /**< Wayland shell_surface (window manager handle) */ + } wl; +#endif +#if defined(SDL_VIDEO_DRIVER_MIR) /* no longer available, left for API/ABI compatibility. Remove in 2.1! */ + struct + { + void *connection; /**< Mir display server connection */ + void *surface; /**< Mir surface */ + } mir; +#endif + +#if defined(SDL_VIDEO_DRIVER_ANDROID) + struct + { + ANativeWindow *window; + EGLSurface surface; + } android; +#endif + +#if defined(SDL_VIDEO_DRIVER_VIVANTE) + struct + { + EGLNativeDisplayType display; + EGLNativeWindowType window; + } vivante; +#endif + + /* Make sure this union is always 64 bytes (8 64-bit pointers). */ + /* Be careful not to overflow this if you add a new target! */ + Uint8 dummy[64]; + } info; +}; + +#endif /* SDL_PROTOTYPES_ONLY */ + +typedef struct SDL_SysWMinfo SDL_SysWMinfo; + +/* Function prototypes */ +/** + * \brief This function allows access to driver-dependent window information. + * + * \param window The window about which information is being requested + * \param info This structure must be initialized with the SDL version, and is + * then filled in with information about the given window. + * + * \return SDL_TRUE if the function is implemented and the version member of + * the \c info struct is valid, SDL_FALSE otherwise. + * + * You typically use this function like this: + * \code + * SDL_SysWMinfo info; + * SDL_VERSION(&info.version); + * if ( SDL_GetWindowWMInfo(window, &info) ) { ... } + * \endcode + */ +extern DECLSPEC SDL_bool SDLCALL SDL_GetWindowWMInfo(SDL_Window * window, + SDL_SysWMinfo * info); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_syswm_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test.h new file mode 100644 index 0000000..17a33dc --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test.h @@ -0,0 +1,69 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +#ifndef SDL_test_h_ +#define SDL_test_h_ + +#include "SDL.h" +#include "SDL_test_assert.h" +#include "SDL_test_common.h" +#include "SDL_test_compare.h" +#include "SDL_test_crc32.h" +#include "SDL_test_font.h" +#include "SDL_test_fuzzer.h" +#include "SDL_test_harness.h" +#include "SDL_test_images.h" +#include "SDL_test_log.h" +#include "SDL_test_md5.h" +#include "SDL_test_memory.h" +#include "SDL_test_random.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* Global definitions */ + +/* + * Note: Maximum size of SDLTest log message is less than SDL's limit + * to ensure we can fit additional information such as the timestamp. + */ +#define SDLTEST_MAX_LOGMESSAGE_LENGTH 3584 + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_assert.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_assert.h new file mode 100644 index 0000000..b3ebb62 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_assert.h @@ -0,0 +1,105 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_assert.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + * + * Assert API for test code and test cases + * + */ + +#ifndef SDL_test_assert_h_ +#define SDL_test_assert_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Fails the assert. + */ +#define ASSERT_FAIL 0 + +/** + * \brief Passes the assert. + */ +#define ASSERT_PASS 1 + +/** + * \brief Assert that logs and break execution flow on failures. + * + * \param assertCondition Evaluated condition or variable to assert; fail (==0) or pass (!=0). + * \param assertDescription Message to log with the assert describing it. + */ +void SDLTest_Assert(int assertCondition, SDL_PRINTF_FORMAT_STRING const char *assertDescription, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Assert for test cases that logs but does not break execution flow on failures. Updates assertion counters. + * + * \param assertCondition Evaluated condition or variable to assert; fail (==0) or pass (!=0). + * \param assertDescription Message to log with the assert describing it. + * + * \returns Returns the assertCondition so it can be used to externally to break execution flow if desired. + */ +int SDLTest_AssertCheck(int assertCondition, SDL_PRINTF_FORMAT_STRING const char *assertDescription, ...) SDL_PRINTF_VARARG_FUNC(2); + +/** + * \brief Explicitly pass without checking an assertion condition. Updates assertion counter. + * + * \param assertDescription Message to log with the assert describing it. + */ +void SDLTest_AssertPass(SDL_PRINTF_FORMAT_STRING const char *assertDescription, ...) SDL_PRINTF_VARARG_FUNC(1); + +/** + * \brief Resets the assert summary counters to zero. + */ +void SDLTest_ResetAssertSummary(void); + +/** + * \brief Logs summary of all assertions (total, pass, fail) since last reset as INFO or ERROR. + */ +void SDLTest_LogAssertSummary(void); + + +/** + * \brief Converts the current assert summary state to a test result. + * + * \returns TEST_RESULT_PASSED, TEST_RESULT_FAILED, or TEST_RESULT_NO_ASSERT + */ +int SDLTest_AssertSummaryToTestResult(void); + +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_assert_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_common.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_common.h new file mode 100644 index 0000000..c34d0d1 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_common.h @@ -0,0 +1,205 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_common.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* Ported from original test\common.h file. */ + +#ifndef SDL_test_common_h_ +#define SDL_test_common_h_ + +#include "SDL.h" + +#if defined(__PSP__) +#define DEFAULT_WINDOW_WIDTH 480 +#define DEFAULT_WINDOW_HEIGHT 272 +#else +#define DEFAULT_WINDOW_WIDTH 640 +#define DEFAULT_WINDOW_HEIGHT 480 +#endif + +#define VERBOSE_VIDEO 0x00000001 +#define VERBOSE_MODES 0x00000002 +#define VERBOSE_RENDER 0x00000004 +#define VERBOSE_EVENT 0x00000008 +#define VERBOSE_AUDIO 0x00000010 + +typedef struct +{ + /* SDL init flags */ + char **argv; + Uint32 flags; + Uint32 verbose; + + /* Video info */ + const char *videodriver; + int display; + const char *window_title; + const char *window_icon; + Uint32 window_flags; + int window_x; + int window_y; + int window_w; + int window_h; + int window_minW; + int window_minH; + int window_maxW; + int window_maxH; + int logical_w; + int logical_h; + float scale; + int depth; + int refresh_rate; + int num_windows; + SDL_Window **windows; + + /* Renderer info */ + const char *renderdriver; + Uint32 render_flags; + SDL_bool skip_renderer; + SDL_Renderer **renderers; + SDL_Texture **targets; + + /* Audio info */ + const char *audiodriver; + SDL_AudioSpec audiospec; + + /* GL settings */ + int gl_red_size; + int gl_green_size; + int gl_blue_size; + int gl_alpha_size; + int gl_buffer_size; + int gl_depth_size; + int gl_stencil_size; + int gl_double_buffer; + int gl_accum_red_size; + int gl_accum_green_size; + int gl_accum_blue_size; + int gl_accum_alpha_size; + int gl_stereo; + int gl_multisamplebuffers; + int gl_multisamplesamples; + int gl_retained_backing; + int gl_accelerated; + int gl_major_version; + int gl_minor_version; + int gl_debug; + int gl_profile_mask; +} SDLTest_CommonState; + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* Function prototypes */ + +/** + * \brief Parse command line parameters and create common state. + * + * \param argv Array of command line parameters + * \param flags Flags indicating which subsystem to initialize (i.e. SDL_INIT_VIDEO | SDL_INIT_AUDIO) + * + * \returns Returns a newly allocated common state object. + */ +SDLTest_CommonState *SDLTest_CommonCreateState(char **argv, Uint32 flags); + +/** + * \brief Process one common argument. + * + * \param state The common state describing the test window to create. + * \param index The index of the argument to process in argv[]. + * + * \returns The number of arguments processed (i.e. 1 for --fullscreen, 2 for --video [videodriver], or -1 on error. + */ +int SDLTest_CommonArg(SDLTest_CommonState * state, int index); + + +/** + * \brief Logs command line usage info. + * + * This logs the appropriate command line options for the subsystems in use + * plus other common options, and then any application-specific options. + * This uses the SDL_Log() function and splits up output to be friendly to + * 80-character-wide terminals. + * + * \param state The common state describing the test window for the app. + * \param argv0 argv[0], as passed to main/SDL_main. + * \param options an array of strings for application specific options. The last element of the array should be NULL. + */ +void SDLTest_CommonLogUsage(SDLTest_CommonState * state, const char *argv0, const char **options); + +/** + * \brief Open test window. + * + * \param state The common state describing the test window to create. + * + * \returns True if initialization succeeded, false otherwise + */ +SDL_bool SDLTest_CommonInit(SDLTest_CommonState * state); + +/** + * \brief Easy argument handling when test app doesn't need any custom args. + * + * \param state The common state describing the test window to create. + * \param argc argc, as supplied to SDL_main + * \param argv argv, as supplied to SDL_main + * + * \returns False if app should quit, true otherwise. + */ +SDL_bool SDLTest_CommonDefaultArgs(SDLTest_CommonState * state, const int argc, char **argv); + +/** + * \brief Common event handler for test windows. + * + * \param state The common state used to create test window. + * \param event The event to handle. + * \param done Flag indicating we are done. + * + */ +void SDLTest_CommonEvent(SDLTest_CommonState * state, SDL_Event * event, int *done); + +/** + * \brief Close test window. + * + * \param state The common state used to create test window. + * + */ +void SDLTest_CommonQuit(SDLTest_CommonState * state); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_common_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_compare.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_compare.h new file mode 100644 index 0000000..1f751c8 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_compare.h @@ -0,0 +1,69 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_compare.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + + Defines comparison functions (i.e. for surfaces). + +*/ + +#ifndef SDL_test_compare_h_ +#define SDL_test_compare_h_ + +#include "SDL.h" + +#include "SDL_test_images.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Compares a surface and with reference image data for equality + * + * \param surface Surface used in comparison + * \param referenceSurface Test Surface used in comparison + * \param allowable_error Allowable difference (=sum of squared difference for each RGB component) in blending accuracy. + * + * \returns 0 if comparison succeeded, >0 (=number of pixels for which the comparison failed) if comparison failed, -1 if any of the surfaces were NULL, -2 if the surface sizes differ. + */ +int SDLTest_CompareSurfaces(SDL_Surface *surface, SDL_Surface *referenceSurface, int allowable_error); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_compare_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_crc32.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_crc32.h new file mode 100644 index 0000000..e615d89 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_crc32.h @@ -0,0 +1,124 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_crc32.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + + Implements CRC32 calculations (default output is Perl String::CRC32 compatible). + +*/ + +#ifndef SDL_test_crc32_h_ +#define SDL_test_crc32_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/* ------------ Definitions --------- */ + +/* Definition shared by all CRC routines */ + +#ifndef CrcUint32 + #define CrcUint32 unsigned int +#endif +#ifndef CrcUint8 + #define CrcUint8 unsigned char +#endif + +#ifdef ORIGINAL_METHOD + #define CRC32_POLY 0x04c11db7 /* AUTODIN II, Ethernet, & FDDI */ +#else + #define CRC32_POLY 0xEDB88320 /* Perl String::CRC32 compatible */ +#endif + +/** + * Data structure for CRC32 (checksum) computation + */ + typedef struct { + CrcUint32 crc32_table[256]; /* CRC table */ + } SDLTest_Crc32Context; + +/* ---------- Function Prototypes ------------- */ + +/** + * \brief Initialize the CRC context + * + * Note: The function initializes the crc table required for all crc calculations. + * + * \param crcContext pointer to context variable + * + * \returns 0 for OK, -1 on error + * + */ + int SDLTest_Crc32Init(SDLTest_Crc32Context * crcContext); + + +/** + * \brief calculate a crc32 from a data block + * + * \param crcContext pointer to context variable + * \param inBuf input buffer to checksum + * \param inLen length of input buffer + * \param crc32 pointer to Uint32 to store the final CRC into + * + * \returns 0 for OK, -1 on error + * + */ +int SDLTest_Crc32Calc(SDLTest_Crc32Context * crcContext, CrcUint8 *inBuf, CrcUint32 inLen, CrcUint32 *crc32); + +/* Same routine broken down into three steps */ +int SDLTest_Crc32CalcStart(SDLTest_Crc32Context * crcContext, CrcUint32 *crc32); +int SDLTest_Crc32CalcEnd(SDLTest_Crc32Context * crcContext, CrcUint32 *crc32); +int SDLTest_Crc32CalcBuffer(SDLTest_Crc32Context * crcContext, CrcUint8 *inBuf, CrcUint32 inLen, CrcUint32 *crc32); + + +/** + * \brief clean up CRC context + * + * \param crcContext pointer to context variable + * + * \returns 0 for OK, -1 on error + * +*/ + +int SDLTest_Crc32Done(SDLTest_Crc32Context * crcContext); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_crc32_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_font.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_font.h new file mode 100644 index 0000000..8fa0784 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_font.h @@ -0,0 +1,81 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_font.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +#ifndef SDL_test_font_h_ +#define SDL_test_font_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* Function prototypes */ + +#define FONT_CHARACTER_SIZE 8 + +/** + * \brief Draw a string in the currently set font. + * + * \param renderer The renderer to draw on. + * \param x The X coordinate of the upper left corner of the character. + * \param y The Y coordinate of the upper left corner of the character. + * \param c The character to draw. + * + * \returns Returns 0 on success, -1 on failure. + */ +int SDLTest_DrawCharacter(SDL_Renderer *renderer, int x, int y, char c); + +/** + * \brief Draw a string in the currently set font. + * + * \param renderer The renderer to draw on. + * \param x The X coordinate of the upper left corner of the string. + * \param y The Y coordinate of the upper left corner of the string. + * \param s The string to draw. + * + * \returns Returns 0 on success, -1 on failure. + */ +int SDLTest_DrawString(SDL_Renderer *renderer, int x, int y, const char *s); + + +/** + * \brief Cleanup textures used by font drawing functions. + */ +void SDLTest_CleanupTextDrawing(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_font_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_fuzzer.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_fuzzer.h new file mode 100644 index 0000000..7259685 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_fuzzer.h @@ -0,0 +1,384 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_fuzzer.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + + Data generators for fuzzing test data in a reproducible way. + +*/ + +#ifndef SDL_test_fuzzer_h_ +#define SDL_test_fuzzer_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/* + Based on GSOC code by Markus Kauppila +*/ + + +/** + * \file + * Note: The fuzzer implementation uses a static instance of random context + * internally which makes it thread-UNsafe. + */ + +/** + * Initializes the fuzzer for a test + * + * \param execKey Execution "Key" that initializes the random number generator uniquely for the test. + * + */ +void SDLTest_FuzzerInit(Uint64 execKey); + + +/** + * Returns a random Uint8 + * + * \returns Generated integer + */ +Uint8 SDLTest_RandomUint8(void); + +/** + * Returns a random Sint8 + * + * \returns Generated signed integer + */ +Sint8 SDLTest_RandomSint8(void); + + +/** + * Returns a random Uint16 + * + * \returns Generated integer + */ +Uint16 SDLTest_RandomUint16(void); + +/** + * Returns a random Sint16 + * + * \returns Generated signed integer + */ +Sint16 SDLTest_RandomSint16(void); + + +/** + * Returns a random integer + * + * \returns Generated integer + */ +Sint32 SDLTest_RandomSint32(void); + + +/** + * Returns a random positive integer + * + * \returns Generated integer + */ +Uint32 SDLTest_RandomUint32(void); + +/** + * Returns random Uint64. + * + * \returns Generated integer + */ +Uint64 SDLTest_RandomUint64(void); + + +/** + * Returns random Sint64. + * + * \returns Generated signed integer + */ +Sint64 SDLTest_RandomSint64(void); + +/** + * \returns random float in range [0.0 - 1.0[ + */ +float SDLTest_RandomUnitFloat(void); + +/** + * \returns random double in range [0.0 - 1.0[ + */ +double SDLTest_RandomUnitDouble(void); + +/** + * \returns random float. + * + */ +float SDLTest_RandomFloat(void); + +/** + * \returns random double. + * + */ +double SDLTest_RandomDouble(void); + +/** + * Returns a random boundary value for Uint8 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomUint8BoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 + * RandomUint8BoundaryValue(1, 20, SDL_FALSE) returns 0 or 21 + * RandomUint8BoundaryValue(0, 99, SDL_FALSE) returns 100 + * RandomUint8BoundaryValue(0, 255, SDL_FALSE) returns 0 (error set) + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or 0 with error set + */ +Uint8 SDLTest_RandomUint8BoundaryValue(Uint8 boundary1, Uint8 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Uint16 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomUint16BoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 + * RandomUint16BoundaryValue(1, 20, SDL_FALSE) returns 0 or 21 + * RandomUint16BoundaryValue(0, 99, SDL_FALSE) returns 100 + * RandomUint16BoundaryValue(0, 0xFFFF, SDL_FALSE) returns 0 (error set) + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or 0 with error set + */ +Uint16 SDLTest_RandomUint16BoundaryValue(Uint16 boundary1, Uint16 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Uint32 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomUint32BoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 + * RandomUint32BoundaryValue(1, 20, SDL_FALSE) returns 0 or 21 + * RandomUint32BoundaryValue(0, 99, SDL_FALSE) returns 100 + * RandomUint32BoundaryValue(0, 0xFFFFFFFF, SDL_FALSE) returns 0 (with error set) + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or 0 with error set + */ +Uint32 SDLTest_RandomUint32BoundaryValue(Uint32 boundary1, Uint32 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Uint64 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomUint64BoundaryValue(10, 20, SDL_TRUE) returns 10, 11, 19 or 20 + * RandomUint64BoundaryValue(1, 20, SDL_FALSE) returns 0 or 21 + * RandomUint64BoundaryValue(0, 99, SDL_FALSE) returns 100 + * RandomUint64BoundaryValue(0, 0xFFFFFFFFFFFFFFFF, SDL_FALSE) returns 0 (with error set) + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or 0 with error set + */ +Uint64 SDLTest_RandomUint64BoundaryValue(Uint64 boundary1, Uint64 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Sint8 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomSint8BoundaryValue(-10, 20, SDL_TRUE) returns -11, -10, 19 or 20 + * RandomSint8BoundaryValue(-100, -10, SDL_FALSE) returns -101 or -9 + * RandomSint8BoundaryValue(SINT8_MIN, 99, SDL_FALSE) returns 100 + * RandomSint8BoundaryValue(SINT8_MIN, SINT8_MAX, SDL_FALSE) returns SINT8_MIN (== error value) with error set + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or SINT8_MIN with error set + */ +Sint8 SDLTest_RandomSint8BoundaryValue(Sint8 boundary1, Sint8 boundary2, SDL_bool validDomain); + + +/** + * Returns a random boundary value for Sint16 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomSint16BoundaryValue(-10, 20, SDL_TRUE) returns -11, -10, 19 or 20 + * RandomSint16BoundaryValue(-100, -10, SDL_FALSE) returns -101 or -9 + * RandomSint16BoundaryValue(SINT16_MIN, 99, SDL_FALSE) returns 100 + * RandomSint16BoundaryValue(SINT16_MIN, SINT16_MAX, SDL_FALSE) returns SINT16_MIN (== error value) with error set + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or SINT16_MIN with error set + */ +Sint16 SDLTest_RandomSint16BoundaryValue(Sint16 boundary1, Sint16 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Sint32 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomSint32BoundaryValue(-10, 20, SDL_TRUE) returns -11, -10, 19 or 20 + * RandomSint32BoundaryValue(-100, -10, SDL_FALSE) returns -101 or -9 + * RandomSint32BoundaryValue(SINT32_MIN, 99, SDL_FALSE) returns 100 + * RandomSint32BoundaryValue(SINT32_MIN, SINT32_MAX, SDL_FALSE) returns SINT32_MIN (== error value) + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or SINT32_MIN with error set + */ +Sint32 SDLTest_RandomSint32BoundaryValue(Sint32 boundary1, Sint32 boundary2, SDL_bool validDomain); + +/** + * Returns a random boundary value for Sint64 within the given boundaries. + * Boundaries are inclusive, see the usage examples below. If validDomain + * is true, the function will only return valid boundaries, otherwise non-valid + * boundaries are also possible. + * If boundary1 > boundary2, the values are swapped + * + * Usage examples: + * RandomSint64BoundaryValue(-10, 20, SDL_TRUE) returns -11, -10, 19 or 20 + * RandomSint64BoundaryValue(-100, -10, SDL_FALSE) returns -101 or -9 + * RandomSint64BoundaryValue(SINT64_MIN, 99, SDL_FALSE) returns 100 + * RandomSint64BoundaryValue(SINT64_MIN, SINT64_MAX, SDL_FALSE) returns SINT64_MIN (== error value) and error set + * + * \param boundary1 Lower boundary limit + * \param boundary2 Upper boundary limit + * \param validDomain Should the generated boundary be valid (=within the bounds) or not? + * + * \returns Random boundary value for the given range and domain or SINT64_MIN with error set + */ +Sint64 SDLTest_RandomSint64BoundaryValue(Sint64 boundary1, Sint64 boundary2, SDL_bool validDomain); + + +/** + * Returns integer in range [min, max] (inclusive). + * Min and max values can be negative values. + * If Max in smaller than min, then the values are swapped. + * Min and max are the same value, that value will be returned. + * + * \param min Minimum inclusive value of returned random number + * \param max Maximum inclusive value of returned random number + * + * \returns Generated random integer in range + */ +Sint32 SDLTest_RandomIntegerInRange(Sint32 min, Sint32 max); + + +/** + * Generates random null-terminated string. The minimum length for + * the string is 1 character, maximum length for the string is 255 + * characters and it can contain ASCII characters from 32 to 126. + * + * Note: Returned string needs to be deallocated. + * + * \returns Newly allocated random string; or NULL if length was invalid or string could not be allocated. + */ +char * SDLTest_RandomAsciiString(void); + + +/** + * Generates random null-terminated string. The maximum length for + * the string is defined by the maxLength parameter. + * String can contain ASCII characters from 32 to 126. + * + * Note: Returned string needs to be deallocated. + * + * \param maxLength The maximum length of the generated string. + * + * \returns Newly allocated random string; or NULL if maxLength was invalid or string could not be allocated. + */ +char * SDLTest_RandomAsciiStringWithMaximumLength(int maxLength); + + +/** + * Generates random null-terminated string. The length for + * the string is defined by the size parameter. + * String can contain ASCII characters from 32 to 126. + * + * Note: Returned string needs to be deallocated. + * + * \param size The length of the generated string + * + * \returns Newly allocated random string; or NULL if size was invalid or string could not be allocated. + */ +char * SDLTest_RandomAsciiStringOfSize(int size); + +/** + * Returns the invocation count for the fuzzer since last ...FuzzerInit. + */ +int SDLTest_GetFuzzerInvocationCount(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_fuzzer_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_harness.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_harness.h new file mode 100644 index 0000000..f5ae92c --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_harness.h @@ -0,0 +1,134 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_harness.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + Defines types for test case definitions and the test execution harness API. + + Based on original GSOC code by Markus Kauppila +*/ + +#ifndef SDL_test_h_arness_h +#define SDL_test_h_arness_h + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/* ! Definitions for test case structures */ +#define TEST_ENABLED 1 +#define TEST_DISABLED 0 + +/* ! Definition of all the possible test return values of the test case method */ +#define TEST_ABORTED -1 +#define TEST_STARTED 0 +#define TEST_COMPLETED 1 +#define TEST_SKIPPED 2 + +/* ! Definition of all the possible test results for the harness */ +#define TEST_RESULT_PASSED 0 +#define TEST_RESULT_FAILED 1 +#define TEST_RESULT_NO_ASSERT 2 +#define TEST_RESULT_SKIPPED 3 +#define TEST_RESULT_SETUP_FAILURE 4 + +/* !< Function pointer to a test case setup function (run before every test) */ +typedef void (*SDLTest_TestCaseSetUpFp)(void *arg); + +/* !< Function pointer to a test case function */ +typedef int (*SDLTest_TestCaseFp)(void *arg); + +/* !< Function pointer to a test case teardown function (run after every test) */ +typedef void (*SDLTest_TestCaseTearDownFp)(void *arg); + +/** + * Holds information about a single test case. + */ +typedef struct SDLTest_TestCaseReference { + /* !< Func2Stress */ + SDLTest_TestCaseFp testCase; + /* !< Short name (or function name) "Func2Stress" */ + char *name; + /* !< Long name or full description "This test pushes func2() to the limit." */ + char *description; + /* !< Set to TEST_ENABLED or TEST_DISABLED (test won't be run) */ + int enabled; +} SDLTest_TestCaseReference; + +/** + * Holds information about a test suite (multiple test cases). + */ +typedef struct SDLTest_TestSuiteReference { + /* !< "PlatformSuite" */ + char *name; + /* !< The function that is run before each test. NULL skips. */ + SDLTest_TestCaseSetUpFp testSetUp; + /* !< The test cases that are run as part of the suite. Last item should be NULL. */ + const SDLTest_TestCaseReference **testCases; + /* !< The function that is run after each test. NULL skips. */ + SDLTest_TestCaseTearDownFp testTearDown; +} SDLTest_TestSuiteReference; + + +/** + * \brief Generates a random run seed string for the harness. The generated seed will contain alphanumeric characters (0-9A-Z). + * + * Note: The returned string needs to be deallocated by the caller. + * + * \param length The length of the seed string to generate + * + * \returns The generated seed string + */ +char *SDLTest_GenerateRunSeed(const int length); + +/** + * \brief Execute a test suite using the given run seed and execution key. + * + * \param testSuites Suites containing the test case. + * \param userRunSeed Custom run seed provided by user, or NULL to autogenerate one. + * \param userExecKey Custom execution key provided by user, or 0 to autogenerate one. + * \param filter Filter specification. NULL disables. Case sensitive. + * \param testIterations Number of iterations to run each test case. + * + * \returns Test run result; 0 when all tests passed, 1 if any tests failed. + */ +int SDLTest_RunSuites(SDLTest_TestSuiteReference *testSuites[], const char *userRunSeed, Uint64 userExecKey, const char *filter, int testIterations); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_h_arness_h */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_images.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_images.h new file mode 100644 index 0000000..b893481 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_images.h @@ -0,0 +1,78 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_images.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + + Defines some images for tests. + +*/ + +#ifndef SDL_test_images_h_ +#define SDL_test_images_h_ + +#include "SDL.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + *Type for test images. + */ +typedef struct SDLTest_SurfaceImage_s { + int width; + int height; + unsigned int bytes_per_pixel; /* 3:RGB, 4:RGBA */ + const char *pixel_data; +} SDLTest_SurfaceImage_t; + +/* Test images */ +SDL_Surface *SDLTest_ImageBlit(void); +SDL_Surface *SDLTest_ImageBlitColor(void); +SDL_Surface *SDLTest_ImageBlitAlpha(void); +SDL_Surface *SDLTest_ImageBlitBlendAdd(void); +SDL_Surface *SDLTest_ImageBlitBlend(void); +SDL_Surface *SDLTest_ImageBlitBlendMod(void); +SDL_Surface *SDLTest_ImageBlitBlendNone(void); +SDL_Surface *SDLTest_ImageBlitBlendAll(void); +SDL_Surface *SDLTest_ImageFace(void); +SDL_Surface *SDLTest_ImagePrimitives(void); +SDL_Surface *SDLTest_ImagePrimitivesBlend(void); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_images_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_log.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_log.h new file mode 100644 index 0000000..01d0fed --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_log.h @@ -0,0 +1,67 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_log.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + * + * Wrapper to log in the TEST category + * + */ + +#ifndef SDL_test_log_h_ +#define SDL_test_log_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Prints given message with a timestamp in the TEST category and INFO priority. + * + * \param fmt Message to be logged + */ +void SDLTest_Log(SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(1); + +/** + * \brief Prints given message with a timestamp in the TEST category and the ERROR priority. + * + * \param fmt Message to be logged + */ +void SDLTest_LogError(SDL_PRINTF_FORMAT_STRING const char *fmt, ...) SDL_PRINTF_VARARG_FUNC(1); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_log_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_md5.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_md5.h new file mode 100644 index 0000000..2bfd7df --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_md5.h @@ -0,0 +1,129 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_md5.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + *********************************************************************** + ** Header file for implementation of MD5 ** + ** RSA Data Security, Inc. MD5 Message-Digest Algorithm ** + ** Created: 2/17/90 RLR ** + ** Revised: 12/27/90 SRD,AJ,BSK,JT Reference C version ** + ** Revised (for MD5): RLR 4/27/91 ** + ** -- G modified to have y&~z instead of y&z ** + ** -- FF, GG, HH modified to add in last register done ** + ** -- Access pattern: round 2 works mod 5, round 3 works mod 3 ** + ** -- distinct additive constant for each step ** + ** -- round 4 added, working mod 7 ** + *********************************************************************** +*/ + +/* + *********************************************************************** + ** Message-digest routines: ** + ** To form the message digest for a message M ** + ** (1) Initialize a context buffer mdContext using MD5Init ** + ** (2) Call MD5Update on mdContext and M ** + ** (3) Call MD5Final on mdContext ** + ** The message digest is now in mdContext->digest[0...15] ** + *********************************************************************** +*/ + +#ifndef SDL_test_md5_h_ +#define SDL_test_md5_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* ------------ Definitions --------- */ + +/* typedef a 32-bit type */ + typedef unsigned long int MD5UINT4; + +/* Data structure for MD5 (Message-Digest) computation */ + typedef struct { + MD5UINT4 i[2]; /* number of _bits_ handled mod 2^64 */ + MD5UINT4 buf[4]; /* scratch buffer */ + unsigned char in[64]; /* input buffer */ + unsigned char digest[16]; /* actual digest after Md5Final call */ + } SDLTest_Md5Context; + +/* ---------- Function Prototypes ------------- */ + +/** + * \brief initialize the context + * + * \param mdContext pointer to context variable + * + * Note: The function initializes the message-digest context + * mdContext. Call before each new use of the context - + * all fields are set to zero. + */ + void SDLTest_Md5Init(SDLTest_Md5Context * mdContext); + + +/** + * \brief update digest from variable length data + * + * \param mdContext pointer to context variable + * \param inBuf pointer to data array/string + * \param inLen length of data array/string + * + * Note: The function updates the message-digest context to account + * for the presence of each of the characters inBuf[0..inLen-1] + * in the message whose digest is being computed. +*/ + + void SDLTest_Md5Update(SDLTest_Md5Context * mdContext, unsigned char *inBuf, + unsigned int inLen); + + +/** + * \brief complete digest computation + * + * \param mdContext pointer to context variable + * + * Note: The function terminates the message-digest computation and + * ends with the desired message digest in mdContext.digest[0..15]. + * Always call before using the digest[] variable. +*/ + + void SDLTest_Md5Final(SDLTest_Md5Context * mdContext); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_md5_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_memory.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_memory.h new file mode 100644 index 0000000..5d4d39e --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_memory.h @@ -0,0 +1,63 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_memory.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +#ifndef SDL_test_memory_h_ +#define SDL_test_memory_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + + +/** + * \brief Start tracking SDL memory allocations + * + * \note This should be called before any other SDL functions for complete tracking coverage + */ +int SDLTest_TrackAllocations(void); + +/** + * \brief Print a log of any outstanding allocations + * + * \note This can be called after SDL_Quit() + */ +void SDLTest_LogAllocations(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_memory_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_random.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_random.h new file mode 100644 index 0000000..71e9c70 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_test_random.h @@ -0,0 +1,115 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_test_random.h + * + * Include file for SDL test framework. + * + * This code is a part of the SDL2_test library, not the main SDL library. + */ + +/* + + A "32-bit Multiply with carry random number generator. Very fast. + Includes a list of recommended multipliers. + + multiply-with-carry generator: x(n) = a*x(n-1) + carry mod 2^32. + period: (a*2^31)-1 + +*/ + +#ifndef SDL_test_random_h_ +#define SDL_test_random_h_ + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* --- Definitions */ + +/* + * Macros that return a random number in a specific format. + */ +#define SDLTest_RandomInt(c) ((int)SDLTest_Random(c)) + +/* + * Context structure for the random number generator state. + */ + typedef struct { + unsigned int a; + unsigned int x; + unsigned int c; + unsigned int ah; + unsigned int al; + } SDLTest_RandomContext; + + +/* --- Function prototypes */ + +/** + * \brief Initialize random number generator with two integers. + * + * Note: The random sequence of numbers returned by ...Random() is the + * same for the same two integers and has a period of 2^31. + * + * \param rndContext pointer to context structure + * \param xi integer that defines the random sequence + * \param ci integer that defines the random sequence + * + */ + void SDLTest_RandomInit(SDLTest_RandomContext * rndContext, unsigned int xi, + unsigned int ci); + +/** + * \brief Initialize random number generator based on current system time. + * + * \param rndContext pointer to context structure + * + */ + void SDLTest_RandomInitTime(SDLTest_RandomContext *rndContext); + + +/** + * \brief Initialize random number generator based on current system time. + * + * Note: ...RandomInit() or ...RandomInitTime() must have been called + * before using this function. + * + * \param rndContext pointer to context structure + * + * \returns A random number (32bit unsigned integer) + * + */ + unsigned int SDLTest_Random(SDLTest_RandomContext *rndContext); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_test_random_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_thread.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_thread.h new file mode 100644 index 0000000..f78b114 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_thread.h @@ -0,0 +1,343 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_thread_h_ +#define SDL_thread_h_ + +/** + * \file SDL_thread.h + * + * Header for the SDL thread management routines. + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +/* Thread synchronization primitives */ +#include "SDL_atomic.h" +#include "SDL_mutex.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/* The SDL thread structure, defined in SDL_thread.c */ +struct SDL_Thread; +typedef struct SDL_Thread SDL_Thread; + +/* The SDL thread ID */ +typedef unsigned long SDL_threadID; + +/* Thread local storage ID, 0 is the invalid ID */ +typedef unsigned int SDL_TLSID; + +/** + * The SDL thread priority. + * + * \note On many systems you require special privileges to set high or time critical priority. + */ +typedef enum { + SDL_THREAD_PRIORITY_LOW, + SDL_THREAD_PRIORITY_NORMAL, + SDL_THREAD_PRIORITY_HIGH, + SDL_THREAD_PRIORITY_TIME_CRITICAL +} SDL_ThreadPriority; + +/** + * The function passed to SDL_CreateThread(). + * It is passed a void* user context parameter and returns an int. + */ +typedef int (SDLCALL * SDL_ThreadFunction) (void *data); + +#if defined(__WIN32__) && !defined(HAVE_LIBC) +/** + * \file SDL_thread.h + * + * We compile SDL into a DLL. This means, that it's the DLL which + * creates a new thread for the calling process with the SDL_CreateThread() + * API. There is a problem with this, that only the RTL of the SDL2.DLL will + * be initialized for those threads, and not the RTL of the calling + * application! + * + * To solve this, we make a little hack here. + * + * We'll always use the caller's _beginthread() and _endthread() APIs to + * start a new thread. This way, if it's the SDL2.DLL which uses this API, + * then the RTL of SDL2.DLL will be used to create the new thread, and if it's + * the application, then the RTL of the application will be used. + * + * So, in short: + * Always use the _beginthread() and _endthread() of the calling runtime + * library! + */ +#define SDL_PASSED_BEGINTHREAD_ENDTHREAD +#include /* _beginthreadex() and _endthreadex() */ + +typedef uintptr_t(__cdecl * pfnSDL_CurrentBeginThread) + (void *, unsigned, unsigned (__stdcall *func)(void *), + void * /*arg*/, unsigned, unsigned * /* threadID */); +typedef void (__cdecl * pfnSDL_CurrentEndThread) (unsigned code); + +/** + * Create a thread. + */ +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThread(SDL_ThreadFunction fn, const char *name, void *data, + pfnSDL_CurrentBeginThread pfnBeginThread, + pfnSDL_CurrentEndThread pfnEndThread); + +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThreadWithStackSize(int (SDLCALL * fn) (void *), + const char *name, const size_t stacksize, void *data, + pfnSDL_CurrentBeginThread pfnBeginThread, + pfnSDL_CurrentEndThread pfnEndThread); + + +/** + * Create a thread. + */ +#if defined(SDL_CreateThread) && SDL_DYNAMIC_API +#undef SDL_CreateThread +#define SDL_CreateThread(fn, name, data) SDL_CreateThread_REAL(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthreadex, (pfnSDL_CurrentEndThread)_endthreadex) +#undef SDL_CreateThreadWithStackSize +#define SDL_CreateThreadWithStackSize(fn, name, stacksize, data) SDL_CreateThreadWithStackSize_REAL(fn, name, stacksize, data, (pfnSDL_CurrentBeginThread)_beginthreadex, (pfnSDL_CurrentEndThread)_endthreadex) +#else +#define SDL_CreateThread(fn, name, data) SDL_CreateThread(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthreadex, (pfnSDL_CurrentEndThread)_endthreadex) +#define SDL_CreateThreadWithStackSize(fn, name, stacksize, data) SDL_CreateThreadWithStackSize(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthreadex, (pfnSDL_CurrentEndThread)_endthreadex) +#endif + +#elif defined(__OS2__) +/* + * just like the windows case above: We compile SDL2 + * into a dll with Watcom's runtime statically linked. + */ +#define SDL_PASSED_BEGINTHREAD_ENDTHREAD +#ifndef __EMX__ +#include +#else +#include +#endif +typedef int (*pfnSDL_CurrentBeginThread)(void (*func)(void *), void *, unsigned, void * /*arg*/); +typedef void (*pfnSDL_CurrentEndThread)(void); +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThread(SDL_ThreadFunction fn, const char *name, void *data, + pfnSDL_CurrentBeginThread pfnBeginThread, + pfnSDL_CurrentEndThread pfnEndThread); +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThreadWithStackSize(SDL_ThreadFunction fn, const char *name, const size_t stacksize, void *data, + pfnSDL_CurrentBeginThread pfnBeginThread, + pfnSDL_CurrentEndThread pfnEndThread); +#if defined(SDL_CreateThread) && SDL_DYNAMIC_API +#undef SDL_CreateThread +#define SDL_CreateThread(fn, name, data) SDL_CreateThread_REAL(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthread, (pfnSDL_CurrentEndThread)_endthread) +#undef SDL_CreateThreadWithStackSize +#define SDL_CreateThreadWithStackSize(fn, name, stacksize, data) SDL_CreateThreadWithStackSize_REAL(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthread, (pfnSDL_CurrentEndThread)_endthread) +#else +#define SDL_CreateThread(fn, name, data) SDL_CreateThread(fn, name, data, (pfnSDL_CurrentBeginThread)_beginthread, (pfnSDL_CurrentEndThread)_endthread) +#define SDL_CreateThreadWithStackSize(fn, name, stacksize, data) SDL_CreateThreadWithStackSize(fn, name, stacksize, data, (pfnSDL_CurrentBeginThread)_beginthread, (pfnSDL_CurrentEndThread)_endthread) +#endif + +#else + +/** + * Create a thread with a default stack size. + * + * This is equivalent to calling: + * SDL_CreateThreadWithStackSize(fn, name, 0, data); + */ +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThread(SDL_ThreadFunction fn, const char *name, void *data); + +/** + * Create a thread. + * + * Thread naming is a little complicated: Most systems have very small + * limits for the string length (Haiku has 32 bytes, Linux currently has 16, + * Visual C++ 6.0 has nine!), and possibly other arbitrary rules. You'll + * have to see what happens with your system's debugger. The name should be + * UTF-8 (but using the naming limits of C identifiers is a better bet). + * There are no requirements for thread naming conventions, so long as the + * string is null-terminated UTF-8, but these guidelines are helpful in + * choosing a name: + * + * http://stackoverflow.com/questions/149932/naming-conventions-for-threads + * + * If a system imposes requirements, SDL will try to munge the string for + * it (truncate, etc), but the original string contents will be available + * from SDL_GetThreadName(). + * + * The size (in bytes) of the new stack can be specified. Zero means "use + * the system default" which might be wildly different between platforms + * (x86 Linux generally defaults to eight megabytes, an embedded device + * might be a few kilobytes instead). + * + * In SDL 2.1, stacksize will be folded into the original SDL_CreateThread + * function. + */ +extern DECLSPEC SDL_Thread *SDLCALL +SDL_CreateThreadWithStackSize(SDL_ThreadFunction fn, const char *name, const size_t stacksize, void *data); + +#endif + +/** + * Get the thread name, as it was specified in SDL_CreateThread(). + * This function returns a pointer to a UTF-8 string that names the + * specified thread, or NULL if it doesn't have a name. This is internal + * memory, not to be free()'d by the caller, and remains valid until the + * specified thread is cleaned up by SDL_WaitThread(). + */ +extern DECLSPEC const char *SDLCALL SDL_GetThreadName(SDL_Thread *thread); + +/** + * Get the thread identifier for the current thread. + */ +extern DECLSPEC SDL_threadID SDLCALL SDL_ThreadID(void); + +/** + * Get the thread identifier for the specified thread. + * + * Equivalent to SDL_ThreadID() if the specified thread is NULL. + */ +extern DECLSPEC SDL_threadID SDLCALL SDL_GetThreadID(SDL_Thread * thread); + +/** + * Set the priority for the current thread + */ +extern DECLSPEC int SDLCALL SDL_SetThreadPriority(SDL_ThreadPriority priority); + +/** + * Wait for a thread to finish. Threads that haven't been detached will + * remain (as a "zombie") until this function cleans them up. Not doing so + * is a resource leak. + * + * Once a thread has been cleaned up through this function, the SDL_Thread + * that references it becomes invalid and should not be referenced again. + * As such, only one thread may call SDL_WaitThread() on another. + * + * The return code for the thread function is placed in the area + * pointed to by \c status, if \c status is not NULL. + * + * You may not wait on a thread that has been used in a call to + * SDL_DetachThread(). Use either that function or this one, but not + * both, or behavior is undefined. + * + * It is safe to pass NULL to this function; it is a no-op. + */ +extern DECLSPEC void SDLCALL SDL_WaitThread(SDL_Thread * thread, int *status); + +/** + * A thread may be "detached" to signify that it should not remain until + * another thread has called SDL_WaitThread() on it. Detaching a thread + * is useful for long-running threads that nothing needs to synchronize + * with or further manage. When a detached thread is done, it simply + * goes away. + * + * There is no way to recover the return code of a detached thread. If you + * need this, don't detach the thread and instead use SDL_WaitThread(). + * + * Once a thread is detached, you should usually assume the SDL_Thread isn't + * safe to reference again, as it will become invalid immediately upon + * the detached thread's exit, instead of remaining until someone has called + * SDL_WaitThread() to finally clean it up. As such, don't detach the same + * thread more than once. + * + * If a thread has already exited when passed to SDL_DetachThread(), it will + * stop waiting for a call to SDL_WaitThread() and clean up immediately. + * It is not safe to detach a thread that might be used with SDL_WaitThread(). + * + * You may not call SDL_WaitThread() on a thread that has been detached. + * Use either that function or this one, but not both, or behavior is + * undefined. + * + * It is safe to pass NULL to this function; it is a no-op. + */ +extern DECLSPEC void SDLCALL SDL_DetachThread(SDL_Thread * thread); + +/** + * \brief Create an identifier that is globally visible to all threads but refers to data that is thread-specific. + * + * \return The newly created thread local storage identifier, or 0 on error + * + * \code + * static SDL_SpinLock tls_lock; + * static SDL_TLSID thread_local_storage; + * + * void SetMyThreadData(void *value) + * { + * if (!thread_local_storage) { + * SDL_AtomicLock(&tls_lock); + * if (!thread_local_storage) { + * thread_local_storage = SDL_TLSCreate(); + * } + * SDL_AtomicUnlock(&tls_lock); + * } + * SDL_TLSSet(thread_local_storage, value, 0); + * } + * + * void *GetMyThreadData(void) + * { + * return SDL_TLSGet(thread_local_storage); + * } + * \endcode + * + * \sa SDL_TLSGet() + * \sa SDL_TLSSet() + */ +extern DECLSPEC SDL_TLSID SDLCALL SDL_TLSCreate(void); + +/** + * \brief Get the value associated with a thread local storage ID for the current thread. + * + * \param id The thread local storage ID + * + * \return The value associated with the ID for the current thread, or NULL if no value has been set. + * + * \sa SDL_TLSCreate() + * \sa SDL_TLSSet() + */ +extern DECLSPEC void * SDLCALL SDL_TLSGet(SDL_TLSID id); + +/** + * \brief Set the value associated with a thread local storage ID for the current thread. + * + * \param id The thread local storage ID + * \param value The value to associate with the ID for the current thread + * \param destructor A function called when the thread exits, to free the value. + * + * \return 0 on success, -1 on error + * + * \sa SDL_TLSCreate() + * \sa SDL_TLSGet() + */ +extern DECLSPEC int SDLCALL SDL_TLSSet(SDL_TLSID id, const void *value, void (SDLCALL *destructor)(void*)); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_thread_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_timer.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_timer.h new file mode 100644 index 0000000..2a47b04 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_timer.h @@ -0,0 +1,115 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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 SDL_timer_h_ +#define SDL_timer_h_ + +/** + * \file SDL_timer.h + * + * Header for the SDL time management routines. + */ + +#include "SDL_stdinc.h" +#include "SDL_error.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Get the number of milliseconds since the SDL library initialization. + * + * \note This value wraps if the program runs for more than ~49 days. + */ +extern DECLSPEC Uint32 SDLCALL SDL_GetTicks(void); + +/** + * \brief Compare SDL ticks values, and return true if A has passed B + * + * e.g. if you want to wait 100 ms, you could do this: + * Uint32 timeout = SDL_GetTicks() + 100; + * while (!SDL_TICKS_PASSED(SDL_GetTicks(), timeout)) { + * ... do work until timeout has elapsed + * } + */ +#define SDL_TICKS_PASSED(A, B) ((Sint32)((B) - (A)) <= 0) + +/** + * \brief Get the current value of the high resolution counter + */ +extern DECLSPEC Uint64 SDLCALL SDL_GetPerformanceCounter(void); + +/** + * \brief Get the count per second of the high resolution counter + */ +extern DECLSPEC Uint64 SDLCALL SDL_GetPerformanceFrequency(void); + +/** + * \brief Wait a specified number of milliseconds before returning. + */ +extern DECLSPEC void SDLCALL SDL_Delay(Uint32 ms); + +/** + * Function prototype for the timer callback function. + * + * The callback function is passed the current timer interval and returns + * the next timer interval. If the returned value is the same as the one + * passed in, the periodic alarm continues, otherwise a new alarm is + * scheduled. If the callback returns 0, the periodic alarm is cancelled. + */ +typedef Uint32 (SDLCALL * SDL_TimerCallback) (Uint32 interval, void *param); + +/** + * Definition of the timer ID type. + */ +typedef int SDL_TimerID; + +/** + * \brief Add a new timer to the pool of timers already running. + * + * \return A timer ID, or 0 when an error occurs. + */ +extern DECLSPEC SDL_TimerID SDLCALL SDL_AddTimer(Uint32 interval, + SDL_TimerCallback callback, + void *param); + +/** + * \brief Remove a timer knowing its ID. + * + * \return A boolean value indicating success or failure. + * + * \warning It is not safe to remove a timer multiple times. + */ +extern DECLSPEC SDL_bool SDLCALL SDL_RemoveTimer(SDL_TimerID id); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_timer_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_touch.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_touch.h new file mode 100644 index 0000000..99dbcb8 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_touch.h @@ -0,0 +1,102 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_touch.h + * + * Include file for SDL touch event handling. + */ + +#ifndef SDL_touch_h_ +#define SDL_touch_h_ + +#include "SDL_stdinc.h" +#include "SDL_error.h" +#include "SDL_video.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +typedef Sint64 SDL_TouchID; +typedef Sint64 SDL_FingerID; + +typedef enum +{ + SDL_TOUCH_DEVICE_INVALID = -1, + SDL_TOUCH_DEVICE_DIRECT, /* touch screen with window-relative coordinates */ + SDL_TOUCH_DEVICE_INDIRECT_ABSOLUTE, /* trackpad with absolute device coordinates */ + SDL_TOUCH_DEVICE_INDIRECT_RELATIVE /* trackpad with screen cursor-relative coordinates */ +} SDL_TouchDeviceType; + +typedef struct SDL_Finger +{ + SDL_FingerID id; + float x; + float y; + float pressure; +} SDL_Finger; + +/* Used as the device ID for mouse events simulated with touch input */ +#define SDL_TOUCH_MOUSEID ((Uint32)-1) + +/* Used as the SDL_TouchID for touch events simulated with mouse input */ +#define SDL_MOUSE_TOUCHID ((Sint64)-1) + + +/* Function prototypes */ + +/** + * \brief Get the number of registered touch devices. + */ +extern DECLSPEC int SDLCALL SDL_GetNumTouchDevices(void); + +/** + * \brief Get the touch ID with the given index, or 0 if the index is invalid. + */ +extern DECLSPEC SDL_TouchID SDLCALL SDL_GetTouchDevice(int index); + +/** + * \brief Get the type of the given touch device. + */ +extern DECLSPEC SDL_TouchDeviceType SDLCALL SDL_GetTouchDeviceType(SDL_TouchID touchID); + +/** + * \brief Get the number of active fingers for a given touch device. + */ +extern DECLSPEC int SDLCALL SDL_GetNumTouchFingers(SDL_TouchID touchID); + +/** + * \brief Get the finger object of the given touch, with the given index. + */ +extern DECLSPEC SDL_Finger * SDLCALL SDL_GetTouchFinger(SDL_TouchID touchID, int index); + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_touch_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_types.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_types.h new file mode 100644 index 0000000..9c3e989 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_types.h @@ -0,0 +1,29 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_types.h + * + * \deprecated + */ + +/* DEPRECATED */ +#include "SDL_stdinc.h" diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_version.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_version.h new file mode 100644 index 0000000..6c7499d --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_version.h @@ -0,0 +1,162 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_version.h + * + * This header defines the current SDL version. + */ + +#ifndef SDL_version_h_ +#define SDL_version_h_ + +#include "SDL_stdinc.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief Information the version of SDL in use. + * + * Represents the library's version as three levels: major revision + * (increments with massive changes, additions, and enhancements), + * minor revision (increments with backwards-compatible changes to the + * major revision), and patchlevel (increments with fixes to the minor + * revision). + * + * \sa SDL_VERSION + * \sa SDL_GetVersion + */ +typedef struct SDL_version +{ + Uint8 major; /**< major version */ + Uint8 minor; /**< minor version */ + Uint8 patch; /**< update version */ +} SDL_version; + +/* Printable format: "%d.%d.%d", MAJOR, MINOR, PATCHLEVEL +*/ +#define SDL_MAJOR_VERSION 2 +#define SDL_MINOR_VERSION 0 +#define SDL_PATCHLEVEL 10 + +/** + * \brief Macro to determine SDL version program was compiled against. + * + * This macro fills in a SDL_version structure with the version of the + * library you compiled against. This is determined by what header the + * compiler uses. Note that if you dynamically linked the library, you might + * have a slightly newer or older version at runtime. That version can be + * determined with SDL_GetVersion(), which, unlike SDL_VERSION(), + * is not a macro. + * + * \param x A pointer to a SDL_version struct to initialize. + * + * \sa SDL_version + * \sa SDL_GetVersion + */ +#define SDL_VERSION(x) \ +{ \ + (x)->major = SDL_MAJOR_VERSION; \ + (x)->minor = SDL_MINOR_VERSION; \ + (x)->patch = SDL_PATCHLEVEL; \ +} + +/** + * This macro turns the version numbers into a numeric value: + * \verbatim + (1,2,3) -> (1203) + \endverbatim + * + * This assumes that there will never be more than 100 patchlevels. + */ +#define SDL_VERSIONNUM(X, Y, Z) \ + ((X)*1000 + (Y)*100 + (Z)) + +/** + * This is the version number macro for the current SDL version. + */ +#define SDL_COMPILEDVERSION \ + SDL_VERSIONNUM(SDL_MAJOR_VERSION, SDL_MINOR_VERSION, SDL_PATCHLEVEL) + +/** + * This macro will evaluate to true if compiled with SDL at least X.Y.Z. + */ +#define SDL_VERSION_ATLEAST(X, Y, Z) \ + (SDL_COMPILEDVERSION >= SDL_VERSIONNUM(X, Y, Z)) + +/** + * \brief Get the version of SDL that is linked against your program. + * + * If you are linking to SDL dynamically, then it is possible that the + * current version will be different than the version you compiled against. + * This function returns the current version, while SDL_VERSION() is a + * macro that tells you what version you compiled with. + * + * \code + * SDL_version compiled; + * SDL_version linked; + * + * SDL_VERSION(&compiled); + * SDL_GetVersion(&linked); + * printf("We compiled against SDL version %d.%d.%d ...\n", + * compiled.major, compiled.minor, compiled.patch); + * printf("But we linked against SDL version %d.%d.%d.\n", + * linked.major, linked.minor, linked.patch); + * \endcode + * + * This function may be called safely at any time, even before SDL_Init(). + * + * \sa SDL_VERSION + */ +extern DECLSPEC void SDLCALL SDL_GetVersion(SDL_version * ver); + +/** + * \brief Get the code revision of SDL that is linked against your program. + * + * Returns an arbitrary string (a hash value) uniquely identifying the + * exact revision of the SDL library in use, and is only useful in comparing + * against other revisions. It is NOT an incrementing number. + */ +extern DECLSPEC const char *SDLCALL SDL_GetRevision(void); + +/** + * \brief Get the revision number of SDL that is linked against your program. + * + * Returns a number uniquely identifying the exact revision of the SDL + * library in use. It is an incrementing number based on commits to + * hg.libsdl.org. + */ +extern DECLSPEC int SDLCALL SDL_GetRevisionNumber(void); + + +/* Ends C function definitions when using C++ */ +#ifdef __cplusplus +} +#endif +#include "close_code.h" + +#endif /* SDL_version_h_ */ + +/* vi: set ts=4 sw=4 expandtab: */ diff --git a/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_video.h b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_video.h new file mode 100644 index 0000000..352afd4 --- /dev/null +++ b/vendor/lite/winlib/SDL2-2.0.10/i686-w64-mingw32/include/SDL2/SDL_video.h @@ -0,0 +1,1276 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2019 Sam Lantinga + + 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. +*/ + +/** + * \file SDL_video.h + * + * Header file for SDL video functions. + */ + +#ifndef SDL_video_h_ +#define SDL_video_h_ + +#include "SDL_stdinc.h" +#include "SDL_pixels.h" +#include "SDL_rect.h" +#include "SDL_surface.h" + +#include "begin_code.h" +/* Set up for C function definitions, even when using C++ */ +#ifdef __cplusplus +extern "C" { +#endif + +/** + * \brief The structure that defines a display mode + * + * \sa SDL_GetNumDisplayModes() + * \sa SDL_GetDisplayMode() + * \sa SDL_GetDesktopDisplayMode() + * \sa SDL_GetCurrentDisplayMode() + * \sa SDL_GetClosestDisplayMode() + * \sa SDL_SetWindowDisplayMode() + * \sa SDL_GetWindowDisplayMode() + */ +typedef struct +{ + Uint32 format; /**< pixel format */ + int w; /**< width, in screen coordinates */ + int h; /**< height, in screen coordinates */ + int refresh_rate; /**< refresh rate (or zero for unspecified) */ + void *driverdata; /**< driver-specific data, initialize to 0 */ +} SDL_DisplayMode; + +/** + * \brief The type used to identify a window + * + * \sa SDL_CreateWindow() + * \sa SDL_CreateWindowFrom() + * \sa SDL_DestroyWindow() + * \sa SDL_GetWindowData() + * \sa SDL_GetWindowFlags() + * \sa SDL_GetWindowGrab() + * \sa SDL_GetWindowPosition() + * \sa SDL_GetWindowSize() + * \sa SDL_GetWindowTitle() + * \sa SDL_HideWindow() + * \sa SDL_MaximizeWindow() + * \sa SDL_MinimizeWindow() + * \sa SDL_RaiseWindow() + * \sa SDL_RestoreWindow() + * \sa SDL_SetWindowData() + * \sa SDL_SetWindowFullscreen() + * \sa SDL_SetWindowGrab() + * \sa SDL_SetWindowIcon() + * \sa SDL_SetWindowPosition() + * \sa SDL_SetWindowSize() + * \sa SDL_SetWindowBordered() + * \sa SDL_SetWindowResizable() + * \sa SDL_SetWindowTitle() + * \sa SDL_ShowWindow() + */ +typedef struct SDL_Window SDL_Window; + +/** + * \brief The flags on a window + * + * \sa SDL_GetWindowFlags() + */ +typedef enum +{ + /* !!! FIXME: change this to name = (1<3Y&4(hAZYq(6aj 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

BVJUobuwd7iYY<+KX$wIP|4= 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 Ha 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%0D%s`xv*R%1g9RBKrkMC5&IBe+ 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

Tv^W7Akenj*a@ujCh-Kq~D^gcy5xFR|^ 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Ø}%m;!(wL8erMNVt7|Pxg(Sevqi-yE~#KK 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%0Agjf`)hc* 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 P)J4BUAAP5-^+TOp()7uY&R$z`V;q;{FnTtJO!e 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�Iml~tD%n5sa2!t)C&{lZ6k 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

B_K1x`^-i!lv-Lbf|U< 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

Clr%-x4P%W>9U<=6WagO%* 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

RyQ_QE~{Q#x6W63d1bw?rttEH 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/x~ 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%0Df_yFPn{VOk&xeyYu$ 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%0DAcK-sg%?N1;w8$HEKAY zsH6h`8Wmz1PBRSL05#vSiMpjEeW{|m9aLVjjV^m5d8x+q7AVvv$-iJqx z>5~dI{Z5cQ!HL=GI9#)wc?f*0z0Dp+PN{Dy__LKwZe_m&r}k_&kIT1bzdn}Mz@m-q zvaf+q^K+<>zSm2x=)sXMpAe+Qi`luLAUk&fC6H$CG%JJt;_4z3v5HA{0=cs5zsXJ) zD%`2yWRY8P96uIf@a!87|7Z@sE0Th2FPHS!b9mdI9^mj_r7yKqVvI*Ii49DM<`Zf+2c|Q8_|oakF%2P8TnE3LWNyzJ&NMlnxq{?E_7L z`88GK*G1_=pvxQxdb={47;ceALt)Kms>#qMh z^lMZ-z9{_A~C3@eu3`$-JVC!&cx_EbI4^DQ!-5&>d}F@iBH3K#p#0(lQ}A;n(GpFK|(%ZPG7UUHF@zd+|3ZVO~c8KtYZ$UzgnnU*8iK~vNoHO1%;xkUoSE+WcAC8eD0mlO$6K?~=Afd#fOrxZqH*wL z2uTK)!wb)D0hsLFpwuqBhr&u!tX+7<1=@h<7&x)3vq5C-FPK-qbe=Ya?I;No(_vC7 z*s1))w0R2>%pbRG_?$W1tiVSX5iT|or_HoAd5juUyG0}aKG~d98n&j)oV6(-qwM^W zZ%kWLM)don`5(Y!?a#2+jc{;XYN(ca5APcU0{}bpygFre*pH+&$N*y&FXv;CAiO4J z#;YqqH3Kv6C7v_>O8Bz)ja=bZsSXnQ5JY#2@B;|@LpXMAh-N>fdg_7-winFoirsI0 z9tmaVX#*cgI>%&UZH6S=`_uEbyq)XShKc%$)F{vG+^q?u*) zG@O`RKcOI~SxnGLR-m5?**8zxw35A*DTNY$sgKebpeo4xks!&;$y4)}{hqms7PFsq z42lGu{EF$QAX`9$<6jPff5$}{ZL+WRuFVp)ya(4S7OtpK%=l`tbRF97X#VHq1IS^k&8`3xXiai5Ffw?LnOKa;&iZDHQ=pO zyREPo@ed;C4-&5sJL%!+bBXWj#6RQ3)30YvjEVeeFgpPH85p90g-P~T|0XW+UJp*h}u=KKBSfc%de?m2c^^B zNGDaW>(J*KATy58Tm^HzYBgq2Em0Ud5tN^qbow_h!mG-4AAI)!jS6W~u?C>vAmU%= ziC>5CHK5*yxQaE|Rjg^*3@oZxr@&&$)%wZC7VD=4nMT5L70cvT-C-zYE0*byzJ?+h z=+_wPx>Wip3V8O3F;U#t22e8ZuLR72$bV*1q%9 zTDy%phw6-B|DuM^>{4Mk6JfUfUzai?-tjCw{3>O4A+hA}tCaavD>znS^6$lTf+z{9B_ZOg9(E3>9>wr$uy$IhPsX1So&^nm)UAV0!$Q|$`i zH??NK0KV`9>V2rGIrG6Z0hzJz_&R7`Y}xV467YNl!LKp(IjM9t5;G@*$eYKN$pd3Z zYqR(YeB`c2w}#VXySYl%Ue8m9(h|Jt6Wo+b@WD^gjf739;cFM7&H9w>dyY<-+cnwD zW(_jO8ss99b0J_1vL3m~K)>|pLAWf{uFEUVAa_CYJD}c&8iPCu<_RF9Rd8<*Q$?-7 zN|rrRTu_NIC2)1B{V`tPKVW-Z0)40v_$3&4@G8t9hO=i%q zvFj13@`oTbCAZU_jBJ5=A8PEn7nuG)W*R(kyJoYXRB>KMglS#!!??_9!fYoxF+aln z1IR?6Uy})krP4iKL-Zpcw#$UyfK-2*g+juU%bqlCh7o73#~)P${vE$nccen=sO>ppCT6NSik>PRzJPbLaVE_|i6OmULp-OkG>c z^{@M^NvF)$cxph5%t9;kaEv$((C0Np7PXegQ-zwlKt}}@*@o*MU|s=6FI7b?wxq}I z#hM;4W=`|sWqhlqD|2Bfv7s*#qFo2$=I|-SJcga6sdkrkRB@QhF^xJHKPzX^TXLbDYKGVvJW;D4AFw*SD2Pha;4Tjsp3AQxOy4ri4YtH zRL|#OIi4lJg7d#;Ne$C9oB{SyFuww7+I3-a1f%HM25*gUQhCQt5j5Gk*uQU75KM1>d5(TWw=d`XwneQ&~;H?OZmy)-kVhbm`>dB#PZb zF`>3Z`Iglc0#33@nj%y|);GZvwy2mNY_j@4$xd1TC+kiB*#rsO75Fv9{ikHQ6w*vH zh_FAzLnyE`I9oWy6CoTK_gUmIZ*3-#B zD(0Ip`R{@KO~d|la-!OZ&ik_d42+`)NszgKAPApLx@LaDSly`{KIfmCvUd}M+QUDg zeQs=JRx}z^x3k|8{t0IPP~mn;Ych~_Q%eY=IP)xpM6@$#(@NN5l5PbrQ*^UotbPqt z!ZY_fyriX*(}c^_$&t1OM2zD4xQCLVI<5^A{6)}*Ez;R$%tOgtUB=ixZgX<5Yc3Bq zwd~>KKDN&*vVGj6Ni&<9ikS`vOl}6`5DE3U`FJw@8d_({Vi{+<=%e322gUxC(xnLr zXH$m_=4k577lh@rUpZ~8f+1~&Gi2F5iP3zYY}2_BhVxC^bJ80=-zO)BD&M!D^B)15 z?~Tcf65G5V1s2%fq;z!=71b9nPJJy|I= zW`Jr0hVA|~V=5It^INBEJR#Y6J_)RzNYKU5{0gYq7n<>4jp5y_vg)$Z)H?F-WwTe&L8tn;A{TlU)O3)7f3g=tK(#ulEGEj(jw;kgYx zZ&aEz{8)>eg!wg1!6C_X7vyEsNas~sM?@gcj3I4P;PvIZ|Kr*5xxKzat-fnIczs_- zzAgMi+vq#AjlKt2eG~h$y6N@R-q3{EA!_s;mP|i^yi7q%HK*?v(B>1-Mqk^;sOfUG zw4YV9vOTZvmC-GAZ&4;q^Vu)iRkgGcMH+zpKh$uvU(y_F^D_|Iy>07nzvReReci(* zp%sEFfFUYI#}Y#rY*ZZkBzL{}O;?1TCj3dD=1#&d0BefSG7|S9h#eOpBX29g$>2%J z+b`MkJ1_4OWc^F>cJ9F5hN!#)LF`zbDH1aXP6YZjCf+ld9)Kk>3qa(pX-!=9U*Z-r zGbt7txAkEw7Dmd2-@ww#6^sgh61{9=3r4S`KLy&dkNF;9*yQR0aH)5!pET+{F);4K_cA%f94|)ZR<(qr5G|^J)C}=jqdc? zk}%_^t>wJBHG0i_&$mQd5<9CUx&j?80S3>VyM(OXlGw+6*E{%Fhd9_GI3e93##uy} zP0wF#dLBT=CZ8UCgqAR$qM7u(m`LwNyqR-is@p12Qw6e?P-TpkwCL9CFt&m<6b{58 zST7SZD`U(%On0L>q-KQ9`u9!4{RwmFK`jQj(ilJ^aN88$pXeh4yn)iM1C#A^;r>Ks zeP>$1>LBvd46=h(;C4koO9x7Jk+Lf zBYdZuH2(Tur14C74^8ZEyQ*O9mrCQ|i7pQ!EV=&H)3Pr?ua%TvLhbayaW5_sMPq}^ zUf5ZAkkj@^w{~jdpSND$tJmL8%)=TVhjQU9HL3TC))jo6*{B zVK;1o;+3ydttF$M<1t?bT}GQdrbg(vMGO3@?K7ciw1YXUR4Z3nI)6g*G}p$e+jD~O znQ#}?)n~}Y$AK{`7tH0p^6dykIR5zI=rkS z(Iw1pS}A`iEdD1csTW#^sV&eF z;R?cjkMxZ|cJF!YK%!{uO0cpZoxHOU0ohvc`++~e;yJYRaFQHkCp-GXbM*a%&#Z9t z%H4EwoN#Q1(P?Izj2img8&tSwqIkCM2Y44mXnwm2JtR?LQhPmexNeBww9s7>#ZMDc zy+=e+`&(#iY7OH9JSGDDGB63k4vFIQ$1r+Cgz@PdV_i=yHjGqe2jCftrw=?b122(l zgSu+4lfl-F#M2~CJ)UMU9FJ!;p2?0uePZ?$kUs~xz#{dvS&+Q}q{`PX9c4PX91F`% zCis4Wbs*w~T<~0FK+Ox_H#!_OwCY4Vl$S9mK$(QicL!KU?kIP`sxz0tvr zm?I*5(|ez-KH>4I;Eh~WvtaoGuB_mIDnlHEcRPX!a~5)gi5c{6aHy?BH)41YZV0<* zOYevg^7fT?JPVB1ggw*(jXydFueIL5>|u(XROfDJ3&Qila7&8gU`;w!Z)4bTPm&~^ z7w)Ax`YN^JuYi3cb6!|$&-qA=Hd~4>2z!V_XAPu)A^N&wE5htwxGpT4L~!+sp!XrX zKT!QA9%kV=LJxoB;c7gW0gd9C`X-pEpYqczVFN)8@*>`a=uL4+MDc;t3BZWR;28uo zioQW2F5&4Mph2QO!m|}<{*i}TNOnPF!+&@fb`TPPy5rN7FM5g0GUrhNF>gUKdw|h- zhAN}!}PQGDuUTZi;J!Wp8~2E^052C*coUPS;N_2rt>rvFmnlQ<0&+odCDZ_fWq{Zh{+5C z-M0J5_M>1c2kwR8cvIoSPYz|3C~Ux%;gbj?+e1>w%R3-Sj-{tc+pEey>j?Rl&`%mT)6_om*6gq_us zUkv5~VASjV>}K57FX$=EjUyFd@BKz-oOAhU*?$xI5oS4#P)zF%1he}_e;`a<>1j61 zY(C3$@6RS~kRoDB(m(~uxSv`hX|!mI%zufx+lS>I?>zpfnVEX>l}f3tC3=LJv)vNwOfl^ zh);`cHxOnQ+b?uBINy=k;VP}mD2)`dH@e_k+XkC~L{>YKWWlG}2AeTS-3tU8HHTqT zmC27B9n1Gd{5bGxk3x!p$sNjgrV(Ux2t0EvCU1bk=58kJ?sHd#BpaIhxF4q|JOE@i zQ<5t%4dU$fj+w{8ej)5*xE*Zq96mB;I5;EhqJH(iaC{Hco!E!o20LcvqjEHI)5z?M z%plkUIbkX+8%PZ?jm&@yZ3|!;nd9-y1{y_X8kswIx(zUm%p&B5fqs1>lR!-7L=gGP zx=ztBgdsW=mhMm}8Lp|%oJX$biCrU8cLmg@alZwR*>1isiRpm}W;y=U`ioC9=ku_~ zDRV1Cd=FPMsCVFa5opkP-HkPD2L~F?5PdVzPc z4>{ETQaCeBhPRaV zTth02RiCIOD}Y9Y7(KW0^iRO(*%x_XpkGsW&@&5XW>74eb+9rzA6&${XF{!>bB&$} zM|hmYqo>g+(<3Ip=&tRG821#UR3h%ra5QuU@pUbe0ib3rA@?{r+!eN~;?dwNa|Ho@ zY(^tWftU=2V5TfR&oE@`o9W1|mI;;xU*=@6-?e5Fqy-dYOP<^{$UY0EifX!x#oE5< z?;tg|5t)hO1daCBkcSKAV|b#b%RmdR3AUnrrj*_3i7nw!4H%ZqaGJQStAF$tuOgsZe&_)7v zbCGA}0W0yumW}L(J7B5u$O-vQXcV%l?gS;(f~rRETdX0#=H1wf0Xl5C{Xe8!Gacoz z<}T#%63vMinYWqm1axC{keew}GYZWI%zWn>JeTW1fZ*rWWS|=) zCxMHZ$mZ)8pp$`qO};WKS_M<)ClL88v_&p^x~qgfOKri=4oI6J`kqY|pnF@%f)4BreqN9aKk zPsMXGVE6UB1S1C%q)_wA!t@?QJL7FoR=vnsP>LXrbUN#cmUa94rO;QTv%YD$1nD}b z+?i#^EDy4y}5SZn%yRpn`T)RgTX3SO=(o*YnRQ)scH{O+5}ab z5hCAE#bYe2vb{%tL!h1|-oF6T72ZVnp@cKnwV|IAqO;MnO9;_U z=6wmt?Y3d~R`Ux2YJ~Lt&}|^vra@OMMZVfG?Z=(aal>62ZB8sopM{93M?u*%O!B_P zIxKDrPfbSc_odiHpgNCX)B_k%m2@|WV4XyrUzC1Mq6UJpqJDCshIRoZEnSnW557cY z1=ofM*2i84BDBg2USkB`B*A>>wFfj+>vDo;Ip5Hgcp`$ezg$#HjmF)`tE$)KiOThoyD1J8MktO=biKfJS`Sd$ty%8|q zIi>0#0!;Vy4NQqZzoz>0ozqO1GkPN@$tc5+$5sEwppx24p|ENPnQh?mgsvtv-xdUw zLpdPcXmex|^XRD1eni?ESfV3F)qCiaPyb1Q)z zZs2X34fL;?+%8!EbzW5pmCT#qikNOLgGXOazf0G=#$<3|8f)m&wZ3CnECbA!YD@6U z2bx8!DbW)$nm%{?1K2x7CZ5;uyaZHrrz`k52-hy~#G&o5g?zX6Ijl2u_P@1Kq$Ph7 zE%HdGo^D0h2sNWw+RFn`Z^>?;s0}mj1FbSl`Bh_Lzv&1T>p-;41PwGC3&o)?FW|_0 z1ll)>h6Qu$v!=zm2q75l*Um2&&y|*EMt9IQ7IO!};?po%DEGV=I(uQk5{YbjM z1%hSov<5+KogaKJ(<_!WxyQw;ucBFkZi!)ER6tC+nhx#Egs0aylmJW-+XfxeBz{d1 zW5Tl^^ch9fwusd{0CG5?DnX`c%|7GEjM{wJ|#0Ww87W0vhrR#b1Gr7Bj&bml#q`QZIbR@DLC{y$>~0i)t_ffy|fi_^E}N*#y&1KzjWV z_6yGs5Yw;}#B7LX0d;c-F@yNyoyVn*QXv;L6B&SF)JkW{c)GB%eKFYz)OKqmtI8W~+GiZe5IB%`jGH0k@Ex(#^Di8c4) zxd=HbQc7jbiy*FxAnNvXsi~{NBc8fihsoaNJTF@MKmxKWiCJd&Fp4}6q%LMokz>Xz zcDscl&NG+}VO1Yc zGF?#hDH7z%{)9&ZuAlj+myuT~=yaOF(UPH(e3?RR8^eZCkkMlcmg^O8El8|PT!~V$ zUT=KwMV%Xf2EF;+e>|6s1GCjO91Stj`DNr9gxyQi=DdbmKv3DGaj(+im7G&*lC}u8 zV}VA6nDk{^pp^RiLnF)hgKi!Luheiwjy0rG^CU=fHp44;l$yB;H6OtRnf+$O6B9Jw ziGmd+jDw+SxQmA?i2E|2Zs<`q@9L&_&#~TfqVw>IlSoFeTv6A6=P-Gu;5iacRtcVu z=RKz#U07{U_XjWIdGGno3tMa~i-zrGrj`L%Hvf{i>M#P#+vUY`DLdO{`u2V$WTx?~ zm?eAa*A#p%3~nYU(*s1?3RG7D(%kR6SQiFY@?<-YN4>CGP>DdlMi`d`Z<4SHAhr{B z5J)Rbx3zDcjoC~BZYZNsd=M0k;*zI~Ywxibc(jD;*9ia3PU$X?W`==iD}1^{))G*O z$R?<&C2%A8b1P6Ssn6qi4#-T7@xM#KS4B=IXVDQ;7e7TYiC>MBNGY1t8@9x<;1Y|@ zotvrm2JBQKFt;quh;^BE3T$b%+hJIEDmfR^E#y#`gtBZ>1t}f~N-545H#PMT+?BKV zIc;h)zf*svpNsT!3qQ@0a8oG@*YH-0=i~A0MF6TLXut#-YoJjiO%jz{zu~k7iJJ|2 z2GAg>=i@nD50d^do;UTNSjHbpKM6D_wyW@53=Gl2(7c7phApLNzIVGlUoIzpEe^d) z_&)$ss7_z3W<|ec*f3;;=wawG=YwdQRhe^<2M)t~Zk0iIt1jb=Yv#d$LEb*DA-#Pbm7dw@wQg>x2}QY%>< z+m)E2_Y+}X0H#nj9nSk$z$E8asFDoy3w;n$#J^K=t^$!a(K;y?WY-~B$o8lgNzSaH z5HoP@XVJVYz3#Lia|g(1fuy0Dih0e^UV3Y}R87wYJg4HBWro5z&-;s3On_BFjWiaVWgeQ z<+FH92l_R+yscgF8!%_qIVzi(HkWI51NoU%-;Gxr!DvOQ5P>2!L%PfvF=l)I&2o)* zwh}PHBt#mR(Q2pVDw6s&@oTJ8$wS_LHtt~6@HCA8kRH%;RZWtS4X|7HvQ@W}6hZHO z%T_-{Gbu>zoTyyI{5ue&hxc4Pnc1yi_s3JcSJMjwg49*vuB(U15J1O7a@W;AKq4r} zhLx-D!6PV`5cXVMjz^GsgNGq73sNs2;3nb|q|WEzc$5;P-Vb}OQi22>R+O!p427V> zN#(23G_->DXZ2eBLW(&nkXitDS3H8$W*+LH5R^O>_FDZXq860Q412HoEmjbet?jq! zB4i56F6p)UW8xB&T@dzLRgWA&pJDx0?EPz53s1CrCYtO@57hL24bMzQzQC)bT{}F<3$B zRUWQKj$ro(Q~g%|n%D%X53$w(q(abdxAIjRkt*naT+dZ+LoMjrt8CT2q)yObY1yjh zkT2MyU)kyn&JPzXAo4u1zI1fBOx_FVln2^Vz!H!PJ%6?DF;=c*MT1)U$-W7T|E1)bORT=fq) z1)X2+x#|aK1)V?dzj_OC9dIIwa+CSNQRVmgJw12qgs*{LS(Egg9t1pFC(7rupJ{|4~aG+DGuQRB|-!-}1$mVJWK(kv+Yfqucbj;PorNERJbdT{B1rFu-e$FzMc zXa~LUg&o6WQE4fJgoGf9%7f%i_HkUtp`~<_ASB3e3Q^J##ISB8pko;2EDOVN9VMcC zH#FD}%AHbSwp8(0Jrve%514xpRv`^Y=#Yq-HQgk(LqD>lqr;n6EuJNMSTQo&f0H{! zW9~xYayoOZc`ls9D^f0c%G*Lo=;j!lak{%Sn@5H3lCz4F(4%wMzne{6&$O{`FPC^n zu&YsyoU4qa*_m`V47QU})_Z4bFvr8|x4c?Zf5jnn`|gGT`lU!@TkG{Vv6NHhItTp` zIKZSdozFeq`$aMfb@s|pxJdVQX|>r2#Xck?B4J-iR>{~eDvBx>%_toiJ80jqrkjtf zf4BBwhl1L!myIwf*gqY~ki^dSjG&0pczNn^9VK8$&u~!3iQ&B?(v3S$D?K7T)#O#x zIcG372`?GZZ4gRSr-MNqoqz*Mp;t7#^o598!1!w|)QPU^Mpu`yg-azCkqUm6Vv_Z6mKVsTmPXG+XsCVx*vsDkTve3M6uL zG{hx%OtcO-Tpe0q9%(l=#zKn5#pppC5=}E>^JqBdw?#)eZWTV%rt%^g^ssm` zMWSzVcaZIu+H9}4>0zidB%f^);|xAq9LuC!F8D$~=NmPeOLt>w*hnFo5?9FQS6-ULng_>cl;tJ(V=_2&3oU!!OWDJ43W>tr94VCH<~Fnd9F^)i-y=F&EGdyrECteyD&;Mu4CiQxe9P>JXx`@ z1xml{dt977roi#}*lbZ?!Y?i*W})Mwk?|#Ikt=Nm#oE%ouJ+~>T4L%p_Bvr-?3Ig( zNkyJivX|w9O-?V*2fISFLKr30J@cw+P{$rLlZ-;tcP!e;)H*a_V@C`{D@a>w|2C|k zrw0a0SiR=KW+>QUImoEw{eRhkw5=8qM4cqgl0R3!|x430Wsvm zM>8-6V#r%SC?JNkQZ_fS5Dh54ZMb{Pw*Eo52Ri=<+(Vq-a{1q_tp5yf-23AmTgz4WRhe;%;*OM{!?qe$S8yJT_w5C^DBbQDiP>3U|aFMdsL}$Q--ZLhcqw z2T!$H%RK}@r%52i@poz?+*Pw?v!bkGb&O3F@#x3_2QlfkVA6rG~TIlBrK9| z2`>bVG60Kdt#ZczkjXjMc&A*1BfUl8nTU_{O#&h!8Sd(jceL(Tz8yglN`b=U^0%#? zaY2KPB#S%C`Q^R=u#UNw*zN+Phup`2R8aE68Lje_PqHE1ahEv1+|vQ5ZeG(WpFsR_ ze`P~%TGJ|@Kp}FkwIPGcTICZcMDFix$n^47`2-4)`?w7`vbVCpT#4HL4kumieMWly!#J-vwA_DNbUvnY z$l$9@CQ}Oh-&_YD_KD*)aLeHR)+Q59b=|RpLLhUazuQP0~Yxn&*K>ue);5Yc9X^?qu|y z;`J8VYb}37=bg{U>8y~5#$C=Z8t*OQF^cJn!|W20H{~_J?>7d-O1kt_i{`i{|4N@JHO|XE8YT2 zpA!9xmL^xH)GS^M&2>gTtp@Hph9++;waRNIU;+TmTVZZ}AAh?;^UsRQ{{2Wu2_X?f zDd1`+0JM0203sBMLgF6)h~kfmqAx;5*(l7j6|dhxU~9IIVv`eqT=5Q!Qz#0Ff6Yem zlA@Ri$(aCAn&*5J&0tTB3sB(mP5@De_xSB8f?#tU!~C%}Tjt;%@BGVf&vyQNM7%|S zzCCzk%IR)NR!2#;jiyx`V?~~fd$03*8l_EteZXt86}`8dYDXq_l|_sDe(SX?B4#r4 zKPeKyF9^Rq&c<^6j*!ewP<8{LV)Lo^eiC|Ex+%CpHuvLs% z=MN%(6$i5h$NI1ox*PWe=Z}!cONX!$UOo%gu~XUnpYD(s1sU&AEVPjW-GB&E>9&`pD=-YE z?2og^dN0Mf(t5p&w&auY<4|Bl6|3xkB2F2?bisB6RNmupG1*Ed>(0#=Db!G0W&i@wfznot; z?p9a@0$rlJr}M{UOX?GrBPB^imMSHVJ)A$vA^LkPeUa#$)HWLHBHkYW=_*&J0ApT0 z@d|odZ&arBi$?@9nA}c=aFU$P4lTErMa$XUq2sb5a*Fa1HYi@l&_-Fyu4{O|1f;U= z$DQfa*LAq7onJTNu62Ihrn}MkbwTc5oIkFNq#kWUQj&C&^NZt2=Z|uTev-u(iQY-w zp~jX^m+khjdZ*-`2+;D#ITNS|+FV-OD(nT8NY45l5((R4iR9?=-0dX^dxs^GbI%Tm zqN$7frTK2~VDTckR`ZE5&7)WAMl_!o(>z9$*L-43^B7TH^NBIdV?=RnqfgR&FROW( zT&sCQO!Mdkz!A+GVw%T@@|riqG>;MGHE)P%9wUnCD!=sYXZ5X+dm2EqDJNG(Dhk$D z6u1kEjlRmxHf^h9ZQYytxR0$Tx|jE3=l>j+6@F8HbocJr&M%(-^(T2Ft&Ei1DF72@ zId>ZG6rBh9hV{yM2S`&%3wE#7?Z1jwO@`d>06JGWg+z}SIXfHg6gfiy5lg{o&d&lKTMwy_^~F zkbpKlw-}DG3`KGmTLw9fA=*&;iA>O$@ZAjQR5`jISA*XbxThQR6gj&3R_KtZb%r%o zkR!p71tg`hayQm&0a>^a_ZH`mre8OC-VKOG?qdKwaFpa)P@4_9{?QyoeUw7?V%|F5 z3ekOx`%SR^D2?@t@m%Ta33} z&eIkvXN$$Yfb*usda6!%{9P26R2JCow_U{%mzP?t`7?GXlDI<^Y+4QlNatmsq_!3!sKcM6tQ zMDfB&^|tgrIc>ztmby5uE&0>nl>ne~+doDgv44y_V)Fk{0c8EHw)A(Bt9t?y z!HOQ2w#t{a0di*N0_0n21LT~U3y{y6B~oW8C!```>T6BfB9pd6K&=K@Xc9Cf zpM)uS6>{Vu#QGDlHO-WK(x&7SGbOKOjyGX$+O$^4A*l;kpbb(g=}$52umpJHQZ&2` zBBNs3He^b#2-0hA^YLmVlSy)(HQoj}9|A?PJ~w!GZ}s`XI`0ll8yXE&62wJBdGaZF z@?1K@;CGO{X-IR~W78>qSzU|JGK8!szt490O=SGUIf&IW;Pv#8M2qd+HX;wDm_$WJ zX`B?1#H75^ix*U8(vwRNnFg}LAae^m8((JvRB$kxukAfQ&D;TnkY0$e>k^Bt!|Hb6f7GIHBLW-n*GARDZq~kRnC@A%> z<0?(^%a!#E(PTVQz&vH+_JQO%>Ju`M3&#vY&qX>9mO1rurCskdMSa`*>); zeKbDEOOLu6QT`qv9n@cxx+o>@CZLOqyp*eoF`_eZtHKrbG|+WNnP4as`W(>h|Dc$7 zQA)we$^VO_;i8mJ#s475r6RY8^)FZc7+Zp5i4h8JM zM!utLfSftTTQBEvi_MF(J_%i5gie$rCOaIE?>xgZQI6PcfR|tggmhgUb&9Z-_Dv(Z z%rvh;ybSOPA}FBgwOC&-Ho7M0I-LgyJ=l0%W`_7 zo3)30_nUTos+uufH-IQPeR2Wv?Pmh&3J<}+nA&_gP1(W6luDf5ua}%LMf&5PbqCaPRRHhLY2q>rC2dne}vFS zYw=no%y{5`)gUYMx(>Xy0%Agi*aXCd3UeRuzl2K9%Jy6@0FbMJ?hsoBkNnX;(R^WP zQV|+jl<41VD1HNA{%df)v0l+jC>ByG-8S0Hm}@?o;_7c?Tm`L2?fR9GAQ^U69%u2HV^8zS;dH$(+{;3i((C|;mi<&BlR;644^^*_Y z=)iKOiM@U;&iMeRadm2yN7f)6ir{wZ%}cHKN_kOvL5&h*c^mV*jd|W&FG#K7Pn;2Q zYl|I`r&7LXiAAxX-T%_simK1YoYUIgfaVhJlM+SdbX4x$!HnWwz;%U7O;;$ygMhDJ z7MqtvQ7vbk3<}j7UAU!t%-YtWZs3Lh3_8Z(9BsW(DY|5<1rVq1!TN{ux23t<;!_bC zZ!Soe6M8lf8|hdPx?iXfz?gDo0*snACYIn?+i%8_w0+D2?#z~59e(_Rt>5TjlJ&jkIDmEG$Y4xu4%J~)$huk_7!K5g& zF7BxTh*x*=EVte$1@A#pyjf36%zAxP8eHrAx{c#W=l2{^dKtKz0GbCmx3?jI0;;VD z4NVAd^l`-`Jtb84BD6_mgoFL;Pa-47<)1yLfA%UlHzI+~P*ENR;FY6fk-U^#X#(1d zYtwUnh294k>Vd7IzSsGEY^tW7#%to~{BxAn`^8geW0oWRq>x-ihZd4@v-Qf6exi^o zB_etzy-=r1)Xp6Y=_EOO8*if=8^t6=p>sA^p~{QRwLlT6!4EF`C~#8IO0Ac(pW&Y* z$4af2)Eg}}FEv&Q8KV%sgEEt+&vhBnPB5u}VIY7{_nGVpsLaS60D#t=D8n5(ult4Y zTn2Px0ij@7ML{p_gghbW)q7bHt2TKu6GylewFX1%b8b9-MeLuy#;@4@vtm}X{`vos zN7eA6@OmkDy#TyX-X!rz4^oxqi$lV=4iky1mZB!gR z5GV?{1B~!`If~Xtf22XTDSnb(VZ=;%3dgce^{j2o#$hXvUk#vuoZF3eiWIP%xfEH; z(W_y*w*e_3_j3Sd*|EmTnTuN19Fbm}Z?~aX3P3Dp1yB^MEGt;mqo7x`Trp134IRoO zUrLlgvY>y~#T&{C{~R;5VlWaKk)Q@ZuB4H62|CwkIZ=+y?e!@yPtbQDC$M{sUgmd zQ!Mv01{o{GTR^>T(Q+(XMDRaz$Q)b3tUgOm%InwYpDXQQFb}LkRGacC(*+}U0T?ll z)Lj^pY|I|1Iyn{8F@Pkyci*s%sn zP@}O#j3yd`*i--aUF+<1&m9I+zVHA4^E~^W_pII4UVHDg*DmMWC@hm>IR2kVoVhGX ziM$|ogLf^Pf=Zuwc+6BlSqGO<7-m_G{&OuH`wZ{5z@ff)`)Ne>oVh6Y6+*`=(YSAf zYmnw`xme1A!%+V*ZlRdbu{woME10uzh{)Ui0yDZqB2iq7={y|y8i)I(5xyGtO%YDS zE{4BI=}j2s7ZFZmTuf;m92z}u@d(%BIaBo{xlqRH8n&4An(@tOHs{oEIi}&VmkP2^I1dikFXr(g0=aib}c3e7-1_Nd~7Ys;< z#`KYPI-602wGQKhj(`!+a? zEsx{&dxhy#JYpOMK%6GLzb*mC@TUL!aCsBn-&HbiAHp%TPeJdobW-UIM>F3jLMk1B z0hnro3GzPjZ!BI$e_z`Z+bVD@H~;J*)k|?YBLDe;|0R(rYWe$zvMBHv+_&x(F(H2e zaS!N-%G)m*39n< z+u_ju80ohPeF)z9HwBB}SRwpNflU!khp7hT0=Nd+pX76eJcc*MZP?TpAR=^2Sf|GX(G5lpJSCF_U6EN+BJ8bS!?8bo|jwh9C52=y+QDh}n3M zQ(}q7LnPiC1l|Wro$=o;0);*ZTgDAT@Ukr&b^PPF|1rWo40;pZO_&GQpx*hx`Qb_) zgWIINL&TCOho*)@61@FlBH?)6`0;i%Hi^zTRXlh*7fwBh?pKd|B-sM4ff~(2)OK)4 z-iL@ALprGOWAqG&xJ)gUBI7hj5${+ccoR)C9bA&v;5I@aQv{nYLC2(vOvI0^{{fCo zhM!G8;55bjn0n6$`xwHc?bMR`2ZZ>$gzCP5_mS8qf{Dc&zZvcl3zuvl*r0UYeg?;q z^L~er$MDAQgu6uTk_`mUDgCH35{W)=aY1=r_D7KB5^NN2hieSp`okfm+EyZVJ#Y382)N^{$ni zI0cg?ekmCBc?xb1D|{2TQB^{njoW<+(Oge5xMSq4ozkowa_<59P z!?oLpJD80Kw?V`5Mpp3_`Bh7NhVrl{VpkrR=>>4|a7DzuJQ)AXI=UW4qT4im-lFu^ z#nWH6B$ocVC9(9^Es3SSZi!Db-6}6mCwW6W$s6KH-VjgnhIo=USdvIOVtERZJWCno zP3vxg7YEvVTK*H#@;8H363W8ao6Ka$XcU+60VzV34luJ^{GfO{4MVxK&@f&qnZe}? z7~>F%pV{V-PKNFSN6ggMNB9=p*~;R_KDEG%t*vqlBWtT1tci- z!2vSDjS899T?&24vV42UN+hQtF4=98z&F2z;Uf`PpNKTU(YzgN9=;=wS~O&Q9k}=5xcXcGHw5lvIIgd6fqMzgUtIn6;rf8iC1W3MTP)lg!0*7l56AV;QE*(3 zP3))Zu-$Rz`m4W20n?SkaUH^6j{tKeVK-b8ECCe2wS#L9cQBk^kco$X0&)COgI{9s z{#<_G(g4%TLVTYd)8RjV`fD37-IH*?j?qV9vQIY#ZW5foZp_sg|8Cq1@;nvW)4-R& zT?NNIxtrj&!1;^&lI`HS!*O%b?}Tmy<`$~oiS*(9cDLW__H@6=9W+PxgY(y}B3R&X ztaKh@@|Qns#Is1=^=avS^|%ucG|?|k=b5`#;og9ICl4L+0z$76(x;QX}%n8!fi$_eW;ds7u7o0!g>`xZ^aMvM>KL^aPOydqXf9}^G;cXcH-6(B_ z-w5{z+-|sr;dwHc={BVE5btl{7$@&QpL+USsy~0~eF{)^p8jOn^F0ywYe1u02X`af zO>nvG(*YXu=LvX!jVspmpeu2|8qQxEfj7b33HJ*)f8BC0@(V3nI$)&{ z&aV~tiN6o$SHhQe($#9eQtkbJaR}xoaN9bfy&#NVd-whmKtCOB7Tij>QxCg_`#9`;r!Q1Jl%h%4{!Clh4Jy8Jxd31Ls8j zQMe~#^x~s*=6xjYoNfDSDKKZ-7sGLe?XNF@Im7-3T-MQ^nn+9r<_C0U!*TZPFaNb6 z|G^$l=Y*7#T|XQ3^lc~Tcb;x4)sIbW!TpzTFTnAGQ~u(&p*q1G4mTKX6db=1bq3to zaQ+>?ma~Q^2xSnv^;GTth4(@$8f5qu9$LOPg zFNnhOjedVE#blU{|D?lD?Cpl*m;3zXKfC8Yx992pTX~Zac6luPPe-EMaCgJq2j{QJ zqxFM|wd0^m;QZykk@z@hFU9EmjwHW$xE8dVWAts~QEs^B;9iFF7r*vOw-fGdxDVm} z1-BbEw8I41U;L!(({SBE>l33B4~82KH#$b249r<|J`!l*6TzKp0AIr03_tJBF#h@% z{EmVj|E_H+oWJ;IW1L*KhvVehU!08I1jm`^`*405>irX^W6uH3 LJuZHv2erIBw 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�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%0Dk{>CprLVvSfd+LU} zQAhL_j#ni&%!h;ig1^yD*|-l5`itGYXyf(xrN3EEowDIh_@uvZv18>s=&->hp+7yrM4a5rJf8yS6E!IF7<`w4*Cy-4p# z6U%)8(klV-jr5+j0J&J`#d2TdhvhCI+-Lu9g>WZCdMAkcoDX&2)a5b&yA#qr7c2q0 z@EbrlA{0aW5 z#Bsit7kZWd5`UWLSEO*#`=(tg=;r};79PgWyQI`%faQB#m491g=D(|j3rX~zZD?=1c3N7 z5K}Sq|Gxytr?96EPfQZVKE{D`%N$?wR)No-uT@va=wG~A3k8m7JF4gBtE)qQxW1}A z7Cu;A7lJ-im5x=1$(0N3`9t+=mfg?4i7nN$H^O3BbrjP0mg=Z|r!A|l4;Zv-S*&%x*j2tRbBP`^ASk+9dK{0uHLW%&Gf&V4qz`hNyiUi8&0Z+3%6gv>!-r5 zKo?+r;ijY4G6Z8#C4AWfD7Y@HP8TFWgB_<85Pf~O#d6dLurh}S7Y6|aIz2u)1<=Gj z(yND+K*=#kL}1#{+YcjKX{9_1s(7;q zvCkkwG<3Fv)0~#OJSvkQ7+XUqF)9}V-