jax 1.1.1 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -0
- data/.rvmrc +2 -3
- data/.travis.yml +8 -22
- data/README.md +2 -2
- data/Rakefile +128 -96
- data/app/assets/javascripts/jax/controller-list.js.coffee +22 -0
- data/app/assets/javascripts/jax/dom-helpers.js.coffee +17 -0
- data/app/assets/javascripts/jax/jasmine_runner.js +177 -0
- data/app/assets/javascripts/jax/runtime.js +6 -0
- data/app/assets/javascripts/jax/shader_editor.js.coffee +33 -0
- data/app/assets/stylesheets/jax/controller-list.css +5 -0
- data/app/assets/stylesheets/jax/jasmine.css +16 -0
- data/app/assets/stylesheets/jax/nav.css +41 -0
- data/app/assets/stylesheets/jax/runtime.css +47 -0
- data/app/assets/stylesheets/jax/shader_editor.css +3 -0
- data/app/assets/stylesheets/jax/suite.css +82 -0
- data/app/controllers/jax/suite_controller.rb +48 -0
- data/app/views/jax/suite/jasmine.html.erb +38 -0
- data/app/views/jax/suite/run_webgl.html.erb +49 -0
- data/app/views/jax/suite/shader_editor.html.erb +24 -0
- data/app/views/layouts/jax.html.erb +40 -0
- data/bin/jax +8 -4
- data/config/routes.rb +2 -0
- data/config.ru +5 -0
- data/features/rails/resources.feature +45 -0
- data/features/rails/shaders.feature +13 -0
- data/features/rails/specs.feature +24 -0
- data/features/runtime.feature +15 -0
- data/features/step_definitions/environment_steps.rb +15 -0
- data/features/step_definitions/response_steps.rb +13 -0
- data/features/step_definitions/runtime.rb +11 -0
- data/features/step_definitions/web_steps.rb +223 -0
- data/features/support/env.rb +75 -0
- data/features/support/paths.rb +30 -0
- data/features/support/rails_environment.rb +3 -0
- data/features/support/selectors.rb +39 -0
- data/features/support/setup.rb +17 -0
- data/jax.gemspec +22 -16
- data/lib/assets/javascripts/jax/anim_frame.js +64 -0
- data/lib/assets/javascripts/jax/application.js +16 -0
- data/lib/assets/javascripts/jax/builtin/all.js +21 -0
- data/lib/assets/javascripts/jax/builtin/meshes/cube.js +83 -0
- data/lib/assets/javascripts/jax/builtin/meshes/plane.js +67 -0
- data/lib/assets/javascripts/jax/builtin/meshes/quad.js +89 -0
- data/lib/assets/javascripts/jax/builtin/meshes/sphere.js +65 -0
- data/lib/assets/javascripts/jax/builtin/meshes/teapot.js +48 -0
- data/lib/assets/javascripts/jax/builtin/meshes/torus.js +64 -0
- data/lib/assets/javascripts/jax/compatibility.js +312 -0
- data/lib/assets/javascripts/jax/context.js +741 -0
- data/lib/assets/javascripts/jax/core/base.js +69 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat3.js +20 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/mat4.js +10 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/quat4.js +148 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec2.js +25 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec3.js +86 -0
- data/lib/assets/javascripts/jax/core/glMatrix_ext/vec4.js +28 -0
- data/lib/assets/javascripts/jax/core/helper.js +44 -0
- data/lib/assets/javascripts/jax/core/math.js +61 -0
- data/lib/assets/javascripts/jax/core/matrix_stack.js +310 -0
- data/lib/assets/javascripts/jax/core/util.js +271 -0
- data/lib/assets/javascripts/jax/core.js +43 -0
- data/lib/assets/javascripts/jax/events.js +304 -0
- data/lib/assets/javascripts/jax/geometry/line.js +185 -0
- data/lib/assets/javascripts/jax/geometry/plane.js +371 -0
- data/lib/assets/javascripts/jax/geometry/triangle/inliner.rb +94 -0
- data/lib/assets/javascripts/jax/geometry/triangle/slow_tri_tri_intersect.js +20 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect.js +281 -0
- data/lib/assets/javascripts/jax/geometry/triangle/tri_tri_intersect_optimized.js +564 -0
- data/lib/assets/javascripts/jax/geometry/triangle.js +311 -0
- data/lib/assets/javascripts/jax/geometry.js +14 -0
- data/lib/assets/javascripts/jax/mvc/controller.js +188 -0
- data/lib/assets/javascripts/jax/mvc/model.js +302 -0
- data/lib/assets/javascripts/jax/mvc/route_set.js +148 -0
- data/lib/assets/javascripts/jax/mvc/view.js +43 -0
- data/lib/assets/javascripts/jax/mvc/view_manager.js +65 -0
- data/lib/assets/javascripts/jax/noise.js +251 -0
- data/lib/assets/javascripts/jax/prototype/class.js +81 -0
- data/lib/assets/javascripts/jax/prototype/core.js +112 -0
- data/lib/assets/javascripts/jax/prototype/extensions.js +142 -0
- data/lib/assets/javascripts/jax/vendor/ejs.js +1 -0
- data/lib/assets/javascripts/jax/vendor/glMatrix.js +7 -0
- data/lib/assets/javascripts/jax/webgl/camera.js +697 -0
- data/lib/assets/javascripts/jax/webgl/cleanup.js +1 -0
- data/lib/assets/javascripts/jax/webgl/core/buffer.js +292 -0
- data/lib/assets/javascripts/jax/webgl/core/data_region.js +184 -0
- data/lib/assets/javascripts/jax/webgl/core/data_segment.js +255 -0
- data/lib/assets/javascripts/jax/webgl/core/events.js +99 -0
- data/lib/assets/javascripts/jax/webgl/core/framebuffer.js +316 -0
- data/lib/assets/javascripts/jax/webgl/core.js +6 -0
- data/lib/assets/javascripts/jax/webgl/material.js +381 -0
- data/lib/assets/javascripts/jax/webgl/mesh/normals.js +37 -0
- data/lib/assets/javascripts/jax/webgl/mesh/support.js +104 -0
- data/lib/assets/javascripts/jax/webgl/mesh/tangent_space.js +111 -0
- data/lib/assets/javascripts/jax/webgl/mesh.js +440 -0
- data/lib/assets/javascripts/jax/webgl/scene/frustum.js +422 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_manager.js +141 -0
- data/lib/assets/javascripts/jax/webgl/scene/light_source.js +300 -0
- data/lib/assets/javascripts/jax/webgl/scene.js +16 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/attribute.js +53 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator/uniform.js +71 -0
- data/lib/assets/javascripts/jax/webgl/shader/delegator.js +13 -0
- data/lib/assets/javascripts/jax/webgl/shader/manifest.js +70 -0
- data/lib/assets/javascripts/jax/webgl/shader/program.js +138 -0
- data/lib/assets/javascripts/jax/webgl/shader.js +299 -0
- data/lib/assets/javascripts/jax/webgl/shader_chain.js +267 -0
- data/lib/assets/javascripts/jax/webgl/texture.js +506 -0
- data/lib/assets/javascripts/jax/webgl/world.js +279 -0
- data/lib/assets/javascripts/jax/webgl.js +109 -0
- data/lib/assets/javascripts/jax.js +136 -0
- data/{builtin/app/shaders/basic/common.ejs → lib/assets/javascripts/shaders/basic/common.glsl} +0 -0
- data/{builtin/app/shaders/basic/fragment.ejs → lib/assets/javascripts/shaders/basic/fragment.glsl} +0 -0
- data/{builtin/app/shaders/basic/vertex.ejs → lib/assets/javascripts/shaders/basic/vertex.glsl} +1 -1
- data/{builtin/app/shaders/depthmap/common.ejs → lib/assets/javascripts/shaders/depthmap/common.glsl} +0 -0
- data/{builtin/app/shaders/depthmap/fragment.ejs → lib/assets/javascripts/shaders/depthmap/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/depthmap/material.js +0 -0
- data/{builtin/app/shaders/depthmap/vertex.ejs → lib/assets/javascripts/shaders/depthmap/vertex.glsl} +0 -0
- data/{builtin/app/shaders/fog/common.ejs → lib/assets/javascripts/shaders/fog/common.glsl} +0 -0
- data/{builtin/app/shaders/fog/fragment.ejs → lib/assets/javascripts/shaders/fog/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/fog/material.js +6 -8
- data/{builtin/app/shaders/fog/vertex.ejs → lib/assets/javascripts/shaders/fog/vertex.glsl} +0 -0
- data/{builtin/app/shaders/functions/depth_map.ejs → lib/assets/javascripts/shaders/functions/depth_map.glsl} +0 -0
- data/{builtin/app/shaders/functions/lights.ejs → lib/assets/javascripts/shaders/functions/lights.glsl} +0 -0
- data/{builtin/app/shaders/functions/noise.ejs → lib/assets/javascripts/shaders/functions/noise.glsl} +0 -0
- data/lib/assets/javascripts/shaders/lighting/common.glsl +5 -0
- data/{builtin/app/shaders/lighting/fragment.ejs → lib/assets/javascripts/shaders/lighting/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/lighting/material.js +2 -4
- data/{builtin/app/shaders/lighting/vertex.ejs → lib/assets/javascripts/shaders/lighting/vertex.glsl} +0 -0
- data/{builtin/app/shaders/normal_map/common.ejs → lib/assets/javascripts/shaders/normal_map/common.glsl} +1 -1
- data/{builtin/app/shaders/normal_map/fragment.ejs → lib/assets/javascripts/shaders/normal_map/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/normal_map/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/normal_map/material.js +11 -0
- data/{builtin/app/shaders/normal_map/vertex.ejs → lib/assets/javascripts/shaders/normal_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/common.ejs → lib/assets/javascripts/shaders/paraboloid/common.glsl} +0 -0
- data/{builtin/app/shaders/paraboloid/fragment.ejs → lib/assets/javascripts/shaders/paraboloid/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/paraboloid/material.js +2 -4
- data/{builtin/app/shaders/paraboloid/vertex.ejs → lib/assets/javascripts/shaders/paraboloid/vertex.glsl} +0 -0
- data/{builtin/app/shaders/picking/common.ejs → lib/assets/javascripts/shaders/picking/common.glsl} +0 -0
- data/{builtin/app/shaders/picking/fragment.ejs → lib/assets/javascripts/shaders/picking/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/picking/material.js +2 -4
- data/{builtin/app/shaders/picking/vertex.ejs → lib/assets/javascripts/shaders/picking/vertex.glsl} +0 -0
- data/{builtin/app/shaders/shadow_map/common.ejs → lib/assets/javascripts/shaders/shadow_map/common.glsl} +2 -1
- data/{builtin/app/shaders/shadow_map/fragment.ejs → lib/assets/javascripts/shaders/shadow_map/fragment.glsl} +1 -1
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/manifest.yml +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/shadow_map/material.js +4 -6
- data/{builtin/app/shaders/shadow_map/vertex.ejs → lib/assets/javascripts/shaders/shadow_map/vertex.glsl} +0 -0
- data/{builtin/app/shaders/texture/common.ejs → lib/assets/javascripts/shaders/texture/common.glsl} +0 -0
- data/{builtin/app/shaders/texture/fragment.ejs → lib/assets/javascripts/shaders/texture/fragment.glsl} +0 -0
- data/{builtin/app → lib/assets/javascripts}/shaders/texture/manifest.yml +0 -0
- data/lib/assets/javascripts/shaders/texture/material.js +17 -0
- data/{builtin/app/shaders/texture/vertex.ejs → lib/assets/javascripts/shaders/texture/vertex.glsl} +0 -0
- data/lib/generators/jax/all.rb +16 -0
- data/lib/generators/jax/application/application_generator.rb +48 -0
- data/lib/generators/jax/base/actions.rb +52 -0
- data/lib/generators/jax/base/coffee_generator.rb +30 -0
- data/lib/generators/jax/base/named_base.rb +17 -0
- data/lib/generators/jax/base/plugin_base.rb +108 -0
- data/lib/generators/jax/base/plugin_credentials.rb +99 -0
- data/lib/generators/jax/base/plugin_manifest.rb +75 -0
- data/lib/generators/jax/base/rails_base.rb +30 -0
- data/lib/generators/jax/base/source_root.rb +5 -0
- data/lib/generators/jax/controller/controller_generator.rb +37 -0
- data/lib/generators/jax/helper/helper_generator.rb +30 -0
- data/lib/generators/jax/install/install_generator.rb +27 -0
- data/lib/generators/jax/jax_generator.rb +13 -0
- data/lib/generators/jax/light/light_generator.rb +23 -0
- data/lib/{jax/generators → generators/jax}/material/USAGE +4 -8
- data/lib/generators/jax/material/material_generator.rb +112 -0
- data/lib/generators/jax/model/model_generator.rb +24 -0
- data/lib/generators/jax/plugin/plugin_generator.rb +72 -0
- data/lib/generators/jax/scaffold/scaffold_generator.rb +35 -0
- data/lib/generators/jax/shader/shader_generator.rb +38 -0
- data/lib/jax/commands/plugin_manager.rb +240 -0
- data/lib/jax/commands.rb +69 -0
- data/lib/jax/configuration.rb +64 -0
- data/lib/jax/directive_processor.rb +53 -0
- data/lib/jax/engine.rb +38 -54
- data/lib/jax/helper_methods.rb +3 -0
- data/lib/jax/rails/application.rb +34 -0
- data/lib/jax/resource_file.rb +29 -0
- data/lib/jax/script_loader.rb +68 -0
- data/lib/jax/server.rb +87 -0
- data/lib/jax/shader.rb +70 -172
- data/lib/jax/testing/rails_environment.rb +94 -0
- data/lib/jax/util/tar.rb +75 -0
- data/lib/jax/util.rb +3 -0
- data/lib/jax/version.rb +7 -8
- data/lib/jax.rb +23 -41
- data/spec/bin/jax_spec.rb +149 -0
- data/{lib/jax/generators/app/templates/app/models/.empty_directory → spec/fixtures/public/favicon.ico} +0 -0
- data/spec/fixtures/public/textures/brickwall.jpg +0 -0
- data/spec/fixtures/public/textures/jacks.jpg +0 -0
- data/spec/fixtures/public/textures/normal_map.jpg +0 -0
- data/spec/fixtures/public/textures/rock.png +0 -0
- data/spec/fixtures/public/textures/rock_normal.png +0 -0
- data/spec/fixtures/public/textures/rss.png +0 -0
- data/spec/generators/jax/application_generator_spec.rb +18 -0
- data/spec/generators/jax/controller_generator_spec.rb +102 -0
- data/spec/generators/jax/helper_generator_spec.rb +55 -0
- data/spec/generators/jax/install_generator_spec.rb +30 -0
- data/spec/generators/jax/jax_generator_spec.rb +21 -0
- data/spec/generators/jax/light_generator_spec.rb +27 -0
- data/spec/generators/jax/material_generator_spec.rb +62 -0
- data/spec/generators/jax/model_generator_spec.rb +72 -0
- data/spec/generators/jax/plugin_generator_spec.rb +143 -0
- data/spec/generators/jax/scaffold_generator_spec.rb +35 -0
- data/spec/generators/jax/shader_generator_spec.rb +37 -0
- data/spec/javascripts/helpers/jasmine_webgl_helper.js +13 -0
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_environment_helper.js +7 -2
- data/{lib/jax/generators/app/templates/spec/javascripts/support/spec_helpers → spec/javascripts/helpers}/jax_spec_helper.js +0 -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 +46 -0
- data/spec/javascripts/jax/context_events_spec.js +212 -0
- data/spec/javascripts/jax/context_spec.js +305 -0
- data/spec/javascripts/jax/core/data_region_spec.js +118 -0
- data/spec/javascripts/jax/core/data_segment_spec.js +96 -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/glMatrix_extensions_spec.js +8 -0
- data/spec/javascripts/jax/core/helper_spec.js +61 -0
- data/spec/javascripts/jax/core/matrix_stack_spec.js +28 -0
- data/spec/javascripts/jax/core/utils_spec.js +275 -0
- data/spec/javascripts/jax/geometry/line_spec.js +20 -0
- data/spec/javascripts/jax/geometry/plane_spec.js +181 -0
- data/spec/javascripts/jax/geometry/triangle_spec.js +105 -0
- data/spec/javascripts/jax/mvc/controller_spec.js +156 -0
- data/spec/javascripts/jax/mvc/model_spec.js +93 -0
- data/spec/javascripts/jax/mvc/route_set_spec.js +49 -0
- data/spec/javascripts/jax/mvc/view_manager_spec.js +17 -0
- data/spec/javascripts/jax/noise_spec.js +50 -0
- data/spec/javascripts/jax/optimizations/material_limitations_spec.js +85 -0
- data/spec/javascripts/jax/optimizations/shaders/basic_spec.js +65 -0
- data/spec/javascripts/jax/prototype/extensions_spec.js +34 -0
- data/spec/javascripts/jax/webgl/camera_spec.js +237 -0
- data/spec/javascripts/jax/webgl/core/events_spec.js +47 -0
- data/spec/javascripts/jax/webgl/framebuffer_spec.js +44 -0
- data/spec/javascripts/jax/webgl/lighting_spec.js +108 -0
- data/spec/javascripts/jax/webgl/material_spec.js +117 -0
- data/spec/javascripts/jax/webgl/mesh_spec.js +228 -0
- data/spec/javascripts/jax/webgl/shader/manifest_spec.js +57 -0
- data/spec/javascripts/jax/webgl/shader_chain_spec.js +211 -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 +159 -0
- data/spec/javascripts/jax/webgl_spec.js +5 -0
- data/spec/javascripts/jax/world_spec.js +175 -0
- data/spec/javascripts/jax_spec.js +14 -0
- data/spec/javascripts/node/mocks/webgl.js +159 -0
- data/spec/javascripts/node_helper.js +51 -0
- data/spec/javascripts/shaders/core_materials_spec.js +38 -0
- data/spec/javascripts/shaders/fog_spec.js +15 -0
- data/spec/javascripts/shaders/lighting_spec.js +15 -0
- data/spec/javascripts/shaders/normal_map_spec.js +15 -0
- data/spec/javascripts/shaders/paraboloid_spec.js +33 -0
- data/spec/javascripts/shaders/preprocessor_spec.js +45 -0
- data/spec/javascripts/shaders/shadow_map_spec.js +15 -0
- data/spec/javascripts/shaders/texture_spec.js +37 -0
- data/spec/javascripts/suite/controller_select_spec.js.coffee +24 -0
- data/spec/lib/jax/commands/plugin_manager/credentials_spec.rb +56 -0
- data/spec/lib/jax/commands/plugin_manager/push_spec.rb +62 -0
- data/spec/lib/jax/commands/plugin_manager_spec.rb +204 -0
- data/spec/lib/jax/rails/application_spec.rb +23 -0
- data/spec/lib/jax/shader_spec.rb +67 -0
- data/spec/lib/jax/util/tar_spec.rb +26 -0
- data/spec/{test_helper.rb → spec_helper.rb} +37 -28
- data/spec/support/test_model_generator.rb +14 -0
- data/templates/app/Gemfile.tt +17 -0
- data/templates/app/Rakefile +4 -0
- data/templates/app/config/application.rb +16 -0
- data/{lib/jax/generators/app/templates → templates/app}/config/boot.rb +0 -0
- data/templates/app/config/environment.rb +5 -0
- data/templates/app/config/environments/production.rb +4 -0
- data/templates/app/config.ru +6 -0
- data/{lib/jax/generators/app/templates/app/resources → templates/app/public}/.empty_directory +0 -0
- data/templates/app/script/jax +8 -0
- data/{lib/jax/generators/app/templates/app/views → templates/app/spec}/.empty_directory +0 -0
- data/templates/application_controller.js.coffee.erb +3 -0
- data/templates/application_controller.js.erb +6 -0
- data/templates/application_helper.js.coffee.erb +3 -0
- data/templates/application_helper.js.erb +3 -0
- data/templates/controller.js.coffee.erb +9 -0
- data/templates/controller.js.erb +15 -0
- data/templates/controller_spec.js.coffee.erb +9 -0
- data/templates/controller_spec.js.erb +12 -0
- data/templates/helper.js.coffee.erb +2 -0
- data/templates/helper.js.erb +3 -0
- data/templates/helper_spec.js.coffee.erb +8 -0
- data/templates/helper_spec.js.erb +12 -0
- data/{lib/jax/generators/light_source/templates/light.yml.tt → templates/light_source.resource.erb} +3 -3
- data/{lib/jax/generators/material/templates/material.yml.tt → templates/material.resource.erb} +0 -9
- data/templates/model.js.coffee.erb +3 -0
- data/templates/model.js.erb +5 -0
- data/templates/model_defaults.resource.erb +5 -0
- data/templates/model_spec.js.coffee.erb +16 -0
- data/templates/model_spec.js.erb +18 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/controllers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/helpers/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/models/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/resources/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/app → templates/new_plugin/app/assets/jax}/views/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/init.rb +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/install.rb +0 -0
- data/{lib/jax/generators/plugin/templates/new_plugin/public → templates/new_plugin/spec}/.empty_directory +0 -0
- data/{lib/jax/generators/plugin/templates → templates}/new_plugin/uninstall.rb +0 -0
- data/{lib/jax/generators/shader/templates/common.ejs.tt → templates/shader_common.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/fragment.ejs.tt → templates/shader_fragment.glsl.erb} +0 -0
- data/{lib/jax/generators/shader/templates/manifest.yml.tt → templates/shader_manifest.yml.erb} +0 -0
- data/templates/shader_material.js.coffee.erb +22 -0
- data/{lib/jax/generators/shader/templates/material.js.tt → templates/shader_material.js.erb} +0 -0
- data/templates/shader_spec.js.coffee.erb +16 -0
- data/{lib/jax/generators/shader/templates/spec.js.tt → templates/shader_spec.js.erb} +1 -1
- data/{lib/jax/generators/shader/templates/vertex.ejs.tt → templates/shader_vertex.glsl.erb} +0 -0
- data/templates/view.js.coffee.erb +3 -0
- data/{lib/jax/generators/controller/templates/view.js.tt → templates/view.js.erb} +1 -1
- data/vendor/assets/javascripts/ejs.js +505 -0
- data/vendor/assets/javascripts/glMatrix.js +1772 -0
- data/vendor/assets/javascripts/jasmine.js +2476 -0
- data/vendor/assets/stylesheets/jasmine.css +166 -0
- 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 +478 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/prototype.js +4874 -0
- data/vendor/pdoc_template/html/assets/javascripts/pdoc/tabs.js +506 -0
- data/vendor/pdoc_template/html/assets/stylesheets/jax.css +30 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/api.css +681 -0
- data/vendor/pdoc_template/html/assets/stylesheets/pdoc/pygments.css +62 -0
- data/vendor/pdoc_template/html/helpers.rb +35 -0
- data/vendor/pdoc_template/html/index.erb +18 -0
- data/vendor/pdoc_template/html/item_index.js.erb +6 -0
- data/vendor/pdoc_template/html/layout.erb +67 -0
- data/vendor/pdoc_template/html/leaf.erb +22 -0
- data/vendor/pdoc_template/html/node.erb +30 -0
- data/vendor/pdoc_template/html/partials/class_relationships.erb +19 -0
- data/vendor/pdoc_template/html/partials/classes.erb +7 -0
- data/vendor/pdoc_template/html/partials/constructor.erb +5 -0
- data/vendor/pdoc_template/html/partials/description.erb +5 -0
- data/vendor/pdoc_template/html/partials/link_list.erb +1 -0
- data/vendor/pdoc_template/html/partials/method_signatures.erb +14 -0
- data/vendor/pdoc_template/html/partials/methodized_note.erb +9 -0
- data/vendor/pdoc_template/html/partials/mixins.erb +7 -0
- data/vendor/pdoc_template/html/partials/namespaces.erb +7 -0
- data/vendor/pdoc_template/html/partials/related_utilities.erb +5 -0
- data/vendor/pdoc_template/html/partials/relationships.erb +11 -0
- data/vendor/pdoc_template/html/partials/short_description_list.erb +7 -0
- data/vendor/pdoc_template/html/partials/title.erb +24 -0
- data/vendor/pdoc_template/html/section.erb +18 -0
- metadata +635 -332
- data/builtin/app/shaders/lighting/common.ejs +0 -5
- data/builtin/app/shaders/normal_map/material.js +0 -16
- data/builtin/app/shaders/texture/material.js +0 -18
- data/jax.gems +0 -1
- data/lib/jax/application/builtin/configurable.rb +0 -5
- data/lib/jax/application/builtin/configuration.rb +0 -5
- data/lib/jax/application/builtin.rb +0 -12
- data/lib/jax/application/configurable.rb +0 -19
- data/lib/jax/application/configuration.rb +0 -60
- data/lib/jax/application/railties.rb +0 -26
- data/lib/jax/application.rb +0 -149
- data/lib/jax/core_ext/kernel.rb +0 -7
- data/lib/jax/engine/configurable.rb +0 -19
- data/lib/jax/engine/configuration.rb +0 -49
- data/lib/jax/generators/app/app_generator.rb +0 -96
- data/lib/jax/generators/app/templates/Gemfile.tt +0 -3
- data/lib/jax/generators/app/templates/Rakefile +0 -6
- data/lib/jax/generators/app/templates/app/controllers/application_controller.js.tt +0 -5
- data/lib/jax/generators/app/templates/app/helpers/application_helper.js.tt +0 -3
- data/lib/jax/generators/app/templates/config/application.rb.tt +0 -6
- data/lib/jax/generators/app/templates/config/environment.rb.tt +0 -5
- data/lib/jax/generators/app/templates/config/routes.rb.tt +0 -5
- data/lib/jax/generators/app/templates/public/index.html.tt +0 -26
- data/lib/jax/generators/app/templates/public/javascripts/jax.js +0 -9462
- data/lib/jax/generators/app/templates/public/stylesheets/%file_name%.css.tt +0 -11
- data/lib/jax/generators/app/templates/public/webgl_not_supported.html +0 -26
- data/lib/jax/generators/app/templates/script/jax +0 -7
- data/lib/jax/generators/app/templates/spec/javascripts/controllers/application_controller_spec.js +0 -11
- data/lib/jax/generators/app/templates/spec/javascripts/helpers/application_helper_spec.js +0 -12
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine.yml +0 -91
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_config.rb +0 -23
- data/lib/jax/generators/app/templates/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/lib/jax/generators/app/templates/spec/javascripts/support/spec_layout.html.erb +0 -104
- data/lib/jax/generators/app.rb +0 -18
- data/lib/jax/generators/commands.rb +0 -220
- data/lib/jax/generators/controller/USAGE +0 -9
- data/lib/jax/generators/controller/controller_generator.rb +0 -66
- data/lib/jax/generators/controller/templates/controller_source.js.tt +0 -16
- data/lib/jax/generators/controller/templates/controller_test.js.tt +0 -11
- data/lib/jax/generators/controller/templates/helper.js.tt +0 -3
- data/lib/jax/generators/controller/templates/helper_test.js.tt +0 -12
- data/lib/jax/generators/interactions.rb +0 -56
- data/lib/jax/generators/light_source/USAGE +0 -14
- data/lib/jax/generators/light_source/light_source_generator.rb +0 -46
- data/lib/jax/generators/material/material_generator.rb +0 -80
- data/lib/jax/generators/material/templates/append.yml.tt +0 -7
- data/lib/jax/generators/model/USAGE +0 -5
- data/lib/jax/generators/model/model_generator.rb +0 -40
- data/lib/jax/generators/model/templates/model.js.tt +0 -11
- data/lib/jax/generators/model/templates/test.js.tt +0 -11
- data/lib/jax/generators/packager/package_generator.rb +0 -32
- data/lib/jax/generators/plugin/USAGE +0 -4
- data/lib/jax/generators/plugin/all.rb +0 -113
- data/lib/jax/generators/plugin/credentials.rb +0 -108
- data/lib/jax/generators/plugin/plugin_generator.rb +0 -72
- data/lib/jax/generators/plugin/plugin_manager.rb +0 -254
- data/lib/jax/generators/plugin/templates/new_plugin/config/routes.rb +0 -3
- data/lib/jax/generators/plugin/templates/new_plugin/spec/.empty_directory +0 -0
- data/lib/jax/generators/script_jax_loader.rb +0 -49
- data/lib/jax/generators/shader/USAGE +0 -4
- data/lib/jax/generators/shader/shader_generator.rb +0 -70
- data/lib/jax/monkeypatch/jasmine/config.rb +0 -45
- data/lib/jax/monkeypatch/jasmine/server.rb +0 -50
- data/lib/jax/monkeypatch/jasmine.rb +0 -3
- data/lib/jax/packager/sprockets_template.rb +0 -77
- data/lib/jax/packager.rb +0 -59
- data/lib/jax/plugin/manifest.rb +0 -71
- data/lib/jax/plugin.rb +0 -49
- data/lib/jax/resource_compiler.rb +0 -60
- data/lib/jax/routes.rb +0 -62
- data/lib/jax/tasks/rake.rb +0 -38
- data/spec/benchmark.htm +0 -93
- data/spec/generators/app_generator_test.rb +0 -42
- data/spec/generators/controller_generator_test.rb +0 -47
- data/spec/generators/light_generator_test.rb +0 -37
- data/spec/generators/material_generator_test.rb +0 -22
- data/spec/generators/model_generator_test.rb +0 -26
- data/spec/generators/plugin_generator_test.rb +0 -114
- data/spec/generators/plugin_manager/push_test.rb +0 -59
- data/spec/generators/plugin_manager_test.rb +0 -192
- data/spec/generators/shader_generator_test.rb +0 -38
- data/spec/javascripts/support/jasmine.yml +0 -85
- data/spec/javascripts/support/jasmine_runner.rb +0 -32
- data/spec/lib/jax/application_test.rb +0 -18
- data/spec/lib/jax/generators/plugin/credentials_test.rb +0 -72
- data/spec/lib/jax/packager_test.rb +0 -87
- data/spec/lib/jax/plugin_test.rb +0 -27
- data/spec/lib/jax/reloading_test.rb +0 -23
- data/spec/lib/jax/routes_test.rb +0 -28
- data/spec/lib/jax/shader_test.rb +0 -29
- data/spec/lib/jax/tasks/jax_rake_test.rb +0 -85
- data/spec/support/bases/generator_test_case.rb +0 -108
- data/spec/support/bases/isolated_test_case.rb +0 -148
- data/spec/support/file_exist_matcher.rb +0 -23
- data/spec/support/spec_shell.rb +0 -110
- data/spec/test_app.rb +0 -3
@@ -0,0 +1,299 @@
|
|
1
|
+
//= require_self
|
2
|
+
//= require "jax/webgl/shader/program"
|
3
|
+
|
4
|
+
/**
|
5
|
+
* class Jax.Shader
|
6
|
+
*
|
7
|
+
* Wraps around a WebGL shader program.
|
8
|
+
**/
|
9
|
+
Jax.Shader = (function() {
|
10
|
+
function buildStackTrace(context, glShader, source) {
|
11
|
+
source = source.split(/\n/);
|
12
|
+
var log = context.glGetShaderInfoLog(glShader).split(/\n/);
|
13
|
+
|
14
|
+
/* build a detailed backtrace with error information so devs can actually find the error */
|
15
|
+
var current = 1, injected = [], li;
|
16
|
+
function strToInject() { return current+" : "+source[current-1]; }
|
17
|
+
for (li = 0; li < log.length; li++) {
|
18
|
+
var line = log[li];
|
19
|
+
var match = /0:(\d+):(.*)/.exec(line);
|
20
|
+
if (!match) continue; // blank line
|
21
|
+
var line_number = parseInt(match[1]);
|
22
|
+
if (line_number > current)
|
23
|
+
for (; current < line_number; current++)
|
24
|
+
injected.push(strToInject());
|
25
|
+
if (line_number == current) {
|
26
|
+
injected.push(strToInject());
|
27
|
+
injected.push(":: ERROR : "+match[2]); /* error message */
|
28
|
+
}
|
29
|
+
current = line_number+1;
|
30
|
+
}
|
31
|
+
|
32
|
+
/* prepend a summary so user can debug simple errors at a glance */
|
33
|
+
injected.unshift("");
|
34
|
+
for (li = log.length-1; li >= 0; li--)
|
35
|
+
injected.unshift(log[li]);
|
36
|
+
|
37
|
+
/* finally, add 3 more lines so the user has an easier time finding the problem in ambiguous code */
|
38
|
+
li = current;
|
39
|
+
for (current = li; current < li+3; current++)
|
40
|
+
injected.push(strToInject());
|
41
|
+
|
42
|
+
return injected.join("\n");
|
43
|
+
}
|
44
|
+
|
45
|
+
function compile(context, shader, source) {
|
46
|
+
context.glShaderSource(shader, source);
|
47
|
+
shader.source = source;
|
48
|
+
context.glCompileShader(shader);
|
49
|
+
if (!context.glGetShaderParameter(shader, GL_COMPILE_STATUS))
|
50
|
+
throw new Error(buildStackTrace(context, shader, source));
|
51
|
+
}
|
52
|
+
|
53
|
+
function sanitizeName(name) {
|
54
|
+
return name.replace(/-/, '_');
|
55
|
+
}
|
56
|
+
|
57
|
+
function getExportedVariableName(exportPrefix, name) {
|
58
|
+
return sanitizeName("_"+exportPrefix+"_"+name);
|
59
|
+
}
|
60
|
+
|
61
|
+
/*
|
62
|
+
preprocess shader source code to replace "import(varname, expression)" with the globalized varname if it's been
|
63
|
+
exported (as an attribute of material.exports || self.options.exports), or expression if it hasn't.
|
64
|
+
*/
|
65
|
+
function applyImports(self, options, source) {
|
66
|
+
var rx = /import\((.*?),\s*(.*?)\)/, result;
|
67
|
+
var exp;
|
68
|
+
while (result = rx.exec(source)) {
|
69
|
+
var name = result[1];
|
70
|
+
if (options && (exp = (options.exports && options.exports[name]) || (self.options.exports && self.options.exports[name]))) {
|
71
|
+
var exportedVariableName = getExportedVariableName(options.export_prefix || self.getName(), name);
|
72
|
+
source = source.replace(result[0], result[2].replace(new RegExp(name, "g"), exportedVariableName));
|
73
|
+
}
|
74
|
+
else source = source.replace(result[0], "");
|
75
|
+
}
|
76
|
+
return source;
|
77
|
+
}
|
78
|
+
|
79
|
+
function applyExports(self, options, source) {
|
80
|
+
var rx = /export\((.*?),\s*(.*?)(,\s*(.*?))?\)/, result;
|
81
|
+
// rx should match both 'export(vec4, ambient)' and 'export(vec4, ambient, ambient)'
|
82
|
+
var replacement, name, type, assignment;
|
83
|
+
while (result = rx.exec(source)) {
|
84
|
+
type = result[1];
|
85
|
+
name = result[2];
|
86
|
+
assignment = result[4] || null;
|
87
|
+
replacement = getExportedVariableName(options && options.export_prefix || self.getName(), name)+" = ";
|
88
|
+
if (assignment) replacement += assignment;
|
89
|
+
else replacement += name;
|
90
|
+
source = source.replace(result[0], replacement);
|
91
|
+
}
|
92
|
+
return source;
|
93
|
+
}
|
94
|
+
|
95
|
+
function mangleUniformsAndAttributes(self, material, source) {
|
96
|
+
var map = self.getInputMap(material);
|
97
|
+
for (var name in map)
|
98
|
+
source = source.replace(new RegExp("(^|[^a-zA-Z0-9])"+name+"([^a-zA-Z0-9]|$)", "g"), "$1"+map[name].full_name+"$2");
|
99
|
+
|
100
|
+
// remove the "shared" directive
|
101
|
+
return source.replace(/(^|[^\w])shared\s+/g, "$1");
|
102
|
+
}
|
103
|
+
|
104
|
+
function stripSharedDefinitions(self, options, source) {
|
105
|
+
var map = self.getInputMap(options);
|
106
|
+
for (var i in map) {
|
107
|
+
if (map[i].shared) {
|
108
|
+
if (options.skip_global_definitions && options.skip_global_definitions.indexOf(map[i].full_name) != -1) {
|
109
|
+
var rx = new RegExp("(shared\\s+)"+map[i].scope+"\\s*"+map[i].type+"[^;]*?"+map[i].full_name+"[^;]*?;\n?", "g");
|
110
|
+
source = source.replace(rx, "");
|
111
|
+
}
|
112
|
+
// else source = source.replace(rx, map[i].scope+" "+map[i].type+" "+map[i].full_name+";\n");
|
113
|
+
}
|
114
|
+
}
|
115
|
+
|
116
|
+
return source.replace(/shared\s+/, '');
|
117
|
+
}
|
118
|
+
|
119
|
+
/* TODO separate preprocessing from shader and friends; perhaps a Jax.Shader.Preprocessor class? */
|
120
|
+
function preprocess(self, options, source, isVertex) {
|
121
|
+
source = stripSharedDefinitions(self, options, source);
|
122
|
+
// source = source.replace(/^\s*(shared\s+|)(uniform|attribute|varying)([^;]*)?;\n?/, '');
|
123
|
+
// if (!options || !options.skip_global_definitions)
|
124
|
+
// source = self.getGlobalDefinitions(options, isVertex) + source;
|
125
|
+
source = applyExports(self, options, source);
|
126
|
+
source = applyImports(self, options, source);
|
127
|
+
source = mangleUniformsAndAttributes(self, options, source);
|
128
|
+
|
129
|
+
return source;
|
130
|
+
}
|
131
|
+
|
132
|
+
function sourceWithoutComments(source) {
|
133
|
+
return source.replace(/\/\*.*\*\//g, "");
|
134
|
+
}
|
135
|
+
|
136
|
+
function numArgumentsInMain(source) {
|
137
|
+
// if a comment contains 'void main' in it, we'll get false positives
|
138
|
+
var result = /void\s*main\((.*?)\)\s*\{/.exec(sourceWithoutComments(source));
|
139
|
+
if (result) {
|
140
|
+
result = result[1].replace(/\s*/g, '');
|
141
|
+
if (result == "" || result == "void") return 0;
|
142
|
+
else return result[1].split(/,/).length;
|
143
|
+
}
|
144
|
+
else throw new Error("Could not find main() function in source!\n\n"+source);
|
145
|
+
}
|
146
|
+
|
147
|
+
return Jax.Class.create({
|
148
|
+
initialize: function(obj) {
|
149
|
+
this.options = obj;
|
150
|
+
|
151
|
+
if (obj.vertex) this.setRawSource(obj.vertex, 'vertex');
|
152
|
+
if (obj.fragment) this.setRawSource(obj.fragment, 'fragment');
|
153
|
+
if (obj.common) this.setRawSource(obj.common, 'common');
|
154
|
+
|
155
|
+
this.shaders = { vertex: {}, fragment: {} };
|
156
|
+
},
|
157
|
+
|
158
|
+
getName: function() { return this.options.name; },
|
159
|
+
|
160
|
+
getVertexShader: function(context) {
|
161
|
+
if (!this.options.vertex) return null;
|
162
|
+
this.shaders.vertex[context.id] = this.shaders.vertex[context.id] || context.glCreateShader(GL_VERTEX_SHADER);
|
163
|
+
return this.shaders.vertex[context.id];
|
164
|
+
},
|
165
|
+
|
166
|
+
getFragmentShader: function(context) {
|
167
|
+
if (!this.options.fragment) return null;
|
168
|
+
this.shaders.fragment[context.id] = this.shaders.fragment[context.id] || context.glCreateShader(GL_FRAGMENT_SHADER);
|
169
|
+
return this.shaders.fragment[context.id];
|
170
|
+
},
|
171
|
+
|
172
|
+
getCommonSource: function(material) {
|
173
|
+
return this.options.common ? this.options.common.render(material) : "";
|
174
|
+
},
|
175
|
+
|
176
|
+
getVertexSource: function(material) {
|
177
|
+
var source = this.getRawSource(material, 'vertex');
|
178
|
+
return source && preprocess(this, material, source, true);
|
179
|
+
},
|
180
|
+
|
181
|
+
getPreamble: function(options) {
|
182
|
+
return options && options.ignore_es_precision ? "" : "#ifdef GL_ES\nprecision highp float;\n#endif\n";
|
183
|
+
},
|
184
|
+
|
185
|
+
getFragmentSource: function(material) {
|
186
|
+
var source = this.getRawSource(material, 'fragment');
|
187
|
+
return source && preprocess(this, material, source, false);
|
188
|
+
},
|
189
|
+
|
190
|
+
getVertexArgumentCount: function(options) {
|
191
|
+
var source = this.getVertexSource(options);
|
192
|
+
return numArgumentsInMain(source);
|
193
|
+
},
|
194
|
+
|
195
|
+
getFragmentArgumentCount: function(options) {
|
196
|
+
var source = this.getFragmentSource(options);
|
197
|
+
return numArgumentsInMain(source);
|
198
|
+
},
|
199
|
+
|
200
|
+
getRawSource: function(options, which) {
|
201
|
+
var source = this.options[which];
|
202
|
+
options = Jax.Util.normalizeOptions(options, {shader:this,shader_type:which});
|
203
|
+
if (source && (source = source.render(options))) {
|
204
|
+
var result = this.getPreamble(options);
|
205
|
+
if (!options || !options.skip_export_definitions)
|
206
|
+
result += this.getExportDefinitions(options && options.export_prefix || this.getName());
|
207
|
+
if (!options || !options.skip_common_source)
|
208
|
+
result += this.getCommonSource(options) + "\n";
|
209
|
+
result += source;
|
210
|
+
return result;
|
211
|
+
}
|
212
|
+
return null;
|
213
|
+
},
|
214
|
+
|
215
|
+
getGlobalDefinitions: function(options, isVertex) {
|
216
|
+
var map = this.getInputMap(options);
|
217
|
+
var source = "";
|
218
|
+
for (var i in map) {
|
219
|
+
if (map[i].scope == "attribute" && !isVertex) continue;
|
220
|
+
source += map[i].scope+" "+map[i].type+" "+map[i].full_name+";\n";
|
221
|
+
}
|
222
|
+
return source;
|
223
|
+
},
|
224
|
+
|
225
|
+
setRawSource: function(source, which) { this.options[which] = source && new EJS({text:source}); },
|
226
|
+
|
227
|
+
setVertexSource: function(source) { this.setRawSource(source, 'vertex'); },
|
228
|
+
|
229
|
+
setFragmentSource: function(source) { this.setRawSource(source, 'fragment'); },
|
230
|
+
|
231
|
+
getInputMap: function(options) {
|
232
|
+
var map = {};
|
233
|
+
var prefix = "";
|
234
|
+
|
235
|
+
if (options && options.local_prefix) prefix = options.local_prefix+"_";
|
236
|
+
else if (options && options.export_prefix) prefix = options.export_prefix+"_";
|
237
|
+
|
238
|
+
var source = (this.getRawSource(options, 'common') || "") + "\n\n" +
|
239
|
+
(this.getRawSource(options, 'vertex') || "") + "\n\n" +
|
240
|
+
(this.getRawSource(options, 'fragment') || "");
|
241
|
+
|
242
|
+
// if it's not a "shared" uniform, mangle its name.
|
243
|
+
var rx = new RegExp("(^|\\n|\\s+)((shared\\s+)?)(uniform|attribute|varying)\\s+(\\w+)\\s+((?!"+prefix+")[^;]*);"), result;
|
244
|
+
while (result = rx.exec(source)) {
|
245
|
+
var shared = /shared/.test(result[2]);
|
246
|
+
var scope = result[4];
|
247
|
+
var type = result[5];
|
248
|
+
var names = result[6].split(/,/);
|
249
|
+
|
250
|
+
for (var i = 0; i < names.length; i++) {
|
251
|
+
names[i] = names[i].replace(/^\s+/, '').replace(/\s+$/, '');
|
252
|
+
if (shared) map[names[i]] = names[i];
|
253
|
+
else map[names[i]] = sanitizeName(prefix+names[i]);
|
254
|
+
map[names[i]] = { full_name: map[names[i]], type: type, scope: scope, shared: shared };
|
255
|
+
source = source.replace(new RegExp("(^|[^a-zA-Z0-9_])"+names[i]+"([^a-zA-Z0-9_]|$)", "g"),
|
256
|
+
"$1"+prefix+names[i]+"$2");
|
257
|
+
}
|
258
|
+
}
|
259
|
+
|
260
|
+
return map;
|
261
|
+
},
|
262
|
+
|
263
|
+
getExportDefinitions: function(exportPrefix, skip) {
|
264
|
+
var exports = "";
|
265
|
+
if (this.options.exports) {
|
266
|
+
for (var name in this.options.exports) {
|
267
|
+
if (!skip || skip.indexOf(name) == -1)
|
268
|
+
exports += this.options.exports[name]+" "+getExportedVariableName(exportPrefix, name)+";\n";
|
269
|
+
}
|
270
|
+
}
|
271
|
+
return exports + "\n";
|
272
|
+
},
|
273
|
+
|
274
|
+
build: function(context, material) {
|
275
|
+
var count = 0;
|
276
|
+
if (this.getVertexShader(context)) {
|
277
|
+
count++;
|
278
|
+
compile(context, this.getVertexShader(context), this.getVertexSource(material));
|
279
|
+
}
|
280
|
+
if (this.getFragmentShader(context)) {
|
281
|
+
count++;
|
282
|
+
compile(context, this.getFragmentShader(context), this.getFragmentSource(material));
|
283
|
+
}
|
284
|
+
if (count == 0) throw new Error("No sources specified for shader '"+this.getName()+"'!");
|
285
|
+
}
|
286
|
+
});
|
287
|
+
})();
|
288
|
+
|
289
|
+
(function() {
|
290
|
+
var gl = Jax.getGlobal()['GL'];
|
291
|
+
Jax.Shader.max_varyings = gl ? gl.getParameter(GL_MAX_VARYING_VECTORS) : 0;
|
292
|
+
Jax.Shader.max_vertex_uniforms = gl ? gl.getParameter(GL_MAX_VERTEX_UNIFORM_VECTORS) : 0;
|
293
|
+
Jax.Shader.max_fragment_uniforms = gl ? gl.getParameter(GL_MAX_FRAGMENT_UNIFORM_VECTORS) : 0;
|
294
|
+
Jax.Shader.max_attributes = gl ? gl.getParameter(GL_MAX_VERTEX_ATTRIBS) : 0;
|
295
|
+
Jax.Shader.max_vertex_textures = gl ? gl.getParameter(GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS) : 0;
|
296
|
+
|
297
|
+
// FIXME differentiate between vertex & fragment uniforms
|
298
|
+
Jax.Shader.max_uniforms = Math.min(Jax.Shader.max_fragment_uniforms, Jax.Shader.max_vertex_uniforms);
|
299
|
+
})();
|
@@ -0,0 +1,267 @@
|
|
1
|
+
//= require "jax/webgl/shader"
|
2
|
+
|
3
|
+
Jax.ShaderChain = (function() {
|
4
|
+
function sanitizeName(name) {
|
5
|
+
return name.replace(/-/, '_');
|
6
|
+
}
|
7
|
+
|
8
|
+
function preprocessFunctions(self, prefix, suffix, source) {
|
9
|
+
/* TODO mangle all function and structure names to prevent conflicts -- right now we only mangle main() */
|
10
|
+
|
11
|
+
return source.replace(/void\s*main\s*\(/g, 'void '+sanitizeName(prefix)+'_main_'+sanitizeName(suffix)+'(');
|
12
|
+
}
|
13
|
+
|
14
|
+
function preprocessorOptions(self) {
|
15
|
+
return {
|
16
|
+
shader: self,
|
17
|
+
ignore_es_precision: true,
|
18
|
+
export_prefix: self.getName(),
|
19
|
+
exports: self.gatherExports(),
|
20
|
+
skip_export_definitions: true,
|
21
|
+
skip_global_definitions: [] // array containing definitions so they aren't accidentally redefined
|
22
|
+
};
|
23
|
+
}
|
24
|
+
|
25
|
+
function preventRedefinition(imap, options) {
|
26
|
+
for (var j in imap)
|
27
|
+
options.skip_global_definitions.push(imap[j].full_name);
|
28
|
+
}
|
29
|
+
|
30
|
+
return Jax.Class.create(Jax.Shader.Program, {
|
31
|
+
initialize: function($super, name) {
|
32
|
+
$super();
|
33
|
+
this.name = name;
|
34
|
+
this.shaders.push(this.getMasterShader());
|
35
|
+
this.phases = [];
|
36
|
+
},
|
37
|
+
|
38
|
+
getMasterShader: function() {
|
39
|
+
return this.master_shader = this.master_shader || new Jax.Shader({});
|
40
|
+
},
|
41
|
+
|
42
|
+
addShader: function(shader) {
|
43
|
+
if (typeof(shader) == "string")
|
44
|
+
if (Jax.shaders[shader])
|
45
|
+
shader = Jax.shaders[shader];
|
46
|
+
else throw new Error("Shader is not defined: "+shader);
|
47
|
+
else if (!shader) throw new Error("Argument must be a Jax.Shader, or a String equal to its name");
|
48
|
+
this.phases.push(shader);
|
49
|
+
this.invalidate();
|
50
|
+
if (!shader.getName) throw new Error("Not an instance of Jax.Shader: "+JSON.stringify(shader));
|
51
|
+
return sanitizeName(shader.getName()+(this.phases.length - 1)+"_");
|
52
|
+
},
|
53
|
+
|
54
|
+
getShaderNames: function() {
|
55
|
+
var result = [];
|
56
|
+
for (var i = 0; i < this.phases.length; i++)
|
57
|
+
result[i] = this.phases[i].getName();
|
58
|
+
return result;
|
59
|
+
},
|
60
|
+
|
61
|
+
removeAllShaders: function() {
|
62
|
+
while (this.phases.length > 0) this.phases.pop();
|
63
|
+
},
|
64
|
+
|
65
|
+
link: function($super, context, material) {
|
66
|
+
var program = this.getGLProgram(context);
|
67
|
+
|
68
|
+
if (!program.linked) {
|
69
|
+
var master = this.getMasterShader();
|
70
|
+
|
71
|
+
var numVaryings = this.countVaryings(material),
|
72
|
+
numUniforms = this.countUniforms(material),
|
73
|
+
numAttributes = this.countAttributes(material);
|
74
|
+
|
75
|
+
if (numVaryings > Jax.Shader.max_varyings)
|
76
|
+
throw new RangeError("Varyings ("+numVaryings+") exceed maximum number of varyings ("+Jax.Shader.max_varyings+") supported by GPU! Try using a shorter chain.");
|
77
|
+
if (numUniforms > Jax.Shader.max_uniforms)
|
78
|
+
throw new RangeError("Uniforms ("+numUniforms+") exceed maximum number of uniforms ("+Jax.Shader.max_uniforms+") supported by GPU! Try using a shorter chain.");
|
79
|
+
if (numAttributes > Jax.Shader.max_attributes)
|
80
|
+
throw new RangeError("Attributes ("+numAttributes+") exceed maximum number of attributes ("+Jax.Shader.max_attributes+") supported by GPU! Try using a shorter chain.");
|
81
|
+
|
82
|
+
master.setVertexSource(this.getVertexSource(material));
|
83
|
+
master.setFragmentSource(this.getFragmentSource(material));
|
84
|
+
|
85
|
+
program = $super(context, material);
|
86
|
+
}
|
87
|
+
|
88
|
+
return program;
|
89
|
+
},
|
90
|
+
|
91
|
+
getFragmentSource: function(options) {
|
92
|
+
options = Jax.Util.normalizeOptions(options, preprocessorOptions(this));
|
93
|
+
|
94
|
+
var source = "";
|
95
|
+
source += this.getExportDefinitions(options);
|
96
|
+
|
97
|
+
for (var i = 0; i < this.phases.length; i++) {
|
98
|
+
options.local_prefix = this.phases[i].getName()+i;
|
99
|
+
source += "\n/**** Shader chain index "+i+": "+this.phases[i].getName()+" ****/\n";
|
100
|
+
source += preprocessFunctions(this, this.phases[i].getName()+i, 'f', this.phases[i].getFragmentSource(options));
|
101
|
+
source += "\n\n";
|
102
|
+
|
103
|
+
preventRedefinition(this.phases[i].getInputMap(options), options);
|
104
|
+
}
|
105
|
+
|
106
|
+
return source + this.getFragmentMain(options);
|
107
|
+
},
|
108
|
+
|
109
|
+
getVertexSource: function(options) {
|
110
|
+
options = Jax.Util.normalizeOptions(options, preprocessorOptions(this));
|
111
|
+
|
112
|
+
var source = "";
|
113
|
+
source += this.getExportDefinitions(options);
|
114
|
+
|
115
|
+
for (var i = 0; i < this.phases.length; i++) {
|
116
|
+
options.local_prefix = this.phases[i].getName()+i;
|
117
|
+
source += "\n/**** Shader chain index "+i+": "+this.phases[i].getName()+" ****/\n";
|
118
|
+
source += preprocessFunctions(this, this.phases[i].getName()+i, 'v', this.phases[i].getVertexSource(options));
|
119
|
+
source += "\n\n";
|
120
|
+
|
121
|
+
preventRedefinition(this.phases[i].getInputMap(options), options);
|
122
|
+
}
|
123
|
+
|
124
|
+
return source + this.getVertexMain(options);
|
125
|
+
},
|
126
|
+
|
127
|
+
getVertexMain: function(options) {
|
128
|
+
var functionCalls = "";
|
129
|
+
for (var i = 0; i < this.phases.length; i++) {
|
130
|
+
var args = "";
|
131
|
+
if (this.phases[i].getVertexArgumentCount() > 0)
|
132
|
+
args = "gl_Position";
|
133
|
+
functionCalls += " "+sanitizeName(this.phases[i].getName())+i+"_main_v("+args+");\n";
|
134
|
+
}
|
135
|
+
|
136
|
+
return "/**** Shader chain generated #main ****/\n" +
|
137
|
+
"void main(void) {\n" +
|
138
|
+
functionCalls +
|
139
|
+
"}\n";
|
140
|
+
},
|
141
|
+
|
142
|
+
getFragmentMain: function(options) {
|
143
|
+
var functionCalls = "";
|
144
|
+
var lastTookArguments = false;
|
145
|
+
for (var i = 0; i < this.phases.length; i++) {
|
146
|
+
var args = "";
|
147
|
+
if (this.phases[i].getFragmentArgumentCount() > 0) {
|
148
|
+
lastTookArguments = true;
|
149
|
+
args = "ambient, diffuse, specular";
|
150
|
+
} else lastTookArguments = false;
|
151
|
+
functionCalls += " "+sanitizeName(this.phases[i].getName())+i+"_main_f("+args+");\n";
|
152
|
+
}
|
153
|
+
|
154
|
+
var colors = "#ifdef PASS_TYPE\n"
|
155
|
+
+ " if (PASS_TYPE == "+Jax.Scene.ILLUMINATION_PASS+") gl_FragColor = ambient + diffuse + specular;\n"
|
156
|
+
+ " else gl_FragColor = ambient;\n"
|
157
|
+
+ "#else\n"
|
158
|
+
+ " gl_FragColor = ambient + diffuse + specular;\n"
|
159
|
+
+ "#endif\n";
|
160
|
+
|
161
|
+
return "/**** Shader chain generated #main ****/\n" +
|
162
|
+
"void main(void) {\n" +
|
163
|
+
"vec4 ambient = vec4(1.0,1.0,1.0,1.0), diffuse = vec4(1.0,1.0,1.0,1.0), specular = vec4(1.0,1.0,1.0,1.0);\n" +
|
164
|
+
functionCalls +
|
165
|
+
(lastTookArguments ? colors : "") +
|
166
|
+
"}\n";
|
167
|
+
},
|
168
|
+
|
169
|
+
getExportDefinitions: function(options) {
|
170
|
+
var source = "\n/** Exported shader chain variables **/\n";
|
171
|
+
var skip = [];
|
172
|
+
for (var i = 0; i < this.phases.length; i++) {
|
173
|
+
source += this.phases[i].getExportDefinitions(options.export_prefix, skip);
|
174
|
+
for (var j in this.phases[i].options.exports)
|
175
|
+
skip.push(j);
|
176
|
+
}
|
177
|
+
return source;
|
178
|
+
},
|
179
|
+
|
180
|
+
getGlobalDefinitions: function(options, isVertex) {
|
181
|
+
var source = "\n/** Shared uniforms, attributes and varyings **/\n";
|
182
|
+
var map = this.getInputMap(options);
|
183
|
+
for (var name in map) {
|
184
|
+
if (map[name].scope == "attribute" && !isVertex) continue;
|
185
|
+
source += map[name].scope+" "+map[name].type+" "+map[name].full_name+";\n";
|
186
|
+
}
|
187
|
+
return source;
|
188
|
+
},
|
189
|
+
|
190
|
+
getPerShaderInputMap: function(options) {
|
191
|
+
options = Jax.Util.normalizeOptions(options, {local_prefix:""});
|
192
|
+
var map = {};
|
193
|
+
var tracking_map = {};
|
194
|
+
var name;
|
195
|
+
for (var i = 0; i < this.phases.length; i++) {
|
196
|
+
name = this.phases[i].getName();
|
197
|
+
var entry = (map[name] = map[name] || { uniforms: [], attributes: [], varyings: [] });
|
198
|
+
|
199
|
+
options.local_prefix = this.phases[i].getName()+i;
|
200
|
+
|
201
|
+
var _map = this.phases[i].getInputMap(options);
|
202
|
+
for (name in _map) {
|
203
|
+
var variable = _map[name];
|
204
|
+
// ignore anything that's already been defined, as it's primarily required by a shader with
|
205
|
+
// higher priority (implied that the fact that it came first in the list of phases)
|
206
|
+
if (!tracking_map[variable.full_name]) {
|
207
|
+
if (variable.scope == 'uniform') entry.uniforms.push(variable);
|
208
|
+
else if (variable.scope == 'attribute') entry.attributes.push(variable);
|
209
|
+
else if (variable.scope == 'varying') entry.varyings.push(variable);
|
210
|
+
else throw new Error("unhandled variable scope: "+JSON.stringify(variable));
|
211
|
+
|
212
|
+
tracking_map[variable.full_name] = 1;
|
213
|
+
}
|
214
|
+
}
|
215
|
+
}
|
216
|
+
return map;
|
217
|
+
},
|
218
|
+
|
219
|
+
getInputMap: function(options) {
|
220
|
+
options = Jax.Util.normalizeOptions(options, {local_prefix:""});
|
221
|
+
var map = {};
|
222
|
+
for (var i = 0; i < this.phases.length; i++) {
|
223
|
+
options.local_prefix = this.phases[i].getName()+i;
|
224
|
+
var _map = this.phases[i].getInputMap(options);
|
225
|
+
for (var name in _map) {
|
226
|
+
var variable = _map[name];
|
227
|
+
if (map[variable.full_name]) {
|
228
|
+
if (map[name].type != variable.type)
|
229
|
+
throw new Error("Conflicting types for variable '"+name+"' ("+map[name].type+" and "+variable.type+")!");
|
230
|
+
if (map[name].scope != variable.scope)
|
231
|
+
throw new Error("Conflicting scopes for variable '"+name+"' ("+map[name].scope+" and "+variable.scope+")!");
|
232
|
+
}
|
233
|
+
else map[variable.full_name] = variable;
|
234
|
+
}
|
235
|
+
}
|
236
|
+
|
237
|
+
return map;
|
238
|
+
},
|
239
|
+
|
240
|
+
countVariables: function(scope, options) {
|
241
|
+
var map = this.getInputMap(options);
|
242
|
+
var count = 0;
|
243
|
+
for (var i in map) {
|
244
|
+
if (map[i].scope == scope) count++;
|
245
|
+
}
|
246
|
+
return count;
|
247
|
+
},
|
248
|
+
|
249
|
+
countVaryings: function(options) { return this.countVariables("varying", options); },
|
250
|
+
|
251
|
+
countAttributes: function(options) { return this.countVariables("attribute", options); },
|
252
|
+
|
253
|
+
countUniforms: function(options) { return this.countVariables("uniform", options); },
|
254
|
+
|
255
|
+
gatherExports: function() {
|
256
|
+
var result = {};
|
257
|
+
for (var i = 0; i < this.phases.length; i++) {
|
258
|
+
if (this.phases[i].options.exports) {
|
259
|
+
Jax.Util.merge(this.phases[i].options.exports, result);
|
260
|
+
}
|
261
|
+
}
|
262
|
+
return result;
|
263
|
+
},
|
264
|
+
|
265
|
+
getName: function() { return this.name; }
|
266
|
+
});
|
267
|
+
})();
|