jax 0.0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +12 -0
- data/.gitmodules +3 -0
- data/.rvmrc +7 -0
- data/Gemfile +4 -0
- data/README.rdoc +32 -0
- data/Rakefile +144 -0
- data/bin/jax +11 -0
- data/builtin/shaders/basic/common.ejs +11 -0
- data/builtin/shaders/basic/fragment.ejs +5 -0
- data/builtin/shaders/basic/vertex.ejs +13 -0
- data/builtin/shaders/depthmap/common.ejs +1 -0
- data/builtin/shaders/depthmap/fragment.ejs +5 -0
- data/builtin/shaders/depthmap/vertex.ejs +7 -0
- data/builtin/shaders/fog/common.ejs +7 -0
- data/builtin/shaders/fog/fragment.ejs +23 -0
- data/builtin/shaders/fog/manifest.yml +12 -0
- data/builtin/shaders/fog/material.js +34 -0
- data/builtin/shaders/fog/vertex.ejs +10 -0
- data/builtin/shaders/functions/depth_map.ejs +24 -0
- data/builtin/shaders/functions/lights.ejs +155 -0
- data/builtin/shaders/lighting/common.ejs +5 -0
- data/builtin/shaders/lighting/fragment.ejs +34 -0
- data/builtin/shaders/lighting/manifest.yml +4 -0
- data/builtin/shaders/lighting/material.js +26 -0
- data/builtin/shaders/lighting/vertex.ejs +7 -0
- data/builtin/shaders/normal_map/common.ejs +12 -0
- data/builtin/shaders/normal_map/fragment.ejs +26 -0
- data/builtin/shaders/normal_map/manifest.yml +17 -0
- data/builtin/shaders/normal_map/material.js +16 -0
- data/builtin/shaders/normal_map/vertex.ejs +57 -0
- data/builtin/shaders/paraboloid-depthmap/common.ejs +6 -0
- data/builtin/shaders/paraboloid-depthmap/fragment.ejs +8 -0
- data/builtin/shaders/paraboloid-depthmap/material.js +15 -0
- data/builtin/shaders/paraboloid-depthmap/vertex.ejs +26 -0
- data/builtin/shaders/shadow_map/common.ejs +14 -0
- data/builtin/shaders/shadow_map/fragment.ejs +66 -0
- data/builtin/shaders/shadow_map/manifest.yml +1 -0
- data/builtin/shaders/shadow_map/material.js +26 -0
- data/builtin/shaders/shadow_map/vertex.ejs +46 -0
- data/builtin/shaders/texture/common.ejs +4 -0
- data/builtin/shaders/texture/fragment.ejs +11 -0
- data/builtin/shaders/texture/manifest.yml +17 -0
- data/builtin/shaders/texture/material.js +18 -0
- data/builtin/shaders/texture/vertex.ejs +9 -0
- data/guides/assets/images/book_icon.gif +0 -0
- data/guides/assets/images/bullet.gif +0 -0
- data/guides/assets/images/chapters_icon.gif +0 -0
- data/guides/assets/images/check_bullet.gif +0 -0
- data/guides/assets/images/credits_pic_blank.gif +0 -0
- data/guides/assets/images/edge_badge.png +0 -0
- data/guides/assets/images/feature_tile.gif +0 -0
- data/guides/assets/images/footer_tile.gif +0 -0
- data/guides/assets/images/getting_started/clean_passing_jasmine_suite.png +0 -0
- data/guides/assets/images/getting_started/rock.png +0 -0
- data/guides/assets/images/getting_started/rock_normal.png +0 -0
- data/guides/assets/images/grey_bullet.gif +0 -0
- data/guides/assets/images/header_backdrop.png +0 -0
- data/guides/assets/images/header_tile.gif +0 -0
- data/guides/assets/images/icons/README +5 -0
- data/guides/assets/images/icons/callouts/1.png +0 -0
- data/guides/assets/images/icons/callouts/10.png +0 -0
- data/guides/assets/images/icons/callouts/11.png +0 -0
- data/guides/assets/images/icons/callouts/12.png +0 -0
- data/guides/assets/images/icons/callouts/13.png +0 -0
- data/guides/assets/images/icons/callouts/14.png +0 -0
- data/guides/assets/images/icons/callouts/15.png +0 -0
- data/guides/assets/images/icons/callouts/2.png +0 -0
- data/guides/assets/images/icons/callouts/3.png +0 -0
- data/guides/assets/images/icons/callouts/4.png +0 -0
- data/guides/assets/images/icons/callouts/5.png +0 -0
- data/guides/assets/images/icons/callouts/6.png +0 -0
- data/guides/assets/images/icons/callouts/7.png +0 -0
- data/guides/assets/images/icons/callouts/8.png +0 -0
- data/guides/assets/images/icons/callouts/9.png +0 -0
- data/guides/assets/images/icons/caution.png +0 -0
- data/guides/assets/images/icons/example.png +0 -0
- data/guides/assets/images/icons/home.png +0 -0
- data/guides/assets/images/icons/important.png +0 -0
- data/guides/assets/images/icons/next.png +0 -0
- data/guides/assets/images/icons/note.png +0 -0
- data/guides/assets/images/icons/prev.png +0 -0
- data/guides/assets/images/icons/tip.png +0 -0
- data/guides/assets/images/icons/up.png +0 -0
- data/guides/assets/images/icons/warning.png +0 -0
- data/guides/assets/images/nav_arrow.gif +0 -0
- data/guides/assets/images/tab_grey.gif +0 -0
- data/guides/assets/images/tab_info.gif +0 -0
- data/guides/assets/images/tab_note.gif +0 -0
- data/guides/assets/images/tab_red.gif +0 -0
- data/guides/assets/images/tab_yellow.gif +0 -0
- data/guides/assets/images/tab_yellow.png +0 -0
- data/guides/assets/javascripts/guides.js +7 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushAS3.js +59 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushAppleScript.js +75 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushBash.js +59 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCSharp.js +65 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushColdFusion.js +100 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCpp.js +97 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCss.js +91 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushDelphi.js +55 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushDiff.js +41 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushErlang.js +52 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushGroovy.js +67 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJScript.js +52 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJava.js +57 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJavaFX.js +58 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPerl.js +72 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPhp.js +88 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPlain.js +33 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPowerShell.js +74 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPython.js +64 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushRuby.js +55 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushSass.js +94 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushScala.js +51 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushSql.js +66 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushVb.js +56 -0
- data/guides/assets/javascripts/syntaxhighlighter/shBrushXml.js +69 -0
- data/guides/assets/javascripts/syntaxhighlighter/shCore.js +17 -0
- data/guides/assets/stylesheets/fixes.css +16 -0
- data/guides/assets/stylesheets/main.css +445 -0
- data/guides/assets/stylesheets/print.css +52 -0
- data/guides/assets/stylesheets/reset.css +43 -0
- data/guides/assets/stylesheets/style.css +13 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCore.css +226 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreDefault.css +328 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreDjango.css +331 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreEclipse.css +339 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreEmacs.css +324 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreFadeToGrey.css +328 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreMDUltra.css +324 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreMidnight.css +324 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreRDark.css +324 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeDefault.css +117 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeDjango.css +120 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeEclipse.css +128 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeEmacs.css +113 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeFadeToGrey.css +117 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeJaxGuides.css +116 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeMDUltra.css +113 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeMidnight.css +113 -0
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeRDark.css +113 -0
- data/guides/jax_guides.rb +41 -0
- data/guides/jax_guides/common.rb +7 -0
- data/guides/jax_guides/generator.rb +287 -0
- data/guides/jax_guides/helpers.rb +29 -0
- data/guides/jax_guides/indexer.rb +69 -0
- data/guides/jax_guides/levenshtein.rb +31 -0
- data/guides/jax_guides/textile_extensions.rb +61 -0
- data/guides/source/getting_started.textile +1171 -0
- data/guides/source/index.html.erb +50 -0
- data/guides/source/layout.html.erb +158 -0
- data/guides/source/lighting.textile +5 -0
- data/guides/source/materials.textile +5 -0
- data/guides/source/shaders.textile +5 -0
- data/guides/source/testing.textile +5 -0
- data/guides/w3c_validator.rb +91 -0
- data/jax.gems +1 -0
- data/jax.gemspec +40 -0
- data/lib/jax.rb +28 -0
- data/lib/jax/application.rb +92 -0
- data/lib/jax/application/configuration.rb +27 -0
- data/lib/jax/generators/app.rb +17 -0
- data/lib/jax/generators/app/app_generator.rb +78 -0
- data/lib/jax/generators/app/templates/Gemfile.tt +3 -0
- data/lib/jax/generators/app/templates/Rakefile +6 -0
- data/lib/jax/generators/app/templates/app/controllers/application_controller.js.tt +5 -0
- data/lib/jax/generators/app/templates/app/helpers/application_helper.js.tt +3 -0
- data/lib/jax/generators/app/templates/app/models/.empty_directory +0 -0
- data/lib/jax/generators/app/templates/app/resources/.empty_directory +0 -0
- data/lib/jax/generators/app/templates/app/views/.empty_directory +0 -0
- data/lib/jax/generators/app/templates/config/application.rb.tt +6 -0
- data/lib/jax/generators/app/templates/config/boot.rb +13 -0
- data/lib/jax/generators/app/templates/config/routes.rb.tt +5 -0
- data/lib/jax/generators/app/templates/public/javascripts/jax.js +7561 -0
- data/lib/jax/generators/app/templates/public/webgl_not_supported.html +26 -0
- data/lib/jax/generators/app/templates/script/jax +7 -0
- data/lib/jax/generators/app/templates/spec/javascripts/controllers/application_controller_spec.js +11 -0
- data/lib/jax/generators/app/templates/spec/javascripts/helpers/application_helper_spec.js +12 -0
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine.yml +90 -0
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_config.rb +23 -0
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_runner.rb +32 -0
- data/lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers/jax_spec_helper.js +216 -0
- data/lib/jax/generators/app/templates/spec/javascripts/support/spec_layout.html.erb +63 -0
- data/lib/jax/generators/commands.rb +81 -0
- data/lib/jax/generators/controller/USAGE +9 -0
- data/lib/jax/generators/controller/controller_generator.rb +59 -0
- data/lib/jax/generators/controller/templates/controller_source.js.tt +16 -0
- data/lib/jax/generators/controller/templates/controller_test.js.tt +11 -0
- data/lib/jax/generators/controller/templates/helper.js.tt +3 -0
- data/lib/jax/generators/controller/templates/helper_test.js.tt +12 -0
- data/lib/jax/generators/controller/templates/view.js.tt +4 -0
- data/lib/jax/generators/light_source/USAGE +14 -0
- data/lib/jax/generators/light_source/light_source_generator.rb +47 -0
- data/lib/jax/generators/light_source/templates/light.yml.tt +39 -0
- data/lib/jax/generators/material/USAGE +29 -0
- data/lib/jax/generators/material/material_generator.rb +81 -0
- data/lib/jax/generators/material/templates/append.yml.tt +7 -0
- data/lib/jax/generators/material/templates/material.yml.tt +33 -0
- data/lib/jax/generators/model/USAGE +5 -0
- data/lib/jax/generators/model/model_generator.rb +42 -0
- data/lib/jax/generators/model/templates/model.js.tt +11 -0
- data/lib/jax/generators/model/templates/test.js.tt +11 -0
- data/lib/jax/generators/script_jax_loader.rb +32 -0
- data/lib/jax/monkeypatch/jasmine.rb +3 -0
- data/lib/jax/monkeypatch/jasmine/config.rb +21 -0
- data/lib/jax/monkeypatch/jasmine/server.rb +50 -0
- data/lib/jax/packager.rb +58 -0
- data/lib/jax/packager/sprockets_template.rb +49 -0
- data/lib/jax/resource_compiler.rb +50 -0
- data/lib/jax/routes.rb +61 -0
- data/lib/jax/shader.rb +158 -0
- data/lib/jax/tasks/rake.rb +34 -0
- data/lib/jax/version.rb +12 -0
- data/public/images/brickwall.jpg +0 -0
- data/public/images/jacks.jpg +0 -0
- data/public/images/normal_map.jpg +0 -0
- data/public/images/rock.png +0 -0
- data/public/images/rockNormal.png +0 -0
- data/public/images/rss.png +0 -0
- data/public/webgl_not_supported.html +26 -0
- data/spec/example_app/Gemfile +1 -0
- data/spec/example_app/Rakefile +15 -0
- data/spec/example_app/app/controllers/application_controller.js +5 -0
- data/spec/example_app/app/controllers/courthouse_controller.js +24 -0
- data/spec/example_app/app/controllers/lighting_controller.js +69 -0
- data/spec/example_app/app/controllers/shadows_controller.js +130 -0
- data/spec/example_app/app/controllers/textures_controller.js +52 -0
- data/spec/example_app/app/helpers/application_helper.js +3 -0
- data/spec/example_app/app/helpers/textures_helper.js +3 -0
- data/spec/example_app/app/models/character.js +23 -0
- data/spec/example_app/app/models/door.js +10 -0
- data/spec/example_app/app/models/scene.js +19 -0
- data/spec/example_app/app/resources/characters/judge.yml +3 -0
- data/spec/example_app/app/resources/doors/courthouse_door.yml +5 -0
- data/spec/example_app/app/resources/light_sources/directional_light.yml +13 -0
- data/spec/example_app/app/resources/light_sources/point_light.yml +31 -0
- data/spec/example_app/app/resources/light_sources/spot_light.yml +15 -0
- data/spec/example_app/app/resources/light_sources/sun.yml +7 -0
- data/spec/example_app/app/resources/light_sources/textures_point.yml +34 -0
- data/spec/example_app/app/resources/materials/bricks.yml +36 -0
- data/spec/example_app/app/resources/materials/lighting_with_shadows.yml +27 -0
- data/spec/example_app/app/resources/scenes/courthouse.yml +4 -0
- data/spec/example_app/app/views/courthouse/index.js +4 -0
- data/spec/example_app/app/views/lighting/index.js +4 -0
- data/spec/example_app/app/views/shadows/index.js +6 -0
- data/spec/example_app/app/views/textures/index.js +4 -0
- data/spec/example_app/config/application.rb +6 -0
- data/spec/example_app/config/boot.rb +13 -0
- data/spec/example_app/config/routes.rb +6 -0
- data/spec/example_app/public/images/185__normalmap.png +0 -0
- data/spec/example_app/public/images/face_norm.jpg +0 -0
- data/spec/example_app/public/images/rock.png +0 -0
- data/spec/example_app/public/images/rockNormal.png +0 -0
- data/spec/example_app/public/images/rss.png +0 -0
- data/spec/example_app/public/webgl_not_supported.html +26 -0
- data/spec/example_app/script/jax +7 -0
- data/spec/example_app/spec/javascripts/controllers/textures_controller_spec.js +11 -0
- data/spec/example_app/spec/javascripts/helpers/application_helper_spec.js +12 -0
- data/spec/example_app/spec/javascripts/resources/directional_light_spec.js +16 -0
- data/spec/example_app/spec/javascripts/resources/point_light_spec.js +17 -0
- data/spec/example_app/spec/javascripts/resources/spot_light_spec.js +18 -0
- data/spec/example_app/spec/javascripts/support/jasmine.yml +89 -0
- data/spec/example_app/spec/javascripts/support/jasmine_runner.rb +32 -0
- data/spec/example_app/spec/javascripts/support/spec_helpers/jax_spec_helper.js +93 -0
- data/spec/example_app/spec/javascripts/support/spec_layout.html.erb +84 -0
- data/spec/generators/app_generator_spec.rb +46 -0
- data/spec/generators/controller_generator_spec.rb +68 -0
- data/spec/generators/light_generator_spec.rb +51 -0
- data/spec/generators/material_generator_spec.rb +35 -0
- data/spec/generators/model_generator_spec.rb +43 -0
- data/spec/javascripts/Player.js +58 -0
- data/spec/javascripts/helpers/SpecHelper.js +216 -0
- data/spec/javascripts/jax/builtin/materials/core_materials_spec.js +41 -0
- data/spec/javascripts/jax/builtin/materials/dual_paraboloid_spec.js +37 -0
- data/spec/javascripts/jax/builtin/materials/fog_spec.js +19 -0
- data/spec/javascripts/jax/builtin/materials/lighting_spec.js +19 -0
- data/spec/javascripts/jax/builtin/materials/normal_map_spec.js +19 -0
- data/spec/javascripts/jax/builtin/materials/shadow_map_spec.js +19 -0
- data/spec/javascripts/jax/builtin/materials/texture_spec.js +19 -0
- data/spec/javascripts/jax/builtin/meshes/cube_spec.js +10 -0
- data/spec/javascripts/jax/builtin/meshes/plane_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/quad_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/sphere_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/teapot_spec.js +8 -0
- data/spec/javascripts/jax/builtin/meshes/torus_spec.js +8 -0
- data/spec/javascripts/jax/compatibility_spec.js +50 -0
- data/spec/javascripts/jax/context_spec.js +82 -0
- data/spec/javascripts/jax/controller_spec.js +145 -0
- data/spec/javascripts/jax/core/delegation_spec.js +48 -0
- data/spec/javascripts/jax/core/events_spec.js +17 -0
- data/spec/javascripts/jax/core/matrix_stack_spec.js +28 -0
- data/spec/javascripts/jax/core/utils_spec.js +256 -0
- data/spec/javascripts/jax/helper_spec.js +33 -0
- data/spec/javascripts/jax/model_spec.js +87 -0
- data/spec/javascripts/jax/optimizations/material_limitations_spec.js +87 -0
- data/spec/javascripts/jax/optimizations/shaders/basic_spec.js +68 -0
- data/spec/javascripts/jax/prototype/extensions_spec.js +34 -0
- data/spec/javascripts/jax/route_set_spec.js +67 -0
- data/spec/javascripts/jax/view_manager_spec.js +17 -0
- data/spec/javascripts/jax/webgl/camera_spec.js +159 -0
- data/spec/javascripts/jax/webgl/framebuffer_spec.js +46 -0
- data/spec/javascripts/jax/webgl/lighting_spec.js +61 -0
- data/spec/javascripts/jax/webgl/material_spec.js +118 -0
- data/spec/javascripts/jax/webgl/mesh_spec.js +86 -0
- data/spec/javascripts/jax/webgl/shader/manifest_spec.js +60 -0
- data/spec/javascripts/jax/webgl/shader_chain_spec.js +192 -0
- data/spec/javascripts/jax/webgl/shader_spec.js +276 -0
- data/spec/javascripts/jax/webgl/tangent_space_spec.js +142 -0
- data/spec/javascripts/jax/webgl/texture_spec.js +162 -0
- data/spec/javascripts/jax/webgl_spec.js +5 -0
- data/spec/javascripts/jax/world_spec.js +88 -0
- data/spec/javascripts/jax_spec.js +27 -0
- data/spec/javascripts/support/jasmine.yml +85 -0
- data/spec/javascripts/support/jasmine_runner.rb +32 -0
- data/spec/lib/jax/routes_spec.rb +24 -0
- data/spec/lib/jax/shader_spec.rb +57 -0
- data/spec/lib/jax/tasks/jax_rake_spec.rb +79 -0
- data/spec/spec_helper.rb +11 -0
- data/spec/support/file_exist_matcher.rb +23 -0
- data/spec/support/spec_shell.rb +97 -0
- data/src/jax.js +84 -0
- data/src/jax/anim_frame.js +47 -0
- data/src/jax/builtin/all.js +7 -0
- data/src/jax/builtin/meshes/cube.js +62 -0
- data/src/jax/builtin/meshes/plane.js +36 -0
- data/src/jax/builtin/meshes/quad.js +80 -0
- data/src/jax/builtin/meshes/sphere.js +46 -0
- data/src/jax/builtin/meshes/teapot.js +38 -0
- data/src/jax/builtin/meshes/torus.js +46 -0
- data/src/jax/compatibility.js +140 -0
- data/src/jax/context.js +253 -0
- data/src/jax/controller.js +157 -0
- data/src/jax/core.js +39 -0
- data/src/jax/core/math.js +40 -0
- data/src/jax/core/matrix_stack.js +306 -0
- data/src/jax/core/util.js +226 -0
- data/src/jax/events.js +179 -0
- data/src/jax/geometry.js +3 -0
- data/src/jax/geometry/plane.js +59 -0
- data/src/jax/helper.js +8 -0
- data/src/jax/model.js +163 -0
- data/src/jax/prototype/class.js +78 -0
- data/src/jax/prototype/core.js +112 -0
- data/src/jax/prototype/extensions.js +124 -0
- data/src/jax/route_set.js +125 -0
- data/src/jax/vendor/ejs.js +4 -0
- data/src/jax/vendor/glMatrix.js +3 -0
- data/src/jax/view.js +37 -0
- data/src/jax/view_manager.js +46 -0
- data/src/jax/webgl.js +98 -0
- data/src/jax/webgl/camera.js +526 -0
- data/src/jax/webgl/core.js +6 -0
- data/src/jax/webgl/core/buffer.js +161 -0
- data/src/jax/webgl/core/edge.js +6 -0
- data/src/jax/webgl/core/events.js +25 -0
- data/src/jax/webgl/core/face.js +8 -0
- data/src/jax/webgl/core/framebuffer.js +206 -0
- data/src/jax/webgl/material.js +375 -0
- data/src/jax/webgl/mesh.js +412 -0
- data/src/jax/webgl/scene.js +11 -0
- data/src/jax/webgl/scene/frustum.js +260 -0
- data/src/jax/webgl/scene/light_manager.js +112 -0
- data/src/jax/webgl/scene/light_source.js +248 -0
- data/src/jax/webgl/shader.js +282 -0
- data/src/jax/webgl/shader/delegator.js +13 -0
- data/src/jax/webgl/shader/delegator/attribute.js +53 -0
- data/src/jax/webgl/shader/delegator/uniform.js +71 -0
- data/src/jax/webgl/shader/manifest.js +64 -0
- data/src/jax/webgl/shader/program.js +140 -0
- data/src/jax/webgl/shader_chain.js +256 -0
- data/src/jax/webgl/texture.js +312 -0
- data/src/jax/webgl/world.js +119 -0
- data/vendor/ejs/.svn/all-wcprops +17 -0
- data/vendor/ejs/.svn/entries +114 -0
- data/vendor/ejs/.svn/text-base/Eratta.txt.svn-base +3 -0
- data/vendor/ejs/.svn/text-base/license.txt.svn-base +21 -0
- data/vendor/ejs/Eratta.txt +3 -0
- data/vendor/ejs/example/.svn/all-wcprops +29 -0
- data/vendor/ejs/example/.svn/entries +164 -0
- data/vendor/ejs/example/.svn/prop-base/ejs.gif.svn-base +5 -0
- data/vendor/ejs/example/.svn/text-base/demo.html.svn-base +54 -0
- data/vendor/ejs/example/.svn/text-base/ejs.gif.svn-base +0 -0
- data/vendor/ejs/example/.svn/text-base/example.css.svn-base +31 -0
- data/vendor/ejs/example/.svn/text-base/example.js.svn-base +88 -0
- data/vendor/ejs/example/demo.html +54 -0
- data/vendor/ejs/example/ejs.gif +0 -0
- data/vendor/ejs/example/example.css +31 -0
- data/vendor/ejs/example/example.js +88 -0
- data/vendor/ejs/lib/.svn/all-wcprops +11 -0
- data/vendor/ejs/lib/.svn/entries +62 -0
- data/vendor/ejs/lib/.svn/text-base/ejs_fulljslint.js.svn-base +3774 -0
- data/vendor/ejs/lib/ejs_fulljslint.js +3774 -0
- data/vendor/ejs/license.txt +21 -0
- data/vendor/ejs/script/.svn/all-wcprops +17 -0
- data/vendor/ejs/script/.svn/entries +96 -0
- data/vendor/ejs/script/.svn/prop-base/yuicompressor-2.2.4.jar.svn-base +5 -0
- data/vendor/ejs/script/.svn/text-base/production.bat.svn-base +4 -0
- data/vendor/ejs/script/.svn/text-base/yuicompressor-2.2.4.jar.svn-base +0 -0
- data/vendor/ejs/script/production.bat +4 -0
- data/vendor/ejs/script/yuicompressor-2.2.4.jar +0 -0
- data/vendor/ejs/src/.svn/all-wcprops +17 -0
- data/vendor/ejs/src/.svn/entries +96 -0
- data/vendor/ejs/src/.svn/text-base/ejs.js.svn-base +505 -0
- data/vendor/ejs/src/.svn/text-base/view.js.svn-base +200 -0
- data/vendor/ejs/src/ejs.js +505 -0
- data/vendor/ejs/src/view.js +200 -0
- data/vendor/ejs/test/.svn/all-wcprops +23 -0
- data/vendor/ejs/test/.svn/entries +139 -0
- data/vendor/ejs/test/.svn/text-base/index.html.svn-base +18 -0
- data/vendor/ejs/test/.svn/text-base/setup_test.html.svn-base +44 -0
- data/vendor/ejs/test/.svn/text-base/sidebar.html.svn-base +28 -0
- data/vendor/ejs/test/included/.svn/all-wcprops +23 -0
- data/vendor/ejs/test/included/.svn/entries +130 -0
- data/vendor/ejs/test/included/.svn/text-base/prototype.js.svn-base +4184 -0
- data/vendor/ejs/test/included/.svn/text-base/test.css.svn-base +44 -0
- data/vendor/ejs/test/included/.svn/text-base/unittest.js.svn-base +564 -0
- data/vendor/ejs/test/included/prototype.js +4184 -0
- data/vendor/ejs/test/included/test.css +44 -0
- data/vendor/ejs/test/included/unittest.js +564 -0
- data/vendor/ejs/test/index.html +18 -0
- data/vendor/ejs/test/setup_test.html +44 -0
- data/vendor/ejs/test/sidebar.html +28 -0
- data/vendor/ejs/test/templates/.svn/all-wcprops +11 -0
- data/vendor/ejs/test/templates/.svn/entries +62 -0
- data/vendor/ejs/test/templates/.svn/text-base/test.ejs.svn-base +3 -0
- data/vendor/ejs/test/templates/test.ejs +3 -0
- data/vendor/ejs/test/tests/.svn/all-wcprops +23 -0
- data/vendor/ejs/test/tests/.svn/entries +130 -0
- data/vendor/ejs/test/tests/.svn/text-base/rendering.js.svn-base +94 -0
- data/vendor/ejs/test/tests/.svn/text-base/templating.js.svn-base +43 -0
- data/vendor/ejs/test/tests/.svn/text-base/views.js.svn-base +100 -0
- data/vendor/ejs/test/tests/rendering.js +94 -0
- data/vendor/ejs/test/tests/templating.js +43 -0
- data/vendor/ejs/test/tests/views.js +100 -0
- data/vendor/glmatrix/benchmark/js/CanvasMatrix.js +722 -0
- data/vendor/glmatrix/benchmark/js/EWGL_math.js +742 -0
- data/vendor/glmatrix/benchmark/js/mjs.js +1230 -0
- data/vendor/glmatrix/benchmark/matrix_benchmark.html +419 -0
- data/vendor/glmatrix/glMatrix-min.js +32 -0
- data/vendor/glmatrix/glMatrix.js +1815 -0
- data/vendor/glmatrix/unit tests/glMatrix-test.js +74 -0
- data/vendor/glmatrix/unit tests/qunit.css +119 -0
- data/vendor/glmatrix/unit tests/qunit.js +1069 -0
- data/vendor/glmatrix/unit tests/test_glMatrix.html +21 -0
- data/vendor/yuicompressor-2.4.2.jar +0 -0
- metadata +748 -0
@@ -0,0 +1,33 @@
|
|
1
|
+
describe("Jax.Helper", function() {
|
2
|
+
var helper;
|
3
|
+
|
4
|
+
beforeEach(function() {
|
5
|
+
helper = Jax.Helper.create({
|
6
|
+
test_method: function() { return 1; }
|
7
|
+
});
|
8
|
+
});
|
9
|
+
|
10
|
+
it("should define the helper in requesting controllers", function() {
|
11
|
+
var controller = Jax.Controller.create({
|
12
|
+
helpers: function() { return [helper]; }
|
13
|
+
});
|
14
|
+
expect(controller.prototype.test_method).toEqual(helper.test_method);
|
15
|
+
});
|
16
|
+
|
17
|
+
it("should not define the helper in non-requesting controllers", function() {
|
18
|
+
var controller = Jax.Controller.create({});
|
19
|
+
expect(controller.prototype.test_method).toBeUndefined();
|
20
|
+
});
|
21
|
+
|
22
|
+
it("should define the helper in requesting models", function() {
|
23
|
+
var model = Jax.Class.create(Jax.Model, {
|
24
|
+
helpers: function() { return [helper]; }
|
25
|
+
});
|
26
|
+
expect(model.prototype.test_method).toEqual(helper.test_method);
|
27
|
+
});
|
28
|
+
|
29
|
+
it("should not define the helper in non-requesting models", function() {
|
30
|
+
var model = Jax.Class.create(Jax.Model, {});
|
31
|
+
expect(model.prototype.test_method).toBeUndefined();
|
32
|
+
});
|
33
|
+
});
|
@@ -0,0 +1,87 @@
|
|
1
|
+
describe("Jax.Model", function() {
|
2
|
+
var model;
|
3
|
+
|
4
|
+
describe("as a resource", function() {
|
5
|
+
// do these things only once, because we're going to see how one model instance interacts with another
|
6
|
+
var klass, res_data = { "name": {one: { value : 1 } } };
|
7
|
+
klass = Jax.Model.create({});
|
8
|
+
klass.addResources(res_data);
|
9
|
+
|
10
|
+
beforeEach(function() {
|
11
|
+
model = klass.find("name");
|
12
|
+
});
|
13
|
+
|
14
|
+
it("should find new resource instances instead of existing ones", function() {
|
15
|
+
model.two = 2;
|
16
|
+
model = klass.find("name");
|
17
|
+
expect(model.two).toBeUndefined();
|
18
|
+
});
|
19
|
+
|
20
|
+
it("should not alter the original resource data", function() {
|
21
|
+
model.one.value = 2;
|
22
|
+
model = klass.find("name");
|
23
|
+
expect(model.one.value).not.toEqual(2);
|
24
|
+
});
|
25
|
+
});
|
26
|
+
|
27
|
+
describe("without any custom methods", function() {
|
28
|
+
beforeEach(function() {
|
29
|
+
model = Jax.Model.create({
|
30
|
+
initialize: function($super, data) { $super(Jax.Util.normalizeOptions(data, {mesh:new Jax.Mesh.Quad()})); }
|
31
|
+
});
|
32
|
+
});
|
33
|
+
|
34
|
+
describe("instantiated", function() {
|
35
|
+
beforeEach(function() { model = new model(); });
|
36
|
+
|
37
|
+
describe("that is not a shadowcaster", function() {
|
38
|
+
beforeEach(function() { model.shadow_caster = false; });
|
39
|
+
it("should still be lit", function() { expect(model).toBeIlluminated(); });
|
40
|
+
});
|
41
|
+
|
42
|
+
describe("that is not lit", function() {
|
43
|
+
beforeEach(function() { model.lit = false; });
|
44
|
+
it("should not be rendered in illumination pass", function() {
|
45
|
+
expect(model).not.toBeIlluminated();
|
46
|
+
});
|
47
|
+
});
|
48
|
+
|
49
|
+
it("should render properly", function() {
|
50
|
+
var context = new Jax.Context('canvas-element');
|
51
|
+
model.render(context);
|
52
|
+
context.dispose();
|
53
|
+
});
|
54
|
+
});
|
55
|
+
|
56
|
+
it("should fire after_initialize", function() {
|
57
|
+
model.addResources({ "name": { fired: false } });
|
58
|
+
model.addMethods({ after_initialize: function() { this.fired = true; } });
|
59
|
+
expect(model.find("name").fired).toBeTrue();
|
60
|
+
});
|
61
|
+
|
62
|
+
it("should raise an error when searching for a missing ID", function() {
|
63
|
+
model.addResources({"one": { } });
|
64
|
+
expect(function() { model.find("two") }).toThrow(new Error("Resource 'two' not found!"));
|
65
|
+
});
|
66
|
+
|
67
|
+
it("should assign default attribute values", function() {
|
68
|
+
model.addResources({'default':{one:'one'},'name':{two:'two'}});
|
69
|
+
expect(model.find('name').one).toEqual("one");
|
70
|
+
expect(model.find('name').two).toEqual("two");
|
71
|
+
});
|
72
|
+
|
73
|
+
it("should assign attribute values", function() {
|
74
|
+
model.addResources({ "name": { one: "one" } });
|
75
|
+
expect(model.find("name").one).toEqual("one");
|
76
|
+
});
|
77
|
+
|
78
|
+
it("should instantiate a model that is missing default attributes", function() {
|
79
|
+
expect(function() { new model(); }).not.toThrow();
|
80
|
+
});
|
81
|
+
});
|
82
|
+
|
83
|
+
describe("with a custom method", function() {
|
84
|
+
beforeEach(function() { model = Jax.Model.create({method: function() { return "called"; } }); });
|
85
|
+
it("should work", function() { expect(new model().method()).toEqual("called"); });
|
86
|
+
});
|
87
|
+
});
|
@@ -0,0 +1,87 @@
|
|
1
|
+
describe("Jax.Material exceeding GPU limitations", function() {
|
2
|
+
var matr, context, mesh;
|
3
|
+
var layer, layer_class;
|
4
|
+
var real = { varyings: Jax.Shader.max_varyings, uniforms: Jax.Shader.max_uniforms, attributes: Jax.Shader.max_attributes };
|
5
|
+
|
6
|
+
beforeEach(function() {
|
7
|
+
matr = new Jax.Material();
|
8
|
+
mesh = new Jax.Mesh.Quad();
|
9
|
+
context = new Jax.Context('canvas-element');
|
10
|
+
// a layer that uses at least 1 of everything we'll test
|
11
|
+
Jax.shaders['_debug_layer'] = new Jax.Shader({name:"_debug_layer",
|
12
|
+
common:"uniform float X; varying float Z;",
|
13
|
+
vertex:"attribute float Y; void main(void) { Z = X + Y; gl_Position = vec4(0,0,0,1); }",
|
14
|
+
fragment: "void main(void) { gl_FragColor = vec4(Z); }"
|
15
|
+
});
|
16
|
+
layer_class = Jax.Class.create(Jax.Material, {initialize:function($super) { $super({shader:"_debug_layer"}); }});
|
17
|
+
layer = new layer_class();
|
18
|
+
matr.addLayer(new Jax.Material.Lighting());
|
19
|
+
matr.addLayer(layer);
|
20
|
+
});
|
21
|
+
|
22
|
+
afterEach(function() {
|
23
|
+
context.dispose();
|
24
|
+
Jax.Shader.max_varyings = real.varyings;
|
25
|
+
Jax.Shader.max_uniforms = real.uniforms;
|
26
|
+
Jax.Shader.max_attributes = real.attributes;
|
27
|
+
});
|
28
|
+
|
29
|
+
// fake out the max. number of varyings so we can test reliably
|
30
|
+
function stub(what) {
|
31
|
+
var chain = new Jax.ShaderChain();
|
32
|
+
chain.addShader(Jax.shaders[Jax.default_shader]);
|
33
|
+
switch(what) {
|
34
|
+
case 'varyings': Jax.Shader.max_varyings = chain.countVaryings(matr); break;
|
35
|
+
case 'uniforms': Jax.Shader.max_uniforms = chain.countUniforms(matr); break;
|
36
|
+
case 'attributes':Jax.Shader.max_attributes= chain.countAttributes(matr);break;
|
37
|
+
default: throw new Error("wtf?");
|
38
|
+
}
|
39
|
+
}
|
40
|
+
|
41
|
+
describe("on number of varyings", function() {
|
42
|
+
beforeEach(function() { stub('varyings'); });
|
43
|
+
|
44
|
+
it("should first cull any materials which cannot possibly be used", function() {
|
45
|
+
Jax.Shader.max_varyings++; // 1 for the most recent shader; render should produce 1 layer ('lighting'), not 0
|
46
|
+
matr.render(context, mesh, {});
|
47
|
+
// we expect it to be Lighting and not shader_class, because Lighting only has 1 varying. :)
|
48
|
+
expect(matr.layers[0]).toBeKindOf(Jax.Material.Lighting);
|
49
|
+
});
|
50
|
+
|
51
|
+
it("should back off shader steps incrementally", function() {
|
52
|
+
matr.render(context, mesh, {});
|
53
|
+
expect(matr.layers.length).toEqual(0);
|
54
|
+
});
|
55
|
+
});
|
56
|
+
|
57
|
+
describe("on number of attributes", function() {
|
58
|
+
beforeEach(function() { stub('attributes'); });
|
59
|
+
|
60
|
+
it("should first cull any materials which cannot possibly be used", function() {
|
61
|
+
Jax.Shader.max_attributes++; // 1 for the most recent shader; render should produce 1 layer ('lighting'), not 0
|
62
|
+
matr.render(context, mesh, {});
|
63
|
+
// we expect it to be Lighting instead of layer_class, becuase LIghting has no varyings.
|
64
|
+
expect(matr.layers[0]).toBeKindOf(Jax.Material.Lighting);
|
65
|
+
});
|
66
|
+
|
67
|
+
it("should back off shader steps incrementally", function() {
|
68
|
+
matr.render(context, mesh, {});
|
69
|
+
expect(matr.layers.length).toEqual(1); // see above
|
70
|
+
});
|
71
|
+
});
|
72
|
+
|
73
|
+
describe("on number of uniforms", function() {
|
74
|
+
beforeEach(function() { stub('uniforms'); });
|
75
|
+
|
76
|
+
it("should first cull any materials which cannot possibly be used", function() {
|
77
|
+
Jax.Shader.max_uniforms++; // 1 for the most recent shader; render should produce 1 layer ('shader_class'), not 0
|
78
|
+
matr.render(context, mesh, {});
|
79
|
+
expect(matr.layers[0]).toBeKindOf(layer_class);
|
80
|
+
});
|
81
|
+
|
82
|
+
it("should back off shader steps incrementally", function() {
|
83
|
+
matr.render(context, mesh, {});
|
84
|
+
expect(matr.layers.length).toEqual(0);
|
85
|
+
});
|
86
|
+
});
|
87
|
+
});
|
@@ -0,0 +1,68 @@
|
|
1
|
+
describe("Opt: Basic shader", function() {
|
2
|
+
var model, context;
|
3
|
+
var _tex = "/images/rss.png", _norm = "/images/normal_map.jpg";
|
4
|
+
|
5
|
+
beforeEach(function() {
|
6
|
+
context = new Jax.Context('canvas-element');
|
7
|
+
model = new Jax.Model({mesh: new Jax.Mesh.Quad()});
|
8
|
+
context.world.addObject(model);
|
9
|
+
});
|
10
|
+
|
11
|
+
afterEach(function() { context.dispose(); });
|
12
|
+
|
13
|
+
describe("without textures", function() {
|
14
|
+
it("should not build tangent space", function() {
|
15
|
+
spyOn(model.mesh, 'getTangentBuffer').andCallThrough();
|
16
|
+
context.world.render();
|
17
|
+
expect(model.mesh.getTangentBuffer).not.toHaveBeenCalled();
|
18
|
+
});
|
19
|
+
});
|
20
|
+
|
21
|
+
describe("with 1 regular texture", function() {
|
22
|
+
beforeEach(function() {
|
23
|
+
model.mesh.material = new Jax.Material({texture: _tex});
|
24
|
+
});
|
25
|
+
|
26
|
+
it("should not build tangent space", function() {
|
27
|
+
spyOn(model.mesh, 'getTangentBuffer').andCallThrough();
|
28
|
+
context.world.render();
|
29
|
+
expect(model.mesh.getTangentBuffer).not.toHaveBeenCalled();
|
30
|
+
});
|
31
|
+
});
|
32
|
+
|
33
|
+
describe("with 1 normal map texture", function() {
|
34
|
+
beforeEach(function() {
|
35
|
+
model.mesh.material = new Jax.Material({texture: {path:_norm, type:Jax.NORMAL_MAP}});
|
36
|
+
});
|
37
|
+
|
38
|
+
it("should build tangent space", function() {
|
39
|
+
spyOn(model.mesh, 'getTangentBuffer').andCallThrough();
|
40
|
+
context.world.render();
|
41
|
+
expect(model.mesh.getTangentBuffer).toHaveBeenCalled();
|
42
|
+
});
|
43
|
+
});
|
44
|
+
|
45
|
+
describe("with 2 regular textures", function() {
|
46
|
+
beforeEach(function() {
|
47
|
+
model.mesh.material = new Jax.Material({textures: [_tex, _tex]});
|
48
|
+
});
|
49
|
+
|
50
|
+
it("should not build tangent space", function() {
|
51
|
+
spyOn(model.mesh, 'getTangentBuffer').andCallThrough();
|
52
|
+
context.world.render();
|
53
|
+
expect(model.mesh.getTangentBuffer).not.toHaveBeenCalled();
|
54
|
+
});
|
55
|
+
});
|
56
|
+
|
57
|
+
describe("with 1 normal and 1 regular texture", function() {
|
58
|
+
beforeEach(function() {
|
59
|
+
model.mesh.material = new Jax.Material({textures: [_tex, {path:_norm,type:Jax.NORMAL_MAP}]});
|
60
|
+
});
|
61
|
+
|
62
|
+
it("should build tangent space", function() {
|
63
|
+
spyOn(model.mesh, 'getTangentBuffer').andCallThrough();
|
64
|
+
context.world.render();
|
65
|
+
expect(model.mesh.getTangentBuffer).toHaveBeenCalled();
|
66
|
+
});
|
67
|
+
});
|
68
|
+
});
|
@@ -0,0 +1,34 @@
|
|
1
|
+
describe("Prototype extensions:", function() {
|
2
|
+
describe("Class", function() {
|
3
|
+
var klass;
|
4
|
+
var subklass;
|
5
|
+
|
6
|
+
beforeEach(function() {
|
7
|
+
klass = Jax.Class.create({ });
|
8
|
+
subklass = Jax.Class.create(klass, {});
|
9
|
+
});
|
10
|
+
|
11
|
+
it("should be a kind of itself", function() {
|
12
|
+
expect(new klass()).toBeKindOf(klass);
|
13
|
+
});
|
14
|
+
|
15
|
+
it("should not be a kind of its subclass", function() {
|
16
|
+
expect(new klass()).not.toBeKindOf(subklass);
|
17
|
+
});
|
18
|
+
|
19
|
+
describe("Subclass", function() {
|
20
|
+
it("should be a kind of itself", function() {
|
21
|
+
expect(new subklass()).toBeKindOf(subklass);
|
22
|
+
});
|
23
|
+
|
24
|
+
it("should be a kind of its superclass", function() {
|
25
|
+
expect(new subklass()).toBeKindOf(subklass.superclass);
|
26
|
+
});
|
27
|
+
|
28
|
+
/* theoretically the same as above, but... */
|
29
|
+
it("should be a kind of klass", function() {
|
30
|
+
expect(new subklass()).toBeKindOf(klass);
|
31
|
+
});
|
32
|
+
});
|
33
|
+
});
|
34
|
+
});
|
@@ -0,0 +1,67 @@
|
|
1
|
+
describe("Jax.RouteSet", function() {
|
2
|
+
var map;
|
3
|
+
var controller_class = Jax.Controller.create({index: function() { }});
|
4
|
+
Jax.views.push("generic/index", function() { });
|
5
|
+
|
6
|
+
beforeEach(function() { map = new Jax.RouteSet(); });
|
7
|
+
|
8
|
+
describe("route descriptor", function() {
|
9
|
+
var descriptor;
|
10
|
+
|
11
|
+
it("from descriptor", function() {
|
12
|
+
descriptor = map.getRouteDescriptor({controller:controller_class, id: 1});
|
13
|
+
expect(descriptor.controller).toEqual(controller_class);
|
14
|
+
expect(descriptor.action).toEqual("index");
|
15
|
+
expect(descriptor.id).toEqual(1);
|
16
|
+
});
|
17
|
+
|
18
|
+
it("from controller (klass)", function() {
|
19
|
+
descriptor = map.getRouteDescriptor(controller_class);
|
20
|
+
expect(descriptor.controller).toEqual(controller_class);
|
21
|
+
expect(descriptor.action).toEqual("index");
|
22
|
+
});
|
23
|
+
|
24
|
+
it("from controller (klass) and action name (string)", function() {
|
25
|
+
descriptor = map.getRouteDescriptor(controller_class, "action_name");
|
26
|
+
expect(descriptor.controller).toEqual(controller_class);
|
27
|
+
expect(descriptor.action).toEqual("action_name");
|
28
|
+
});
|
29
|
+
});
|
30
|
+
|
31
|
+
describe("with a map", function() {
|
32
|
+
beforeEach(function() { map.map("generic/index", controller_class, "index"); });
|
33
|
+
it("should recognize the route without /index", function() {
|
34
|
+
var route = map.recognize_route("generic");
|
35
|
+
|
36
|
+
expect(route.controller).toEqual(controller_class);
|
37
|
+
expect(route.action).toEqual("index");
|
38
|
+
});
|
39
|
+
});
|
40
|
+
|
41
|
+
describe("with a root", function() {
|
42
|
+
beforeEach(function() { map.root(controller_class, "index"); });
|
43
|
+
|
44
|
+
it("should recognize the root route", function() {
|
45
|
+
var route = map.recognize_route("/");
|
46
|
+
|
47
|
+
expect(route.controller).toEqual(controller_class);
|
48
|
+
expect(route.action).toEqual("index");
|
49
|
+
});
|
50
|
+
|
51
|
+
it("should dispatch to the root controller", function() {
|
52
|
+
spyOn(controller_class, 'invoke').andCallThrough();
|
53
|
+
map.dispatch("/");
|
54
|
+
expect(controller_class.invoke).toHaveBeenCalledWith("index", undefined);
|
55
|
+
});
|
56
|
+
|
57
|
+
it("should return the controller instance", function() {
|
58
|
+
expect(map.dispatch("/")).toBeKindOf(controller_class);
|
59
|
+
});
|
60
|
+
});
|
61
|
+
|
62
|
+
describe("with no root", function() {
|
63
|
+
it("should throw an error recognizing the root route", function() {
|
64
|
+
expect(function() { map.recognize_route("/") }).toThrow(new Error("Route not recognized: '/'"));
|
65
|
+
});
|
66
|
+
});
|
67
|
+
});
|
@@ -0,0 +1,17 @@
|
|
1
|
+
describe("Jax.ViewManager", function() {
|
2
|
+
var views;
|
3
|
+
|
4
|
+
beforeEach(function() { views = new Jax.ViewManager(); });
|
5
|
+
|
6
|
+
describe("with one registered view", function() {
|
7
|
+
beforeEach(function() { views.push("controller/action", function() { }); });
|
8
|
+
|
9
|
+
it("should return the registered view", function() {
|
10
|
+
expect(views.get("controller/action")).toBeKindOf(Jax.View);
|
11
|
+
});
|
12
|
+
|
13
|
+
it("should throw an error when requesting a missing view", function() {
|
14
|
+
expect(function() { return views.get("missing/action"); }).toThrow(new Error("Could not find view at 'missing/action'!"));
|
15
|
+
});
|
16
|
+
});
|
17
|
+
});
|
@@ -0,0 +1,159 @@
|
|
1
|
+
describe("Camera", function() {
|
2
|
+
var camera, control;
|
3
|
+
|
4
|
+
beforeEach(function() { camera = new Jax.Camera(); });
|
5
|
+
|
6
|
+
describe("by default", function() {
|
7
|
+
it("should have position [0,0,0]", function() { expect(camera.getPosition()).toEqualVector([0,0,0]); });
|
8
|
+
it("should have view [0,0,-1]", function() { expect(camera.getViewVector()).toEqualVector([0,0,-1]); });
|
9
|
+
it("should have right [1,0,0]", function() { expect(camera.getRightVector()).toEqualVector([1,0,0]); });
|
10
|
+
it("should have up [0,1,0]", function() { expect(camera.getUpVector()).toEqualVector([0,1,0]); });
|
11
|
+
});
|
12
|
+
|
13
|
+
describe("perspective projection", function() {
|
14
|
+
beforeEach(function() { camera.perspective({fov:45,near:0.1,far:500,width:2048,height:1024}); });
|
15
|
+
|
16
|
+
it("should have fov 45", function() { expect(camera.projection.fov).toEqual(45); });
|
17
|
+
it("should have near 0.1", function() { expect(camera.projection.near).toEqual(0.1); });
|
18
|
+
it("should have far 500", function() { expect(camera.projection.far).toEqual(500); });
|
19
|
+
it("should have width 2048", function() { expect(camera.projection.width).toEqual(2048); });
|
20
|
+
it("should have height 1024", function() { expect(camera.projection.height).toEqual(1024); });
|
21
|
+
});
|
22
|
+
|
23
|
+
describe("ortho projection", function() {
|
24
|
+
beforeEach(function() { camera.ortho({left:-1,right:2,top:3,bottom:-4,near:0.1,far:500}); });
|
25
|
+
|
26
|
+
it("should have left -1", function() { expect(camera.projection.left).toEqual(-1); });
|
27
|
+
it("should have right 2", function() { expect(camera.projection.right).toEqual(2); });
|
28
|
+
it("should have top 3", function() { expect(camera.projection.top).toEqual(3); });
|
29
|
+
it("should have bottom -4", function() { expect(camera.projection.bottom).toEqual(-4); });
|
30
|
+
it("should have near 0.1", function() { expect(camera.projection.near).toEqual(0.1); });
|
31
|
+
it("should have far 500", function() { expect(camera.projection.far).toEqual(500); });
|
32
|
+
});
|
33
|
+
|
34
|
+
it("should set and get position accurately", function() {
|
35
|
+
camera.setPosition(20, 0, 20);
|
36
|
+
expect(camera.getPosition()).toEqualVector([20,0,20]);
|
37
|
+
});
|
38
|
+
|
39
|
+
it("should lookAt the origin without losing position", function() {
|
40
|
+
camera.setPosition(20, 0, 20);
|
41
|
+
expect(camera.getPosition()).toEqualVector([20,0,20]);
|
42
|
+
camera.lookAt([0,0,0], [0,1,0]);
|
43
|
+
expect(camera.getPosition()).toEqualVector([20,0,20]);
|
44
|
+
});
|
45
|
+
|
46
|
+
it("should set view relative to position", function() {
|
47
|
+
camera.setPosition(10, 10, 10);
|
48
|
+
camera.orient([-1, 0, 0], [0, 1, 0]);
|
49
|
+
|
50
|
+
expect(camera.getPosition()).toEqualVector([10,10,10]);
|
51
|
+
expect(camera.getViewVector()).toEqualVector([-1,0,0]);
|
52
|
+
expect(camera.getUpVector()).toEqualVector([0,1,0]);
|
53
|
+
});
|
54
|
+
|
55
|
+
describe("orienting the camera after translation", function() {
|
56
|
+
beforeEach(function() {
|
57
|
+
camera.setPosition(100, 100, 100);
|
58
|
+
camera.orient([0, 0, -1], [0, 1, 0]);
|
59
|
+
});
|
60
|
+
|
61
|
+
it("should not change its position", function() { expect(camera.getPosition()).toEqualVector([100,100,100]); });
|
62
|
+
|
63
|
+
});
|
64
|
+
|
65
|
+
describe("orientation", function() {
|
66
|
+
it(" pos(0,0,1), view(0,-1,0)", function() {
|
67
|
+
camera.setPosition(0,0,1);
|
68
|
+
camera.orient(0,-1,0);
|
69
|
+
expect(camera.getViewVector()).toEqualVector([0,-1,0]);
|
70
|
+
});
|
71
|
+
});
|
72
|
+
|
73
|
+
describe("looking", function() {
|
74
|
+
beforeEach(function() { camera.lookAt([0,0,-1], [0,1,0], [0,0,0]); });
|
75
|
+
|
76
|
+
it("should return position accurately", function() {
|
77
|
+
expect(camera.getPosition()).toEqualVector([0,0,0]);
|
78
|
+
});
|
79
|
+
|
80
|
+
it("should return view accurately", function() {
|
81
|
+
expect(camera.getViewVector()).toEqualVector([0,0,-1]);
|
82
|
+
});
|
83
|
+
|
84
|
+
it("should return up accurately", function() {
|
85
|
+
expect(camera.getUpVector()).toEqualVector([0,1,0]);
|
86
|
+
});
|
87
|
+
|
88
|
+
it("should return right accurately", function() {
|
89
|
+
expect(camera.getRightVector()).toEqualVector([1,0,0]);
|
90
|
+
});
|
91
|
+
});
|
92
|
+
|
93
|
+
it("should set the position using numbers", function() {
|
94
|
+
camera.setPosition(1, 1, 1);
|
95
|
+
expect(camera.getPosition()).toEqualVector([1,1,1]);
|
96
|
+
});
|
97
|
+
|
98
|
+
it("should set the position using a vector", function() {
|
99
|
+
camera.setPosition([1,1,1]);
|
100
|
+
expect(camera.getPosition()).toEqualVector([1,1,1]);
|
101
|
+
});
|
102
|
+
|
103
|
+
describe("orienting the camera with numeric arguments and no position", function() {
|
104
|
+
beforeEach(function() {
|
105
|
+
camera.orient(0, 0, 1, 0, -1, 0);
|
106
|
+
});
|
107
|
+
|
108
|
+
it("position should be 0,0,0", function() { expect(camera.getPosition()).toEqualVector([0,0,0]); });
|
109
|
+
it("view should be 0,0,1", function() { expect(camera.getViewVector()).toEqualVector([0, 0, 1]); });
|
110
|
+
it("up should be 0,-1,0", function() { expect(camera.getUpVector()).toEqualVector([0, -1, 0]); });
|
111
|
+
it("right should be 1,0,0", function() { expect(camera.getRightVector()).toEqualVector([1, 0, 0]); });
|
112
|
+
});
|
113
|
+
|
114
|
+
it("should strafe right", function() {
|
115
|
+
camera.strafe(10);
|
116
|
+
expect(camera.getPosition()).toEqualVector([10, 0, 0]);
|
117
|
+
});
|
118
|
+
|
119
|
+
it("should strafe left", function() {
|
120
|
+
camera.strafe(-10);
|
121
|
+
expect(camera.getPosition()).toEqualVector([-10, 0, 0]);
|
122
|
+
});
|
123
|
+
|
124
|
+
it("should move forward", function() {
|
125
|
+
camera.move(10);
|
126
|
+
expect(camera.getPosition()).toEqualVector([0,0,-10]);
|
127
|
+
});
|
128
|
+
|
129
|
+
it("should move backward", function() {
|
130
|
+
camera.move(-10);
|
131
|
+
expect(camera.getPosition()).toEqualVector([0,0,10]);
|
132
|
+
});
|
133
|
+
|
134
|
+
it("should move 'forward' along a given vector", function() {
|
135
|
+
camera.move(10, [0,1,0]);
|
136
|
+
expect(camera.getPosition()).toEqualVector([0,10,0]);
|
137
|
+
});
|
138
|
+
|
139
|
+
it("should move 'backward' along a given vector", function() {
|
140
|
+
camera.move(-10, [0,1,0]);
|
141
|
+
expect(camera.getPosition()).toEqualVector([0,-10,0]);
|
142
|
+
});
|
143
|
+
|
144
|
+
describe("events", function() {
|
145
|
+
beforeEach(function() {
|
146
|
+
spyOn(camera, 'fireEvent').andCallThrough();
|
147
|
+
});
|
148
|
+
|
149
|
+
it("should fire matrixUpdated when setPosition called", function() {
|
150
|
+
camera.setPosition(1, 1, 1);
|
151
|
+
expect(camera.fireEvent).toHaveBeenCalledWith('matrixUpdated');
|
152
|
+
});
|
153
|
+
|
154
|
+
it("should fire matrixUpdated when orient called", function() {
|
155
|
+
camera.orient(0, 0, -1, 0, 1, 0);
|
156
|
+
expect(camera.fireEvent).toHaveBeenCalledWith('matrixUpdated');
|
157
|
+
});
|
158
|
+
});
|
159
|
+
});
|