jax 0.0.0.9 → 0.0.0.10
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +6 -0
- data/jax.gemspec +6 -2
- data/lib/jax/generators/app/templates/public/javascripts/jax.js +1 -1
- data/lib/jax/version.rb +1 -1
- metadata +3 -533
- 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/dungeon-complete.png +0 -0
- data/guides/assets/images/getting_started/dungeon-normal-map.png +0 -0
- data/guides/assets/images/getting_started/dungeon-rainbow-textured.png +0 -0
- data/guides/assets/images/getting_started/dungeon-rainbow.png +0 -0
- data/guides/assets/images/getting_started/dungeon-textured-lighting.png +0 -0
- data/guides/assets/images/getting_started/dungeon-textured.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/getting_started/teapot-red-directional-point.png +0 -0
- data/guides/assets/images/getting_started/teapot-red-directional.png +0 -0
- data/guides/assets/images/getting_started/teapot-red-nolight.png +0 -0
- data/guides/assets/images/getting_started/teapot-red-spot-point-directional.png +0 -0
- data/guides/assets/images/getting_started/teapot-white.png +0 -0
- data/guides/assets/images/getting_started/teapot-with-model.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 +0 -5
- 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 +0 -7
- data/guides/assets/javascripts/syntaxhighlighter/shBrushAS3.js +0 -59
- data/guides/assets/javascripts/syntaxhighlighter/shBrushAppleScript.js +0 -75
- data/guides/assets/javascripts/syntaxhighlighter/shBrushBash.js +0 -59
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCSharp.js +0 -65
- data/guides/assets/javascripts/syntaxhighlighter/shBrushColdFusion.js +0 -100
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCpp.js +0 -125
- data/guides/assets/javascripts/syntaxhighlighter/shBrushCss.js +0 -91
- data/guides/assets/javascripts/syntaxhighlighter/shBrushDelphi.js +0 -55
- data/guides/assets/javascripts/syntaxhighlighter/shBrushDiff.js +0 -41
- data/guides/assets/javascripts/syntaxhighlighter/shBrushErlang.js +0 -52
- data/guides/assets/javascripts/syntaxhighlighter/shBrushGroovy.js +0 -67
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJScript.js +0 -52
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJava.js +0 -57
- data/guides/assets/javascripts/syntaxhighlighter/shBrushJavaFX.js +0 -58
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPerl.js +0 -72
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPhp.js +0 -88
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPlain.js +0 -33
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPowerShell.js +0 -74
- data/guides/assets/javascripts/syntaxhighlighter/shBrushPython.js +0 -64
- data/guides/assets/javascripts/syntaxhighlighter/shBrushRuby.js +0 -55
- data/guides/assets/javascripts/syntaxhighlighter/shBrushSass.js +0 -94
- data/guides/assets/javascripts/syntaxhighlighter/shBrushScala.js +0 -51
- data/guides/assets/javascripts/syntaxhighlighter/shBrushSql.js +0 -66
- data/guides/assets/javascripts/syntaxhighlighter/shBrushVb.js +0 -56
- data/guides/assets/javascripts/syntaxhighlighter/shBrushXml.js +0 -69
- data/guides/assets/javascripts/syntaxhighlighter/shCore.js +0 -17
- data/guides/assets/stylesheets/fixes.css +0 -16
- data/guides/assets/stylesheets/main.css +0 -445
- data/guides/assets/stylesheets/print.css +0 -52
- data/guides/assets/stylesheets/reset.css +0 -43
- data/guides/assets/stylesheets/style.css +0 -13
- data/guides/assets/stylesheets/syntaxhighlighter/shCore.css +0 -226
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreDefault.css +0 -328
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreDjango.css +0 -331
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreEclipse.css +0 -339
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreEmacs.css +0 -324
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreFadeToGrey.css +0 -328
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreMDUltra.css +0 -324
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreMidnight.css +0 -324
- data/guides/assets/stylesheets/syntaxhighlighter/shCoreRDark.css +0 -324
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeDefault.css +0 -117
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeDjango.css +0 -120
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeEclipse.css +0 -128
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeEmacs.css +0 -113
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeFadeToGrey.css +0 -117
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeJaxGuides.css +0 -116
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeMDUltra.css +0 -113
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeMidnight.css +0 -113
- data/guides/assets/stylesheets/syntaxhighlighter/shThemeRDark.css +0 -113
- data/guides/jax_guides.rb +0 -41
- data/guides/jax_guides/common.rb +0 -7
- data/guides/jax_guides/generator.rb +0 -287
- data/guides/jax_guides/helpers.rb +0 -29
- data/guides/jax_guides/indexer.rb +0 -69
- data/guides/jax_guides/levenshtein.rb +0 -31
- data/guides/jax_guides/textile_extensions.rb +0 -61
- data/guides/partials/_top_nav.html.erb +0 -17
- data/guides/source/getting_started.textile +0 -1210
- data/guides/source/index.html.erb +0 -61
- data/guides/source/layout.html.erb +0 -147
- data/guides/source/lighting.textile +0 -5
- data/guides/source/materials.textile +0 -5
- data/guides/source/matrices.textile +0 -5
- data/guides/source/shaders.textile +0 -499
- data/guides/source/testing.textile +0 -5
- data/guides/w3c_validator.rb +0 -91
- 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 +0 -26
- data/spec/example_app/Gemfile +0 -1
- data/spec/example_app/Rakefile +0 -15
- data/spec/example_app/app/controllers/application_controller.js +0 -5
- data/spec/example_app/app/controllers/courthouse_controller.js +0 -24
- data/spec/example_app/app/controllers/lighting_controller.js +0 -67
- data/spec/example_app/app/controllers/noise_controller.js +0 -50
- data/spec/example_app/app/controllers/picking_controller.js +0 -32
- data/spec/example_app/app/controllers/shadows_controller.js +0 -130
- data/spec/example_app/app/controllers/textures_controller.js +0 -52
- data/spec/example_app/app/helpers/application_helper.js +0 -3
- data/spec/example_app/app/helpers/noise_helper.js +0 -3
- data/spec/example_app/app/helpers/picking_helper.js +0 -3
- data/spec/example_app/app/helpers/textures_helper.js +0 -3
- data/spec/example_app/app/models/blob.js +0 -38
- data/spec/example_app/app/models/character.js +0 -23
- data/spec/example_app/app/models/door.js +0 -10
- data/spec/example_app/app/models/scene.js +0 -19
- data/spec/example_app/app/resources/blobs/default.yml +0 -2
- data/spec/example_app/app/resources/characters/judge.yml +0 -3
- data/spec/example_app/app/resources/doors/courthouse_door.yml +0 -5
- data/spec/example_app/app/resources/light_sources/directional_light.yml +0 -13
- data/spec/example_app/app/resources/light_sources/point_light.yml +0 -31
- data/spec/example_app/app/resources/light_sources/spot_light.yml +0 -15
- data/spec/example_app/app/resources/light_sources/sun.yml +0 -7
- data/spec/example_app/app/resources/light_sources/textures_point.yml +0 -34
- data/spec/example_app/app/resources/materials/blob.yml +0 -28
- data/spec/example_app/app/resources/materials/bricks.yml +0 -36
- data/spec/example_app/app/resources/materials/lighting_with_shadows.yml +0 -27
- data/spec/example_app/app/resources/scenes/courthouse.yml +0 -4
- data/spec/example_app/app/shaders/blob/common.ejs +0 -13
- data/spec/example_app/app/shaders/blob/fragment.ejs +0 -8
- data/spec/example_app/app/shaders/blob/manifest.yml +0 -15
- data/spec/example_app/app/shaders/blob/material.js +0 -51
- data/spec/example_app/app/shaders/blob/vertex.ejs +0 -40
- data/spec/example_app/app/views/courthouse/index.js +0 -4
- data/spec/example_app/app/views/lighting/index.js +0 -4
- data/spec/example_app/app/views/noise/index.js +0 -4
- data/spec/example_app/app/views/picking/index.js +0 -4
- data/spec/example_app/app/views/shadows/index.js +0 -6
- data/spec/example_app/app/views/textures/index.js +0 -4
- data/spec/example_app/config/application.rb +0 -6
- data/spec/example_app/config/boot.rb +0 -13
- data/spec/example_app/config/routes.rb +0 -8
- 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 +0 -26
- data/spec/example_app/script/jax +0 -7
- data/spec/example_app/spec/javascripts/controllers/noise_controller_spec.js +0 -11
- data/spec/example_app/spec/javascripts/controllers/picking_controller_spec.js +0 -11
- data/spec/example_app/spec/javascripts/controllers/textures_controller_spec.js +0 -11
- data/spec/example_app/spec/javascripts/helpers/application_helper_spec.js +0 -12
- data/spec/example_app/spec/javascripts/helpers/noise_helper_spec.js +0 -12
- data/spec/example_app/spec/javascripts/helpers/picking_helper_spec.js +0 -12
- data/spec/example_app/spec/javascripts/models/blob_spec.js +0 -11
- data/spec/example_app/spec/javascripts/resources/directional_light_spec.js +0 -16
- data/spec/example_app/spec/javascripts/resources/point_light_spec.js +0 -17
- data/spec/example_app/spec/javascripts/resources/spot_light_spec.js +0 -18
- data/spec/example_app/spec/javascripts/shaders/blob_spec.js +0 -27
- data/spec/example_app/spec/javascripts/support/jasmine.yml +0 -89
- data/spec/example_app/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/spec/example_app/spec/javascripts/support/spec_helpers/jax_spec_environment_helper.js +0 -33
- data/spec/example_app/spec/javascripts/support/spec_helpers/jax_spec_helper.js +0 -93
- data/spec/example_app/spec/javascripts/support/spec_layout.html.erb +0 -111
- data/spec/javascripts/helpers/jax_spec_environment_helper.js +0 -33
- data/spec/javascripts/helpers/jax_spec_helper.js +0 -216
- data/spec/javascripts/jax/builtin/meshes/cube_spec.js +0 -10
- data/spec/javascripts/jax/builtin/meshes/plane_spec.js +0 -8
- data/spec/javascripts/jax/builtin/meshes/quad_spec.js +0 -8
- data/spec/javascripts/jax/builtin/meshes/sphere_spec.js +0 -8
- data/spec/javascripts/jax/builtin/meshes/teapot_spec.js +0 -8
- data/spec/javascripts/jax/builtin/meshes/torus_spec.js +0 -8
- data/spec/javascripts/jax/compatibility_spec.js +0 -50
- data/spec/javascripts/jax/context_spec.js +0 -82
- data/spec/javascripts/jax/controller_spec.js +0 -145
- data/spec/javascripts/jax/core/delegation_spec.js +0 -48
- data/spec/javascripts/jax/core/events_spec.js +0 -17
- data/spec/javascripts/jax/core/matrix_stack_spec.js +0 -28
- data/spec/javascripts/jax/core/utils_spec.js +0 -275
- data/spec/javascripts/jax/helper_spec.js +0 -33
- data/spec/javascripts/jax/model_spec.js +0 -97
- data/spec/javascripts/jax/optimizations/material_limitations_spec.js +0 -87
- data/spec/javascripts/jax/optimizations/shaders/basic_spec.js +0 -68
- data/spec/javascripts/jax/prototype/extensions_spec.js +0 -34
- data/spec/javascripts/jax/route_set_spec.js +0 -67
- data/spec/javascripts/jax/view_manager_spec.js +0 -17
- data/spec/javascripts/jax/webgl/camera_spec.js +0 -159
- data/spec/javascripts/jax/webgl/framebuffer_spec.js +0 -46
- data/spec/javascripts/jax/webgl/lighting_spec.js +0 -61
- data/spec/javascripts/jax/webgl/material_spec.js +0 -118
- data/spec/javascripts/jax/webgl/mesh_spec.js +0 -86
- data/spec/javascripts/jax/webgl/shader/manifest_spec.js +0 -60
- data/spec/javascripts/jax/webgl/shader_chain_spec.js +0 -192
- data/spec/javascripts/jax/webgl/shader_spec.js +0 -276
- data/spec/javascripts/jax/webgl/tangent_space_spec.js +0 -142
- data/spec/javascripts/jax/webgl/texture_spec.js +0 -162
- data/spec/javascripts/jax/webgl_spec.js +0 -5
- data/spec/javascripts/jax/world_spec.js +0 -161
- data/spec/javascripts/jax_spec.js +0 -27
- data/spec/javascripts/shaders/core_materials_spec.js +0 -42
- data/spec/javascripts/shaders/fog_spec.js +0 -19
- data/spec/javascripts/shaders/lighting_spec.js +0 -19
- data/spec/javascripts/shaders/normal_map_spec.js +0 -19
- data/spec/javascripts/shaders/paraboloid_spec.js +0 -37
- data/spec/javascripts/shaders/preprocessor_spec.js +0 -50
- data/spec/javascripts/shaders/shadow_map_spec.js +0 -19
- data/spec/javascripts/shaders/texture_spec.js +0 -40
- data/src/constants.yml +0 -1
- data/src/constants.yml.erb +0 -1
- data/src/jax.js +0 -119
- data/src/jax/anim_frame.js +0 -51
- data/src/jax/builtin/all.js +0 -7
- data/src/jax/builtin/meshes/cube.js +0 -83
- data/src/jax/builtin/meshes/plane.js +0 -63
- data/src/jax/builtin/meshes/quad.js +0 -86
- data/src/jax/builtin/meshes/sphere.js +0 -65
- data/src/jax/builtin/meshes/teapot.js +0 -48
- data/src/jax/builtin/meshes/torus.js +0 -64
- data/src/jax/compatibility.js +0 -303
- data/src/jax/context.js +0 -420
- data/src/jax/core.js +0 -42
- data/src/jax/core/math.js +0 -55
- data/src/jax/core/matrix_stack.js +0 -311
- data/src/jax/core/util.js +0 -253
- data/src/jax/events.js +0 -234
- data/src/jax/geometry.js +0 -7
- data/src/jax/geometry/plane.js +0 -113
- data/src/jax/mvc/controller.js +0 -195
- data/src/jax/mvc/helper.js +0 -35
- data/src/jax/mvc/model.js +0 -302
- data/src/jax/mvc/route_set.js +0 -125
- data/src/jax/mvc/view.js +0 -43
- data/src/jax/mvc/view_manager.js +0 -47
- data/src/jax/noise.js +0 -206
- data/src/jax/prototype/class.js +0 -81
- data/src/jax/prototype/core.js +0 -112
- data/src/jax/prototype/extensions.js +0 -142
- data/src/jax/vendor/ejs.js +0 -4
- data/src/jax/vendor/glMatrix.js +0 -3
- data/src/jax/webgl.js +0 -98
- data/src/jax/webgl/camera.js +0 -526
- data/src/jax/webgl/core.js +0 -6
- data/src/jax/webgl/core/buffer.js +0 -161
- data/src/jax/webgl/core/edge.js +0 -6
- data/src/jax/webgl/core/events.js +0 -25
- data/src/jax/webgl/core/face.js +0 -8
- data/src/jax/webgl/core/framebuffer.js +0 -211
- data/src/jax/webgl/material.js +0 -392
- data/src/jax/webgl/mesh.js +0 -427
- data/src/jax/webgl/scene.js +0 -11
- data/src/jax/webgl/scene/frustum.js +0 -260
- data/src/jax/webgl/scene/light_manager.js +0 -136
- data/src/jax/webgl/scene/light_source.js +0 -294
- data/src/jax/webgl/shader.js +0 -296
- data/src/jax/webgl/shader/delegator.js +0 -13
- data/src/jax/webgl/shader/delegator/attribute.js +0 -53
- data/src/jax/webgl/shader/delegator/uniform.js +0 -71
- data/src/jax/webgl/shader/manifest.js +0 -64
- data/src/jax/webgl/shader/program.js +0 -140
- data/src/jax/webgl/shader_chain.js +0 -264
- data/src/jax/webgl/texture.js +0 -312
- data/src/jax/webgl/world.js +0 -240
- data/vendor/ejs/.svn/all-wcprops +0 -17
- data/vendor/ejs/.svn/entries +0 -114
- data/vendor/ejs/.svn/text-base/Eratta.txt.svn-base +0 -3
- data/vendor/ejs/.svn/text-base/license.txt.svn-base +0 -21
- data/vendor/ejs/Eratta.txt +0 -3
- data/vendor/ejs/example/.svn/all-wcprops +0 -29
- data/vendor/ejs/example/.svn/entries +0 -164
- data/vendor/ejs/example/.svn/prop-base/ejs.gif.svn-base +0 -5
- data/vendor/ejs/example/.svn/text-base/demo.html.svn-base +0 -54
- data/vendor/ejs/example/.svn/text-base/ejs.gif.svn-base +0 -0
- data/vendor/ejs/example/.svn/text-base/example.css.svn-base +0 -31
- data/vendor/ejs/example/.svn/text-base/example.js.svn-base +0 -88
- data/vendor/ejs/example/demo.html +0 -54
- data/vendor/ejs/example/ejs.gif +0 -0
- data/vendor/ejs/example/example.css +0 -31
- data/vendor/ejs/example/example.js +0 -88
- data/vendor/ejs/lib/.svn/all-wcprops +0 -11
- data/vendor/ejs/lib/.svn/entries +0 -62
- data/vendor/ejs/lib/.svn/text-base/ejs_fulljslint.js.svn-base +0 -3774
- data/vendor/ejs/lib/ejs_fulljslint.js +0 -3774
- data/vendor/ejs/license.txt +0 -21
- data/vendor/ejs/script/.svn/all-wcprops +0 -17
- data/vendor/ejs/script/.svn/entries +0 -96
- data/vendor/ejs/script/.svn/prop-base/yuicompressor-2.2.4.jar.svn-base +0 -5
- data/vendor/ejs/script/.svn/text-base/production.bat.svn-base +0 -4
- data/vendor/ejs/script/.svn/text-base/yuicompressor-2.2.4.jar.svn-base +0 -0
- data/vendor/ejs/script/production.bat +0 -4
- data/vendor/ejs/script/yuicompressor-2.2.4.jar +0 -0
- data/vendor/ejs/src/.svn/all-wcprops +0 -17
- data/vendor/ejs/src/.svn/entries +0 -96
- data/vendor/ejs/src/.svn/text-base/ejs.js.svn-base +0 -505
- data/vendor/ejs/src/.svn/text-base/view.js.svn-base +0 -200
- data/vendor/ejs/src/ejs.js +0 -505
- data/vendor/ejs/src/view.js +0 -200
- data/vendor/ejs/test/.svn/all-wcprops +0 -23
- data/vendor/ejs/test/.svn/entries +0 -139
- data/vendor/ejs/test/.svn/text-base/index.html.svn-base +0 -18
- data/vendor/ejs/test/.svn/text-base/setup_test.html.svn-base +0 -44
- data/vendor/ejs/test/.svn/text-base/sidebar.html.svn-base +0 -28
- data/vendor/ejs/test/included/.svn/all-wcprops +0 -23
- data/vendor/ejs/test/included/.svn/entries +0 -130
- data/vendor/ejs/test/included/.svn/text-base/prototype.js.svn-base +0 -4184
- data/vendor/ejs/test/included/.svn/text-base/test.css.svn-base +0 -44
- data/vendor/ejs/test/included/.svn/text-base/unittest.js.svn-base +0 -564
- data/vendor/ejs/test/included/prototype.js +0 -4184
- data/vendor/ejs/test/included/test.css +0 -44
- data/vendor/ejs/test/included/unittest.js +0 -564
- data/vendor/ejs/test/index.html +0 -18
- data/vendor/ejs/test/setup_test.html +0 -44
- data/vendor/ejs/test/sidebar.html +0 -28
- data/vendor/ejs/test/templates/.svn/all-wcprops +0 -11
- data/vendor/ejs/test/templates/.svn/entries +0 -62
- data/vendor/ejs/test/templates/.svn/text-base/test.ejs.svn-base +0 -3
- data/vendor/ejs/test/templates/test.ejs +0 -3
- data/vendor/ejs/test/tests/.svn/all-wcprops +0 -23
- data/vendor/ejs/test/tests/.svn/entries +0 -130
- data/vendor/ejs/test/tests/.svn/text-base/rendering.js.svn-base +0 -94
- data/vendor/ejs/test/tests/.svn/text-base/templating.js.svn-base +0 -43
- data/vendor/ejs/test/tests/.svn/text-base/views.js.svn-base +0 -100
- data/vendor/ejs/test/tests/rendering.js +0 -94
- data/vendor/ejs/test/tests/templating.js +0 -43
- data/vendor/ejs/test/tests/views.js +0 -100
- data/vendor/glmatrix/benchmark/js/CanvasMatrix.js +0 -722
- data/vendor/glmatrix/benchmark/js/EWGL_math.js +0 -742
- data/vendor/glmatrix/benchmark/js/mjs.js +0 -1230
- data/vendor/glmatrix/benchmark/matrix_benchmark.html +0 -419
- data/vendor/glmatrix/glMatrix-min.js +0 -32
- data/vendor/glmatrix/glMatrix.js +0 -1772
- data/vendor/glmatrix/unit tests/glMatrix-test.js +0 -74
- data/vendor/glmatrix/unit tests/qunit.css +0 -119
- data/vendor/glmatrix/unit tests/qunit.js +0 -1069
- data/vendor/glmatrix/unit tests/test_glMatrix.html +0 -21
- data/vendor/pdoc_template/html/assets/images/pdoc/alias.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/class_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constant.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/constructor.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/description.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/information.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/instance_property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/method_deprecated.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/mixin.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/namespace.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/property.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/related_to.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/search-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/section.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/selected-section-background.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/subclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/superclass.png +0 -0
- data/vendor/pdoc_template/html/assets/images/pdoc/utility.png +0 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/application.js +0 -478
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/prototype.js +0 -4874
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/tabs.js +0 -506
- data/vendor/pdoc_template/html/assets/stylesheets/jax.css +0 -30
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/api.css +0 -681
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/pygments.css +0 -62
- data/vendor/pdoc_template/html/helpers.rb +0 -35
- data/vendor/pdoc_template/html/index.erb +0 -18
- data/vendor/pdoc_template/html/item_index.js.erb +0 -6
- data/vendor/pdoc_template/html/layout.erb +0 -67
- data/vendor/pdoc_template/html/leaf.erb +0 -22
- data/vendor/pdoc_template/html/node.erb +0 -30
- data/vendor/pdoc_template/html/partials/class_relationships.erb +0 -19
- data/vendor/pdoc_template/html/partials/classes.erb +0 -7
- data/vendor/pdoc_template/html/partials/constructor.erb +0 -5
- data/vendor/pdoc_template/html/partials/description.erb +0 -5
- data/vendor/pdoc_template/html/partials/link_list.erb +0 -1
- data/vendor/pdoc_template/html/partials/method_signatures.erb +0 -14
- data/vendor/pdoc_template/html/partials/methodized_note.erb +0 -9
- data/vendor/pdoc_template/html/partials/mixins.erb +0 -7
- data/vendor/pdoc_template/html/partials/namespaces.erb +0 -7
- data/vendor/pdoc_template/html/partials/related_utilities.erb +0 -5
- data/vendor/pdoc_template/html/partials/relationships.erb +0 -11
- data/vendor/pdoc_template/html/partials/short_description_list.erb +0 -7
- data/vendor/pdoc_template/html/partials/title.erb +0 -24
- data/vendor/pdoc_template/html/section.erb +0 -18
- data/vendor/yuicompressor-2.4.2.jar +0 -0
@@ -1,33 +0,0 @@
|
|
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
|
-
});
|
@@ -1,97 +0,0 @@
|
|
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("added to world without a mesh", function() {
|
28
|
-
var context;
|
29
|
-
beforeEach(function() { model = new (Jax.Model.create({after_initialize:function(){}}))({position:[0,0,0]}); context = new Jax.Context('canvas-element'); context.world.addObject(model); });
|
30
|
-
afterEach(function() { context.dispose(); });
|
31
|
-
|
32
|
-
it("should not cause errors when rendering", function() {
|
33
|
-
expect(function() { context.world.render(); }).not.toThrow();
|
34
|
-
});
|
35
|
-
});
|
36
|
-
|
37
|
-
describe("without any custom methods", function() {
|
38
|
-
beforeEach(function() {
|
39
|
-
model = Jax.Model.create({
|
40
|
-
initialize: function($super, data) { $super(Jax.Util.normalizeOptions(data, {mesh:new Jax.Mesh.Quad()})); }
|
41
|
-
});
|
42
|
-
});
|
43
|
-
|
44
|
-
describe("instantiated", function() {
|
45
|
-
beforeEach(function() { model = new model(); });
|
46
|
-
|
47
|
-
describe("that is not a shadowcaster", function() {
|
48
|
-
beforeEach(function() { model.shadow_caster = false; });
|
49
|
-
it("should still be lit", function() { expect(model).toBeIlluminated(); });
|
50
|
-
});
|
51
|
-
|
52
|
-
describe("that is not lit", function() {
|
53
|
-
beforeEach(function() { model.lit = false; });
|
54
|
-
it("should not be rendered in illumination pass", function() {
|
55
|
-
expect(model).not.toBeIlluminated();
|
56
|
-
});
|
57
|
-
});
|
58
|
-
|
59
|
-
it("should render properly", function() {
|
60
|
-
var context = new Jax.Context('canvas-element');
|
61
|
-
model.render(context);
|
62
|
-
context.dispose();
|
63
|
-
});
|
64
|
-
});
|
65
|
-
|
66
|
-
it("should fire after_initialize", function() {
|
67
|
-
model.addResources({ "name": { fired: false } });
|
68
|
-
model.addMethods({ after_initialize: function() { this.fired = true; } });
|
69
|
-
expect(model.find("name").fired).toBeTrue();
|
70
|
-
});
|
71
|
-
|
72
|
-
it("should raise an error when searching for a missing ID", function() {
|
73
|
-
model.addResources({"one": { } });
|
74
|
-
expect(function() { model.find("two") }).toThrow(new Error("Resource 'two' not found!"));
|
75
|
-
});
|
76
|
-
|
77
|
-
it("should assign default attribute values", function() {
|
78
|
-
model.addResources({'default':{one:'one'},'name':{two:'two'}});
|
79
|
-
expect(model.find('name').one).toEqual("one");
|
80
|
-
expect(model.find('name').two).toEqual("two");
|
81
|
-
});
|
82
|
-
|
83
|
-
it("should assign attribute values", function() {
|
84
|
-
model.addResources({ "name": { one: "one" } });
|
85
|
-
expect(model.find("name").one).toEqual("one");
|
86
|
-
});
|
87
|
-
|
88
|
-
it("should instantiate a model that is missing default attributes", function() {
|
89
|
-
expect(function() { new model(); }).not.toThrow();
|
90
|
-
});
|
91
|
-
});
|
92
|
-
|
93
|
-
describe("with a custom method", function() {
|
94
|
-
beforeEach(function() { model = Jax.Model.create({method: function() { return "called"; } }); });
|
95
|
-
it("should work", function() { expect(new model().method()).toEqual("called"); });
|
96
|
-
});
|
97
|
-
});
|
@@ -1,87 +0,0 @@
|
|
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
|
-
});
|
@@ -1,68 +0,0 @@
|
|
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
|
-
});
|
@@ -1,34 +0,0 @@
|
|
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
|
-
});
|
@@ -1,67 +0,0 @@
|
|
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
|
-
});
|
@@ -1,17 +0,0 @@
|
|
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
|
-
});
|
@@ -1,159 +0,0 @@
|
|
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
|
-
});
|