diff --git a/jme3-android-native/decode.gradle b/jme3-android-native/decode.gradle index b26a34b6d..791e62904 100644 --- a/jme3-android-native/decode.gradle +++ b/jme3-android-native/decode.gradle @@ -85,7 +85,9 @@ task copyPreCompiledLibs(type: Copy) { into outputDir } -if (rootProject.ndkExists && rootProject.buildNativeProjects) { +// ndkExists is a boolean from the build.gradle in the root project +// buildNativeProjects is a string set to "true" +if (ndkExists && buildNativeProjects == "true") { // build native libs and update stored pre-compiled libs to commit compileJava.dependsOn { updatePreCompiledLibs } } else { diff --git a/jme3-android-native/openalsoft.gradle b/jme3-android-native/openalsoft.gradle index e64c9dd54..22e47a65a 100644 --- a/jme3-android-native/openalsoft.gradle +++ b/jme3-android-native/openalsoft.gradle @@ -111,7 +111,9 @@ task copyPreCompiledOpenAlSoftLibs(type: Copy) { into outputDir } -if (rootProject.ndkExists && rootProject.buildNativeProjects) { +// ndkExists is a boolean from the build.gradle in the root project +// buildNativeProjects is a string set to "true" +if (ndkExists && buildNativeProjects == "true") { // build native libs and update stored pre-compiled libs to commit compileJava.dependsOn { updatePreCompiledOpenAlSoftLibs } } else { diff --git a/jme3-bullet-native-android/build.gradle b/jme3-bullet-native-android/build.gradle index 30fdd44b5..958d2b094 100644 --- a/jme3-bullet-native-android/build.gradle +++ b/jme3-bullet-native-android/build.gradle @@ -186,7 +186,9 @@ task copyPreCompiledBulletLibs(type: Copy) { into outputDir } -if (rootProject.ndkExists) { +// ndkExists is a boolean from the build.gradle in the root project +// buildNativeProjects is a string set to "true" +if (ndkExists && buildNativeProjects == "true") { // build native libs and update stored pre-compiled libs to commit compileJava.dependsOn { updatePreCompiledBulletLibs } } else { diff --git a/jme3-bullet-native-android/libs/arm64-v8a/libbulletjme.so b/jme3-bullet-native-android/libs/arm64-v8a/libbulletjme.so index 351b02e01..0aff124f8 100755 Binary files a/jme3-bullet-native-android/libs/arm64-v8a/libbulletjme.so and b/jme3-bullet-native-android/libs/arm64-v8a/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/armeabi-v7a/libbulletjme.so b/jme3-bullet-native-android/libs/armeabi-v7a/libbulletjme.so index 800cce23f..a57b41067 100755 Binary files a/jme3-bullet-native-android/libs/armeabi-v7a/libbulletjme.so and b/jme3-bullet-native-android/libs/armeabi-v7a/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/armeabi/libbulletjme.so b/jme3-bullet-native-android/libs/armeabi/libbulletjme.so index 56f12ddc4..0750264f6 100755 Binary files a/jme3-bullet-native-android/libs/armeabi/libbulletjme.so and b/jme3-bullet-native-android/libs/armeabi/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/mips/libbulletjme.so b/jme3-bullet-native-android/libs/mips/libbulletjme.so index 00d9f3f66..90dd9f57c 100755 Binary files a/jme3-bullet-native-android/libs/mips/libbulletjme.so and b/jme3-bullet-native-android/libs/mips/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/mips64/libbulletjme.so b/jme3-bullet-native-android/libs/mips64/libbulletjme.so index ed5523fe1..d79b0d9b7 100755 Binary files a/jme3-bullet-native-android/libs/mips64/libbulletjme.so and b/jme3-bullet-native-android/libs/mips64/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/x86/libbulletjme.so b/jme3-bullet-native-android/libs/x86/libbulletjme.so index 9b5b5015f..66b1b67ae 100755 Binary files a/jme3-bullet-native-android/libs/x86/libbulletjme.so and b/jme3-bullet-native-android/libs/x86/libbulletjme.so differ diff --git a/jme3-bullet-native-android/libs/x86_64/libbulletjme.so b/jme3-bullet-native-android/libs/x86_64/libbulletjme.so index d8538246f..59c6a2ef9 100755 Binary files a/jme3-bullet-native-android/libs/x86_64/libbulletjme.so and b/jme3-bullet-native-android/libs/x86_64/libbulletjme.so differ diff --git a/jme3-bullet/src/main/java/com/jme3/bullet/PhysicsSpace.java b/jme3-bullet/src/main/java/com/jme3/bullet/PhysicsSpace.java index f3575bcdf..debd36959 100644 --- a/jme3-bullet/src/main/java/com/jme3/bullet/PhysicsSpace.java +++ b/jme3-bullet/src/main/java/com/jme3/bullet/PhysicsSpace.java @@ -995,7 +995,7 @@ public class PhysicsSpace { return solverNumIterations; } - private static native void setSolverNumIterations(long physicsSpaceId, int numIterations); + private native void setSolverNumIterations(long physicsSpaceId, int numIterations); public static native void initNativePhysics(); diff --git a/jme3-core/src/plugins/java/com/jme3/material/plugins/J3MLoader.java b/jme3-core/src/plugins/java/com/jme3/material/plugins/J3MLoader.java index 69865acdf..305057027 100644 --- a/jme3-core/src/plugins/java/com/jme3/material/plugins/J3MLoader.java +++ b/jme3-core/src/plugins/java/com/jme3/material/plugins/J3MLoader.java @@ -633,9 +633,7 @@ public class J3MLoader implements AssetLoader { // Not sure if this is needed anymore, since shader caching // is now done by TechniqueDef. technique.setShaderFile(technique.hashCode() + "", technique.hashCode() + "", "GLSL100", "GLSL100"); - } - - if (shaderNames.containsKey(Shader.ShaderType.Vertex) && shaderNames.containsKey(Shader.ShaderType.Fragment)) { + }else if (shaderNames.containsKey(Shader.ShaderType.Vertex) && shaderNames.containsKey(Shader.ShaderType.Fragment)) { technique.setShaderFile(shaderNames, shaderLanguages); } else { technique = null; diff --git a/jme3-core/src/test/java/com/jme3/material/plugins/LoadJ3mdTest.java b/jme3-core/src/test/java/com/jme3/material/plugins/LoadJ3mdTest.java new file mode 100644 index 000000000..ea47129a7 --- /dev/null +++ b/jme3-core/src/test/java/com/jme3/material/plugins/LoadJ3mdTest.java @@ -0,0 +1,100 @@ +/* + * Copyright (c) 2009-2016 jMonkeyEngine + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * * Neither the name of 'jMonkeyEngine' nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ +package com.jme3.material.plugins; + +import com.jme3.asset.AssetManager; +import com.jme3.material.*; +import com.jme3.renderer.*; +import com.jme3.scene.Geometry; +import com.jme3.scene.shape.Box; +import com.jme3.shader.Shader; +import com.jme3.system.*; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.mockito.runners.MockitoJUnitRunner; + +import java.util.*; + +import static org.junit.Assert.assertEquals; + +@RunWith(MockitoJUnitRunner.class) +public class LoadJ3mdTest { + + private Material material; + private final Geometry geometry = new Geometry("Geometry", new Box(1, 1, 1)); + private final EnumSet myCaps = EnumSet.noneOf(Caps.class); + private final RenderManager renderManager = new RenderManager(new NullRenderer() { + @Override + public EnumSet getCaps() { + return LoadJ3mdTest.this.myCaps; + } + }); + + @Test + public void testShaderNodesMaterialDefLoading() { + supportGlsl(100); + material("testMatDef.j3md"); + material.selectTechnique("Default", renderManager); + + assertEquals(material.getActiveTechnique().getDef().getShaderNodes().size(), 2); + Shader s = material.getActiveTechnique().getDef().getShader(TestUtil.createAssetManager(), myCaps, material.getActiveTechnique().getDynamicDefines()); + assertEquals(s.getSources().size(), 2); + } + + private void supportGlsl(int version) { + switch (version) { + case 150: + myCaps.add(Caps.GLSL150); + case 140: + myCaps.add(Caps.GLSL140); + case 130: + myCaps.add(Caps.GLSL130); + case 120: + myCaps.add(Caps.GLSL120); + case 110: + myCaps.add(Caps.GLSL110); + case 100: + myCaps.add(Caps.GLSL100); + break; + } + } + private void caps(Caps... caps) { + myCaps.addAll(Arrays.asList(caps)); + } + + private void material(String path) { + AssetManager assetManager = TestUtil.createAssetManager(); + material = new Material(assetManager, path); + geometry.setMaterial(material); + } + +} diff --git a/jme3-core/src/test/resources/testMatDef.j3md b/jme3-core/src/test/resources/testMatDef.j3md new file mode 100644 index 000000000..bf70b1e2a --- /dev/null +++ b/jme3-core/src/test/resources/testMatDef.j3md @@ -0,0 +1,34 @@ +MaterialDef Simple { + MaterialParameters { + Color Color + } + Technique { + WorldParameters { + WorldViewProjectionMatrix + } + VertexShaderNodes { + ShaderNode CommonVert { + Definition : CommonVert : Common/MatDefs/ShaderNodes/Common/CommonVert.j3sn + InputMappings { + worldViewProjectionMatrix = WorldParam.WorldViewProjectionMatrix + modelPosition = Global.position.xyz + } + OutputMappings { + Global.position = projPosition + } + } + } + FragmentShaderNodes { + ShaderNode ColorMult { + Definition : ColorMult : Common/MatDefs/ShaderNodes/Basic/ColorMult.j3sn + InputMappings { + color1 = MatParam.Color + color2 = Global.color + } + OutputMappings { + Global.color = outColor + } + } + } + } +} \ No newline at end of file