public static int RemapBlockIds(uint[] block_ids, int length) { global::haxe.ds.IntMap <int> new_id = new global::haxe.ds.IntMap <int>(); int next_id = 0; { int _g1 = 0; while ((_g1 < length)) { int i = _g1++; if ((new_id.exists(((int)(((uint)(((uint[])(block_ids))[i]))))) == false)) { new_id.@set(((int)(((uint)(((uint[])(block_ids))[i])))), next_id); ++next_id; } } } { int _g11 = 0; while ((_g11 < length)) { int i1 = _g11++; ((uint[])(block_ids))[i1] = ((uint)((new_id.@get(((int)(((uint)(((uint[])(block_ids))[i1])))))).@value)); } } return(next_id); }
public virtual global::haxe.zip.Huffman treeMake(global::haxe.ds.IntMap bits, int maxbits, int v, int len) { unchecked { #line 76 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" if ((len > maxbits)) { #line 77 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" throw global::haxe.lang.HaxeException.wrap("Invalid huffman"); } #line 78 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" int idx = ((v << 5) | len); if (bits.exists(((int)(idx)))) { #line 80 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" return(global::haxe.zip.Huffman.Found(((int)(global::haxe.lang.Runtime.toInt(bits.@get(((int)(idx)))))))); } #line 81 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" v <<= 1; ++len; #line 83 "C:\\HaxeToolkit\\haxe\\std\\haxe\\zip\\Huffman.hx" return(global::haxe.zip.Huffman.NeedBit(this.treeMake(bits, maxbits, v, len), this.treeMake(bits, maxbits, (v | 1), len))); } #line default }
public virtual void setupMap(object map) { unchecked { { int _g = 0; global::Array <object> _g1 = ((global::Array <object>)(global::Array <object> .__hx_cast <object>(((global::Array)(global::haxe.lang.Runtime.getField(map, "sites", 2094299916, true)))))); while ((_g < _g1.length)) { object data = _g1[_g]; ++_g; global::game.Site site = new global::game.Site(this, ((int)(global::haxe.lang.Runtime.getField_f(data, "id", 23515, true))), ((!(global::haxe.lang.Null <object> .ofDynamic <double>(global::haxe.lang.Runtime.getField(data, "x", 120, true)).hasValue)) ? (global::Math.rand.NextDouble()) : (((double)(global::haxe.lang.Runtime.toDouble(global::haxe.lang.Runtime.getField(data, "x", 120, true)))))), ((!(global::haxe.lang.Null <object> .ofDynamic <double>(global::haxe.lang.Runtime.getField(data, "y", 121, true)).hasValue)) ? (global::Math.rand.NextDouble()) : (((double)(global::haxe.lang.Runtime.toDouble(global::haxe.lang.Runtime.getField(data, "y", 121, true))))))); ((global::haxe.IMap <int, object>)(this.sites)).@set(site.id, site); } } { int _g2 = 0; global::Array <int> _g11 = ((global::Array <int>)(global::Array <object> .__hx_cast <int>(((global::Array)(global::haxe.lang.Runtime.getField(map, "mines", 141062784, true)))))); while ((_g2 < _g11.length)) { int siteId = _g11[_g2]; ++_g2; global::game.Site site1 = ((global::game.Site)((((global::haxe.IMap <int, object>)(this.sites)).@get(siteId)).@value)); site1.isMine = true; ((global::haxe.IMap <int, object>)(this.mines)).@set(siteId, site1); } } int i = 0; { int _g3 = 0; global::Array <object> _g12 = ((global::Array <object>)(global::Array <object> .__hx_cast <object>(((global::Array)(global::haxe.lang.Runtime.getField(map, "rivers", 1477328871, true)))))); while ((_g3 < _g12.length)) { object data1 = _g12[_g3]; ++_g3; int id = global::game._RiverId.RiverId_Impl_._new(i); global::game.River river = new global::game.River(this, id, ((int)(global::haxe.lang.Runtime.getField_f(data1, "source", 842117339, true))), ((int)(global::haxe.lang.Runtime.getField_f(data1, "target", 116192081, true)))); ((global::haxe.ds.IntMap <object>)(global::haxe.ds.IntMap <object> .__hx_cast <object>(((global::haxe.ds.IntMap)(((global::haxe.IMap <int, object>)(this.rivers))))))).@set(id, river); ((global::haxe.IMap <int, object>)(((global::game.Site)((((global::haxe.IMap <int, object>)(this.sites)).@get(river.a)).@value)).rivers)).@set((((river.a == river.a)) ? (river.b) : (river.a)), river); ((global::haxe.IMap <int, object>)(((global::game.Site)((((global::haxe.IMap <int, object>)(this.sites)).@get(river.b)).@value)).rivers)).@set((((river.a == river.b)) ? (river.b) : (river.a)), river); ++i; } } this.mineCount = ((global::Array <int>)(global::Array <object> .__hx_cast <int>(((global::Array)(global::haxe.lang.Runtime.getField(map, "mines", 141062784, true)))))).length; this.siteCount = ((global::Array <object>)(global::Array <object> .__hx_cast <object>(((global::Array)(global::haxe.lang.Runtime.getField(map, "sites", 2094299916, true)))))).length; this.riverCount = ((global::Array <object>)(global::Array <object> .__hx_cast <object>(((global::Array)(global::haxe.lang.Runtime.getField(map, "rivers", 1477328871, true)))))).length; this.maxScore = 0; { object mine = ((global::haxe.IMap <int, object>)(this.mines)).iterator(); while (global::haxe.lang.Runtime.toBool(global::haxe.lang.Runtime.callField(mine, "hasNext", 407283053, null))) { global::game.Site mine1 = ((global::game.Site)(global::haxe.lang.Runtime.callField(mine, "next", 1224901875, null))); global::haxe.IMap <int, int> localScores = new global::haxe.ds.IntMap <int>(); ((global::haxe.IMap <int, object>)(this.scoreDictionary)).@set(mine1.id, localScores); global::Array <object> currentSites = new global::Array <object>(new object[] { mine1 }); global::haxe.IMap <int, int> distances = new global::haxe.ds.IntMap <int>(); distances.@set(mine1.id, 0); { int _g13 = 0; int _g4 = this.siteCount; while ((_g13 < _g4)) { int i1 = _g13++; global::Array <object> nextSites = new global::Array <object>(new object[] {}); { int _g21 = 0; while ((_g21 < currentSites.length)) { global::game.Site site2 = ((global::game.Site)(currentSites[_g21])); ++_g21; { object river1 = ((global::haxe.IMap <int, object>)(site2.rivers)).iterator(); while (global::haxe.lang.Runtime.toBool(global::haxe.lang.Runtime.callField(river1, "hasNext", 407283053, null))) { global::game.River river2 = ((global::game.River)(global::haxe.lang.Runtime.callField(river1, "next", 1224901875, null))); int another = (((river2.a == site2.id)) ? (river2.b) : (river2.a)); if (!(distances.exists(another))) { { int v = (i1 + 1); distances.@set(another, v); } nextSites.push(((global::game.Site)((((global::haxe.IMap <int, object>)(this.sites)).@get(another)).@value))); } } } } } currentSites = nextSites; } } { object siteId1 = distances.keys(); while (global::haxe.lang.Runtime.toBool(global::haxe.lang.Runtime.callField(siteId1, "hasNext", 407283053, null))) { int siteId2 = ((int)(global::haxe.lang.Runtime.toInt(global::haxe.lang.Runtime.callField(siteId1, "next", 1224901875, null)))); global::haxe.lang.Null <int> distance = ((global::haxe.lang.Null <int>)(distances.@get(siteId2))); int score = ((distance).@value * (distance).@value); localScores.@set(siteId2, score); this.maxScore += score; } } } } } }
public static void HistogramReindex(global::Array <object> @out, int[] symbols) { global::Array <object> tmp = new global::Array <object>(); { int _g1 = 0; int _g = @out.length; while ((_g1 < _g)) { int i = _g1++; tmp[i] = new global::encode.histogram.Histogram(((int)((((int[])(((global::encode.histogram.Histogram)(@out[i])).data_)) as global::System.Array).Length))); ((global::encode.histogram.Histogram)(tmp[i])).bit_cost_ = ((global::encode.histogram.Histogram)(@out[i])).bit_cost_; { int _g3 = 0; int _g2 = (((int[])(((global::encode.histogram.Histogram)(@out[i])).data_)) as global::System.Array).Length; while ((_g3 < _g2)) { int a = _g3++; ((int[])(((global::encode.histogram.Histogram)(tmp[i])).data_))[a] = ((int[])(((global::encode.histogram.Histogram)(@out[i])).data_))[a]; } } ((global::encode.histogram.Histogram)(tmp[i])).kDataSize = ((global::encode.histogram.Histogram)(@out[i])).kDataSize; ((global::encode.histogram.Histogram)(tmp[i])).total_count_ = ((global::encode.histogram.Histogram)(@out[i])).total_count_; } } global::haxe.ds.IntMap <int> new_index = new global::haxe.ds.IntMap <int>(); int next_index = 0; { int _g11 = 0; int _g4 = (((int[])(symbols)) as global::System.Array).Length; while ((_g11 < _g4)) { int i1 = _g11++; if ((new_index.exists(((int)(((int[])(symbols))[i1]))) == false)) { new_index.@set(((int)(((int[])(symbols))[i1])), next_index); ((global::encode.histogram.Histogram)(@out[next_index])).bit_cost_ = ((global::encode.histogram.Histogram)(tmp[((int)(((int[])(symbols))[i1]))])).bit_cost_; { int _g31 = 0; int _g21 = (((int[])(((global::encode.histogram.Histogram)(tmp[((int)(((int[])(symbols))[i1]))])).data_)) as global::System.Array).Length; while ((_g31 < _g21)) { int a1 = _g31++; ((int[])(((global::encode.histogram.Histogram)(@out[next_index])).data_))[a1] = ((int[])(((global::encode.histogram.Histogram)(tmp[((int)(((int[])(symbols))[i1]))])).data_))[a1]; } } ((global::encode.histogram.Histogram)(@out[next_index])).kDataSize = ((global::encode.histogram.Histogram)(tmp[((int)(((int[])(symbols))[i1]))])).kDataSize; ((global::encode.histogram.Histogram)(@out[next_index])).total_count_ = ((global::encode.histogram.Histogram)(tmp[((int)(((int[])(symbols))[i1]))])).total_count_; ++next_index; } } } while ((@out.length > next_index)) { @out.pop(); } { int _g12 = 0; int _g5 = (((int[])(symbols)) as global::System.Array).Length; while ((_g12 < _g5)) { int i2 = _g12++; ((int[])(symbols))[i2] = (new_index.@get(((int)(((int[])(symbols))[i2])))).@value; } } }
public virtual object readMap(global::haxe.io.BytesInput i, int length, global::org.msgpack.DecodeOption option) { unchecked { #line 116 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" switch (option._hx_index) { case 0: { #line 128 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::haxe.root.Array pairs = new global::haxe.root.Array(new object[] {}); { #line 129 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g = 0; #line 129 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g1 = length; #line 129 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" while ((_g < _g1)) { #line 129 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int n = _g++; object k = this.decode(i, option); #line 131 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" object v = this.decode(i, option); pairs.push(new global::org.msgpack._Decoder.Pair(k, v)); } } #line 135 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if ((pairs.length == 0)) { #line 136 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" return(new global::haxe.ds.StringMap()); } #line 138 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::haxe.root.ValueType _g2 = global::haxe.root.Type.@typeof(((global::org.msgpack._Decoder.Pair)(pairs.__get(0))).k); #line 138 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" switch (_g2._hx_index) { case 1: { #line 141 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::haxe.ds.IntMap @out = new global::haxe.ds.IntMap(); { #line 142 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g21 = 0; #line 142 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" while ((_g21 < pairs.length)) { #line 142 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::org.msgpack._Decoder.Pair p = ((global::org.msgpack._Decoder.Pair)(pairs.__get(_g21))); #line 142 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" ++_g21; if ((global::haxe.root.Type.@typeof(p.k)._hx_index == 1)) { } else { #line 146 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap("Error: Mixed key type when decoding IntMap"); } #line 149 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if (@out.exists(((int)(global::haxe.lang.Runtime.toInt(p.k))))) { #line 150 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap(global::haxe.lang.Runtime.concat("Error: Duplicate keys found => ", global::haxe.root.Std.@string(p.k))); } #line 152 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" @out.@set(((int)(global::haxe.lang.Runtime.toInt(p.k))), ((object)(p.v))); } } #line 155 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" return(@out); } case 6: { #line 157 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::System.Type c = (_g2 as global::haxe.root.ValueType_TClass).c; #line 157 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if ((global::haxe.root.Type.getClassName(c) == "String")) { #line 158 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::haxe.ds.StringMap out1 = new global::haxe.ds.StringMap(); { #line 159 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g22 = 0; #line 159 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" while ((_g22 < pairs.length)) { #line 159 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::org.msgpack._Decoder.Pair p1 = ((global::org.msgpack._Decoder.Pair)(pairs.__get(_g22))); #line 159 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" ++_g22; { #line 160 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::haxe.root.ValueType _g23 = global::haxe.root.Type.@typeof(p1.k); #line 160 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if ((_g23._hx_index == 6)) { #line 161 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" global::System.Type c1 = (_g23 as global::haxe.root.ValueType_TClass).c; #line 161 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if ((global::haxe.root.Type.getClassName(c1) == "String")) { } else { #line 163 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap("Error: Mixed key type when decoding StringMap"); } } else { #line 163 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap("Error: Mixed key type when decoding StringMap"); } } #line 166 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" if (out1.exists(global::haxe.lang.Runtime.toString(p1.k))) { #line 167 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap(global::haxe.lang.Runtime.concat("Error: Duplicate keys found => ", global::haxe.root.Std.@string(p1.k))); } #line 169 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" out1.@set(global::haxe.lang.Runtime.toString(p1.k), ((object)(p1.v))); } } #line 172 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" return(out1); } else { #line 175 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap("Error: Unsupported key Type"); } } default: { #line 175 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" throw global::haxe.lang.HaxeException.wrap("Error: Unsupported key Type"); } } } case 1: { #line 118 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" object out2 = new global::haxe.lang.DynamicObject(new int[] {}, new object[] {}, new int[] {}, new double[] {}); { #line 119 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g3 = 0; #line 119 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int _g11 = length; #line 119 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" while ((_g3 < _g11)) { #line 119 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" int n1 = _g3++; object k1 = this.decode(i, option); #line 121 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" object v1 = this.decode(i, option); global::haxe.root.Reflect.setField(out2, global::haxe.root.Std.@string(k1), v1); } } #line 125 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" return(out2); } } #line 115 "D:\\project\\sangong\\sangong\\src\\org\\msgpack\\Decoder.hx" return(null); } #line default }