Przeglądaj źródła

more heaps_compact_mem support

Nicolas Cannasse 3 lat temu
rodzic
commit
3c13285d50
4 zmienionych plików z 13 dodań i 4 usunięć
  1. 2 0
      h3d/impl/DirectXDriver.hx
  2. 2 0
      h3d/impl/GlDriver.hx
  3. 3 0
      hxsl/Cache.hx
  4. 6 4
      hxsl/HlslOut.hx

+ 2 - 0
h3d/impl/DirectXDriver.hx

@@ -798,7 +798,9 @@ class DirectXDriver extends h3d.impl.Driver {
 		var h = new hxsl.HlslOut();
 		var h = new hxsl.HlslOut();
 		if( shader.code == null ){
 		if( shader.code == null ){
 			shader.code = h.run(shader.data);
 			shader.code = h.run(shader.data);
+			#if !heaps_compact_mem
 			shader.data.funs = null;
 			shader.data.funs = null;
+			#end
 		}
 		}
 		var bytes = getBinaryPayload(shader.vertex, shader.code);
 		var bytes = getBinaryPayload(shader.vertex, shader.code);
 		if( bytes == null ) {
 		if( bytes == null ) {

+ 2 - 0
h3d/impl/GlDriver.hx

@@ -285,7 +285,9 @@ class GlDriver extends Driver {
 		var s = gl.createShader(type);
 		var s = gl.createShader(type);
 		if( shader.code == null ){
 		if( shader.code == null ){
 			shader.code = glout.run(shader.data);
 			shader.code = glout.run(shader.data);
+			#if !heaps_compact_mem
 			shader.data.funs = null;
 			shader.data.funs = null;
+			#end
 		}
 		}
 		gl.shaderSource(s, shader.code);
 		gl.shaderSource(s, shader.code);
 		gl.compileShader(s);
 		gl.compileShader(s);

+ 3 - 0
hxsl/Cache.hx

@@ -382,6 +382,9 @@ class Cache {
 		var flat = new Flatten();
 		var flat = new Flatten();
 		var c = new RuntimeShaderData();
 		var c = new RuntimeShaderData();
 		var data = flat.flatten(s, kind, constsToGlobal);
 		var data = flat.flatten(s, kind, constsToGlobal);
+		#if (hl && heaps_compact_mem)
+		data = hl.Api.compact(data, null, 0, null);
+		#end
 		var textures = [];
 		var textures = [];
 		c.consts = flat.consts;
 		c.consts = flat.consts;
 		c.texturesCount = 0;
 		c.texturesCount = 0;

+ 6 - 4
hxsl/HlslOut.hx

@@ -196,10 +196,12 @@ class HlslOut {
 	function addVar( v : TVar ) {
 	function addVar( v : TVar ) {
 		switch( v.type ) {
 		switch( v.type ) {
 		case TArray(t, size), TBuffer(t,size):
 		case TArray(t, size), TBuffer(t,size):
-			var old = v.type;
-			v.type = t;
-			addVar(v);
-			v.type = old;
+			addVar({
+				id : v.id,
+				name : v.name,
+				type : t,
+				kind : v.kind,
+			});
 			addArraySize(size);
 			addArraySize(size);
 		default:
 		default:
 			addType(v.type);
 			addType(v.type);