diff --git a/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.md5 b/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.md5 new file mode 100644 index 0000000..4e35117 --- /dev/null +++ b/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.md5 @@ -0,0 +1,3 @@ +source_md5="d7f6549e6809bd7867b8eddd75e6bf21" +dest_md5="5ffeebbcc8d5267b91604532d96bb1b8" + diff --git a/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.stex b/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.stex new file mode 100644 index 0000000..ef1add5 Binary files /dev/null and b/.import/01.png-cde89d2e22e814dc7e1c03ad1ae60fc8.stex differ diff --git a/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.md5 b/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.md5 new file mode 100644 index 0000000..e2fe972 --- /dev/null +++ b/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.md5 @@ -0,0 +1,3 @@ +source_md5="08508f40b546910b1402b3112090f91b" +dest_md5="e0c73e34852c5022decad6fa02ab3751" + diff --git a/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.stex b/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.stex new file mode 100644 index 0000000..6273a86 Binary files /dev/null and b/.import/02.png-565e9fad4b9e7654bf4734eef9558b27.stex differ diff --git a/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.md5 b/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.md5 new file mode 100644 index 0000000..0d9c56e --- /dev/null +++ b/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.md5 @@ -0,0 +1,3 @@ +source_md5="1f9f974b587331877eed69671dd0e4eb" +dest_md5="ef8cc989a7589833798cbd0ac33c570e" + diff --git a/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.stex b/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.stex new file mode 100644 index 0000000..740302f Binary files /dev/null and b/.import/03.png-ee94f121a78d4b259af8b218d886a3ba.stex differ diff --git a/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.md5 b/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.md5 new file mode 100644 index 0000000..20051b1 --- /dev/null +++ b/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.md5 @@ -0,0 +1,3 @@ +source_md5="1b53eb9a9fcb93f627f874626999b9eb" +dest_md5="9819eb2b6721fbc4c0775333c6fea578" + diff --git a/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.stex b/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.stex new file mode 100644 index 0000000..361d08e Binary files /dev/null and b/.import/04.png-2402feb8d542f9ff23436c21d6d4ef01.stex differ diff --git a/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.md5 b/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.md5 new file mode 100644 index 0000000..701cac6 --- /dev/null +++ b/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.md5 @@ -0,0 +1,3 @@ +source_md5="616f770983d550594de6dce58cdfd5b8" +dest_md5="414052470ffd09abfeb6269dab77457a" + diff --git a/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.stex b/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.stex new file mode 100644 index 0000000..9c3d476 Binary files /dev/null and b/.import/05.png-466e5244046f26b5eca5cc8db52b6dfa.stex differ diff --git a/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.md5 b/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.md5 new file mode 100644 index 0000000..a77095e --- /dev/null +++ b/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.md5 @@ -0,0 +1,3 @@ +source_md5="51a447ce69fcff71e80170c780f9c28f" +dest_md5="e6542e0003b1854f4980b3777aee0058" + diff --git a/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.stex b/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.stex new file mode 100644 index 0000000..05420db Binary files /dev/null and b/.import/06.png-fcc7c9c5c94e7db6a91f4a99bf42555b.stex differ diff --git a/.import/07.png-e947307142bf1106994846430a12203d.md5 b/.import/07.png-e947307142bf1106994846430a12203d.md5 new file mode 100644 index 0000000..08d9b45 --- /dev/null +++ b/.import/07.png-e947307142bf1106994846430a12203d.md5 @@ -0,0 +1,3 @@ +source_md5="c88c31a2ad1ec997f056c337bb14fd69" +dest_md5="f71fccd25b69981f299d45c848db7732" + diff --git a/.import/07.png-e947307142bf1106994846430a12203d.stex b/.import/07.png-e947307142bf1106994846430a12203d.stex new file mode 100644 index 0000000..bc8224b Binary files /dev/null and b/.import/07.png-e947307142bf1106994846430a12203d.stex differ diff --git a/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.md5 b/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.md5 new file mode 100644 index 0000000..b1f82c9 --- /dev/null +++ b/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.md5 @@ -0,0 +1,3 @@ +source_md5="7cf0a9570d1e462911f42f3b53e050f7" +dest_md5="c9cf2750187c016a50d4097d5dda6df0" + diff --git a/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.stex b/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.stex new file mode 100644 index 0000000..09bb1ba Binary files /dev/null and b/.import/08.png-e782d1f7bcff637d0c89b51a0d947156.stex differ diff --git a/.import/09.png-68faca3e92eaa2343e65680caa40761e.md5 b/.import/09.png-68faca3e92eaa2343e65680caa40761e.md5 new file mode 100644 index 0000000..bc3388d --- /dev/null +++ b/.import/09.png-68faca3e92eaa2343e65680caa40761e.md5 @@ -0,0 +1,3 @@ +source_md5="baed976d717bd3d06dfee2ea39d78001" +dest_md5="84b92cada2bb86a76f4d853d3ca3db3e" + diff --git a/.import/09.png-68faca3e92eaa2343e65680caa40761e.stex b/.import/09.png-68faca3e92eaa2343e65680caa40761e.stex new file mode 100644 index 0000000..c01f585 Binary files /dev/null and b/.import/09.png-68faca3e92eaa2343e65680caa40761e.stex differ diff --git a/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.md5 b/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.md5 new file mode 100644 index 0000000..d29d502 --- /dev/null +++ b/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.md5 @@ -0,0 +1,3 @@ +source_md5="ce544e6879468566e1b066c7f19d56c2" +dest_md5="d9c5e6f3a9b36002fbab5175dc75e6d8" + diff --git a/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.stex b/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.stex new file mode 100644 index 0000000..34a5234 Binary files /dev/null and b/.import/10.png-2e9d79cc2933cd27f14cfe10e4a6efb0.stex differ diff --git a/.import/11.png-124b765e7b665d992611f1fa61008dbd.md5 b/.import/11.png-124b765e7b665d992611f1fa61008dbd.md5 new file mode 100644 index 0000000..1045509 --- /dev/null +++ b/.import/11.png-124b765e7b665d992611f1fa61008dbd.md5 @@ -0,0 +1,3 @@ +source_md5="6ff53942f0ce0fcb9a306e580fa97f39" +dest_md5="810ec6074d3a18ebff1452a634665afb" + diff --git a/.import/11.png-124b765e7b665d992611f1fa61008dbd.stex b/.import/11.png-124b765e7b665d992611f1fa61008dbd.stex new file mode 100644 index 0000000..821dcf5 Binary files /dev/null and b/.import/11.png-124b765e7b665d992611f1fa61008dbd.stex differ diff --git a/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.md5 b/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.md5 new file mode 100644 index 0000000..5370fc4 --- /dev/null +++ b/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.md5 @@ -0,0 +1,3 @@ +source_md5="04accdc4c4f1d3d280b68d470534a78f" +dest_md5="1cb6c44f9c651138f8f5e8750908b270" + diff --git a/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.stex b/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.stex new file mode 100644 index 0000000..f563251 Binary files /dev/null and b/.import/12.png-1e50adc873fea9b94eb3f363443ba5df.stex differ diff --git a/.import/13.png-0458b237574837488355bda1d4821436.md5 b/.import/13.png-0458b237574837488355bda1d4821436.md5 new file mode 100644 index 0000000..218af85 --- /dev/null +++ b/.import/13.png-0458b237574837488355bda1d4821436.md5 @@ -0,0 +1,3 @@ +source_md5="493285cf2283a88931bc4d22bbe8e349" +dest_md5="a45edf455a810faa5c05b9e2b0098b3f" + diff --git a/.import/13.png-0458b237574837488355bda1d4821436.stex b/.import/13.png-0458b237574837488355bda1d4821436.stex new file mode 100644 index 0000000..49ffe10 Binary files /dev/null and b/.import/13.png-0458b237574837488355bda1d4821436.stex differ diff --git a/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.md5 b/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.md5 new file mode 100644 index 0000000..5bbb4df --- /dev/null +++ b/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.md5 @@ -0,0 +1,3 @@ +source_md5="3ebc69f789c0e9dcee5cf8ab5824a11b" +dest_md5="8ed0d2755216511d9d228e847fe196a8" + diff --git a/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.stex b/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.stex new file mode 100644 index 0000000..175acf9 Binary files /dev/null and b/.import/14.png-46635d47b94b5c3ef71f5cb38b56f4b5.stex differ diff --git a/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.md5 b/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.md5 new file mode 100644 index 0000000..a0a71b7 --- /dev/null +++ b/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.md5 @@ -0,0 +1,3 @@ +source_md5="54f287e88233a1920a1eb939d96e3b5b" +dest_md5="4055e971d03ffd5e736391a96138ed2c" + diff --git a/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.stex b/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.stex new file mode 100644 index 0000000..4997024 Binary files /dev/null and b/.import/15.png-16e955f89b1b34b7e13de3a3572fabc3.stex differ diff --git a/.import/16.png-857622aa4229f7bc724252b517cc3f66.md5 b/.import/16.png-857622aa4229f7bc724252b517cc3f66.md5 new file mode 100644 index 0000000..5fce23b --- /dev/null +++ b/.import/16.png-857622aa4229f7bc724252b517cc3f66.md5 @@ -0,0 +1,3 @@ +source_md5="fad064526892b2616b527a15bf77fe4c" +dest_md5="15345cbad66f889e0a5ba1f8c07bf12a" + diff --git a/.import/16.png-857622aa4229f7bc724252b517cc3f66.stex b/.import/16.png-857622aa4229f7bc724252b517cc3f66.stex new file mode 100644 index 0000000..6559db7 Binary files /dev/null and b/.import/16.png-857622aa4229f7bc724252b517cc3f66.stex differ diff --git a/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.md5 b/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.md5 new file mode 100644 index 0000000..63a7364 --- /dev/null +++ b/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.md5 @@ -0,0 +1,3 @@ +source_md5="286c8805e99d6970b39b38f7be879b1f" +dest_md5="acfb2143e15a47081fb47956641b3df5" + diff --git a/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.stex b/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.stex new file mode 100644 index 0000000..a0aba67 Binary files /dev/null and b/.import/17.png-1fb9472cceb61f6755419658d9fa8c97.stex differ diff --git a/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.md5 b/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.md5 new file mode 100644 index 0000000..6a52f35 --- /dev/null +++ b/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.md5 @@ -0,0 +1,3 @@ +source_md5="4f675585ad0a1944e9fc80e5e6dcb486" +dest_md5="a40e63036d46c179faa2b605e2df7dae" + diff --git a/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.stex b/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.stex new file mode 100644 index 0000000..6391105 Binary files /dev/null and b/.import/18.png-3578c0a6e9a9c6b8f52efa5971d7fd7f.stex differ diff --git a/.import/19.png-d809bd40789551fd8184500fd160d790.md5 b/.import/19.png-d809bd40789551fd8184500fd160d790.md5 new file mode 100644 index 0000000..d6b1396 --- /dev/null +++ b/.import/19.png-d809bd40789551fd8184500fd160d790.md5 @@ -0,0 +1,3 @@ +source_md5="c976c40625f767184f1abe468db5f375" +dest_md5="89d0f955158748232850929655a1f385" + diff --git a/.import/19.png-d809bd40789551fd8184500fd160d790.stex b/.import/19.png-d809bd40789551fd8184500fd160d790.stex new file mode 100644 index 0000000..3b91a50 Binary files /dev/null and b/.import/19.png-d809bd40789551fd8184500fd160d790.stex differ diff --git a/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.md5 b/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.md5 new file mode 100644 index 0000000..5778b9b --- /dev/null +++ b/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.md5 @@ -0,0 +1,3 @@ +source_md5="73730ecfde474d999a027b06288751b6" +dest_md5="56ff97848ca913268d375e80bd5bb872" + diff --git a/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.stex b/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.stex new file mode 100644 index 0000000..37a823c Binary files /dev/null and b/.import/20 Enemies.png-225138b476414105eb81e9f4a07ea65a.stex differ diff --git a/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.md5 b/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.md5 new file mode 100644 index 0000000..5be3563 --- /dev/null +++ b/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.md5 @@ -0,0 +1,3 @@ +source_md5="84affb6c644a02eeb2ca3289a4478f33" +dest_md5="f548e7b1fc715424e41da85b0210f349" + diff --git a/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.stex b/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.stex new file mode 100644 index 0000000..9345d45 Binary files /dev/null and b/.import/20.png-e8dcbee6f1fd1f587020749f0ece0561.stex differ diff --git a/.import/21.png-d79d49d977239fb0dac1286627467e0e.md5 b/.import/21.png-d79d49d977239fb0dac1286627467e0e.md5 new file mode 100644 index 0000000..23498b7 --- /dev/null +++ b/.import/21.png-d79d49d977239fb0dac1286627467e0e.md5 @@ -0,0 +1,3 @@ +source_md5="00647eca8e6ed0149fb651a55eed68d5" +dest_md5="dc9fe6ca508c16b917ae7c11306bf46d" + diff --git a/.import/21.png-d79d49d977239fb0dac1286627467e0e.stex b/.import/21.png-d79d49d977239fb0dac1286627467e0e.stex new file mode 100644 index 0000000..888f698 Binary files /dev/null and b/.import/21.png-d79d49d977239fb0dac1286627467e0e.stex differ diff --git a/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.md5 b/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.md5 new file mode 100644 index 0000000..db03494 --- /dev/null +++ b/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.md5 @@ -0,0 +1,3 @@ +source_md5="6ac40e97760aee2267872319a5ac1c06" +dest_md5="3d162a17b3e7016023c781fb86108761" + diff --git a/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.stex b/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.stex new file mode 100644 index 0000000..fa7c050 Binary files /dev/null and b/.import/22.png-f73750e240bed490efd6fcc608bcf2c0.stex differ diff --git a/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.md5 b/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.md5 new file mode 100644 index 0000000..d2361eb --- /dev/null +++ b/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.md5 @@ -0,0 +1,3 @@ +source_md5="c01e777908fc433e2f7e3d48a1af9ada" +dest_md5="4fcbfb48d77eab8fb164728bb61cd79c" + diff --git a/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.stex b/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.stex new file mode 100644 index 0000000..3906dba Binary files /dev/null and b/.import/23.png-1ef11f1c9b42df6f98db34b13b194514.stex differ diff --git a/.import/24.png-44442d803aaabd234742a716aedb5438.md5 b/.import/24.png-44442d803aaabd234742a716aedb5438.md5 new file mode 100644 index 0000000..47b0dc4 --- /dev/null +++ b/.import/24.png-44442d803aaabd234742a716aedb5438.md5 @@ -0,0 +1,3 @@ +source_md5="6127aab3b8ff227fa95e49c8facf53d2" +dest_md5="2e52f95ea73bae1ab761b01f84fdf5ae" + diff --git a/.import/24.png-44442d803aaabd234742a716aedb5438.stex b/.import/24.png-44442d803aaabd234742a716aedb5438.stex new file mode 100644 index 0000000..e82df3b Binary files /dev/null and b/.import/24.png-44442d803aaabd234742a716aedb5438.stex differ diff --git a/.import/25.png-fc93de9d4a740398e55712545fe4fd86.md5 b/.import/25.png-fc93de9d4a740398e55712545fe4fd86.md5 new file mode 100644 index 0000000..6f7e8e0 --- /dev/null +++ b/.import/25.png-fc93de9d4a740398e55712545fe4fd86.md5 @@ -0,0 +1,3 @@ +source_md5="38f83ad87ce5b9e1033a9808b27232d0" +dest_md5="e667155f3882f1ca4cfb78abff4e3228" + diff --git a/.import/25.png-fc93de9d4a740398e55712545fe4fd86.stex b/.import/25.png-fc93de9d4a740398e55712545fe4fd86.stex new file mode 100644 index 0000000..60d2ae9 Binary files /dev/null and b/.import/25.png-fc93de9d4a740398e55712545fe4fd86.stex differ diff --git a/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.md5 b/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.md5 new file mode 100644 index 0000000..ca0d360 --- /dev/null +++ b/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.md5 @@ -0,0 +1,3 @@ +source_md5="4c60a5b7b5675434f647d2964402a84f" +dest_md5="5c9733907f63748859fe2a82377168d6" + diff --git a/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.stex b/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.stex new file mode 100644 index 0000000..13139ce Binary files /dev/null and b/.import/26.png-61b89d5ea2a8550cbca60239c7a07cac.stex differ diff --git a/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.md5 b/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.md5 new file mode 100644 index 0000000..b081021 --- /dev/null +++ b/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.md5 @@ -0,0 +1,3 @@ +source_md5="40265837ef70a977c1acb2efe19b40b1" +dest_md5="042d24dd43c82fda298d05301dc6de9c" + diff --git a/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.stex b/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.stex new file mode 100644 index 0000000..47271ad Binary files /dev/null and b/.import/27.png-f33372f67c70d0b0f4f70c8bad825fd9.stex differ diff --git a/.import/28.png-620da1f0422c82cb65c701f72a047b5b.md5 b/.import/28.png-620da1f0422c82cb65c701f72a047b5b.md5 new file mode 100644 index 0000000..2f3e31d --- /dev/null +++ b/.import/28.png-620da1f0422c82cb65c701f72a047b5b.md5 @@ -0,0 +1,3 @@ +source_md5="b4f5454651b31f958f55ba10f2102662" +dest_md5="96e4fe43e16ad57bf1286d875a0192bc" + diff --git a/.import/28.png-620da1f0422c82cb65c701f72a047b5b.stex b/.import/28.png-620da1f0422c82cb65c701f72a047b5b.stex new file mode 100644 index 0000000..2efa598 Binary files /dev/null and b/.import/28.png-620da1f0422c82cb65c701f72a047b5b.stex differ diff --git a/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.md5 b/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.md5 new file mode 100644 index 0000000..3359228 --- /dev/null +++ b/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.md5 @@ -0,0 +1,3 @@ +source_md5="617b1485fcef9a94953b0608f6dd4215" +dest_md5="1b54ebd20c1996c5f83727a8ff1bcfe4" + diff --git a/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.stex b/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.stex new file mode 100644 index 0000000..70c8603 Binary files /dev/null and b/.import/29.png-bc551ec6b2381e0bff4eb0d3cae6a0f3.stex differ diff --git a/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.md5 b/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.md5 new file mode 100644 index 0000000..e155280 --- /dev/null +++ b/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.md5 @@ -0,0 +1,3 @@ +source_md5="b9d3d9c462ea5f310879644dc22b90ca" +dest_md5="243be82976724ed7d18ecc8fd08e6283" + diff --git a/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.stex b/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.stex new file mode 100644 index 0000000..e0b9d21 Binary files /dev/null and b/.import/30.png-f145112e89da5c0fa1c4b0c7ed64b01f.stex differ diff --git a/.import/31.png-1f51e3340a42f8b978995db12fc2a270.md5 b/.import/31.png-1f51e3340a42f8b978995db12fc2a270.md5 new file mode 100644 index 0000000..272ff5f --- /dev/null +++ b/.import/31.png-1f51e3340a42f8b978995db12fc2a270.md5 @@ -0,0 +1,3 @@ +source_md5="7332e2ccf70241eef0d3c837eba8560c" +dest_md5="0ea995635dfdbd420480946f4e80a2aa" + diff --git a/.import/31.png-1f51e3340a42f8b978995db12fc2a270.stex b/.import/31.png-1f51e3340a42f8b978995db12fc2a270.stex new file mode 100644 index 0000000..69522a8 Binary files /dev/null and b/.import/31.png-1f51e3340a42f8b978995db12fc2a270.stex differ diff --git a/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.md5 b/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.md5 new file mode 100644 index 0000000..472b378 --- /dev/null +++ b/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.md5 @@ -0,0 +1,3 @@ +source_md5="4e1f62217b65790564c3f903b65e4637" +dest_md5="2cd52708193d83fa976cd78bb0a5e3f3" + diff --git a/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.stex b/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.stex new file mode 100644 index 0000000..a2af56e Binary files /dev/null and b/.import/32.png-ba91b9d31de3f960a2a5e16f194daf07.stex differ diff --git a/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.md5 b/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.md5 new file mode 100644 index 0000000..05a7791 --- /dev/null +++ b/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.md5 @@ -0,0 +1,3 @@ +source_md5="682046f85570a44f0902dbc7583615bf" +dest_md5="c7581433e3888ed3f8c400c2ee485039" + diff --git a/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.stex b/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.stex new file mode 100644 index 0000000..08436f5 Binary files /dev/null and b/.import/33.png-30cd949c604b7aafdc1cba3e5f14089e.stex differ diff --git a/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.md5 b/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.md5 new file mode 100644 index 0000000..c54c03c --- /dev/null +++ b/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.md5 @@ -0,0 +1,3 @@ +source_md5="4fbd87c9be43814740cb1e07429183c4" +dest_md5="5d11fad5f37868312341c3b82e25e9a9" + diff --git a/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.stex b/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.stex new file mode 100644 index 0000000..5a68481 Binary files /dev/null and b/.import/34.png-f8f6a0078dd2d6c353754a08015f877f.stex differ diff --git a/.import/35.png-c594128421e6b688c04669797ba8a380.md5 b/.import/35.png-c594128421e6b688c04669797ba8a380.md5 new file mode 100644 index 0000000..11b48cc --- /dev/null +++ b/.import/35.png-c594128421e6b688c04669797ba8a380.md5 @@ -0,0 +1,3 @@ +source_md5="4ca4713c74ec75f1735473f080cbb1b0" +dest_md5="06301c777b2a98ee6ed11ee756b6734d" + diff --git a/.import/35.png-c594128421e6b688c04669797ba8a380.stex b/.import/35.png-c594128421e6b688c04669797ba8a380.stex new file mode 100644 index 0000000..a7ad9fb Binary files /dev/null and b/.import/35.png-c594128421e6b688c04669797ba8a380.stex differ diff --git a/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.md5 b/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.md5 new file mode 100644 index 0000000..5bdd2f3 --- /dev/null +++ b/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.md5 @@ -0,0 +1,3 @@ +source_md5="0a3663508994f5a64b59b0fd318f8396" +dest_md5="42ce3d206a35019bbe9dfa0bf0f26767" + diff --git a/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.stex b/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.stex new file mode 100644 index 0000000..e575405 Binary files /dev/null and b/.import/36.png-2f122d761d7fe48ac87faf4cf99b3367.stex differ diff --git a/.import/37.png-e0f05c20c4a574886dbf418360754513.md5 b/.import/37.png-e0f05c20c4a574886dbf418360754513.md5 new file mode 100644 index 0000000..e5c973e --- /dev/null +++ b/.import/37.png-e0f05c20c4a574886dbf418360754513.md5 @@ -0,0 +1,3 @@ +source_md5="dc22ace9201c806fdf9fc9cb438d5175" +dest_md5="4354919a31747c402c4ad26005800910" + diff --git a/.import/37.png-e0f05c20c4a574886dbf418360754513.stex b/.import/37.png-e0f05c20c4a574886dbf418360754513.stex new file mode 100644 index 0000000..687e8f8 Binary files /dev/null and b/.import/37.png-e0f05c20c4a574886dbf418360754513.stex differ diff --git a/.import/38.png-9ad1c4986189d5904cc06f913ad42687.md5 b/.import/38.png-9ad1c4986189d5904cc06f913ad42687.md5 new file mode 100644 index 0000000..7fc2a2a --- /dev/null +++ b/.import/38.png-9ad1c4986189d5904cc06f913ad42687.md5 @@ -0,0 +1,3 @@ +source_md5="b765f20e7e7a16b59262a0ba5e245a20" +dest_md5="a3e6a8a1029155b856dfe3f4d3445bd1" + diff --git a/.import/38.png-9ad1c4986189d5904cc06f913ad42687.stex b/.import/38.png-9ad1c4986189d5904cc06f913ad42687.stex new file mode 100644 index 0000000..b871852 Binary files /dev/null and b/.import/38.png-9ad1c4986189d5904cc06f913ad42687.stex differ diff --git a/.import/39.png-844b08bd7347291639770ebfbb16f333.md5 b/.import/39.png-844b08bd7347291639770ebfbb16f333.md5 new file mode 100644 index 0000000..c482082 --- /dev/null +++ b/.import/39.png-844b08bd7347291639770ebfbb16f333.md5 @@ -0,0 +1,3 @@ +source_md5="c889d1617a2130f2454ed940eb55e2a6" +dest_md5="53ecb9229ca59bdf81c057ebbf7ed88f" + diff --git a/.import/39.png-844b08bd7347291639770ebfbb16f333.stex b/.import/39.png-844b08bd7347291639770ebfbb16f333.stex new file mode 100644 index 0000000..1a9a31f Binary files /dev/null and b/.import/39.png-844b08bd7347291639770ebfbb16f333.stex differ diff --git a/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.md5 b/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.md5 new file mode 100644 index 0000000..d94850d --- /dev/null +++ b/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.md5 @@ -0,0 +1,3 @@ +source_md5="332ce8ae0ea6da6ce0dfe0dab7da5496" +dest_md5="33265e9912ca5a29234df08bbf1251db" + diff --git a/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.stex b/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.stex new file mode 100644 index 0000000..fb21afa Binary files /dev/null and b/.import/40.png-abae9a7cdb7168ab50f9b9ed8bc0df2d.stex differ diff --git a/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.md5 b/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.md5 new file mode 100644 index 0000000..6c93928 --- /dev/null +++ b/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.md5 @@ -0,0 +1,3 @@ +source_md5="1ec256afdf7de31a869bc88fddff9943" +dest_md5="08921b76f2caff6ce478b1b86b814495" + diff --git a/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.stex b/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.stex new file mode 100644 index 0000000..ae296d1 Binary files /dev/null and b/.import/41.png-bedba95f5a13017cd87139dbe9f6b497.stex differ diff --git a/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.md5 b/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.md5 new file mode 100644 index 0000000..6fcda5a --- /dev/null +++ b/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.md5 @@ -0,0 +1,3 @@ +source_md5="13b602a32df5aae75a97615edc7c57a9" +dest_md5="2f85daa2d76ca6efaa1105c09bd7ab48" + diff --git a/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.stex b/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.stex new file mode 100644 index 0000000..1585712 Binary files /dev/null and b/.import/42.png-5dcea205382ade2fcc77aa397ccf5de9.stex differ diff --git a/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.md5 b/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.md5 new file mode 100644 index 0000000..eecb144 --- /dev/null +++ b/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.md5 @@ -0,0 +1,3 @@ +source_md5="9526f399e906a5b10330d8b3a679a4d7" +dest_md5="0e6f92e2a5d4108517c2d210464701c8" + diff --git a/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.stex b/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.stex new file mode 100644 index 0000000..b1eb1be Binary files /dev/null and b/.import/43.png-3a23f6dc7c7b2d098dec6114d07e9c7a.stex differ diff --git a/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.md5 b/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.md5 new file mode 100644 index 0000000..fe19ff0 --- /dev/null +++ b/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.md5 @@ -0,0 +1,3 @@ +source_md5="1b9f7f955f3e615a21cf8198a6b8ed35" +dest_md5="df4ad41e03231afa39116a476e73044f" + diff --git a/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.stex b/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.stex new file mode 100644 index 0000000..17e45b7 Binary files /dev/null and b/.import/44.png-8f1f4b62fda298e34f9d279232bd3663.stex differ diff --git a/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.md5 b/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.md5 new file mode 100644 index 0000000..b27e3cb --- /dev/null +++ b/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.md5 @@ -0,0 +1,3 @@ +source_md5="d1153f6c9c605634f08a1f5e594e9260" +dest_md5="4baae78052f746f51b9d66ee51062507" + diff --git a/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.stex b/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.stex new file mode 100644 index 0000000..dc47964 Binary files /dev/null and b/.import/45.png-1d7559c57bb772cc02375eb6fc280e66.stex differ diff --git a/.import/46.png-18dafed866a86bebe18faa9225cdbc16.md5 b/.import/46.png-18dafed866a86bebe18faa9225cdbc16.md5 new file mode 100644 index 0000000..8d9a860 --- /dev/null +++ b/.import/46.png-18dafed866a86bebe18faa9225cdbc16.md5 @@ -0,0 +1,3 @@ +source_md5="5e1bacd2980de985fe15bc3eac170f11" +dest_md5="876daa55d1c227481da8b6bbc4c2202a" + diff --git a/.import/46.png-18dafed866a86bebe18faa9225cdbc16.stex b/.import/46.png-18dafed866a86bebe18faa9225cdbc16.stex new file mode 100644 index 0000000..163ced4 Binary files /dev/null and b/.import/46.png-18dafed866a86bebe18faa9225cdbc16.stex differ diff --git a/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.md5 b/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.md5 new file mode 100644 index 0000000..b3fe5c8 --- /dev/null +++ b/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.md5 @@ -0,0 +1,3 @@ +source_md5="30b54134f5a79564400ea90e451d7c18" +dest_md5="b015229d6b6a4a29f340ba645ea283cc" + diff --git a/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.stex b/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.stex new file mode 100644 index 0000000..3ef51a1 Binary files /dev/null and b/.import/47.png-bdf7b6a0d9b49b02633b9dacf016a634.stex differ diff --git a/.import/48.png-4e774fbf299ffec195813310a1cda981.md5 b/.import/48.png-4e774fbf299ffec195813310a1cda981.md5 new file mode 100644 index 0000000..2aef2b8 --- /dev/null +++ b/.import/48.png-4e774fbf299ffec195813310a1cda981.md5 @@ -0,0 +1,3 @@ +source_md5="768351a97acbbd8428ca33b073c7a866" +dest_md5="bd06e4d21d02111661ac8546b94c5886" + diff --git a/.import/48.png-4e774fbf299ffec195813310a1cda981.stex b/.import/48.png-4e774fbf299ffec195813310a1cda981.stex new file mode 100644 index 0000000..8f0e8c5 Binary files /dev/null and b/.import/48.png-4e774fbf299ffec195813310a1cda981.stex differ diff --git a/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.md5 b/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.md5 new file mode 100644 index 0000000..5ace660 --- /dev/null +++ b/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.md5 @@ -0,0 +1,3 @@ +source_md5="e4482f7db83104af60eaf931a8b2b1c1" +dest_md5="d22ff6219e6bd41abde76ae89bb89404" + diff --git a/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.stex b/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.stex new file mode 100644 index 0000000..4f64d9e Binary files /dev/null and b/.import/49.png-4f2b4514609dfd6f0a9d8ded7330a35f.stex differ diff --git a/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.md5 b/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.md5 new file mode 100644 index 0000000..73d1652 --- /dev/null +++ b/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.md5 @@ -0,0 +1,3 @@ +source_md5="b87c87dec1916d3bee96ce69ec9fbb03" +dest_md5="a71e0a134e4e9ea5e4ae70d2edbfba95" + diff --git a/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.stex b/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.stex new file mode 100644 index 0000000..f27b3a3 Binary files /dev/null and b/.import/50.png-d7457dfc9f516fa69a09777d4fc56ff7.stex differ diff --git a/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.md5 b/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.md5 new file mode 100644 index 0000000..f0de4cd --- /dev/null +++ b/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.md5 @@ -0,0 +1,3 @@ +source_md5="b9bb58144606336efcd4862d35482f47" +dest_md5="78adad310c664b6cd9e37675a5c76bd1" + diff --git a/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.stex b/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.stex new file mode 100644 index 0000000..73a5412 Binary files /dev/null and b/.import/Achievements.png-c5ffe02dbdfdc5aef3eebc74de7b5165.stex differ diff --git a/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.md5 b/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.md5 new file mode 100644 index 0000000..a08115a --- /dev/null +++ b/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.md5 @@ -0,0 +1,3 @@ +source_md5="9449bf1f8d68ac08331aa091d6095e34" +dest_md5="730f680b1f3c190d6c8f79c433ebb37a" + diff --git a/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.stex b/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.stex new file mode 100644 index 0000000..d5da1ad Binary files /dev/null and b/.import/Appearing (96x96).png-52369794fca062552a9af21e370552a7.stex differ diff --git a/.import/Apple.png-2178a7e1094a8f806cc094be41254817.md5 b/.import/Apple.png-2178a7e1094a8f806cc094be41254817.md5 new file mode 100644 index 0000000..900afd9 --- /dev/null +++ b/.import/Apple.png-2178a7e1094a8f806cc094be41254817.md5 @@ -0,0 +1,3 @@ +source_md5="de3dbfa7d33e6bb344d0560e36d8bf53" +dest_md5="35f9ba353881f03137940e0bdfe8f339" + diff --git a/.import/Apple.png-2178a7e1094a8f806cc094be41254817.stex b/.import/Apple.png-2178a7e1094a8f806cc094be41254817.stex new file mode 100644 index 0000000..2dd64cc Binary files /dev/null and b/.import/Apple.png-2178a7e1094a8f806cc094be41254817.stex differ diff --git a/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.md5 b/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.md5 new file mode 100644 index 0000000..201d5a0 --- /dev/null +++ b/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.md5 @@ -0,0 +1,3 @@ +source_md5="661cfd0fdba294a951eb63c556684a64" +dest_md5="fdaa75c8fa670e336eab56b6137f267f" + diff --git a/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.stex b/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.stex new file mode 100644 index 0000000..ae621af Binary files /dev/null and b/.import/Back.png-de5ecf31b7be28c110ab15880804d2e6.stex differ diff --git a/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.md5 b/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.md5 new file mode 100644 index 0000000..3c79725 --- /dev/null +++ b/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.md5 @@ -0,0 +1,3 @@ +source_md5="03466a1dbd95724e705efe17e72c1c4e" +dest_md5="eb623f4f644e55e70b11634171c55590" + diff --git a/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.stex b/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.stex new file mode 100644 index 0000000..9f49b5e Binary files /dev/null and b/.import/Bananas.png-86be5e7df502b53efa9b62813a7dcefd.stex differ diff --git a/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.md5 b/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.md5 new file mode 100644 index 0000000..b1345a0 --- /dev/null +++ b/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.md5 @@ -0,0 +1,3 @@ +source_md5="79bec88f1bab85f2d3304eb64c52e6c6" +dest_md5="e299b055b57893daa3fec18dc0610d1c" + diff --git a/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.stex b/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.stex new file mode 100644 index 0000000..e61155f Binary files /dev/null and b/.import/Blink (42x42).png-b64b5b4549446cc5c1f9fcdb517868f4.stex differ diff --git a/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.md5 b/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.md5 new file mode 100644 index 0000000..374166b --- /dev/null +++ b/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.md5 @@ -0,0 +1,3 @@ +source_md5="9bbd5e13344ea15e95a0f4fd6aa69c58" +dest_md5="22890909cfd6b02feca65b3acda0a436" + diff --git a/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.stex b/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.stex new file mode 100644 index 0000000..8fa683e Binary files /dev/null and b/.import/Blink (54x52).png-6c6d32b20adee866d6fb561792631d1c.stex differ diff --git a/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.md5 b/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.md5 new file mode 100644 index 0000000..dfd9d25 --- /dev/null +++ b/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.md5 @@ -0,0 +1,3 @@ +source_md5="f86e07aab82505fc49710152f83cc385" +dest_md5="5026f9bff97ec9be5ff2ebfc0ee68b11" + diff --git a/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.stex b/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.stex new file mode 100644 index 0000000..e2c219c Binary files /dev/null and b/.import/Blue.png-4d5d660e0eb522a27d822027f44cc5ed.stex differ diff --git a/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.md5 b/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.md5 new file mode 100644 index 0000000..91bfed0 --- /dev/null +++ b/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.md5 @@ -0,0 +1,3 @@ +source_md5="a8905ebb8b4ca7775d234e61b70b0e04" +dest_md5="5ed7cba4d55ad2ae0fe45b6e4aa2a9cc" + diff --git a/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.stex b/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.stex new file mode 100644 index 0000000..2c0cbfb Binary files /dev/null and b/.import/Bottom Hit (42x42).png-b0dc9201f9a10b19238edd36b41dbc94.stex differ diff --git a/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.md5 b/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.md5 new file mode 100644 index 0000000..b425188 --- /dev/null +++ b/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.md5 @@ -0,0 +1,3 @@ +source_md5="874481bac6b073f542879e7463e40803" +dest_md5="77238e2c51c650425fec8769f3649383" + diff --git a/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.stex b/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.stex new file mode 100644 index 0000000..69d774e Binary files /dev/null and b/.import/Bottom Hit (54x52).png-d128d486712cf2f040e6c16e42cfbbc8.stex differ diff --git a/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.md5 b/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.md5 new file mode 100644 index 0000000..3e53d2d --- /dev/null +++ b/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.md5 @@ -0,0 +1,3 @@ +source_md5="6d23401e8929d47311c40131196da579" +dest_md5="2fcb7de55867b29b4d33e8771aac1ab6" + diff --git a/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.stex b/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.stex new file mode 100644 index 0000000..1c78057 Binary files /dev/null and b/.import/Break.png-93223a6371772b2ec3f93f8fe064f5cd.stex differ diff --git a/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.md5 b/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.md5 new file mode 100644 index 0000000..13581c2 --- /dev/null +++ b/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.md5 @@ -0,0 +1,3 @@ +source_md5="903e8cddbfc8055f0f48b419cf458a60" +dest_md5="f943554ffcb754cb94a7c77357c3c9df" + diff --git a/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.stex b/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.stex new file mode 100644 index 0000000..2f6514c Binary files /dev/null and b/.import/Break.png-b648b0438fd6cc4a527cc6db8d20f77f.stex differ diff --git a/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.md5 b/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.md5 new file mode 100644 index 0000000..2c33287 --- /dev/null +++ b/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.md5 @@ -0,0 +1,3 @@ +source_md5="1be585cdc218d7ac43f127498803c283" +dest_md5="14916f0b2f4af4ae8bf606281754f19a" + diff --git a/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.stex b/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.stex new file mode 100644 index 0000000..9aa21c4 Binary files /dev/null and b/.import/Break.png-df9e0b71ae470b5848a749b1f8955207.stex differ diff --git a/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.md5 b/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.md5 new file mode 100644 index 0000000..77a2943 --- /dev/null +++ b/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.md5 @@ -0,0 +1,3 @@ +source_md5="2c7df5d45d132f6c3e298aaa28f90e94" +dest_md5="d8b29abd976ceac908c0937c0a197204" + diff --git a/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.stex b/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.stex new file mode 100644 index 0000000..2d206cc Binary files /dev/null and b/.import/Brown Off.png-21fd26ad2d8819844ab64661a75aee3f.stex differ diff --git a/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.md5 b/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.md5 new file mode 100644 index 0000000..22c7446 --- /dev/null +++ b/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.md5 @@ -0,0 +1,3 @@ +source_md5="9de63939bf58f9e0cdcd28b463724797" +dest_md5="ca9ce225c40d3e53c7999f7a70b4d185" + diff --git a/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.stex b/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.stex new file mode 100644 index 0000000..174d7f1 Binary files /dev/null and b/.import/Brown On (32x8).png-31f6de32ba67264bcd5ff96efe295404.stex differ diff --git a/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.md5 b/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.md5 new file mode 100644 index 0000000..78f38c7 --- /dev/null +++ b/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.md5 @@ -0,0 +1,3 @@ +source_md5="45c9c887fa73b0ade76974de63ab9157" +dest_md5="ed8e58f8cfb52d2dc6e742b8df7102a2" + diff --git a/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.stex b/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.stex new file mode 100644 index 0000000..0c77aef Binary files /dev/null and b/.import/Brown.png-643724a9a6e722c556a3f6e862e0c34c.stex differ diff --git a/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.md5 b/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.md5 new file mode 100644 index 0000000..ec83000 --- /dev/null +++ b/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.md5 @@ -0,0 +1,3 @@ +source_md5="06dd0d1de25353ef396f9850ab16061e" +dest_md5="fc69b0bac7b198ce1383c9b65dc3cd54" + diff --git a/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.stex b/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.stex new file mode 100644 index 0000000..7214c6b Binary files /dev/null and b/.import/Chain.png-8ce64d19933aa2d21def1587d4e0f964.stex differ diff --git a/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.md5 b/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.md5 new file mode 100644 index 0000000..a3ef3ce --- /dev/null +++ b/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.md5 @@ -0,0 +1,3 @@ +source_md5="69669f8f421b508058cdf1232dc49e28" +dest_md5="70158982dbfb4ba34064911f3f5e18ee" + diff --git a/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.stex b/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.stex new file mode 100644 index 0000000..fab7e10 Binary files /dev/null and b/.import/Chain.png-ccaeeaf36876167f0b3de2f70901aa83.stex differ diff --git a/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.md5 b/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.md5 new file mode 100644 index 0000000..b82d72c --- /dev/null +++ b/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.md5 @@ -0,0 +1,3 @@ +source_md5="16dff8265ca29df58e378bebbdd40295" +dest_md5="93484b912433587e2d1a51eb99306e99" + diff --git a/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.stex b/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.stex new file mode 100644 index 0000000..28c2e18 Binary files /dev/null and b/.import/Chain.png-fb2cfc39c1f17b6f55534c9b6fa7f360.stex differ diff --git a/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.md5 b/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.md5 new file mode 100644 index 0000000..c021a5c --- /dev/null +++ b/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.md5 @@ -0,0 +1,3 @@ +source_md5="dd8752c20a0f69ab173f1ead16044462" +dest_md5="0b0925ccbb186d5363092448cd769d90" + diff --git a/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.stex b/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.stex new file mode 100644 index 0000000..db10a84 Binary files /dev/null and b/.import/Checkpoint (Flag Idle)(64x64).png-b9d899460b7a59a39a2c6c304cae1024.stex differ diff --git a/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.md5 b/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.md5 new file mode 100644 index 0000000..393ee1e --- /dev/null +++ b/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.md5 @@ -0,0 +1,3 @@ +source_md5="c4730e5429a75691e2d2a9351c76738e" +dest_md5="61809600052e5408f417a6fa7929410b" + diff --git a/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.stex b/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.stex new file mode 100644 index 0000000..fe87861 Binary files /dev/null and b/.import/Checkpoint (Flag Out) (64x64).png-b32d6e94538728f068a1f485611066b1.stex differ diff --git a/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.md5 b/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.md5 new file mode 100644 index 0000000..b151553 --- /dev/null +++ b/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.md5 @@ -0,0 +1,3 @@ +source_md5="9126203dc833ec3b7dfb7a05e41910e5" +dest_md5="1e4a56b5ef464ee840f602408766c637" + diff --git a/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.stex b/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.stex new file mode 100644 index 0000000..799d98e Binary files /dev/null and b/.import/Checkpoint (No Flag).png-bb0bbe21c00cd8f6680aabdb1e515431.stex differ diff --git a/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.md5 b/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.md5 new file mode 100644 index 0000000..f2a6139 --- /dev/null +++ b/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.md5 @@ -0,0 +1,3 @@ +source_md5="fc2a60aee885c33d0d10e643157213e4" +dest_md5="c3a5795e141570ed3bf14ff79b8ecfc5" + diff --git a/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.stex b/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.stex new file mode 100644 index 0000000..476fd0e Binary files /dev/null and b/.import/Cherries.png-0e4a4e2cbff2131046ddd7515e43514f.stex differ diff --git a/.import/Close.png-9d245b5874f67d77a12125986730bd3a.md5 b/.import/Close.png-9d245b5874f67d77a12125986730bd3a.md5 new file mode 100644 index 0000000..c9c104c --- /dev/null +++ b/.import/Close.png-9d245b5874f67d77a12125986730bd3a.md5 @@ -0,0 +1,3 @@ +source_md5="5c3a207383c5642288b01d314855a42a" +dest_md5="57955aa914143d81c1b1cbd49ae58347" + diff --git a/.import/Close.png-9d245b5874f67d77a12125986730bd3a.stex b/.import/Close.png-9d245b5874f67d77a12125986730bd3a.stex new file mode 100644 index 0000000..f176f3c Binary files /dev/null and b/.import/Close.png-9d245b5874f67d77a12125986730bd3a.stex differ diff --git a/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.md5 b/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.md5 new file mode 100644 index 0000000..1202580 --- /dev/null +++ b/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.md5 @@ -0,0 +1,3 @@ +source_md5="198338c29ad1fc5273407d7bb50d07d1" +dest_md5="94dcebd5f24f82f82ef9151f970fa38f" + diff --git a/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.stex b/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.stex new file mode 100644 index 0000000..26dbb69 Binary files /dev/null and b/.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.stex differ diff --git a/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.md5 b/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.md5 new file mode 100644 index 0000000..1202580 --- /dev/null +++ b/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.md5 @@ -0,0 +1,3 @@ +source_md5="198338c29ad1fc5273407d7bb50d07d1" +dest_md5="94dcebd5f24f82f82ef9151f970fa38f" + diff --git a/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.stex b/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.stex new file mode 100644 index 0000000..26dbb69 Binary files /dev/null and b/.import/Cloud 1.png-46d7cef0b15e33e72c013ff454b5d3a2.stex differ diff --git a/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.md5 b/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.md5 new file mode 100644 index 0000000..1202580 --- /dev/null +++ b/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.md5 @@ -0,0 +1,3 @@ +source_md5="198338c29ad1fc5273407d7bb50d07d1" +dest_md5="94dcebd5f24f82f82ef9151f970fa38f" + diff --git a/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.stex b/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.stex new file mode 100644 index 0000000..26dbb69 Binary files /dev/null and b/.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.stex differ diff --git a/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.md5 b/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.md5 new file mode 100644 index 0000000..3f25687 --- /dev/null +++ b/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.md5 @@ -0,0 +1,3 @@ +source_md5="0a701aefc4819f2b125aa3b8d74f102c" +dest_md5="f9bbca7cd9c362ba9c707eb328dc764e" + diff --git a/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.stex b/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.stex new file mode 100644 index 0000000..23962de Binary files /dev/null and b/.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.stex differ diff --git a/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.md5 b/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.md5 new file mode 100644 index 0000000..3f25687 --- /dev/null +++ b/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.md5 @@ -0,0 +1,3 @@ +source_md5="0a701aefc4819f2b125aa3b8d74f102c" +dest_md5="f9bbca7cd9c362ba9c707eb328dc764e" + diff --git a/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.stex b/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.stex new file mode 100644 index 0000000..23962de Binary files /dev/null and b/.import/Cloud 10.png-89aac4c2797642ba7279c7d03560a4c4.stex differ diff --git a/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.md5 b/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.md5 new file mode 100644 index 0000000..5b24894 --- /dev/null +++ b/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.md5 @@ -0,0 +1,3 @@ +source_md5="3eb50496fc0e2b5ca215509f8701eb4c" +dest_md5="63cf56b3c7d4572118b86f4b033bbacd" + diff --git a/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.stex b/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.stex new file mode 100644 index 0000000..ff612ae Binary files /dev/null and b/.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.stex differ diff --git a/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.md5 b/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.md5 new file mode 100644 index 0000000..5b24894 --- /dev/null +++ b/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.md5 @@ -0,0 +1,3 @@ +source_md5="3eb50496fc0e2b5ca215509f8701eb4c" +dest_md5="63cf56b3c7d4572118b86f4b033bbacd" + diff --git a/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.stex b/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.stex new file mode 100644 index 0000000..ff612ae Binary files /dev/null and b/.import/Cloud 11.png-dc9fcabc469d2f197c039f73c46938f3.stex differ diff --git a/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.md5 b/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.md5 new file mode 100644 index 0000000..3e1d014 --- /dev/null +++ b/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.md5 @@ -0,0 +1,3 @@ +source_md5="10d3577a324cc064e6ce5548dd9a67b1" +dest_md5="8b4bdc0825d3f366606423aad74a67e8" + diff --git a/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.stex b/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.stex new file mode 100644 index 0000000..25f5cc7 Binary files /dev/null and b/.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.stex differ diff --git a/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.md5 b/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.md5 new file mode 100644 index 0000000..3e1d014 --- /dev/null +++ b/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.md5 @@ -0,0 +1,3 @@ +source_md5="10d3577a324cc064e6ce5548dd9a67b1" +dest_md5="8b4bdc0825d3f366606423aad74a67e8" + diff --git a/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.stex b/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.stex new file mode 100644 index 0000000..25f5cc7 Binary files /dev/null and b/.import/Cloud 12.png-d3fe1bcb6707e42b2233919a4b0e8756.stex differ diff --git a/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.md5 b/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.md5 new file mode 100644 index 0000000..7a86d4f --- /dev/null +++ b/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.md5 @@ -0,0 +1,3 @@ +source_md5="2cd9dfdb878149793f9bf99b77c36015" +dest_md5="a8e866974afa10d78474f8e59fc38d39" + diff --git a/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.stex b/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.stex new file mode 100644 index 0000000..afc1582 Binary files /dev/null and b/.import/Cloud 13.png-2a7509209ec0221d093587abc6e974be.stex differ diff --git a/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.md5 b/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.md5 new file mode 100644 index 0000000..7a86d4f --- /dev/null +++ b/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.md5 @@ -0,0 +1,3 @@ +source_md5="2cd9dfdb878149793f9bf99b77c36015" +dest_md5="a8e866974afa10d78474f8e59fc38d39" + diff --git a/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.stex b/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.stex new file mode 100644 index 0000000..afc1582 Binary files /dev/null and b/.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.stex differ diff --git a/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.md5 b/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.md5 new file mode 100644 index 0000000..cbd8677 --- /dev/null +++ b/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.md5 @@ -0,0 +1,3 @@ +source_md5="bf4e261d9cb498ba3c54144e6f2ab465" +dest_md5="2a65fd2bbffc4e84f441e24768644fe4" + diff --git a/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.stex b/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.stex new file mode 100644 index 0000000..353f21b Binary files /dev/null and b/.import/Cloud 14.png-66e1a30c3d4d9809b91a4aa1bc7a1920.stex differ diff --git a/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.md5 b/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.md5 new file mode 100644 index 0000000..cbd8677 --- /dev/null +++ b/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.md5 @@ -0,0 +1,3 @@ +source_md5="bf4e261d9cb498ba3c54144e6f2ab465" +dest_md5="2a65fd2bbffc4e84f441e24768644fe4" + diff --git a/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.stex b/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.stex new file mode 100644 index 0000000..353f21b Binary files /dev/null and b/.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.stex differ diff --git a/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.md5 b/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.md5 new file mode 100644 index 0000000..f21e84e --- /dev/null +++ b/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.md5 @@ -0,0 +1,3 @@ +source_md5="641c9a5702581bcfb5415514e3e0397d" +dest_md5="bbfdf98d797d9238080e77f642fb75e4" + diff --git a/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.stex b/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.stex new file mode 100644 index 0000000..5895c78 Binary files /dev/null and b/.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.stex differ diff --git a/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.md5 b/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.md5 new file mode 100644 index 0000000..f21e84e --- /dev/null +++ b/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.md5 @@ -0,0 +1,3 @@ +source_md5="641c9a5702581bcfb5415514e3e0397d" +dest_md5="bbfdf98d797d9238080e77f642fb75e4" + diff --git a/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.stex b/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.stex new file mode 100644 index 0000000..5895c78 Binary files /dev/null and b/.import/Cloud 15.png-bbe716b44401e5a1f3882d750ebb04b8.stex differ diff --git a/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.md5 b/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.md5 new file mode 100644 index 0000000..ccbf1a8 --- /dev/null +++ b/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.md5 @@ -0,0 +1,3 @@ +source_md5="62cf66a536599ed74ba5dc41ae68489e" +dest_md5="b7f442f6b4c1be38f78b0fcad4c5c692" + diff --git a/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.stex b/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.stex new file mode 100644 index 0000000..037cf6f Binary files /dev/null and b/.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.stex differ diff --git a/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.md5 b/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.md5 new file mode 100644 index 0000000..ccbf1a8 --- /dev/null +++ b/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.md5 @@ -0,0 +1,3 @@ +source_md5="62cf66a536599ed74ba5dc41ae68489e" +dest_md5="b7f442f6b4c1be38f78b0fcad4c5c692" + diff --git a/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.stex b/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.stex new file mode 100644 index 0000000..037cf6f Binary files /dev/null and b/.import/Cloud 16.png-f2c4b239ff7beeb0a4d9ba4ebc875d3f.stex differ diff --git a/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.md5 b/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.md5 new file mode 100644 index 0000000..3c7ec08 --- /dev/null +++ b/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.md5 @@ -0,0 +1,3 @@ +source_md5="a0a63265e5527891b1c797e0d8a0560d" +dest_md5="7487812ac955787d5106491f394413e0" + diff --git a/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.stex b/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.stex new file mode 100644 index 0000000..9fc0018 Binary files /dev/null and b/.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.stex differ diff --git a/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.md5 b/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.md5 new file mode 100644 index 0000000..3c7ec08 --- /dev/null +++ b/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.md5 @@ -0,0 +1,3 @@ +source_md5="a0a63265e5527891b1c797e0d8a0560d" +dest_md5="7487812ac955787d5106491f394413e0" + diff --git a/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.stex b/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.stex new file mode 100644 index 0000000..9fc0018 Binary files /dev/null and b/.import/Cloud 17.png-9b6bb60d66dbbf0191a121d16b90c14b.stex differ diff --git a/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.md5 b/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.md5 new file mode 100644 index 0000000..69f0e7a --- /dev/null +++ b/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.md5 @@ -0,0 +1,3 @@ +source_md5="beeb202195e83c384b8be3974a5c32a2" +dest_md5="1474afbae430220cc65958b546b2c8dc" + diff --git a/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.stex b/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.stex new file mode 100644 index 0000000..f511e75 Binary files /dev/null and b/.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.stex differ diff --git a/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.md5 b/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.md5 new file mode 100644 index 0000000..69f0e7a --- /dev/null +++ b/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.md5 @@ -0,0 +1,3 @@ +source_md5="beeb202195e83c384b8be3974a5c32a2" +dest_md5="1474afbae430220cc65958b546b2c8dc" + diff --git a/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.stex b/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.stex new file mode 100644 index 0000000..f511e75 Binary files /dev/null and b/.import/Cloud 18.png-f748b1f8396bf0a025b42c0e26acb403.stex differ diff --git a/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.md5 b/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.md5 new file mode 100644 index 0000000..a47762e --- /dev/null +++ b/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.md5 @@ -0,0 +1,3 @@ +source_md5="618974b9cabc859e3213937b8baf7abc" +dest_md5="5c6268b4abe5927bcaf9c786002f533b" + diff --git a/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.stex b/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.stex new file mode 100644 index 0000000..a761ba6 Binary files /dev/null and b/.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.stex differ diff --git a/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.md5 b/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.md5 new file mode 100644 index 0000000..a47762e --- /dev/null +++ b/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.md5 @@ -0,0 +1,3 @@ +source_md5="618974b9cabc859e3213937b8baf7abc" +dest_md5="5c6268b4abe5927bcaf9c786002f533b" + diff --git a/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.stex b/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.stex new file mode 100644 index 0000000..a761ba6 Binary files /dev/null and b/.import/Cloud 19.png-c853b5d664b92697bc24da183c55dcd6.stex differ diff --git a/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.md5 b/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.md5 new file mode 100644 index 0000000..62e5369 --- /dev/null +++ b/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.md5 @@ -0,0 +1,3 @@ +source_md5="a773252a81f89b02bb5ae3d1f049a86a" +dest_md5="e9b2a7cf676129c527a26a8d17dfb0a5" + diff --git a/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.stex b/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.stex new file mode 100644 index 0000000..fc94466 Binary files /dev/null and b/.import/Cloud 2.png-3f93b2e8efe623c15b509b3d3c20792b.stex differ diff --git a/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.md5 b/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.md5 new file mode 100644 index 0000000..62e5369 --- /dev/null +++ b/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.md5 @@ -0,0 +1,3 @@ +source_md5="a773252a81f89b02bb5ae3d1f049a86a" +dest_md5="e9b2a7cf676129c527a26a8d17dfb0a5" + diff --git a/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.stex b/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.stex new file mode 100644 index 0000000..fc94466 Binary files /dev/null and b/.import/Cloud 2.png-abf9a02795b0af33391ca1130d025bf9.stex differ diff --git a/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.md5 b/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.md5 new file mode 100644 index 0000000..62e5369 --- /dev/null +++ b/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.md5 @@ -0,0 +1,3 @@ +source_md5="a773252a81f89b02bb5ae3d1f049a86a" +dest_md5="e9b2a7cf676129c527a26a8d17dfb0a5" + diff --git a/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.stex b/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.stex new file mode 100644 index 0000000..fc94466 Binary files /dev/null and b/.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.stex differ diff --git a/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.md5 b/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.md5 new file mode 100644 index 0000000..f2471b2 --- /dev/null +++ b/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.md5 @@ -0,0 +1,3 @@ +source_md5="955a97a5d50e8ed50e1fbaa2295b8d21" +dest_md5="bd583b9a02cce9e57a5b8b6399fb8608" + diff --git a/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.stex b/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.stex new file mode 100644 index 0000000..0597fda Binary files /dev/null and b/.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.stex differ diff --git a/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.md5 b/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.md5 new file mode 100644 index 0000000..f2471b2 --- /dev/null +++ b/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.md5 @@ -0,0 +1,3 @@ +source_md5="955a97a5d50e8ed50e1fbaa2295b8d21" +dest_md5="bd583b9a02cce9e57a5b8b6399fb8608" + diff --git a/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.stex b/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.stex new file mode 100644 index 0000000..0597fda Binary files /dev/null and b/.import/Cloud 20.png-cdbefceb454648a3ba7c46077f393208.stex differ diff --git a/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.md5 b/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.md5 new file mode 100644 index 0000000..9bc86c4 --- /dev/null +++ b/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.md5 @@ -0,0 +1,3 @@ +source_md5="1d2bea1b415fc405b5b91ffcb25f6ad8" +dest_md5="1d8e9b22ec3de59b8d4e420f1730ae4f" + diff --git a/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.stex b/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.stex new file mode 100644 index 0000000..0e1f7d8 Binary files /dev/null and b/.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.stex differ diff --git a/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.md5 b/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.md5 new file mode 100644 index 0000000..9bc86c4 --- /dev/null +++ b/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.md5 @@ -0,0 +1,3 @@ +source_md5="1d2bea1b415fc405b5b91ffcb25f6ad8" +dest_md5="1d8e9b22ec3de59b8d4e420f1730ae4f" + diff --git a/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.stex b/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.stex new file mode 100644 index 0000000..0e1f7d8 Binary files /dev/null and b/.import/Cloud 3.png-69d597d53588ed7eaefd9396c595f56d.stex differ diff --git a/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.md5 b/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.md5 new file mode 100644 index 0000000..9bc86c4 --- /dev/null +++ b/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.md5 @@ -0,0 +1,3 @@ +source_md5="1d2bea1b415fc405b5b91ffcb25f6ad8" +dest_md5="1d8e9b22ec3de59b8d4e420f1730ae4f" + diff --git a/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.stex b/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.stex new file mode 100644 index 0000000..0e1f7d8 Binary files /dev/null and b/.import/Cloud 3.png-89bbd77d7715c80035128bf3a1d03a14.stex differ diff --git a/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.md5 b/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.md5 new file mode 100644 index 0000000..cfbe5c2 --- /dev/null +++ b/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.md5 @@ -0,0 +1,3 @@ +source_md5="cd6a85606853c91c3e4da5f00a1efa05" +dest_md5="333d9215e2caa65b553a7df8660abee6" + diff --git a/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.stex b/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.stex new file mode 100644 index 0000000..8985ab0 Binary files /dev/null and b/.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.stex differ diff --git a/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.md5 b/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.md5 new file mode 100644 index 0000000..cfbe5c2 --- /dev/null +++ b/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.md5 @@ -0,0 +1,3 @@ +source_md5="cd6a85606853c91c3e4da5f00a1efa05" +dest_md5="333d9215e2caa65b553a7df8660abee6" + diff --git a/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.stex b/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.stex new file mode 100644 index 0000000..8985ab0 Binary files /dev/null and b/.import/Cloud 4.png-5c5a5165efe1ab19243598d180f3d446.stex differ diff --git a/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.md5 b/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.md5 new file mode 100644 index 0000000..cfbe5c2 --- /dev/null +++ b/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.md5 @@ -0,0 +1,3 @@ +source_md5="cd6a85606853c91c3e4da5f00a1efa05" +dest_md5="333d9215e2caa65b553a7df8660abee6" + diff --git a/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.stex b/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.stex new file mode 100644 index 0000000..8985ab0 Binary files /dev/null and b/.import/Cloud 4.png-5ceb5a90c5571b401fb8b298810b66ae.stex differ diff --git a/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.md5 b/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.md5 new file mode 100644 index 0000000..feb6b2b --- /dev/null +++ b/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.md5 @@ -0,0 +1,3 @@ +source_md5="fcd6701de2fa821ca9a68c8fee239c38" +dest_md5="372604fe7bb43445bd8105a6cee9227d" + diff --git a/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.stex b/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.stex new file mode 100644 index 0000000..7f4c316 Binary files /dev/null and b/.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.stex differ diff --git a/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.md5 b/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.md5 new file mode 100644 index 0000000..feb6b2b --- /dev/null +++ b/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.md5 @@ -0,0 +1,3 @@ +source_md5="fcd6701de2fa821ca9a68c8fee239c38" +dest_md5="372604fe7bb43445bd8105a6cee9227d" + diff --git a/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.stex b/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.stex new file mode 100644 index 0000000..7f4c316 Binary files /dev/null and b/.import/Cloud 5.png-d62110091a62b94a471de48216102dfd.stex differ diff --git a/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.md5 b/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.md5 new file mode 100644 index 0000000..feb6b2b --- /dev/null +++ b/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.md5 @@ -0,0 +1,3 @@ +source_md5="fcd6701de2fa821ca9a68c8fee239c38" +dest_md5="372604fe7bb43445bd8105a6cee9227d" + diff --git a/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.stex b/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.stex new file mode 100644 index 0000000..7f4c316 Binary files /dev/null and b/.import/Cloud 5.png-e7686204b9d3dfb2c9b25b1a4d0810ca.stex differ diff --git a/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.md5 b/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.md5 new file mode 100644 index 0000000..5b3b5a9 --- /dev/null +++ b/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.md5 @@ -0,0 +1,3 @@ +source_md5="260f5802aa59917289573cb4c4b52537" +dest_md5="f9225163d2670e12b686ea1d9a6ea803" + diff --git a/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.stex b/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.stex new file mode 100644 index 0000000..0e866e9 Binary files /dev/null and b/.import/Cloud 6.png-8b383019c0912cb42214840b3380b037.stex differ diff --git a/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.md5 b/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.md5 new file mode 100644 index 0000000..5b3b5a9 --- /dev/null +++ b/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.md5 @@ -0,0 +1,3 @@ +source_md5="260f5802aa59917289573cb4c4b52537" +dest_md5="f9225163d2670e12b686ea1d9a6ea803" + diff --git a/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.stex b/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.stex new file mode 100644 index 0000000..0e866e9 Binary files /dev/null and b/.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.stex differ diff --git a/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.md5 b/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.md5 new file mode 100644 index 0000000..f7d77b0 --- /dev/null +++ b/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.md5 @@ -0,0 +1,3 @@ +source_md5="1c822ea20f1ac4a473a53c4b08d62901" +dest_md5="d3ab6ef4380304036b99f38313774fa2" + diff --git a/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.stex b/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.stex new file mode 100644 index 0000000..e3e2fa8 Binary files /dev/null and b/.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.stex differ diff --git a/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.md5 b/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.md5 new file mode 100644 index 0000000..f7d77b0 --- /dev/null +++ b/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.md5 @@ -0,0 +1,3 @@ +source_md5="1c822ea20f1ac4a473a53c4b08d62901" +dest_md5="d3ab6ef4380304036b99f38313774fa2" + diff --git a/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.stex b/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.stex new file mode 100644 index 0000000..e3e2fa8 Binary files /dev/null and b/.import/Cloud 7.png-52cd59fefbea69d551ea7ad9f2d5fc84.stex differ diff --git a/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.md5 b/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.md5 new file mode 100644 index 0000000..30fb99e --- /dev/null +++ b/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.md5 @@ -0,0 +1,3 @@ +source_md5="6681125215f7bddfe69bfb1f45025b32" +dest_md5="88be4e4321f4a758265682f9855587b4" + diff --git a/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.stex b/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.stex new file mode 100644 index 0000000..8eeb104 Binary files /dev/null and b/.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.stex differ diff --git a/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.md5 b/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.md5 new file mode 100644 index 0000000..30fb99e --- /dev/null +++ b/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.md5 @@ -0,0 +1,3 @@ +source_md5="6681125215f7bddfe69bfb1f45025b32" +dest_md5="88be4e4321f4a758265682f9855587b4" + diff --git a/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.stex b/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.stex new file mode 100644 index 0000000..8eeb104 Binary files /dev/null and b/.import/Cloud 8.png-be3a6c72ff0c73e6244d7556d1d83f7a.stex differ diff --git a/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.md5 b/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.md5 new file mode 100644 index 0000000..28b2893 --- /dev/null +++ b/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.md5 @@ -0,0 +1,3 @@ +source_md5="8aca2af6c991adfc16b9aa446d1a6640" +dest_md5="d44d98153dd0df281bde654411aed1f4" + diff --git a/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.stex b/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.stex new file mode 100644 index 0000000..72c79f8 Binary files /dev/null and b/.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.stex differ diff --git a/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.md5 b/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.md5 new file mode 100644 index 0000000..28b2893 --- /dev/null +++ b/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.md5 @@ -0,0 +1,3 @@ +source_md5="8aca2af6c991adfc16b9aa446d1a6640" +dest_md5="d44d98153dd0df281bde654411aed1f4" + diff --git a/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.stex b/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.stex new file mode 100644 index 0000000..72c79f8 Binary files /dev/null and b/.import/Cloud 9.png-8d79b476c334c69509d6cfb1e43ed916.stex differ diff --git a/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.md5 b/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.md5 new file mode 100644 index 0000000..b23ae5a --- /dev/null +++ b/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.md5 @@ -0,0 +1,3 @@ +source_md5="0aa8cdedde5af58d5222c2db1e0a96de" +dest_md5="dc40ec16a5f1e3d5a0bbbbc712e77682" + diff --git a/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.stex b/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.stex new file mode 100644 index 0000000..a4e11b0 Binary files /dev/null and b/.import/Collected.png-84001ba02a4fb4a96b75808dba056814.stex differ diff --git a/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.md5 b/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.md5 new file mode 100644 index 0000000..613a262 --- /dev/null +++ b/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.md5 @@ -0,0 +1,3 @@ +source_md5="e23a201b4bfa7999a176dc9ec004c7bc" +dest_md5="c0649ccd537d202a29e92cc488595ab0" + diff --git a/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.stex b/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.stex new file mode 100644 index 0000000..e6ac12a Binary files /dev/null and b/.import/Confetti (16x16).png-d913fb9557994434b0a25aba33d44d83.stex differ diff --git a/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.md5 b/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.md5 new file mode 100644 index 0000000..1f1c85c --- /dev/null +++ b/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.md5 @@ -0,0 +1,3 @@ +source_md5="1b952a596f7dbf7067604bccd7e6728f" +dest_md5="0315e2776d83d81395408965527e083d" + diff --git a/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.stex b/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.stex new file mode 100644 index 0000000..3fcb165 Binary files /dev/null and b/.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.stex differ diff --git a/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.md5 b/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.md5 new file mode 100644 index 0000000..d45dda1 --- /dev/null +++ b/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.md5 @@ -0,0 +1,3 @@ +source_md5="1284313649da02eccc0d3ed6796996a3" +dest_md5="27baa03bbd13f8b7c4bfa7765c2d82b5" + diff --git a/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.stex b/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.stex new file mode 100644 index 0000000..671f8da Binary files /dev/null and b/.import/Desappearing (96x96).png-1bcf5de1c5f809abcaee7243f23fe5f8.stex differ diff --git a/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.md5 b/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.md5 new file mode 100644 index 0000000..b191014 --- /dev/null +++ b/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.md5 @@ -0,0 +1,3 @@ +source_md5="c76baa04d956c9d985c79643d7b2f672" +dest_md5="ff28670bf56e961b924cf26388e20258" + diff --git a/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.stex b/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.stex new file mode 100644 index 0000000..5fdb494 Binary files /dev/null and b/.import/Double Jump (32x32).png-45df782fb235d6b344160ad570c001a7.stex differ diff --git a/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.md5 b/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.md5 new file mode 100644 index 0000000..08122ec --- /dev/null +++ b/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.md5 @@ -0,0 +1,3 @@ +source_md5="612926916a3e8c5deff2023722c465ac" +dest_md5="8f869af5d38a179a8fdf26cb64652c1e" + diff --git a/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.stex b/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.stex new file mode 100644 index 0000000..7a6b39b Binary files /dev/null and b/.import/Double Jump (32x32).png-67511056f187c3a4bfe9001f94a6a00f.stex differ diff --git a/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.md5 b/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.md5 new file mode 100644 index 0000000..6132f46 --- /dev/null +++ b/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.md5 @@ -0,0 +1,3 @@ +source_md5="3f311d2997220b2f434e5c774290bb09" +dest_md5="8d1e1f01eddd3dcc12f686156353fbc9" + diff --git a/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.stex b/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.stex new file mode 100644 index 0000000..99be0ac Binary files /dev/null and b/.import/Double Jump (32x32).png-764f15213dea026d0dfc21d65fe2706b.stex differ diff --git a/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.md5 b/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.md5 new file mode 100644 index 0000000..c6cba9e --- /dev/null +++ b/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.md5 @@ -0,0 +1,3 @@ +source_md5="5afb26aa4240eff1eab105eb3263ab83" +dest_md5="022d7ef6c7c412eb5cb6e0d29fe24a4b" + diff --git a/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.stex b/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.stex new file mode 100644 index 0000000..e0c53ec Binary files /dev/null and b/.import/Double Jump (32x32).png-bc3412b1ef19932ac2b35f76b35e64a3.stex differ diff --git a/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.md5 b/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.md5 new file mode 100644 index 0000000..d81d7b5 --- /dev/null +++ b/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.md5 @@ -0,0 +1,3 @@ +source_md5="c72fceec8ccfcefc030fbc44ccdd68c4" +dest_md5="834893060e00fdd1e65a0b8f20d599b1" + diff --git a/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.stex b/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.stex new file mode 100644 index 0000000..42dce7b Binary files /dev/null and b/.import/Dust Particle.png-8546b7210d475cf2faa2d869ea306296.stex differ diff --git a/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.md5 b/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.md5 new file mode 100644 index 0000000..962f871 --- /dev/null +++ b/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.md5 @@ -0,0 +1,3 @@ +source_md5="e3627d7da583875ddef9a17036cec767" +dest_md5="25b936929ee06a5214b4be5d40aabed4" + diff --git a/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.stex b/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.stex new file mode 100644 index 0000000..a57a82f Binary files /dev/null and b/.import/End (Idle).png-fff83f96b653d4b639661dc1832e9cfc.stex differ diff --git a/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.md5 b/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.md5 new file mode 100644 index 0000000..fd912c0 --- /dev/null +++ b/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.md5 @@ -0,0 +1,3 @@ +source_md5="1ce36017dfe561556f75324a065bc4df" +dest_md5="4333633d115a7b97811325892df7abbd" + diff --git a/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.stex b/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.stex new file mode 100644 index 0000000..23c52fe Binary files /dev/null and b/.import/End (Pressed) (64x64).png-ee8e1447eabe591bfa6ce224fce35966.stex differ diff --git a/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.md5 b/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.md5 new file mode 100644 index 0000000..f14b938 --- /dev/null +++ b/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.md5 @@ -0,0 +1,3 @@ +source_md5="469d2d7814fa8258325eb5d305808315" +dest_md5="0e1c57f4f7cabd2b75d27562124193eb" + diff --git a/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.stex b/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.stex new file mode 100644 index 0000000..11c5071 Binary files /dev/null and b/.import/Fall (32x32).png-1aa2f63f2dde8b4be58d440e681b18db.stex differ diff --git a/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.md5 b/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.md5 new file mode 100644 index 0000000..108c07f --- /dev/null +++ b/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.md5 @@ -0,0 +1,3 @@ +source_md5="5eb8c32845fad5fcc7794247eb91aed0" +dest_md5="8081af87781628de89e1ac7e42ec5498" + diff --git a/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.stex b/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.stex new file mode 100644 index 0000000..a129fd3 Binary files /dev/null and b/.import/Fall (32x32).png-4839f0580a6db3cd50b9b703ac891091.stex differ diff --git a/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.md5 b/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.md5 new file mode 100644 index 0000000..eb4d5dc --- /dev/null +++ b/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.md5 @@ -0,0 +1,3 @@ +source_md5="a20bd61d76132e4301fcfe7aa02ca9ba" +dest_md5="ad48c07fd239ee720ae95b7ab085523a" + diff --git a/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.stex b/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.stex new file mode 100644 index 0000000..fff7ae1 Binary files /dev/null and b/.import/Fall (32x32).png-5a93321e89c7d81cc70b6d486230ab73.stex differ diff --git a/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.md5 b/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.md5 new file mode 100644 index 0000000..8e60e66 --- /dev/null +++ b/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.md5 @@ -0,0 +1,3 @@ +source_md5="f0ef8838b8cbc69f6917d23cb0a5969b" +dest_md5="4acca048e3423b3175c08ffdb2d16150" + diff --git a/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.stex b/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.stex new file mode 100644 index 0000000..dc3a234 Binary files /dev/null and b/.import/Fall (32x32).png-d558755c743efc1f8af509eaade42353.stex differ diff --git a/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.md5 b/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.md5 new file mode 100644 index 0000000..780e21d --- /dev/null +++ b/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.md5 @@ -0,0 +1,3 @@ +source_md5="9402a1c079a419fe53ddda4e7a774922" +dest_md5="2ad72c29dac7448a604ad981e7c02acc" + diff --git a/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.stex b/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.stex new file mode 100644 index 0000000..7492922 Binary files /dev/null and b/.import/Fall.png-a372164a20682200f80fa29d2daa12f5.stex differ diff --git a/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.md5 b/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.md5 new file mode 100644 index 0000000..6990021 --- /dev/null +++ b/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.md5 @@ -0,0 +1,3 @@ +source_md5="31fb9bc36ec926ee64d999d3387b7e09" +dest_md5="4bfc75414296ac8ed3294fa9809ecc43" + diff --git a/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.stex b/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.stex new file mode 100644 index 0000000..ce32b08 Binary files /dev/null and b/.import/Gray.png-fb376bfb3f3ba488d42f39e9c8b7ca8e.stex differ diff --git a/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.md5 b/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.md5 new file mode 100644 index 0000000..e68636e --- /dev/null +++ b/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.md5 @@ -0,0 +1,3 @@ +source_md5="e6eeace8a9d516f2e9768e5228e824fb" +dest_md5="227f000ef67682436789f74dc3baba0b" + diff --git a/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.stex b/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.stex new file mode 100644 index 0000000..6a397ed Binary files /dev/null and b/.import/Green.png-0c5820ee7c8ac027c843f9340626c687.stex differ diff --git a/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.md5 b/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.md5 new file mode 100644 index 0000000..2c08184 --- /dev/null +++ b/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.md5 @@ -0,0 +1,3 @@ +source_md5="5513eff304a382fc4b984d2cf7975cc4" +dest_md5="3030978166cb86e0661bad041dd0d36b" + diff --git a/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.stex b/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.stex new file mode 100644 index 0000000..38bd0e0 Binary files /dev/null and b/.import/Grey Off.png-591d4c4a0ac8df5278657ddc54524a93.stex differ diff --git a/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.md5 b/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.md5 new file mode 100644 index 0000000..d5ff8e1 --- /dev/null +++ b/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.md5 @@ -0,0 +1,3 @@ +source_md5="43a0f74d1389afd48b42aa45455bf1fa" +dest_md5="80f957fe50420ad0f1ab403e490ef2fc" + diff --git a/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.stex b/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.stex new file mode 100644 index 0000000..c5c9f22 Binary files /dev/null and b/.import/Grey On (32x8).png-6cc075eede76e8cce65c92e20377db23.stex differ diff --git a/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.md5 b/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.md5 new file mode 100644 index 0000000..ee76137 --- /dev/null +++ b/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.md5 @@ -0,0 +1,3 @@ +source_md5="a55305158db44491131714a2496e6054" +dest_md5="589e5e518b5ad93ec0c2992537972324" + diff --git a/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.stex b/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.stex new file mode 100644 index 0000000..60ccc32 Binary files /dev/null and b/.import/Hello.png-081c86e6e42c43b949ca94c2af3812b3.stex differ diff --git a/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.md5 b/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.md5 new file mode 100644 index 0000000..8f59e53 --- /dev/null +++ b/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.md5 @@ -0,0 +1,3 @@ +source_md5="b161b5e6801126c9e999d09bf69ccb97" +dest_md5="2b96a27a0f7b808715cf0a0f889971bf" + diff --git a/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.stex b/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.stex new file mode 100644 index 0000000..881f89b Binary files /dev/null and b/.import/Hit (16x32).png-6128858a79b45b05f76c88f548ceb612.stex differ diff --git a/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.md5 b/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.md5 new file mode 100644 index 0000000..d8268bf --- /dev/null +++ b/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.md5 @@ -0,0 +1,3 @@ +source_md5="5c6f27dc5dca69164b459289dba9b4b3" +dest_md5="c7990add397ad6f6b7b7a1300d4c5a03" + diff --git a/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.stex b/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.stex new file mode 100644 index 0000000..c6a82bf Binary files /dev/null and b/.import/Hit (18x18).png-a11d93da82713ed4eadfda59281a0464.stex differ diff --git a/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.md5 b/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.md5 new file mode 100644 index 0000000..1ccd71c --- /dev/null +++ b/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.md5 @@ -0,0 +1,3 @@ +source_md5="27ae8e072417ebe7a11dc56476aa295a" +dest_md5="6be00b46818076400a2769decf18912f" + diff --git a/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.stex b/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.stex new file mode 100644 index 0000000..f2d70ad Binary files /dev/null and b/.import/Hit (28x24).png-64e68479442e64bceb5a7e20d5c803be.stex differ diff --git a/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.md5 b/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.md5 new file mode 100644 index 0000000..4e95df8 --- /dev/null +++ b/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.md5 @@ -0,0 +1,3 @@ +source_md5="7640893b496fd0397eeba89e74e40ea5" +dest_md5="fdbddc4192855432c4da652165a6a14d" + diff --git a/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.stex b/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.stex new file mode 100644 index 0000000..9e1db48 Binary files /dev/null and b/.import/Hit (28x24).png-c5cc84e4fa11a8035be05f45fef6af3b.stex differ diff --git a/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.md5 b/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.md5 new file mode 100644 index 0000000..28758a1 --- /dev/null +++ b/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.md5 @@ -0,0 +1,3 @@ +source_md5="93801a866811246a9b608fee26b0d1fd" +dest_md5="b2b0f6148008957f98b525d9d2d06f84" + diff --git a/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.stex b/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.stex new file mode 100644 index 0000000..21d25f3 Binary files /dev/null and b/.import/Hit (28x24).png-f6daeee09538766a2f3b61922d50c6b1.stex differ diff --git a/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.md5 b/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.md5 new file mode 100644 index 0000000..3016d20 --- /dev/null +++ b/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.md5 @@ -0,0 +1,3 @@ +source_md5="5d93268a09fb2959e1755da4ba201f9e" +dest_md5="cafbd0fb9cba8bf48e181a5f21f2387b" + diff --git a/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.stex b/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.stex new file mode 100644 index 0000000..2aedf19 Binary files /dev/null and b/.import/Hit (32x32).png-58a71445f3677a0480f7c4d3967306e9.stex differ diff --git a/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.md5 b/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.md5 new file mode 100644 index 0000000..aa8540b --- /dev/null +++ b/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.md5 @@ -0,0 +1,3 @@ +source_md5="d03a7bbce7fbda59dd057397f86a8899" +dest_md5="f1560a29f0ee87171cd5eb89861f58a9" + diff --git a/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.stex b/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.stex new file mode 100644 index 0000000..8ab2b99 Binary files /dev/null and b/.import/Hit (32x32).png-a0b8fb1c902e32122bb5d40a99014179.stex differ diff --git a/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.md5 b/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.md5 new file mode 100644 index 0000000..b7d0312 --- /dev/null +++ b/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.md5 @@ -0,0 +1,3 @@ +source_md5="bbd39134a77e658b0b9b64ded537972c" +dest_md5="7daa3df744d00ace1c0d05dd259ef565" + diff --git a/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.stex b/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.stex new file mode 100644 index 0000000..7a4c89d Binary files /dev/null and b/.import/Hit (32x32).png-cac1a2c268367b5c2cb707aef73ad900.stex differ diff --git a/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.md5 b/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.md5 new file mode 100644 index 0000000..5be2c74 --- /dev/null +++ b/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.md5 @@ -0,0 +1,3 @@ +source_md5="52f3056bb8b449aa69017031ecd594bc" +dest_md5="5c7bad2c77710d1ef08e5ebdb154e74b" + diff --git a/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.stex b/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.stex new file mode 100644 index 0000000..a4e6fa3 Binary files /dev/null and b/.import/Hit (32x32).png-e65678847edaa4cbc829346b6458ba80.stex differ diff --git a/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.md5 b/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.md5 new file mode 100644 index 0000000..fa8c5a4 --- /dev/null +++ b/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.md5 @@ -0,0 +1,3 @@ +source_md5="73da8e2bea85232e0f35e0713d887a26" +dest_md5="0846c25808252868d47d0db2e6985e49" + diff --git a/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.stex b/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.stex new file mode 100644 index 0000000..05e6b04 Binary files /dev/null and b/.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.stex differ diff --git a/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.md5 b/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.md5 new file mode 100644 index 0000000..123fac7 --- /dev/null +++ b/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.md5 @@ -0,0 +1,3 @@ +source_md5="40ef02fcab3bd81adf983d77530ce459" +dest_md5="7468a6e051b9210118a2333d90e26aab" + diff --git a/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.stex b/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.stex new file mode 100644 index 0000000..0b9e0e5 Binary files /dev/null and b/.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.stex differ diff --git a/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.md5 b/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.md5 new file mode 100644 index 0000000..58ec251 --- /dev/null +++ b/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.md5 @@ -0,0 +1,3 @@ +source_md5="7eed54b86ba05522718b349b13256527" +dest_md5="8c1218786a3d2a735b069aa5c9e7c541" + diff --git a/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.stex b/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.stex new file mode 100644 index 0000000..e7d1451 Binary files /dev/null and b/.import/HitSide (22x22).png-ea49d40f00b34f01aee6a0511d18b3cd.stex differ diff --git a/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.md5 b/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.md5 new file mode 100644 index 0000000..6c5636e --- /dev/null +++ b/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.md5 @@ -0,0 +1,3 @@ +source_md5="f7a6d02878479b0d8b408ef1d8e071b3" +dest_md5="4e0b3b66b1b46344d1a13fc4990d1ff8" + diff --git a/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.stex b/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.stex new file mode 100644 index 0000000..5385048 Binary files /dev/null and b/.import/HitTop (22x22).png-57ea526eb35f53005a9a6224e9886d48.stex differ diff --git a/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.md5 b/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.md5 new file mode 100644 index 0000000..35388f5 --- /dev/null +++ b/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.md5 @@ -0,0 +1,3 @@ +source_md5="e02aefd5f34a1d92c34e403901dfceac" +dest_md5="a3eb2a7804cf4af31dbf2c59178abd30" + diff --git a/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.stex b/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.stex new file mode 100644 index 0000000..86bdd50 Binary files /dev/null and b/.import/Ice Particle.png-7fce68f4efebde82bc1763cb34a0d63f.stex differ diff --git a/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.md5 b/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.md5 new file mode 100644 index 0000000..b8a0b71 --- /dev/null +++ b/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.md5 @@ -0,0 +1,3 @@ +source_md5="92996e892443163c02ae05afdce12aeb" +dest_md5="0c06240cdf5bb8052d39e928ea72d29d" + diff --git a/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.stex b/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.stex new file mode 100644 index 0000000..b691f59 Binary files /dev/null and b/.import/Idle (18x18).png-24100174ab84ddcfc538f9832bef9d82.stex differ diff --git a/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.md5 b/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.md5 new file mode 100644 index 0000000..76ef898 --- /dev/null +++ b/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.md5 @@ -0,0 +1,3 @@ +source_md5="1b35f85f1241dc1f0597cafbe1eac7f6" +dest_md5="878b68fc19a2ce2d20a23c881da67f34" + diff --git a/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.stex b/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.stex new file mode 100644 index 0000000..398d1f4 Binary files /dev/null and b/.import/Idle (32x32).png-5d9c97515cc905222d069934a49811ca.stex differ diff --git a/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.md5 b/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.md5 new file mode 100644 index 0000000..f67d4de --- /dev/null +++ b/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.md5 @@ -0,0 +1,3 @@ +source_md5="1cb575929ac10fe13dfafa61d78ba28d" +dest_md5="5a8beb119096a9c58bdd763b63416384" + diff --git a/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.stex b/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.stex new file mode 100644 index 0000000..f7d20af Binary files /dev/null and b/.import/Idle (32x32).png-6c8678f6de8c11533a47d09c8e1c94c8.stex differ diff --git a/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.md5 b/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.md5 new file mode 100644 index 0000000..50cdf4a --- /dev/null +++ b/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.md5 @@ -0,0 +1,3 @@ +source_md5="56b53903b6b20059497aac2a92c08b70" +dest_md5="18effb07a22c75efcb38cb90384f477e" + diff --git a/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.stex b/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.stex new file mode 100644 index 0000000..df0b58c Binary files /dev/null and b/.import/Idle (32x32).png-bc46417ef7fb50ae426f78731b0cb88a.stex differ diff --git a/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.md5 b/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.md5 new file mode 100644 index 0000000..d08c883 --- /dev/null +++ b/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.md5 @@ -0,0 +1,3 @@ +source_md5="29c95dbb63a9bf44c42821aa0cf49de8" +dest_md5="59751e394818fe0932e9ab2bf6c1adfe" + diff --git a/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.stex b/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.stex new file mode 100644 index 0000000..2c1ce5d Binary files /dev/null and b/.import/Idle (32x32).png-eed579fc165359c064e81b75a1ae05fa.stex differ diff --git a/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.md5 b/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.md5 new file mode 100644 index 0000000..ca60eb8 --- /dev/null +++ b/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.md5 @@ -0,0 +1,3 @@ +source_md5="df28a79558854cd172e8d82df8414110" +dest_md5="4614242eb5fcc166e675446ec9f162c3" + diff --git a/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.stex b/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.stex new file mode 100644 index 0000000..7362713 Binary files /dev/null and b/.import/Idle.png-34c5f7b761bd5c58138c169d57922c1d.stex differ diff --git a/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.md5 b/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.md5 new file mode 100644 index 0000000..ab98a35 --- /dev/null +++ b/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.md5 @@ -0,0 +1,3 @@ +source_md5="fd7e46184141631c675a0cb993d3df19" +dest_md5="98399900a5631369aa586f37626a936a" + diff --git a/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.stex b/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.stex new file mode 100644 index 0000000..30a92f3 Binary files /dev/null and b/.import/Idle.png-3bb5e189ac84c450187ba89e90a63b41.stex differ diff --git a/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.md5 b/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.md5 new file mode 100644 index 0000000..0a01be2 --- /dev/null +++ b/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.md5 @@ -0,0 +1,3 @@ +source_md5="d627e29f18b4c88d698fada937fdb4f0" +dest_md5="93c9d36efd5922ef0c419c184d647f35" + diff --git a/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.stex b/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.stex new file mode 100644 index 0000000..ec95b39 Binary files /dev/null and b/.import/Idle.png-594b4c8298f589317086d9404b6efa5e.stex differ diff --git a/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.md5 b/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.md5 new file mode 100644 index 0000000..f5beb26 --- /dev/null +++ b/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.md5 @@ -0,0 +1,3 @@ +source_md5="9a1c4cc3188aaae2247f378b2458b9d9" +dest_md5="c8c982e0039bb81059b77c5db2686d41" + diff --git a/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.stex b/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.stex new file mode 100644 index 0000000..1cd7bac Binary files /dev/null and b/.import/Idle.png-5e9c92bd1d4757c353d46d6dc3e52cd1.stex differ diff --git a/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.md5 b/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.md5 new file mode 100644 index 0000000..23f2c9d --- /dev/null +++ b/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.md5 @@ -0,0 +1,3 @@ +source_md5="186a0ffbe08411c54dba5e5e5895fec5" +dest_md5="1fed0a696fae3a8e92266237fc3113ff" + diff --git a/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.stex b/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.stex new file mode 100644 index 0000000..25fa668 Binary files /dev/null and b/.import/Idle.png-76dfa46baf4140bfd589e0b4248f0cdd.stex differ diff --git a/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.md5 b/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.md5 new file mode 100644 index 0000000..df640ca --- /dev/null +++ b/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.md5 @@ -0,0 +1,3 @@ +source_md5="64c275b1b14a4c8cd49088ce8ebf0db5" +dest_md5="dd9bd08c4bc74e420d2746328c488cc2" + diff --git a/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.stex b/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.stex new file mode 100644 index 0000000..2b18082 Binary files /dev/null and b/.import/Idle.png-8ab7fcc9d9c777ad1d84eea26083524a.stex differ diff --git a/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.md5 b/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.md5 new file mode 100644 index 0000000..d350132 --- /dev/null +++ b/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.md5 @@ -0,0 +1,3 @@ +source_md5="b84872c4a33d548bc129b1e282ff79be" +dest_md5="b3f1dacd319349af713404c38edf05ba" + diff --git a/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.stex b/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.stex new file mode 100644 index 0000000..ad5ea8e Binary files /dev/null and b/.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.stex differ diff --git a/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.md5 b/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.md5 new file mode 100644 index 0000000..a33759a --- /dev/null +++ b/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.md5 @@ -0,0 +1,3 @@ +source_md5="d0c63302c00f5e0e9bc3bcffefe3c3fe" +dest_md5="3f5d6f3f97fd7ad4b23766a986ce0718" + diff --git a/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.stex b/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.stex new file mode 100644 index 0000000..49f2038 Binary files /dev/null and b/.import/Idle.png-cc69e6276d2881b2c70442100bf1ecd1.stex differ diff --git a/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.md5 b/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.md5 new file mode 100644 index 0000000..3537b8e --- /dev/null +++ b/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.md5 @@ -0,0 +1,3 @@ +source_md5="21bb703677084f2aaf62323b83483f8e" +dest_md5="97a55465d71fa5bd9f3aadca460e43de" + diff --git a/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.stex b/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.stex new file mode 100644 index 0000000..4501475 Binary files /dev/null and b/.import/Idle.png-d2e8ce10d66d0a78bc0852b818c0a518.stex differ diff --git a/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.md5 b/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.md5 new file mode 100644 index 0000000..dbca442 --- /dev/null +++ b/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.md5 @@ -0,0 +1,3 @@ +source_md5="1c868ca3c1adb54c332a149e7e55f130" +dest_md5="7d309018cd8b1d99b114f73827a81951" + diff --git a/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.stex b/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.stex new file mode 100644 index 0000000..8227162 Binary files /dev/null and b/.import/Jump (28x28).png-b730e17ad0176b6432203c398707b518.stex differ diff --git a/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.md5 b/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.md5 new file mode 100644 index 0000000..c26ecb1 --- /dev/null +++ b/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.md5 @@ -0,0 +1,3 @@ +source_md5="99da59b514370539951a76ba1fe51821" +dest_md5="151b2f7af71f411390b4b291789d69f6" + diff --git a/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.stex b/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.stex new file mode 100644 index 0000000..9412a97 Binary files /dev/null and b/.import/Jump (32x32).png-6c2fa01d5c1ab74564ae46f21f78738f.stex differ diff --git a/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.md5 b/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.md5 new file mode 100644 index 0000000..c66fdc9 --- /dev/null +++ b/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.md5 @@ -0,0 +1,3 @@ +source_md5="f28e95fc98b251913baf3a21d5602381" +dest_md5="8a30ec47473e920c04923b2abe4436ed" + diff --git a/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.stex b/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.stex new file mode 100644 index 0000000..62664d7 Binary files /dev/null and b/.import/Jump (32x32).png-959aa6f9630c60b978998044ff1c43ad.stex differ diff --git a/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.md5 b/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.md5 new file mode 100644 index 0000000..fd8d163 --- /dev/null +++ b/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.md5 @@ -0,0 +1,3 @@ +source_md5="227e7b266efa1d99027231418c8be8e5" +dest_md5="f40e8bad3e3d710886ee87b2383ce8da" + diff --git a/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.stex b/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.stex new file mode 100644 index 0000000..01c5920 Binary files /dev/null and b/.import/Jump (32x32).png-ceaf027d21a4471442166e21feb0e7d2.stex differ diff --git a/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.md5 b/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.md5 new file mode 100644 index 0000000..9b18ecc --- /dev/null +++ b/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.md5 @@ -0,0 +1,3 @@ +source_md5="cafaf2f48f36c9a6655a37f9c1c47b4a" +dest_md5="33e5c3e73b41b3ff0b85afe7e5b1209a" + diff --git a/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.stex b/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.stex new file mode 100644 index 0000000..122dee9 Binary files /dev/null and b/.import/Jump (32x32).png-ef255b16acbc9c0e32e28ed6f1f7b43a.stex differ diff --git a/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.md5 b/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.md5 new file mode 100644 index 0000000..8924f32 --- /dev/null +++ b/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.md5 @@ -0,0 +1,3 @@ +source_md5="91f6e778b76a50dabceb57f3010b4f73" +dest_md5="b718ad1bb72525eedd2f0758877275f2" + diff --git a/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.stex b/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.stex new file mode 100644 index 0000000..a398ad6 Binary files /dev/null and b/.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.stex differ diff --git a/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.md5 b/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.md5 new file mode 100644 index 0000000..ccde777 --- /dev/null +++ b/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.md5 @@ -0,0 +1,3 @@ +source_md5="3d903dd9bf3421c31a5373b0920c876e" +dest_md5="7f4e05e1eeed667d3154489f02be0687" + diff --git a/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.stex b/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.stex new file mode 100644 index 0000000..94b3780 Binary files /dev/null and b/.import/Kiwi.png-7655615fd729501272da61b06032dd7c.stex differ diff --git a/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.md5 b/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.md5 new file mode 100644 index 0000000..b0ec1a8 --- /dev/null +++ b/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.md5 @@ -0,0 +1,3 @@ +source_md5="e3854b8ad5633b1f8017d08b7a783047" +dest_md5="ea71ca21f23fc781b02e2312a16f8d8f" + diff --git a/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.stex b/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.stex new file mode 100644 index 0000000..ff62464 Binary files /dev/null and b/.import/Leaderboard.png-29cb546c779d89b119087ad36bac7ffb.stex differ diff --git a/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.md5 b/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.md5 new file mode 100644 index 0000000..3c63759 --- /dev/null +++ b/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.md5 @@ -0,0 +1,3 @@ +source_md5="29e183472fc139814d5245a14b0c2ebd" +dest_md5="d2f15579a4ed0beb9933d21555667aa2" + diff --git a/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.stex b/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.stex new file mode 100644 index 0000000..8ca02ea Binary files /dev/null and b/.import/Left Hit (42x42).png-d744e4efa57538d71a9b92a75887055a.stex differ diff --git a/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.md5 b/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.md5 new file mode 100644 index 0000000..6c199b9 --- /dev/null +++ b/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.md5 @@ -0,0 +1,3 @@ +source_md5="1c14ae2c7378d90e92307e9fa5998540" +dest_md5="2f014a77eed6278cd86b9634f1b0d215" + diff --git a/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.stex b/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.stex new file mode 100644 index 0000000..1584ce4 Binary files /dev/null and b/.import/Left Hit (54x52).png-1bdebdd9409dbf8296058a38f4aacd17.stex differ diff --git a/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.md5 b/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.md5 new file mode 100644 index 0000000..b0ab0cc --- /dev/null +++ b/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.md5 @@ -0,0 +1,3 @@ +source_md5="5364f08108b6f75ff31b5b7c84f9789a" +dest_md5="35ed3bf2c194843b88c3c24f5cc2a495" + diff --git a/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.stex b/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.stex new file mode 100644 index 0000000..e015cae Binary files /dev/null and b/.import/Levels.png-b85982662f4115499bf9834fc9b556a2.stex differ diff --git a/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.md5 b/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.md5 new file mode 100644 index 0000000..3ceb3c9 --- /dev/null +++ b/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.md5 @@ -0,0 +1,3 @@ +source_md5="1c83a8dcf75d313055ce4509b0f1e87c" +dest_md5="bdc91dcbc78a289f551132fae6ea0a36" + diff --git a/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.mp3str b/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.mp3str new file mode 100644 index 0000000..f03d128 Binary files /dev/null and b/.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.mp3str differ diff --git a/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.md5 b/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.md5 new file mode 100644 index 0000000..5d39df5 --- /dev/null +++ b/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.md5 @@ -0,0 +1,3 @@ +source_md5="eb6f978fbf95d76587bcf656c649540b" +dest_md5="3d303f275640a67cdd4f5923afe800b1" + diff --git a/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.stex b/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.stex new file mode 100644 index 0000000..8ddf783 Binary files /dev/null and b/.import/Melon.png-f78818fb7d4fa7a4e2fca3a326be275d.stex differ diff --git a/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.md5 b/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.md5 new file mode 100644 index 0000000..2417293 --- /dev/null +++ b/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.md5 @@ -0,0 +1,3 @@ +source_md5="d9b98c54de3691a1112cd98e273eb651" +dest_md5="bb7c1e5a7f7592945fe1866adf30d752" + diff --git a/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.stex b/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.stex new file mode 100644 index 0000000..f7827ed Binary files /dev/null and b/.import/Mud Particle.png-38059822c147681a2caa2e9f444a7548.stex differ diff --git a/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.md5 b/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.md5 new file mode 100644 index 0000000..b787e76 --- /dev/null +++ b/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.md5 @@ -0,0 +1,3 @@ +source_md5="2f75777c57c36c83c6140bbd7b97a5e1" +dest_md5="4aa6569ae6098017019a8362160ca06e" + diff --git a/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.stex b/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.stex new file mode 100644 index 0000000..c86687e Binary files /dev/null and b/.import/Next.png-9c243af4a85949eb3ff50522fec35aee.stex differ diff --git a/.import/Off.png-06084f681ee156b9a3b8668d887e385c.md5 b/.import/Off.png-06084f681ee156b9a3b8668d887e385c.md5 new file mode 100644 index 0000000..94b3f9f --- /dev/null +++ b/.import/Off.png-06084f681ee156b9a3b8668d887e385c.md5 @@ -0,0 +1,3 @@ +source_md5="0e7288b787c57532b4549fbdb6bce311" +dest_md5="b4759137a41bbd9e605384e6b60fa19a" + diff --git a/.import/Off.png-06084f681ee156b9a3b8668d887e385c.stex b/.import/Off.png-06084f681ee156b9a3b8668d887e385c.stex new file mode 100644 index 0000000..c6bb851 Binary files /dev/null and b/.import/Off.png-06084f681ee156b9a3b8668d887e385c.stex differ diff --git a/.import/Off.png-44ed848594f84d083ddb660834c65270.md5 b/.import/Off.png-44ed848594f84d083ddb660834c65270.md5 new file mode 100644 index 0000000..b1020d2 --- /dev/null +++ b/.import/Off.png-44ed848594f84d083ddb660834c65270.md5 @@ -0,0 +1,3 @@ +source_md5="2984d7e69a4f68c94d6ead997e68e3d3" +dest_md5="ec43c80d4c5afa42fc8fb33f93c52916" + diff --git a/.import/Off.png-44ed848594f84d083ddb660834c65270.stex b/.import/Off.png-44ed848594f84d083ddb660834c65270.stex new file mode 100644 index 0000000..b608a36 Binary files /dev/null and b/.import/Off.png-44ed848594f84d083ddb660834c65270.stex differ diff --git a/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.md5 b/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.md5 new file mode 100644 index 0000000..2ae0e2a --- /dev/null +++ b/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.md5 @@ -0,0 +1,3 @@ +source_md5="66d27386fec46e0b052941957d9bdc22" +dest_md5="14966e45436e38b8f26c3dae4e843ae2" + diff --git a/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.stex b/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.stex new file mode 100644 index 0000000..d2984f8 Binary files /dev/null and b/.import/Off.png-4741a93eb67ce85a1a4408d7d2e20b9b.stex differ diff --git a/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.md5 b/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.md5 new file mode 100644 index 0000000..eee8600 --- /dev/null +++ b/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.md5 @@ -0,0 +1,3 @@ +source_md5="61cbabffca58576e5d8e0b7abf38b95e" +dest_md5="b9fa49e64f156b2d43a6c613e04fb8b1" + diff --git a/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.stex b/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.stex new file mode 100644 index 0000000..afbe2fa Binary files /dev/null and b/.import/Off.png-e752bb45d26a897a868398d18f15ddcf.stex differ diff --git a/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.md5 b/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.md5 new file mode 100644 index 0000000..2e7db9f --- /dev/null +++ b/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.md5 @@ -0,0 +1,3 @@ +source_md5="eaf35fcb43611e2d738a475b2a66beae" +dest_md5="cb3f4b1cbefa6ee95f4dcbbdc188d226" + diff --git a/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.stex b/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.stex new file mode 100644 index 0000000..2aac51e Binary files /dev/null and b/.import/On (16x32).png-8d900df8e5c50662e15e915e4d34af8c.stex differ diff --git a/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.md5 b/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.md5 new file mode 100644 index 0000000..a74fd36 --- /dev/null +++ b/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.md5 @@ -0,0 +1,3 @@ +source_md5="70f1ada6b967d83982dc663d838c88ed" +dest_md5="3f5f0a5ecbaec85016431a659b0bfe39" + diff --git a/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.stex b/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.stex new file mode 100644 index 0000000..e668a25 Binary files /dev/null and b/.import/On (24x8).png-a776c12f97854b128bee7597d8827205.stex differ diff --git a/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.md5 b/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.md5 new file mode 100644 index 0000000..c40ead0 --- /dev/null +++ b/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.md5 @@ -0,0 +1,3 @@ +source_md5="025cf6ddf15c55f73d65ce670e45b94d" +dest_md5="177346d475d5bb73c41657211dc69442" + diff --git a/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.stex b/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.stex new file mode 100644 index 0000000..d97031f Binary files /dev/null and b/.import/On (32x10).png-5b0a006c037cf676498a85d27fafa5a8.stex differ diff --git a/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.md5 b/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.md5 new file mode 100644 index 0000000..9e6fded --- /dev/null +++ b/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.md5 @@ -0,0 +1,3 @@ +source_md5="817477a39df8b330334e3866c1cb574b" +dest_md5="5650f44f318aa73e5e50e978a34ab73b" + diff --git a/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.stex b/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.stex new file mode 100644 index 0000000..f866cc7 Binary files /dev/null and b/.import/On (38x38).png-cb53e90b3ffd91f9dbf9a9d347f189dd.stex differ diff --git a/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.md5 b/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.md5 new file mode 100644 index 0000000..7edd13c --- /dev/null +++ b/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.md5 @@ -0,0 +1,3 @@ +source_md5="60e0f68620c442b9403a477bbe3588ed" +dest_md5="e0540091e5970a01302c48890f0e076e" + diff --git a/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.stex b/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.stex new file mode 100644 index 0000000..78e1e20 Binary files /dev/null and b/.import/Orange.png-47ddb8573015db4c33e648ca5fb8ebe6.stex differ diff --git a/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.md5 b/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.md5 new file mode 100644 index 0000000..f6752fd --- /dev/null +++ b/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.md5 @@ -0,0 +1,3 @@ +source_md5="8ed4876040c692b6f353e40ddc9466d4" +dest_md5="c20b8365047458189d5341e987cbc690" + diff --git a/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.stex b/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.stex new file mode 100644 index 0000000..a04c9c6 Binary files /dev/null and b/.import/Part 1 (22x22).png-139edd763b2dd9b9784fa415dd3fae78.stex differ diff --git a/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.md5 b/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.md5 new file mode 100644 index 0000000..906711c --- /dev/null +++ b/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.md5 @@ -0,0 +1,3 @@ +source_md5="ee32674efcd862136828db547dae6cb5" +dest_md5="3fa0b25c169502e78d1fceab710b5897" + diff --git a/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.stex b/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.stex new file mode 100644 index 0000000..fcc3c55 Binary files /dev/null and b/.import/Part 2 (22x22).png-083376665866a311a5e6632feaca345f.stex differ diff --git a/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.md5 b/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.md5 new file mode 100644 index 0000000..13e5150 --- /dev/null +++ b/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.md5 @@ -0,0 +1,3 @@ +source_md5="0740bf84a38504383c80103d60582217" +dest_md5="0eb73f88f0653fd62306c6dc8bc33444" + diff --git a/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.stex b/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.stex new file mode 100644 index 0000000..7f9ea51 Binary files /dev/null and b/.import/Pineapple.png-3257086a97d42fb1abe4cb984be34a98.stex differ diff --git a/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.md5 b/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.md5 new file mode 100644 index 0000000..bd894ca --- /dev/null +++ b/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.md5 @@ -0,0 +1,3 @@ +source_md5="31b5e360eb9610c58138bb7cfdfb96a1" +dest_md5="4915fdbf5d2c4de4f578eff92b97f5ac" + diff --git a/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.stex b/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.stex new file mode 100644 index 0000000..da40be5 Binary files /dev/null and b/.import/Pink.png-fb382a1cec1961eef37753767de4ed42.stex differ diff --git a/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.md5 b/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.md5 new file mode 100644 index 0000000..b0fad89 --- /dev/null +++ b/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.md5 @@ -0,0 +1,3 @@ +source_md5="23f2b2a41eb467518bbfef795d876dc8" +dest_md5="b9897f89f8021fcfa524e77f8802b23f" + diff --git a/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.stex b/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.stex new file mode 100644 index 0000000..0271aab Binary files /dev/null and b/.import/Play.png-fe2f50bd7df6414dca84fa20c9f8b796.stex differ diff --git a/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.md5 b/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.md5 new file mode 100644 index 0000000..c7a3a19 --- /dev/null +++ b/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.md5 @@ -0,0 +1,3 @@ +source_md5="8d760106f298c5bc335c551a7740642b" +dest_md5="1d6f93a00ffa846961ada63139181c54" + diff --git a/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.stex b/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.stex new file mode 100644 index 0000000..67335d6 Binary files /dev/null and b/.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.stex differ diff --git a/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.md5 b/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.md5 new file mode 100644 index 0000000..9682403 --- /dev/null +++ b/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.md5 @@ -0,0 +1,3 @@ +source_md5="c63a3a14721d926b03801f38b81b66a6" +dest_md5="717747d80c4cf4cc43e1b915224d0d35" + diff --git a/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.stex b/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.stex new file mode 100644 index 0000000..bb44b71 Binary files /dev/null and b/.import/Previous.png-b11921d30a529c45bb5fb6669a356f16.stex differ diff --git a/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.md5 b/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.md5 new file mode 100644 index 0000000..395ac57 --- /dev/null +++ b/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.md5 @@ -0,0 +1,3 @@ +source_md5="f8cc6aa8fd738e6e4db8b6607b7e6c37" +dest_md5="6c54410350d36a1a04f3cef3bdbbbaea" + diff --git a/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.stex b/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.stex new file mode 100644 index 0000000..03f9fa3 Binary files /dev/null and b/.import/Purple.png-d35a88d756356a9437da9d3b962e6ffa.stex differ diff --git a/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.md5 b/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.md5 new file mode 100644 index 0000000..0c266a4 --- /dev/null +++ b/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.md5 @@ -0,0 +1,3 @@ +source_md5="45fe1343f546485e8e288b122467f2fd" +dest_md5="954c030b0658e97cc730c4c126a84144" + diff --git a/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.stex b/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.stex new file mode 100644 index 0000000..9f68f1a Binary files /dev/null and b/.import/Restart.png-31fcd0c19e14045b4902442a6929eb71.stex differ diff --git a/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.md5 b/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.md5 new file mode 100644 index 0000000..ec3e131 --- /dev/null +++ b/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.md5 @@ -0,0 +1,3 @@ +source_md5="c2e11c4f2e75253e649d39f6e0dcb46d" +dest_md5="550cd5604cdf67876be3afd665d69899" + diff --git a/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.stex b/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.stex new file mode 100644 index 0000000..2bbe75f Binary files /dev/null and b/.import/Right Hit (42x42).png-9b034419a6dd0cc3f25dbf6236719e32.stex differ diff --git a/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.md5 b/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.md5 new file mode 100644 index 0000000..9b9ab70 --- /dev/null +++ b/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.md5 @@ -0,0 +1,3 @@ +source_md5="6f7f8c608eb77606721304f074ff439b" +dest_md5="a68a8b5915fbae1b52778712406c6803" + diff --git a/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.stex b/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.stex new file mode 100644 index 0000000..43493ff Binary files /dev/null and b/.import/Right Hit (54x52).png-5f2f2465c7b93168ce142ad0c624287b.stex differ diff --git a/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.md5 b/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.md5 new file mode 100644 index 0000000..e0aa136 --- /dev/null +++ b/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.md5 @@ -0,0 +1,3 @@ +source_md5="96a45652f4ce649bcef2cb8425fb344b" +dest_md5="440c45469e4928715b6e489dfa9e0708" + diff --git a/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.stex b/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.stex new file mode 100644 index 0000000..e4c2d41 Binary files /dev/null and b/.import/Run (32x32).png-02c43f80cfb6bf654de404d7488f4559.stex differ diff --git a/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.md5 b/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.md5 new file mode 100644 index 0000000..2326dfa --- /dev/null +++ b/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.md5 @@ -0,0 +1,3 @@ +source_md5="016f388a07f71a930fd79a7a806d5da8" +dest_md5="b5b80cde75a15195b6f64c3de2a669c7" + diff --git a/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.stex b/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.stex new file mode 100644 index 0000000..24690c6 Binary files /dev/null and b/.import/Run (32x32).png-102cd8d4c21a5c38b37154f540e63017.stex differ diff --git a/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.md5 b/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.md5 new file mode 100644 index 0000000..0aae571 --- /dev/null +++ b/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.md5 @@ -0,0 +1,3 @@ +source_md5="25fcce89dfb6673a81d384091c87353d" +dest_md5="cef9c1402a754e9d7bf333b7b206b607" + diff --git a/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.stex b/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.stex new file mode 100644 index 0000000..e9ca236 Binary files /dev/null and b/.import/Run (32x32).png-3bd7171b38bb6793f25e78880e993f97.stex differ diff --git a/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.md5 b/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.md5 new file mode 100644 index 0000000..3bc2823 --- /dev/null +++ b/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.md5 @@ -0,0 +1,3 @@ +source_md5="b04bbc82dc692516a4b13c0d9d5b9ebd" +dest_md5="646e2cc11ec673e6a6e2525658eb671f" + diff --git a/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.stex b/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.stex new file mode 100644 index 0000000..88eb618 Binary files /dev/null and b/.import/Run (32x32).png-b27a5d36211eeed0c3b615b90d38e3f7.stex differ diff --git a/.import/Run.png-5667008b09d030d2656b5293577011cb.md5 b/.import/Run.png-5667008b09d030d2656b5293577011cb.md5 new file mode 100644 index 0000000..e9e0789 --- /dev/null +++ b/.import/Run.png-5667008b09d030d2656b5293577011cb.md5 @@ -0,0 +1,3 @@ +source_md5="d669d6d29759bb17aa8838cfa4179e8f" +dest_md5="4b693f945e7f3b531faa816f249d81a8" + diff --git a/.import/Run.png-5667008b09d030d2656b5293577011cb.stex b/.import/Run.png-5667008b09d030d2656b5293577011cb.stex new file mode 100644 index 0000000..e441353 Binary files /dev/null and b/.import/Run.png-5667008b09d030d2656b5293577011cb.stex differ diff --git a/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.md5 b/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.md5 new file mode 100644 index 0000000..58a14ef --- /dev/null +++ b/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.md5 @@ -0,0 +1,3 @@ +source_md5="21612a022cf0d4cd0f2d9e6c431acb20" +dest_md5="babd02cb2768f4263fe0cc92c7d3b5a9" + diff --git a/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.stex b/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.stex new file mode 100644 index 0000000..f358d41 Binary files /dev/null and b/.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.stex differ diff --git a/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.md5 b/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.md5 new file mode 100644 index 0000000..911e54e --- /dev/null +++ b/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.md5 @@ -0,0 +1,3 @@ +source_md5="5d3b5ca60b81488357c35f295102b2af" +dest_md5="bcc6a08cd27fba46fbfa66e57800a7d3" + diff --git a/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.stex b/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.stex new file mode 100644 index 0000000..06142ec Binary files /dev/null and b/.import/Sand Mud Ice (16x6).png-23abf04f39a1d2e136a9917aaa54a80a.stex differ diff --git a/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.md5 b/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.md5 new file mode 100644 index 0000000..4f77b99 --- /dev/null +++ b/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.md5 @@ -0,0 +1,3 @@ +source_md5="4eb5d75f4ac258086dc6033848b861c1" +dest_md5="186d355c707d084f8088ceba052efeb1" + diff --git a/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.stex b/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.stex new file mode 100644 index 0000000..6c419c7 Binary files /dev/null and b/.import/Sand Particle.png-f0125788f947f90186a196b96b5be1f8.stex differ diff --git a/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.md5 b/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.md5 new file mode 100644 index 0000000..f69d910 --- /dev/null +++ b/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.md5 @@ -0,0 +1,3 @@ +source_md5="a56908d71e428647c51e73af372739ab" +dest_md5="1e6de739c7c707a8de8daf5aeeab2aed" + diff --git a/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.stex b/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.stex new file mode 100644 index 0000000..a0ba9ac Binary files /dev/null and b/.import/Settings.png-8af262f2612fa51106c48d95dbbc2fc5.stex differ diff --git a/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.md5 b/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.md5 new file mode 100644 index 0000000..62fed0b --- /dev/null +++ b/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.md5 @@ -0,0 +1,3 @@ +source_md5="e0a519d1a807df82abc87e6a2375d20f" +dest_md5="c1b07c08ab458e275cd0500b59c509de" + diff --git a/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.stex b/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.stex new file mode 100644 index 0000000..6027459 Binary files /dev/null and b/.import/Shadow.png-c341870afc9c4ee6d5403afbb1d836e1.stex differ diff --git a/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.md5 b/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.md5 new file mode 100644 index 0000000..f32156c --- /dev/null +++ b/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.md5 @@ -0,0 +1,3 @@ +source_md5="7905ea048fe1afbdaf2130728f94a86b" +dest_md5="479dc18b91c7234924979ad0300854d3" + diff --git a/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.stex b/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.stex new file mode 100644 index 0000000..3133b15 Binary files /dev/null and b/.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.stex differ diff --git a/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.md5 b/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.md5 new file mode 100644 index 0000000..9af9b72 --- /dev/null +++ b/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.md5 @@ -0,0 +1,3 @@ +source_md5="80489916819a87e28af7fbb56eed2181" +dest_md5="1f808addc013022aaa27f781d42f9dfe" + diff --git a/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.stex b/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.stex new file mode 100644 index 0000000..3d3e009 Binary files /dev/null and b/.import/Spiked Ball.png-a854948839636f18112d6744a60c33b6.stex differ diff --git a/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.md5 b/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.md5 new file mode 100644 index 0000000..f661c66 --- /dev/null +++ b/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.md5 @@ -0,0 +1,3 @@ +source_md5="3b3666dde41d33e4ae75c6e614dd5f51" +dest_md5="b4ef551f8f0cc2a061ce30f62e24dec3" + diff --git a/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.stex b/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.stex new file mode 100644 index 0000000..15f342a Binary files /dev/null and b/.import/Start (Idle).png-f41c04ccceb5444c936963e1f3dc8369.stex differ diff --git a/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.md5 b/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.md5 new file mode 100644 index 0000000..478a948 --- /dev/null +++ b/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.md5 @@ -0,0 +1,3 @@ +source_md5="3c1467f4bf5f1e0c877f66a8a05900b8" +dest_md5="eb95b63c1379d029410fe2f6500ffccf" + diff --git a/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.stex b/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.stex new file mode 100644 index 0000000..bc48ea6 Binary files /dev/null and b/.import/Start (Moving) (64x64).png-8d0a31c9d5384752b0ada16dd929f63a.stex differ diff --git a/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.md5 b/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.md5 new file mode 100644 index 0000000..7eb2a44 --- /dev/null +++ b/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.md5 @@ -0,0 +1,3 @@ +source_md5="568a3f91b8f6102f1b518c1aba0e8e09" +dest_md5="f8a77dd2b0f7d2fec496b4abfd852921" + diff --git a/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.stex b/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.stex new file mode 100644 index 0000000..38fe73d Binary files /dev/null and b/.import/Strawberry.png-cdcfa3cffc271dda1740d507f514a931.stex differ diff --git a/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.md5 b/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.md5 new file mode 100644 index 0000000..087b799 --- /dev/null +++ b/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.md5 @@ -0,0 +1,3 @@ +source_md5="df891f02449c0565d51e2bf7823a0e38" +dest_md5="11806177c65d8f6be9bee13ca11bafb6" + diff --git a/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.stex b/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.stex new file mode 100644 index 0000000..696373d Binary files /dev/null and b/.import/Terrain (16x16).png-d67fa55ef1137d5d467cd35bc318d487.stex differ diff --git a/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.md5 b/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.md5 new file mode 100644 index 0000000..b09293f --- /dev/null +++ b/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.md5 @@ -0,0 +1,3 @@ +source_md5="33dfcfb4172f57930890a12c80f23201" +dest_md5="9e3b3f77b8a8b02d38a6261eacb1cb2f" + diff --git a/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.stex b/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.stex new file mode 100644 index 0000000..461ee97 Binary files /dev/null and b/.import/Text (Black) (8x10).png-392deb1d0e94edd8300e49a078f29964.stex differ diff --git a/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.md5 b/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.md5 new file mode 100644 index 0000000..6564053 --- /dev/null +++ b/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.md5 @@ -0,0 +1,3 @@ +source_md5="493235653c61f14237c213dec97a9f2f" +dest_md5="c85866345a4e42e16f28fe7dd84a178c" + diff --git a/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.stex b/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.stex new file mode 100644 index 0000000..b88acfb Binary files /dev/null and b/.import/Text (White) (8x10).png-9a62180c2df11d21ff1274532c8f7210.stex differ diff --git a/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.md5 b/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.md5 new file mode 100644 index 0000000..3a279f3 --- /dev/null +++ b/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.md5 @@ -0,0 +1,3 @@ +source_md5="a7bc34c2035ccb90c16b7693209d03fd" +dest_md5="dc264004659ddb8326dd9da4ac250945" + diff --git a/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.stex b/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.stex new file mode 100644 index 0000000..dbcf343 Binary files /dev/null and b/.import/Top Hit (42x42).png-50fd4b85ee801eceb84fd5b3984b0ba4.stex differ diff --git a/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.md5 b/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.md5 new file mode 100644 index 0000000..18f9c82 --- /dev/null +++ b/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.md5 @@ -0,0 +1,3 @@ +source_md5="cd0107843e57eba78eb61589422d8ec7" +dest_md5="00ff49a9c1c892b963ac0d0c688a9b97" + diff --git a/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.stex b/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.stex new file mode 100644 index 0000000..2c7526f Binary files /dev/null and b/.import/Top Hit (54x52).png-07ed53cc345aab58703cffcbbc2285b9.stex differ diff --git a/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.md5 b/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.md5 new file mode 100644 index 0000000..878eb29 --- /dev/null +++ b/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.md5 @@ -0,0 +1,3 @@ +source_md5="676092b6943e94a165bea63707f4518f" +dest_md5="58edabf180c098c53f75ffd533338cb5" + diff --git a/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.stex b/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.stex new file mode 100644 index 0000000..72794ed Binary files /dev/null and b/.import/Transition.png-49b95473a2db35fc8dba6f6bddce28f5.stex differ diff --git a/.import/Volume.png-681bda24f87f246986bf0ab86e503341.md5 b/.import/Volume.png-681bda24f87f246986bf0ab86e503341.md5 new file mode 100644 index 0000000..dbc9992 --- /dev/null +++ b/.import/Volume.png-681bda24f87f246986bf0ab86e503341.md5 @@ -0,0 +1,3 @@ +source_md5="60060aab64ff40a0a996820f64a308b3" +dest_md5="307e07e99d2df27b44b29730ab4adbc2" + diff --git a/.import/Volume.png-681bda24f87f246986bf0ab86e503341.stex b/.import/Volume.png-681bda24f87f246986bf0ab86e503341.stex new file mode 100644 index 0000000..3ab5463 Binary files /dev/null and b/.import/Volume.png-681bda24f87f246986bf0ab86e503341.stex differ diff --git a/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.md5 b/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.md5 new file mode 100644 index 0000000..0f46921 --- /dev/null +++ b/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.md5 @@ -0,0 +1,3 @@ +source_md5="76cbdd4a22d50bd65ac02be8a5eb1547" +dest_md5="6845c5c1b0011009d8e793553971b150" + diff --git a/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.stex b/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.stex new file mode 100644 index 0000000..49bc16e Binary files /dev/null and b/.import/Wall Jump (32x32).png-b990cc50ecb5f7e10c39cc7affb1a712.stex differ diff --git a/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.md5 b/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.md5 new file mode 100644 index 0000000..1c3e61b --- /dev/null +++ b/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.md5 @@ -0,0 +1,3 @@ +source_md5="552254b40eac6d10d2c3d779edb92116" +dest_md5="2f385436713723fb172d046f24c18c13" + diff --git a/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.stex b/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.stex new file mode 100644 index 0000000..0ad67bf Binary files /dev/null and b/.import/Wall Jump (32x32).png-c919df218fc9fcbceedfbc53ea33cf2e.stex differ diff --git a/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.md5 b/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.md5 new file mode 100644 index 0000000..fc074f9 --- /dev/null +++ b/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.md5 @@ -0,0 +1,3 @@ +source_md5="981385687727fd9d279f8c73c1c4826a" +dest_md5="b91849c8e61d3fdc83df66ec2e28aaec" + diff --git a/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.stex b/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.stex new file mode 100644 index 0000000..a2dca05 Binary files /dev/null and b/.import/Wall Jump (32x32).png-cc8cfc7237a0b3dff013c752aefb09f0.stex differ diff --git a/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.md5 b/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.md5 new file mode 100644 index 0000000..61574c3 --- /dev/null +++ b/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.md5 @@ -0,0 +1,3 @@ +source_md5="955d352171a2b666ae705b6205856ce1" +dest_md5="1b5bba76815b7d2752d4e22228d72763" + diff --git a/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.stex b/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.stex new file mode 100644 index 0000000..00ef4ae Binary files /dev/null and b/.import/Wall Jump (32x32).png-f419e68d3bdd3f2ab083e2ac8f891aac.stex differ diff --git a/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.md5 b/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.md5 new file mode 100644 index 0000000..fc074f9 --- /dev/null +++ b/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.md5 @@ -0,0 +1,3 @@ +source_md5="981385687727fd9d279f8c73c1c4826a" +dest_md5="b91849c8e61d3fdc83df66ec2e28aaec" + diff --git a/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.stex b/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.stex new file mode 100644 index 0000000..a2dca05 Binary files /dev/null and b/.import/Wall Jump.png-a593a9ab99c09769888f99b29234c2eb.stex differ diff --git a/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.md5 b/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.md5 new file mode 100644 index 0000000..d628abf --- /dev/null +++ b/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.md5 @@ -0,0 +1,3 @@ +source_md5="c3f96416e21f366bc0c3635ce5b530d5" +dest_md5="995622b2ae155919539dd54772bc0547" + diff --git a/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.stex b/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.stex new file mode 100644 index 0000000..9a08e2c Binary files /dev/null and b/.import/Yellow.png-56156c7987e518e90bc9f4e689bfbddc.stex differ diff --git a/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.md5 b/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.md5 new file mode 100644 index 0000000..e646ecf --- /dev/null +++ b/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.md5 @@ -0,0 +1,3 @@ +source_md5="3465bf2f805089224dd5110f062d2dc0" +dest_md5="5deb3b46df4c4e2ecddf82664871759a" + diff --git a/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.sample b/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.sample new file mode 100644 index 0000000..c6fb92a Binary files /dev/null and b/.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.sample differ diff --git a/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.md5 b/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.md5 new file mode 100644 index 0000000..a048764 --- /dev/null +++ b/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.md5 @@ -0,0 +1,3 @@ +source_md5="70cf7d86ddab5f67cb7c7f33a2621240" +dest_md5="d80bf9e795b50d0e27228330ac110b1d" + diff --git a/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.stex b/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.stex new file mode 100644 index 0000000..d8bf170 Binary files /dev/null and b/.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.stex differ diff --git a/.import/back.png-dff1cd8076833f0221eee3db86f61783.md5 b/.import/back.png-dff1cd8076833f0221eee3db86f61783.md5 new file mode 100644 index 0000000..bd986d1 --- /dev/null +++ b/.import/back.png-dff1cd8076833f0221eee3db86f61783.md5 @@ -0,0 +1,3 @@ +source_md5="34f68387141ca8ce8b55ed7153c8ae2a" +dest_md5="d0717e29204234e9ea0cf11c177158e8" + diff --git a/.import/back.png-dff1cd8076833f0221eee3db86f61783.stex b/.import/back.png-dff1cd8076833f0221eee3db86f61783.stex new file mode 100644 index 0000000..8ce67fd Binary files /dev/null and b/.import/back.png-dff1cd8076833f0221eee3db86f61783.stex differ diff --git a/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.md5 b/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.md5 new file mode 100644 index 0000000..305bea6 --- /dev/null +++ b/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.md5 @@ -0,0 +1,3 @@ +source_md5="ad62da056f401723274ffe1c8378c3db" +dest_md5="21e56d103fe793f2bf97aa330198e7fa" + diff --git a/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.stex b/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.stex new file mode 100644 index 0000000..6144751 Binary files /dev/null and b/.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.stex differ diff --git a/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.md5 b/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.md5 new file mode 100644 index 0000000..281eeb4 --- /dev/null +++ b/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.md5 @@ -0,0 +1,3 @@ +source_md5="b5818f2130fc1ff306a2a9643412b2e8" +dest_md5="3d43ad523c78ed8f00925b49fcf0cdfb" + diff --git a/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.stex b/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.stex new file mode 100644 index 0000000..ecb809b Binary files /dev/null and b/.import/clock.png-0b59f1864c2966e68f1301e328a381e5.stex differ diff --git a/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.md5 b/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.md5 new file mode 100644 index 0000000..39c615c --- /dev/null +++ b/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.md5 @@ -0,0 +1,3 @@ +source_md5="78f64b90287ae0111a284cf77fbb3d67" +dest_md5="e3baa252ee2dde7355e6dbce688cb270" + diff --git a/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.stex b/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.stex new file mode 100644 index 0000000..d2bea14 Binary files /dev/null and b/.import/cloud_1.png-1e64d58f5580e1f717b6554819d7cb92.stex differ diff --git a/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.md5 b/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.md5 new file mode 100644 index 0000000..52dc630 --- /dev/null +++ b/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.md5 @@ -0,0 +1,3 @@ +source_md5="221bf9c71d58f4902d8b9569821f01b8" +dest_md5="e6ad96d8463e676fb210bd38548cf35b" + diff --git a/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.stex b/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.stex new file mode 100644 index 0000000..1ee36ec Binary files /dev/null and b/.import/cloud_2.png-fddd34e9d7b63c90756c8fa0e3a88c7b.stex differ diff --git a/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.md5 b/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.md5 new file mode 100644 index 0000000..752241e --- /dev/null +++ b/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.md5 @@ -0,0 +1,3 @@ +source_md5="b459a4abb3c98599942d3359f3d73870" +dest_md5="1e0e5e95ad315ebdf068b8e55738a6d7" + diff --git a/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.stex b/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.stex new file mode 100644 index 0000000..3431741 Binary files /dev/null and b/.import/cloud_3.png-5950363b80b57b3f44a3bf981a68c710.stex differ diff --git a/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.md5 b/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.md5 new file mode 100644 index 0000000..bc7e7b6 --- /dev/null +++ b/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.md5 @@ -0,0 +1,3 @@ +source_md5="d88d0af7202ed3ae0c6f65d88efc13ee" +dest_md5="60a44a8927364b5d34edd589e1bffb29" + diff --git a/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.stex b/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.stex new file mode 100644 index 0000000..dd98e91 Binary files /dev/null and b/.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.stex differ diff --git a/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.md5 b/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.md5 new file mode 100644 index 0000000..cda5669 --- /dev/null +++ b/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.md5 @@ -0,0 +1,3 @@ +source_md5="c9b8b4e85a53ce0e7add721a872d0479" +dest_md5="3370a4e29e3ba1ce6cb006cfbfc5b12c" + diff --git a/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.sample b/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.sample new file mode 100644 index 0000000..77662e3 Binary files /dev/null and b/.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.sample differ diff --git a/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.md5 b/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.md5 new file mode 100644 index 0000000..4702158 --- /dev/null +++ b/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.md5 @@ -0,0 +1,3 @@ +source_md5="54ede9d26640f65101b871ad73bd4167" +dest_md5="da10ada180e7718bf6a21f6783892661" + diff --git a/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.stex b/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.stex new file mode 100644 index 0000000..665ad05 Binary files /dev/null and b/.import/die.png-dab1cfc16121fcfeb20b721c3986a64f.stex differ diff --git a/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.md5 b/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.md5 new file mode 100644 index 0000000..5a8af41 --- /dev/null +++ b/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.md5 @@ -0,0 +1,3 @@ +source_md5="c6ca36f8b45e135f7bc943a0a2af14c7" +dest_md5="28da58ce112ad2928ce85b0d3f779cce" + diff --git a/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.stex b/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.stex new file mode 100644 index 0000000..a4a0767 Binary files /dev/null and b/.import/enemy.png-3796cbd9472a4e95d6e04d990963e9a8.stex differ diff --git a/.import/explode.wav-1427bde96c86e9944df6457780bdca97.md5 b/.import/explode.wav-1427bde96c86e9944df6457780bdca97.md5 new file mode 100644 index 0000000..cbcb808 --- /dev/null +++ b/.import/explode.wav-1427bde96c86e9944df6457780bdca97.md5 @@ -0,0 +1,3 @@ +source_md5="c49bffd6268c2fb061a578c559fbd988" +dest_md5="7a739636437435e6aafc96c9466a244d" + diff --git a/.import/explode.wav-1427bde96c86e9944df6457780bdca97.sample b/.import/explode.wav-1427bde96c86e9944df6457780bdca97.sample new file mode 100644 index 0000000..cb29317 Binary files /dev/null and b/.import/explode.wav-1427bde96c86e9944df6457780bdca97.sample differ diff --git a/.import/favicon.png-67c6e2983692f67236160725530a2740.md5 b/.import/favicon.png-67c6e2983692f67236160725530a2740.md5 new file mode 100644 index 0000000..77ab870 --- /dev/null +++ b/.import/favicon.png-67c6e2983692f67236160725530a2740.md5 @@ -0,0 +1,3 @@ +source_md5="e4dbfa624efd0f017aee2553059d618f" +dest_md5="a4ae5eaed2f51e7425759dd679bf3aed" + diff --git a/.import/favicon.png-67c6e2983692f67236160725530a2740.stex b/.import/favicon.png-67c6e2983692f67236160725530a2740.stex new file mode 100644 index 0000000..cc9f516 Binary files /dev/null and b/.import/favicon.png-67c6e2983692f67236160725530a2740.stex differ diff --git a/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.md5 b/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.md5 new file mode 100644 index 0000000..38b7c95 --- /dev/null +++ b/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.md5 @@ -0,0 +1,3 @@ +source_md5="2bee03b60b972081ba283218f52722fc" +dest_md5="5f09f704794a79eefa2d66289ada4c02" + diff --git a/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.stex b/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.stex new file mode 100644 index 0000000..f2f5ba6 Binary files /dev/null and b/.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.stex differ diff --git a/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.md5 b/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.md5 new file mode 100644 index 0000000..a2a2095 --- /dev/null +++ b/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.md5 @@ -0,0 +1,3 @@ +source_md5="1f67e1a106d3e747fc1d6f27a0fbb18f" +dest_md5="b65e468a3bf3612b922b9b62282a5122" + diff --git a/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.stex b/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.stex new file mode 100644 index 0000000..bee57a3 Binary files /dev/null and b/.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.stex differ diff --git a/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.md5 b/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.md5 new file mode 100644 index 0000000..999f7d0 --- /dev/null +++ b/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.md5 @@ -0,0 +1,3 @@ +source_md5="378b99e4a48283953967b74922605f27" +dest_md5="82060685affa11faa5e98ad630f3edb8" + diff --git a/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.stex b/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.stex new file mode 100644 index 0000000..d0feb96 Binary files /dev/null and b/.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.stex differ diff --git a/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.md5 b/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.md5 new file mode 100644 index 0000000..bef7c67 --- /dev/null +++ b/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.md5 @@ -0,0 +1,3 @@ +source_md5="f078c04803ace41f58a424eaff4f6ab0" +dest_md5="3b37cab8afe66418289df521c061f54f" + diff --git a/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.stex b/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.stex new file mode 100644 index 0000000..08316b1 Binary files /dev/null and b/.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.stex differ diff --git a/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.md5 b/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.md5 new file mode 100644 index 0000000..c433478 --- /dev/null +++ b/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.md5 @@ -0,0 +1,3 @@ +source_md5="756554533b22efde4b6d643ddab12224" +dest_md5="f763495515f29f18b2f33dca17347598" + diff --git a/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.stex b/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.stex new file mode 100644 index 0000000..269398e Binary files /dev/null and b/.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.stex differ diff --git a/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.md5 b/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.md5 new file mode 100644 index 0000000..514e3c2 --- /dev/null +++ b/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.md5 @@ -0,0 +1,3 @@ +source_md5="ce60125d5b1639a3b88d652aea6ca0c3" +dest_md5="3f6b5d58e309ff9b5798315e37d35329" + diff --git a/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.sample b/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.sample new file mode 100644 index 0000000..3d97de8 Binary files /dev/null and b/.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.sample differ diff --git a/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.md5 b/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.md5 index 7b61c3e..430952b 100644 --- a/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.md5 +++ b/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.md5 @@ -1,3 +1,3 @@ -source_md5="47313fa4c47a9963fddd764e1ec6e4a8" -dest_md5="2ded9e7f9060e2b530aab678b135fc5b" +source_md5="bda589ff2d7e77b9ab93fd84208c118e" +dest_md5="a4ae5eaed2f51e7425759dd679bf3aed" diff --git a/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex b/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex index 3ca6461..cc9f516 100644 Binary files a/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex and b/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex differ diff --git a/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.md5 b/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.md5 new file mode 100644 index 0000000..8c1672d --- /dev/null +++ b/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.md5 @@ -0,0 +1,3 @@ +source_md5="1fabfb3967ed03567fcd6956a1f62b8b" +dest_md5="4f2dace244d98083ec7ee6b18d5930cd" + diff --git a/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.stex b/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.stex new file mode 100644 index 0000000..6089995 Binary files /dev/null and b/.import/idle.png-2bbf8a5ea1d50c72f11b88a35fb26337.stex differ diff --git a/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.md5 b/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.md5 new file mode 100644 index 0000000..b190980 --- /dev/null +++ b/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.md5 @@ -0,0 +1,3 @@ +source_md5="f15f2f75683475fb46217cb108a91d44" +dest_md5="9c68996fffebbcd3dfa4c286498b3934" + diff --git a/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.sample b/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.sample new file mode 100644 index 0000000..36ba31f Binary files /dev/null and b/.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.sample differ diff --git a/.import/p1.png-c1d994578c830421642f80b075591df2.md5 b/.import/p1.png-c1d994578c830421642f80b075591df2.md5 new file mode 100644 index 0000000..6593a64 --- /dev/null +++ b/.import/p1.png-c1d994578c830421642f80b075591df2.md5 @@ -0,0 +1,3 @@ +source_md5="e9b75e2b4775be60e46939d9abf462dc" +dest_md5="fb3f5fdc25120874b121fd95fa7f22a2" + diff --git a/.import/p1.png-c1d994578c830421642f80b075591df2.stex b/.import/p1.png-c1d994578c830421642f80b075591df2.stex new file mode 100644 index 0000000..75edbb5 Binary files /dev/null and b/.import/p1.png-c1d994578c830421642f80b075591df2.stex differ diff --git a/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.md5 b/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.md5 new file mode 100644 index 0000000..18fbaa5 --- /dev/null +++ b/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.md5 @@ -0,0 +1,3 @@ +source_md5="743e7b8e46c001d013bab778821a3df5" +dest_md5="797f949f91dceb488f541645fd7672a9" + diff --git a/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.stex b/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.stex new file mode 100644 index 0000000..c9271ca Binary files /dev/null and b/.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.stex differ diff --git a/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.md5 b/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.md5 new file mode 100644 index 0000000..f946ecd --- /dev/null +++ b/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.md5 @@ -0,0 +1,3 @@ +source_md5="7f6e8904845ad5c56505790a380306cb" +dest_md5="b1a41e198f777f1ec236267449c58055" + diff --git a/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.stex b/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.stex new file mode 100644 index 0000000..58bce1c Binary files /dev/null and b/.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.stex differ diff --git a/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.md5 b/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.md5 new file mode 100644 index 0000000..ddd1fa6 --- /dev/null +++ b/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.md5 @@ -0,0 +1,3 @@ +source_md5="6176ce54d9fd489fb0d0c5699fce3a86" +dest_md5="94570426a19e1ba85e87d7e035cd5ba7" + diff --git a/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.stex b/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.stex new file mode 100644 index 0000000..01881ea Binary files /dev/null and b/.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.stex differ diff --git a/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.md5 b/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.md5 new file mode 100644 index 0000000..17e1bda --- /dev/null +++ b/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.md5 @@ -0,0 +1,3 @@ +source_md5="2ecdf73c4fefd5b1de0a4849f0fda76e" +dest_md5="3db007d0db65c47bbb801035d49175d2" + diff --git a/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.sample b/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.sample new file mode 100644 index 0000000..50016ee Binary files /dev/null and b/.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.sample differ diff --git a/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.md5 b/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.md5 new file mode 100644 index 0000000..f5f25d4 --- /dev/null +++ b/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.md5 @@ -0,0 +1,3 @@ +source_md5="040cc6becf207c235a777e3c062de29d" +dest_md5="0c3b173675089816d93139315a8ec45a" + diff --git a/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.stex b/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.stex new file mode 100644 index 0000000..bb4b223 Binary files /dev/null and b/.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.stex differ diff --git a/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.md5 b/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.md5 new file mode 100644 index 0000000..65ea647 --- /dev/null +++ b/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.md5 @@ -0,0 +1,3 @@ +source_md5="39e6f61641ebf537ab27738ace8de772" +dest_md5="80d0a055347737d014c477e0f7132471" + diff --git a/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.stex b/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.stex new file mode 100644 index 0000000..9d56cc2 Binary files /dev/null and b/.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.stex differ diff --git a/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.md5 b/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.md5 new file mode 100644 index 0000000..5cc50d0 --- /dev/null +++ b/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.md5 @@ -0,0 +1,3 @@ +source_md5="03631db2417f5a1aa03ae752fc5310a8" +dest_md5="7946f7e060d65f7f8682c41d8dd47357" + diff --git a/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.stex b/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.stex new file mode 100644 index 0000000..5c8b9bd Binary files /dev/null and b/.import/platform.png-c73f1310fbd4e31409c35045b2535d99.stex differ diff --git a/.import/player.png-7e0e35de6dba839f26194e685a1466d3.md5 b/.import/player.png-7e0e35de6dba839f26194e685a1466d3.md5 new file mode 100644 index 0000000..8248d92 --- /dev/null +++ b/.import/player.png-7e0e35de6dba839f26194e685a1466d3.md5 @@ -0,0 +1,3 @@ +source_md5="fa86c885e1015501b7b0eceac53f507b" +dest_md5="a5f828f1b048cca0a79e03ea47f819b2" + diff --git a/.import/player.png-7e0e35de6dba839f26194e685a1466d3.stex b/.import/player.png-7e0e35de6dba839f26194e685a1466d3.stex new file mode 100644 index 0000000..b7f5081 Binary files /dev/null and b/.import/player.png-7e0e35de6dba839f26194e685a1466d3.stex differ diff --git a/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.md5 b/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.md5 new file mode 100644 index 0000000..719c573 --- /dev/null +++ b/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.md5 @@ -0,0 +1,3 @@ +source_md5="5e40c71ffa5f89c13b0836a0b2b6454e" +dest_md5="7197debab5b5544251ca3d87f3fb2a7f" + diff --git a/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.stex b/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.stex new file mode 100644 index 0000000..b319467 Binary files /dev/null and b/.import/player_body.png-e7fa9006e025b36ab2d2d91298124905.stex differ diff --git a/.import/png.png-ae222b277f75a3b704952b45afab4b90.md5 b/.import/png.png-ae222b277f75a3b704952b45afab4b90.md5 new file mode 100644 index 0000000..16f5007 --- /dev/null +++ b/.import/png.png-ae222b277f75a3b704952b45afab4b90.md5 @@ -0,0 +1,3 @@ +source_md5="221a0280689ef2e8d076495fa9867191" +dest_md5="65f36f9ba5467b38c0f1cee41cf098e9" + diff --git a/.import/png.png-ae222b277f75a3b704952b45afab4b90.stex b/.import/png.png-ae222b277f75a3b704952b45afab4b90.stex new file mode 100644 index 0000000..1d6f78e Binary files /dev/null and b/.import/png.png-ae222b277f75a3b704952b45afab4b90.stex differ diff --git a/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.md5 b/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.md5 new file mode 100644 index 0000000..91f6949 --- /dev/null +++ b/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.md5 @@ -0,0 +1,3 @@ +source_md5="0c39635a62587df7c2eb16d89cd9eb39" +dest_md5="63bb756e03ae3d9d923307321bdb2146" + diff --git a/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.stex b/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.stex new file mode 100644 index 0000000..1194bb4 Binary files /dev/null and b/.import/run.png-fe455861d618268d9b57d5ebc3bad5ec.stex differ diff --git a/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.md5 b/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.md5 new file mode 100644 index 0000000..65b85fd --- /dev/null +++ b/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.md5 @@ -0,0 +1,3 @@ +source_md5="f5ba9e194efe60112086c39a99012792" +dest_md5="738c709aaec08ff2ac8a7e1a1a617479" + diff --git a/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.stex b/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.stex new file mode 100644 index 0000000..f45978c Binary files /dev/null and b/.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.stex differ diff --git a/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.md5 b/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.md5 new file mode 100644 index 0000000..adb9d87 --- /dev/null +++ b/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.md5 @@ -0,0 +1,3 @@ +source_md5="5c1909840119124623da414167fad697" +dest_md5="e23e0c00233c31ae5963fb0dde2ff0c8" + diff --git a/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.sample b/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.sample new file mode 100644 index 0000000..39e8b2f Binary files /dev/null and b/.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.sample differ diff --git a/.import/splash.png-929ed8a00b89ba36c51789452f874c77.md5 b/.import/splash.png-929ed8a00b89ba36c51789452f874c77.md5 new file mode 100644 index 0000000..8061723 --- /dev/null +++ b/.import/splash.png-929ed8a00b89ba36c51789452f874c77.md5 @@ -0,0 +1,3 @@ +source_md5="3e5ff23914c786de2bff2fd320075cf9" +dest_md5="738c709aaec08ff2ac8a7e1a1a617479" + diff --git a/.import/splash.png-929ed8a00b89ba36c51789452f874c77.stex b/.import/splash.png-929ed8a00b89ba36c51789452f874c77.stex new file mode 100644 index 0000000..f45978c Binary files /dev/null and b/.import/splash.png-929ed8a00b89ba36c51789452f874c77.stex differ diff --git a/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.md5 b/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.md5 new file mode 100644 index 0000000..a2a58cf --- /dev/null +++ b/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.md5 @@ -0,0 +1,3 @@ +source_md5="c8d24785562a9d26a2e056bbdf1bb853" +dest_md5="6422fae6a5ca317bca30c382d473ea9b" + diff --git a/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.stex b/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.stex new file mode 100644 index 0000000..a95c527 Binary files /dev/null and b/.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.stex differ diff --git a/.import/tile.png-801f14104a51997c7e2366d892ec377e.md5 b/.import/tile.png-801f14104a51997c7e2366d892ec377e.md5 new file mode 100644 index 0000000..f4fa0ac --- /dev/null +++ b/.import/tile.png-801f14104a51997c7e2366d892ec377e.md5 @@ -0,0 +1,3 @@ +source_md5="5c3b1bec3db3ac53c9b21a5bb3b252ee" +dest_md5="d4dbc0a04eea6ebc83b1bedbc0b517ae" + diff --git a/.import/tile.png-801f14104a51997c7e2366d892ec377e.stex b/.import/tile.png-801f14104a51997c7e2366d892ec377e.stex new file mode 100644 index 0000000..a07f0e8 Binary files /dev/null and b/.import/tile.png-801f14104a51997c7e2366d892ec377e.stex differ diff --git a/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.md5 b/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.md5 new file mode 100644 index 0000000..433d34b --- /dev/null +++ b/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.md5 @@ -0,0 +1,3 @@ +source_md5="23277c8b16a3c4da788d00600973bbb6" +dest_md5="f68408d547ed60286bb1fd640d772b57" + diff --git a/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.stex b/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.stex new file mode 100644 index 0000000..9437f96 Binary files /dev/null and b/.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.stex differ diff --git a/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.md5 b/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.md5 new file mode 100644 index 0000000..e9002bb --- /dev/null +++ b/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.md5 @@ -0,0 +1,3 @@ +source_md5="edc70082ba9172f17f4ce143a0277bae" +dest_md5="a9e91af2f1e654d712edf68769af2650" + diff --git a/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.stex b/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.stex new file mode 100644 index 0000000..550955e Binary files /dev/null and b/.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.stex differ diff --git a/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.md5 b/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.md5 new file mode 100644 index 0000000..c53334b --- /dev/null +++ b/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.md5 @@ -0,0 +1,3 @@ +source_md5="46ed6e39305b2d05718ad193cb17da91" +dest_md5="01c80a62a65b764cdcce815b0e1e6bc4" + diff --git a/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.stex b/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.stex new file mode 100644 index 0000000..f8fcb25 Binary files /dev/null and b/.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.stex differ diff --git a/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.md5 b/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.md5 new file mode 100644 index 0000000..96711cc --- /dev/null +++ b/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.md5 @@ -0,0 +1,3 @@ +source_md5="ff7bcdf783741aa16b68b1213bdc21b5" +dest_md5="0c7ef1f1d481859be64a4f6b8114e888" + diff --git a/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.stex b/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.stex new file mode 100644 index 0000000..9f754c3 Binary files /dev/null and b/.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.stex differ diff --git a/export_presets.cfg b/export_presets.cfg new file mode 100644 index 0000000..75f61c3 --- /dev/null +++ b/export_presets.cfg @@ -0,0 +1,290 @@ +[preset.0] + +name="Linux/X11" +platform="Linux/X11" +runnable=true +custom_features="" +export_filter="all_resources" +include_filter="" +exclude_filter="" +export_path="release/linux/runner" +script_export_mode=1 +script_encryption_key="" + +[preset.0.options] + +custom_template/debug="" +custom_template/release="" +binary_format/64_bits=true +binary_format/embed_pck=false +texture_format/bptc=false +texture_format/s3tc=true +texture_format/etc=false +texture_format/etc2=false +texture_format/no_bptc_fallbacks=true + +[preset.1] + +name="Windows Desktop" +platform="Windows Desktop" +runnable=true +custom_features="" +export_filter="all_resources" +include_filter="" +exclude_filter="" +export_path="release/windows/runner.exe" +script_export_mode=1 +script_encryption_key="" + +[preset.1.options] + +custom_template/debug="" +custom_template/release="" +binary_format/64_bits=true +binary_format/embed_pck=false +texture_format/bptc=false +texture_format/s3tc=true +texture_format/etc=false +texture_format/etc2=false +texture_format/no_bptc_fallbacks=true +codesign/enable=false +codesign/identity="" +codesign/password="" +codesign/timestamp=true +codesign/timestamp_server_url="" +codesign/digest_algorithm=1 +codesign/description="" +codesign/custom_options=PoolStringArray( ) +application/icon="" +application/file_version="" +application/product_version="" +application/company_name="" +application/product_name="" +application/file_description="" +application/copyright="" +application/trademarks="" + +[preset.2] + +name="HTML5" +platform="HTML5" +runnable=true +custom_features="" +export_filter="all_resources" +include_filter="" +exclude_filter="" +export_path="release/web/runner.html" +script_export_mode=1 +script_encryption_key="" + +[preset.2.options] + +custom_template/debug="" +custom_template/release="" +variant/export_type=0 +vram_texture_compression/for_desktop=true +vram_texture_compression/for_mobile=false +html/custom_html_shell="" +html/head_include="" +html/canvas_resize_policy=2 +html/experimental_virtual_keyboard=false + +[preset.3] + +name="Android" +platform="Android" +runnable=true +custom_features="" +export_filter="all_resources" +include_filter="" +exclude_filter="" +export_path="release/android/Runner.apk" +script_export_mode=1 +script_encryption_key="" + +[preset.3.options] + +custom_template/debug="" +custom_template/release="" +custom_template/use_custom_build=false +custom_template/export_format=0 +architectures/armeabi-v7a=true +architectures/arm64-v8a=true +architectures/x86=false +architectures/x86_64=false +keystore/debug="" +keystore/debug_user="" +keystore/debug_password="" +keystore/release="/home/piyush/Projects/Runner/release.keystore" +keystore/release_user="Piyush Raj" +keystore/release_password="p0mch1ck#" +one_click_deploy/clear_previous_install=false +version/code=1 +version/name="1.0" +package/unique_name="sng.urrsm.$genname" +package/name="Runner" +package/signed=true +launcher_icons/main_192x192="" +launcher_icons/adaptive_foreground_432x432="" +launcher_icons/adaptive_background_432x432="" +graphics/32_bits_framebuffer=true +graphics/opengl_debug=false +xr_features/xr_mode=0 +xr_features/degrees_of_freedom=0 +xr_features/hand_tracking=0 +xr_features/focus_awareness=false +screen/immersive_mode=true +screen/support_small=true +screen/support_normal=true +screen/support_large=true +screen/support_xlarge=true +command_line/extra_args="" +apk_expansion/enable=false +apk_expansion/SALT="" +apk_expansion/public_key="" +permissions/custom_permissions=PoolStringArray( ) +permissions/access_checkin_properties=false +permissions/access_coarse_location=false +permissions/access_fine_location=false +permissions/access_location_extra_commands=false +permissions/access_mock_location=false +permissions/access_network_state=false +permissions/access_surface_flinger=false +permissions/access_wifi_state=false +permissions/account_manager=false +permissions/add_voicemail=false +permissions/authenticate_accounts=false +permissions/battery_stats=false +permissions/bind_accessibility_service=false +permissions/bind_appwidget=false +permissions/bind_device_admin=false +permissions/bind_input_method=false +permissions/bind_nfc_service=false +permissions/bind_notification_listener_service=false +permissions/bind_print_service=false +permissions/bind_remoteviews=false +permissions/bind_text_service=false +permissions/bind_vpn_service=false +permissions/bind_wallpaper=false +permissions/bluetooth=false +permissions/bluetooth_admin=false +permissions/bluetooth_privileged=false +permissions/brick=false +permissions/broadcast_package_removed=false +permissions/broadcast_sms=false +permissions/broadcast_sticky=false +permissions/broadcast_wap_push=false +permissions/call_phone=false +permissions/call_privileged=false +permissions/camera=false +permissions/capture_audio_output=false +permissions/capture_secure_video_output=false +permissions/capture_video_output=false +permissions/change_component_enabled_state=false +permissions/change_configuration=false +permissions/change_network_state=false +permissions/change_wifi_multicast_state=false +permissions/change_wifi_state=false +permissions/clear_app_cache=false +permissions/clear_app_user_data=false +permissions/control_location_updates=false +permissions/delete_cache_files=false +permissions/delete_packages=false +permissions/device_power=false +permissions/diagnostic=false +permissions/disable_keyguard=false +permissions/dump=false +permissions/expand_status_bar=false +permissions/factory_test=false +permissions/flashlight=false +permissions/force_back=false +permissions/get_accounts=false +permissions/get_package_size=false +permissions/get_tasks=false +permissions/get_top_activity_info=false +permissions/global_search=false +permissions/hardware_test=false +permissions/inject_events=false +permissions/install_location_provider=false +permissions/install_packages=false +permissions/install_shortcut=false +permissions/internal_system_window=false +permissions/internet=false +permissions/kill_background_processes=false +permissions/location_hardware=false +permissions/manage_accounts=false +permissions/manage_app_tokens=false +permissions/manage_documents=false +permissions/master_clear=false +permissions/media_content_control=false +permissions/modify_audio_settings=false +permissions/modify_phone_state=false +permissions/mount_format_filesystems=false +permissions/mount_unmount_filesystems=false +permissions/nfc=false +permissions/persistent_activity=false +permissions/process_outgoing_calls=false +permissions/read_calendar=false +permissions/read_call_log=false +permissions/read_contacts=false +permissions/read_external_storage=false +permissions/read_frame_buffer=false +permissions/read_history_bookmarks=false +permissions/read_input_state=false +permissions/read_logs=false +permissions/read_phone_state=false +permissions/read_profile=false +permissions/read_sms=false +permissions/read_social_stream=false +permissions/read_sync_settings=false +permissions/read_sync_stats=false +permissions/read_user_dictionary=false +permissions/reboot=false +permissions/receive_boot_completed=false +permissions/receive_mms=false +permissions/receive_sms=false +permissions/receive_wap_push=false +permissions/record_audio=false +permissions/reorder_tasks=false +permissions/restart_packages=false +permissions/send_respond_via_message=false +permissions/send_sms=false +permissions/set_activity_watcher=false +permissions/set_alarm=false +permissions/set_always_finish=false +permissions/set_animation_scale=false +permissions/set_debug_app=false +permissions/set_orientation=false +permissions/set_pointer_speed=false +permissions/set_preferred_applications=false +permissions/set_process_limit=false +permissions/set_time=false +permissions/set_time_zone=false +permissions/set_wallpaper=false +permissions/set_wallpaper_hints=false +permissions/signal_persistent_processes=false +permissions/status_bar=false +permissions/subscribed_feeds_read=false +permissions/subscribed_feeds_write=false +permissions/system_alert_window=false +permissions/transmit_ir=false +permissions/uninstall_shortcut=false +permissions/update_device_stats=false +permissions/use_credentials=false +permissions/use_sip=false +permissions/vibrate=false +permissions/wake_lock=false +permissions/write_apn_settings=false +permissions/write_calendar=false +permissions/write_call_log=false +permissions/write_contacts=false +permissions/write_external_storage=false +permissions/write_gservices=false +permissions/write_history_bookmarks=false +permissions/write_profile=false +permissions/write_secure_settings=false +permissions/write_settings=false +permissions/write_sms=false +permissions/write_social_stream=false +permissions/write_sync_settings=false +permissions/write_user_dictionary=false diff --git a/icon.png b/icon.png index c98fbb6..8527744 100644 Binary files a/icon.png and b/icon.png differ diff --git a/project.godot b/project.godot index 1883412..4acd5cf 100644 --- a/project.godot +++ b/project.godot @@ -8,14 +8,145 @@ config_version=4 +_global_script_classes=[ { +"base": "KinematicBody2D", +"class": "Actor", +"language": "GDScript", +"path": "res://src/actors/Actor.gd" +}, { +"base": "Area2D", +"class": "Brick", +"language": "GDScript", +"path": "res://src/objects/Brick.gd" +}, { +"base": "RigidBody2D", +"class": "Bullet", +"language": "GDScript", +"path": "res://src/objects/Bullet.gd" +}, { +"base": "KinematicBody2D", +"class": "Enemy", +"language": "GDScript", +"path": "res://src/actors/Enemy.gd" +}, { +"base": "Node2D", +"class": "Game", +"language": "GDScript", +"path": "res://src/scenes/Game.gd" +}, { +"base": "Control", +"class": "GameOverOrWon", +"language": "GDScript", +"path": "res://src/scenes/GameOver_Won.gd" +}, { +"base": "Position2D", +"class": "Gun", +"language": "GDScript", +"path": "res://src/objects/Gun.gd" +}, { +"base": "CanvasLayer", +"class": "Hud", +"language": "GDScript", +"path": "res://src/layers/Hud.gd" +}, { +"base": "Area2D", +"class": "MagicBox", +"language": "GDScript", +"path": "res://src/objects/MagicBox.gd" +}, { +"base": "Control", +"class": "MainMenu", +"language": "GDScript", +"path": "res://src/scenes/MainMenu.gd" +}, { +"base": "KinematicBody2D", +"class": "Player", +"language": "GDScript", +"path": "res://src/actors/Player.gd" +} ] +_global_script_class_icons={ +"Actor": "", +"Brick": "", +"Bullet": "", +"Enemy": "", +"Game": "", +"GameOverOrWon": "", +"Gun": "", +"Hud": "", +"MagicBox": "", +"MainMenu": "", +"Player": "" +} + [application] config/name="Runner" +run/main_scene="res://src/scenes/MainMenu.tscn" +boot_splash/image="res://splash.png" +boot_splash/fullsize=false +boot_splash/use_filter=false +boot_splash/bg_color=Color( 0.0470588, 0.498039, 0.6, 1 ) config/icon="res://icon.png" +[autoload] + +Global="*res://src/global/Global.tscn" + +[display] + +window/stretch/mode="viewport" +window/stretch/aspect="keep" + +[gui] + +theme/custom="res://samagri/theme/user_interface.tres" + +[input] + +move_right={ +"deadzone": 0.5, +"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":16777233,"unicode":0,"echo":false,"script":null) +, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":68,"unicode":0,"echo":false,"script":null) + ] +} +move_left={ +"deadzone": 0.5, +"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":16777231,"unicode":0,"echo":false,"script":null) +, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":65,"unicode":0,"echo":false,"script":null) + ] +} +jump={ +"deadzone": 0.5, +"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":16777232,"unicode":0,"echo":false,"script":null) +, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":87,"unicode":0,"echo":false,"script":null) + ] +} +shoot={ +"deadzone": 0.5, +"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":16777238,"unicode":0,"echo":false,"script":null) +, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":75,"unicode":0,"echo":false,"script":null) + ] +} +pause={ +"deadzone": 0.5, +"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":80,"unicode":0,"echo":false,"script":null) + ] +} + +[layer_names] + +2d_physics/layer_1="Player" +2d_physics/layer_2="Enemy" +2d_physics/layer_3="Brick" +2d_physics/layer_4="MagicBox" +2d_physics/layer_5="Level" +2d_physics/layer_6="Killer" +2d_physics/layer_7="Bullet" + [physics] common/enable_pause_aware_picking=true +2d/default_gravity=900 [rendering] diff --git a/release/android/Runner.apk b/release/android/Runner.apk new file mode 100644 index 0000000..8b4e6ba Binary files /dev/null and b/release/android/Runner.apk differ diff --git a/release/linux/runner b/release/linux/runner new file mode 100755 index 0000000..79d88b6 Binary files /dev/null and b/release/linux/runner differ diff --git a/release/linux/runner.pck b/release/linux/runner.pck new file mode 100644 index 0000000..5e22c19 Binary files /dev/null and b/release/linux/runner.pck differ diff --git a/release/web/favicon.png b/release/web/favicon.png new file mode 100644 index 0000000..679598c Binary files /dev/null and b/release/web/favicon.png differ diff --git a/release/web/favicon.png.import b/release/web/favicon.png.import new file mode 100644 index 0000000..46101bf --- /dev/null +++ b/release/web/favicon.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/favicon.png-67c6e2983692f67236160725530a2740.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://release/web/favicon.png" +dest_files=[ "res://.import/favicon.png-67c6e2983692f67236160725530a2740.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/release/web/runner.audio.worklet.js b/release/web/runner.audio.worklet.js new file mode 100644 index 0000000..6b3f80c --- /dev/null +++ b/release/web/runner.audio.worklet.js @@ -0,0 +1,186 @@ +/*************************************************************************/ +/* audio.worklet.js */ +/*************************************************************************/ +/* This file is part of: */ +/* GODOT ENGINE */ +/* https://godotengine.org */ +/*************************************************************************/ +/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */ +/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */ +/* */ +/* Permission is hereby granted, free of charge, to any person obtaining */ +/* a copy of this software and associated documentation files (the */ +/* "Software"), to deal in the Software without restriction, including */ +/* without limitation the rights to use, copy, modify, merge, publish, */ +/* distribute, sublicense, and/or sell copies of the Software, and to */ +/* permit persons to whom the Software is furnished to do so, subject to */ +/* the following conditions: */ +/* */ +/* The above copyright notice and this permission notice shall be */ +/* included in all copies or substantial portions of the Software. */ +/* */ +/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */ +/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */ +/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/ +/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */ +/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */ +/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */ +/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ +/*************************************************************************/ + +class RingBuffer { + constructor(p_buffer, p_state) { + this.buffer = p_buffer; + this.avail = p_state; + this.rpos = 0; + this.wpos = 0; + } + + data_left() { + return Atomics.load(this.avail, 0); + } + + space_left() { + return this.buffer.length - this.data_left(); + } + + read(output) { + const size = this.buffer.length; + let from = 0; + let to_write = output.length; + if (this.rpos + to_write > size) { + const high = size - this.rpos; + output.set(this.buffer.subarray(this.rpos, size)); + from = high; + to_write -= high; + this.rpos = 0; + } + output.set(this.buffer.subarray(this.rpos, this.rpos + to_write), from); + this.rpos += to_write; + Atomics.add(this.avail, 0, -output.length); + Atomics.notify(this.avail, 0); + } + + write(p_buffer) { + const to_write = p_buffer.length; + const mw = this.buffer.length - this.wpos; + if (mw >= to_write) { + this.buffer.set(p_buffer, this.wpos); + } else { + const high = p_buffer.subarray(0, to_write - mw); + const low = p_buffer.subarray(to_write - mw); + this.buffer.set(high, this.wpos); + this.buffer.set(low); + } + let diff = to_write; + if (this.wpos + diff >= this.buffer.length) { + diff -= this.buffer.length; + } + this.wpos += diff; + Atomics.add(this.avail, 0, to_write); + Atomics.notify(this.avail, 0); + } +} + +class GodotProcessor extends AudioWorkletProcessor { + constructor() { + super(); + this.running = true; + this.lock = null; + this.notifier = null; + this.output = null; + this.output_buffer = new Float32Array(); + this.input = null; + this.input_buffer = new Float32Array(); + this.port.onmessage = (event) => { + const cmd = event.data['cmd']; + const data = event.data['data']; + this.parse_message(cmd, data); + }; + } + + process_notify() { + Atomics.add(this.notifier, 0, 1); + Atomics.notify(this.notifier, 0); + } + + parse_message(p_cmd, p_data) { + if (p_cmd === 'start' && p_data) { + const state = p_data[0]; + let idx = 0; + this.lock = state.subarray(idx, ++idx); + this.notifier = state.subarray(idx, ++idx); + const avail_in = state.subarray(idx, ++idx); + const avail_out = state.subarray(idx, ++idx); + this.input = new RingBuffer(p_data[1], avail_in); + this.output = new RingBuffer(p_data[2], avail_out); + } else if (p_cmd === 'stop') { + this.runing = false; + this.output = null; + this.input = null; + } + } + + static array_has_data(arr) { + return arr.length && arr[0].length && arr[0][0].length; + } + + process(inputs, outputs, parameters) { + if (!this.running) { + return false; // Stop processing. + } + if (this.output === null) { + return true; // Not ready yet, keep processing. + } + const process_input = GodotProcessor.array_has_data(inputs); + if (process_input) { + const input = inputs[0]; + const chunk = input[0].length * input.length; + if (this.input_buffer.length !== chunk) { + this.input_buffer = new Float32Array(chunk); + } + if (this.input.space_left() >= chunk) { + GodotProcessor.write_input(this.input_buffer, input); + this.input.write(this.input_buffer); + } else { + this.port.postMessage('Input buffer is full! Skipping input frame.'); + } + } + const process_output = GodotProcessor.array_has_data(outputs); + if (process_output) { + const output = outputs[0]; + const chunk = output[0].length * output.length; + if (this.output_buffer.length !== chunk) { + this.output_buffer = new Float32Array(chunk); + } + if (this.output.data_left() >= chunk) { + this.output.read(this.output_buffer); + GodotProcessor.write_output(output, this.output_buffer); + } else { + this.port.postMessage('Output buffer has not enough frames! Skipping output frame.'); + } + } + this.process_notify(); + return true; + } + + static write_output(dest, source) { + const channels = dest.length; + for (let ch = 0; ch < channels; ch++) { + for (let sample = 0; sample < dest[ch].length; sample++) { + dest[ch][sample] = source[sample * channels + ch]; + } + } + } + + static write_input(dest, source) { + const channels = source.length; + for (let ch = 0; ch < channels; ch++) { + for (let sample = 0; sample < source[ch].length; sample++) { + dest[sample * channels + ch] = source[ch][sample]; + } + } + } +} + +registerProcessor('godot-processor', GodotProcessor); diff --git a/release/web/runner.html b/release/web/runner.html new file mode 100644 index 0000000..759a02e --- /dev/null +++ b/release/web/runner.html @@ -0,0 +1,246 @@ + + + + + + + Runner + + + + + + HTML5 canvas appears to be unsupported in the current browser.
+ Please try updating or use a different browser. +
+
+ + + +
+ + + + + + diff --git a/release/web/runner.js b/release/web/runner.js new file mode 100644 index 0000000..62c9e05 --- /dev/null +++ b/release/web/runner.js @@ -0,0 +1,772 @@ + +var Godot = (function() { + var _scriptDir = typeof document !== 'undefined' && document.currentScript ? document.currentScript.src : undefined; + + return ( +function(Godot) { + Godot = Godot || {}; + +var Module=typeof Godot!=="undefined"?Godot:{};var readyPromiseResolve,readyPromiseReject;Module["ready"]=new Promise(function(resolve,reject){readyPromiseResolve=resolve;readyPromiseReject=reject});var moduleOverrides={};var key;for(key in Module){if(Module.hasOwnProperty(key)){moduleOverrides[key]=Module[key]}}var arguments_=[];var thisProgram="./this.program";var quit_=function(status,toThrow){throw toThrow};var ENVIRONMENT_IS_WEB=false;var ENVIRONMENT_IS_WORKER=false;var ENVIRONMENT_IS_NODE=false;var ENVIRONMENT_IS_SHELL=false;ENVIRONMENT_IS_WEB=typeof window==="object";ENVIRONMENT_IS_WORKER=typeof importScripts==="function";ENVIRONMENT_IS_NODE=typeof process==="object"&&typeof process.versions==="object"&&typeof process.versions.node==="string";ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;var scriptDirectory="";function locateFile(path){if(Module["locateFile"]){return Module["locateFile"](path,scriptDirectory)}return scriptDirectory+path}var read_,readAsync,readBinary,setWindowTitle;if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){if(ENVIRONMENT_IS_WORKER){scriptDirectory=self.location.href}else if(typeof document!=="undefined"&&document.currentScript){scriptDirectory=document.currentScript.src}if(_scriptDir){scriptDirectory=_scriptDir}if(scriptDirectory.indexOf("blob:")!==0){scriptDirectory=scriptDirectory.substr(0,scriptDirectory.lastIndexOf("/")+1)}else{scriptDirectory=""}{read_=function(url){var xhr=new XMLHttpRequest;xhr.open("GET",url,false);xhr.send(null);return xhr.responseText};if(ENVIRONMENT_IS_WORKER){readBinary=function(url){var xhr=new XMLHttpRequest;xhr.open("GET",url,false);xhr.responseType="arraybuffer";xhr.send(null);return new Uint8Array(xhr.response)}}readAsync=function(url,onload,onerror){var xhr=new XMLHttpRequest;xhr.open("GET",url,true);xhr.responseType="arraybuffer";xhr.onload=function(){if(xhr.status==200||xhr.status==0&&xhr.response){onload(xhr.response);return}onerror()};xhr.onerror=onerror;xhr.send(null)}}setWindowTitle=function(title){document.title=title}}else{}var out=Module["print"]||console.log.bind(console);var err=Module["printErr"]||console.warn.bind(console);for(key in moduleOverrides){if(moduleOverrides.hasOwnProperty(key)){Module[key]=moduleOverrides[key]}}moduleOverrides=null;if(Module["arguments"])arguments_=Module["arguments"];if(Module["thisProgram"])thisProgram=Module["thisProgram"];if(Module["quit"])quit_=Module["quit"];var STACK_ALIGN=16;function alignMemory(size,factor){if(!factor)factor=STACK_ALIGN;return Math.ceil(size/factor)*factor}function warnOnce(text){if(!warnOnce.shown)warnOnce.shown={};if(!warnOnce.shown[text]){warnOnce.shown[text]=1;err(text)}}var tempRet0=0;var setTempRet0=function(value){tempRet0=value};var getTempRet0=function(){return tempRet0};var wasmBinary;if(Module["wasmBinary"])wasmBinary=Module["wasmBinary"];var noExitRuntime=Module["noExitRuntime"]||false;if(typeof WebAssembly!=="object"){abort("no native wasm support detected")}function setValue(ptr,value,type,noSafe){type=type||"i8";if(type.charAt(type.length-1)==="*")type="i32";switch(type){case"i1":HEAP8[ptr>>0]=value;break;case"i8":HEAP8[ptr>>0]=value;break;case"i16":HEAP16[ptr>>1]=value;break;case"i32":HEAP32[ptr>>2]=value;break;case"i64":tempI64=[value>>>0,(tempDouble=value,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[ptr>>2]=tempI64[0],HEAP32[ptr+4>>2]=tempI64[1];break;case"float":HEAPF32[ptr>>2]=value;break;case"double":HEAPF64[ptr>>3]=value;break;default:abort("invalid type for setValue: "+type)}}function getValue(ptr,type,noSafe){type=type||"i8";if(type.charAt(type.length-1)==="*")type="i32";switch(type){case"i1":return HEAP8[ptr>>0];case"i8":return HEAP8[ptr>>0];case"i16":return HEAP16[ptr>>1];case"i32":return HEAP32[ptr>>2];case"i64":return HEAP32[ptr>>2];case"float":return HEAPF32[ptr>>2];case"double":return HEAPF64[ptr>>3];default:abort("invalid type for getValue: "+type)}return null}var wasmMemory;var ABORT=false;var EXITSTATUS;function assert(condition,text){if(!condition){abort("Assertion failed: "+text)}}function getCFunc(ident){var func=Module["_"+ident];assert(func,"Cannot call unknown function "+ident+", make sure it is exported");return func}function ccall(ident,returnType,argTypes,args,opts){var toC={"string":function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0){var len=(str.length<<2)+1;ret=stackAlloc(len);stringToUTF8(str,ret,len)}return ret},"array":function(arr){var ret=stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}};function convertReturnValue(ret){if(returnType==="string")return UTF8ToString(ret);if(returnType==="boolean")return Boolean(ret);return ret}var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i=endIdx))++endPtr;if(endPtr-idx>16&&heap.subarray&&UTF8Decoder){return UTF8Decoder.decode(heap.subarray(idx,endPtr))}else{var str="";while(idx>10,56320|ch&1023)}}}return str}function UTF8ToString(ptr,maxBytesToRead){return ptr?UTF8ArrayToString(HEAPU8,ptr,maxBytesToRead):""}function stringToUTF8Array(str,heap,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i=55296&&u<=57343){var u1=str.charCodeAt(++i);u=65536+((u&1023)<<10)|u1&1023}if(u<=127){if(outIdx>=endIdx)break;heap[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;heap[outIdx++]=192|u>>6;heap[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;heap[outIdx++]=224|u>>12;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}else{if(outIdx+3>=endIdx)break;heap[outIdx++]=240|u>>18;heap[outIdx++]=128|u>>12&63;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}}heap[outIdx]=0;return outIdx-startIdx}function stringToUTF8(str,outPtr,maxBytesToWrite){return stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite)}function lengthBytesUTF8(str){var len=0;for(var i=0;i=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127)++len;else if(u<=2047)len+=2;else if(u<=65535)len+=3;else len+=4}return len}function allocateUTF8(str){var size=lengthBytesUTF8(str)+1;var ret=_malloc(size);if(ret)stringToUTF8Array(str,HEAP8,ret,size);return ret}function allocateUTF8OnStack(str){var size=lengthBytesUTF8(str)+1;var ret=stackAlloc(size);stringToUTF8Array(str,HEAP8,ret,size);return ret}function writeArrayToMemory(array,buffer){HEAP8.set(array,buffer)}function writeAsciiToMemory(str,buffer,dontAddNull){for(var i=0;i>0]=str.charCodeAt(i)}if(!dontAddNull)HEAP8[buffer>>0]=0}function alignUp(x,multiple){if(x%multiple>0){x+=multiple-x%multiple}return x}var buffer,HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;function updateGlobalBufferAndViews(buf){buffer=buf;Module["HEAP8"]=HEAP8=new Int8Array(buf);Module["HEAP16"]=HEAP16=new Int16Array(buf);Module["HEAP32"]=HEAP32=new Int32Array(buf);Module["HEAPU8"]=HEAPU8=new Uint8Array(buf);Module["HEAPU16"]=HEAPU16=new Uint16Array(buf);Module["HEAPU32"]=HEAPU32=new Uint32Array(buf);Module["HEAPF32"]=HEAPF32=new Float32Array(buf);Module["HEAPF64"]=HEAPF64=new Float64Array(buf)}var INITIAL_MEMORY=Module["INITIAL_MEMORY"]||16777216;var wasmTable;var __ATPRERUN__=[];var __ATINIT__=[];var __ATMAIN__=[];var __ATEXIT__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;var runtimeExited=false;__ATINIT__.push({func:function(){___wasm_call_ctors()}});function preRun(){if(Module["preRun"]){if(typeof Module["preRun"]=="function")Module["preRun"]=[Module["preRun"]];while(Module["preRun"].length){addOnPreRun(Module["preRun"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}function initRuntime(){runtimeInitialized=true;if(!Module["noFSInit"]&&!FS.init.initialized)FS.init();TTY.init();SOCKFS.root=FS.mount(SOCKFS,{},null);callRuntimeCallbacks(__ATINIT__)}function preMain(){FS.ignorePermissions=false;callRuntimeCallbacks(__ATMAIN__)}function exitRuntime(){callRuntimeCallbacks(__ATEXIT__);FS.quit();TTY.shutdown();runtimeExited=true}function postRun(){if(Module["postRun"]){if(typeof Module["postRun"]=="function")Module["postRun"]=[Module["postRun"]];while(Module["postRun"].length){addOnPostRun(Module["postRun"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function addOnPreRun(cb){__ATPRERUN__.unshift(cb)}function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb)}var runDependencies=0;var runDependencyWatcher=null;var dependenciesFulfilled=null;function getUniqueRunDependency(id){return id}function addRunDependency(id){runDependencies++;if(Module["monitorRunDependencies"]){Module["monitorRunDependencies"](runDependencies)}}function removeRunDependency(id){runDependencies--;if(Module["monitorRunDependencies"]){Module["monitorRunDependencies"](runDependencies)}if(runDependencies==0){if(runDependencyWatcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}Module["preloadedImages"]={};Module["preloadedAudios"]={};function abort(what){if(Module["onAbort"]){Module["onAbort"](what)}what+="";err(what);ABORT=true;EXITSTATUS=1;what="abort("+what+"). Build with -s ASSERTIONS=1 for more info.";var e=new WebAssembly.RuntimeError(what);readyPromiseReject(e);throw e}function hasPrefix(str,prefix){return String.prototype.startsWith?str.startsWith(prefix):str.indexOf(prefix)===0}var dataURIPrefix="data:application/octet-stream;base64,";function isDataURI(filename){return hasPrefix(filename,dataURIPrefix)}var wasmBinaryFile="godot.javascript.opt.wasm";if(!isDataURI(wasmBinaryFile)){wasmBinaryFile=locateFile(wasmBinaryFile)}function getBinary(file){try{if(file==wasmBinaryFile&&wasmBinary){return new Uint8Array(wasmBinary)}if(readBinary){return readBinary(file)}else{throw"both async and sync fetching of the wasm failed"}}catch(err){abort(err)}}function getBinaryPromise(){if(!wasmBinary&&(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER)){if(typeof fetch==="function"){return fetch(wasmBinaryFile,{credentials:"same-origin"}).then(function(response){if(!response["ok"]){throw"failed to load wasm binary file at '"+wasmBinaryFile+"'"}return response["arrayBuffer"]()}).catch(function(){return getBinary(wasmBinaryFile)})}}return Promise.resolve().then(function(){return getBinary(wasmBinaryFile)})}function createWasm(){var info={"a":asmLibraryArg};function receiveInstance(instance,module){var exports=instance.exports;Module["asm"]=exports;wasmMemory=Module["asm"]["Xj"];updateGlobalBufferAndViews(wasmMemory.buffer);wasmTable=Module["asm"]["pk"];removeRunDependency("wasm-instantiate")}addRunDependency("wasm-instantiate");function receiveInstantiatedSource(output){receiveInstance(output["instance"])}function instantiateArrayBuffer(receiver){return getBinaryPromise().then(function(binary){return WebAssembly.instantiate(binary,info)}).then(receiver,function(reason){err("failed to asynchronously prepare wasm: "+reason);abort(reason)})}function instantiateAsync(){if(!wasmBinary&&typeof WebAssembly.instantiateStreaming==="function"&&!isDataURI(wasmBinaryFile)&&typeof fetch==="function"){return fetch(wasmBinaryFile,{credentials:"same-origin"}).then(function(response){var result=WebAssembly.instantiateStreaming(response,info);return result.then(receiveInstantiatedSource,function(reason){err("wasm streaming compile failed: "+reason);err("falling back to ArrayBuffer instantiation");return instantiateArrayBuffer(receiveInstantiatedSource)})})}else{return instantiateArrayBuffer(receiveInstantiatedSource)}}if(Module["instantiateWasm"]){try{var exports=Module["instantiateWasm"](info,receiveInstance);return exports}catch(e){err("Module.instantiateWasm callback failed with error: "+e);return false}}instantiateAsync().catch(readyPromiseReject);return{}}var tempDouble;var tempI64;var ASM_CONSTS={1693668:function($0,$1,$2,$3){GLctx.getBufferSubData($0,$1,HEAPU8,$2,$3)}};function callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbacks.shift();if(typeof callback=="function"){callback(Module);continue}var func=callback.func;if(typeof func==="number"){if(callback.arg===undefined){wasmTable.get(func)()}else{wasmTable.get(func)(callback.arg)}}else{func(callback.arg===undefined?null:callback.arg)}}}function _atexit(func,arg){__ATEXIT__.unshift({func:func,arg:arg})}function ___cxa_atexit(a0,a1){return _atexit(a0,a1)}var PATH={splitPath:function(filename){var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return splitPathRe.exec(filename).slice(1)},normalizeArray:function(parts,allowAboveRoot){var up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i];if(last==="."){parts.splice(i,1)}else if(last===".."){parts.splice(i,1);up++}else if(up){parts.splice(i,1);up--}}if(allowAboveRoot){for(;up;up--){parts.unshift("..")}}return parts},normalize:function(path){var isAbsolute=path.charAt(0)==="/",trailingSlash=path.substr(-1)==="/";path=PATH.normalizeArray(path.split("/").filter(function(p){return!!p}),!isAbsolute).join("/");if(!path&&!isAbsolute){path="."}if(path&&trailingSlash){path+="/"}return(isAbsolute?"/":"")+path},dirname:function(path){var result=PATH.splitPath(path),root=result[0],dir=result[1];if(!root&&!dir){return"."}if(dir){dir=dir.substr(0,dir.length-1)}return root+dir},basename:function(path){if(path==="/")return"/";path=PATH.normalize(path);path=path.replace(/\/$/,"");var lastSlash=path.lastIndexOf("/");if(lastSlash===-1)return path;return path.substr(lastSlash+1)},extname:function(path){return PATH.splitPath(path)[3]},join:function(){var paths=Array.prototype.slice.call(arguments,0);return PATH.normalize(paths.join("/"))},join2:function(l,r){return PATH.normalize(l+"/"+r)}};function getRandomDevice(){if(typeof crypto==="object"&&typeof crypto["getRandomValues"]==="function"){var randomBuffer=new Uint8Array(1);return function(){crypto.getRandomValues(randomBuffer);return randomBuffer[0]}}else return function(){abort("randomDevice")}}var PATH_FS={resolve:function(){var resolvedPath="",resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?arguments[i]:FS.cwd();if(typeof path!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!path){return""}resolvedPath=path+"/"+resolvedPath;resolvedAbsolute=path.charAt(0)==="/"}resolvedPath=PATH.normalizeArray(resolvedPath.split("/").filter(function(p){return!!p}),!resolvedAbsolute).join("/");return(resolvedAbsolute?"/":"")+resolvedPath||"."},relative:function(from,to){from=PATH_FS.resolve(from).substr(1);to=PATH_FS.resolve(to).substr(1);function trim(arr){var start=0;for(;start=0;end--){if(arr[end]!=="")break}if(start>end)return[];return arr.slice(start,end-start+1)}var fromParts=trim(from.split("/"));var toParts=trim(to.split("/"));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;i0){out(UTF8ArrayToString(tty.output,0));tty.output=[]}}},default_tty1_ops:{put_char:function(tty,val){if(val===null||val===10){err(UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}},flush:function(tty){if(tty.output&&tty.output.length>0){err(UTF8ArrayToString(tty.output,0));tty.output=[]}}}};function mmapAlloc(size){var alignedSize=alignMemory(size,16384);var ptr=_malloc(alignedSize);while(size=newCapacity)return;var CAPACITY_DOUBLING_MAX=1024*1024;newCapacity=Math.max(newCapacity,prevCapacity*(prevCapacity>>0);if(prevCapacity!=0)newCapacity=Math.max(newCapacity,256);var oldContents=node.contents;node.contents=new Uint8Array(newCapacity);if(node.usedBytes>0)node.contents.set(oldContents.subarray(0,node.usedBytes),0)},resizeFileStorage:function(node,newSize){if(node.usedBytes==newSize)return;if(newSize==0){node.contents=null;node.usedBytes=0}else{var oldContents=node.contents;node.contents=new Uint8Array(newSize);if(oldContents){node.contents.set(oldContents.subarray(0,Math.min(newSize,node.usedBytes)))}node.usedBytes=newSize}},node_ops:{getattr:function(node){var attr={};attr.dev=FS.isChrdev(node.mode)?node.id:1;attr.ino=node.id;attr.mode=node.mode;attr.nlink=1;attr.uid=0;attr.gid=0;attr.rdev=node.rdev;if(FS.isDir(node.mode)){attr.size=4096}else if(FS.isFile(node.mode)){attr.size=node.usedBytes}else if(FS.isLink(node.mode)){attr.size=node.link.length}else{attr.size=0}attr.atime=new Date(node.timestamp);attr.mtime=new Date(node.timestamp);attr.ctime=new Date(node.timestamp);attr.blksize=4096;attr.blocks=Math.ceil(attr.size/attr.blksize);return attr},setattr:function(node,attr){if(attr.mode!==undefined){node.mode=attr.mode}if(attr.timestamp!==undefined){node.timestamp=attr.timestamp}if(attr.size!==undefined){MEMFS.resizeFileStorage(node,attr.size)}},lookup:function(parent,name){throw FS.genericErrors[44]},mknod:function(parent,name,mode,dev){return MEMFS.createNode(parent,name,mode,dev)},rename:function(old_node,new_dir,new_name){if(FS.isDir(old_node.mode)){var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(new_node){for(var i in new_node.contents){throw new FS.ErrnoError(55)}}}delete old_node.parent.contents[old_node.name];old_node.parent.timestamp=Date.now();old_node.name=new_name;new_dir.contents[new_name]=old_node;new_dir.timestamp=old_node.parent.timestamp;old_node.parent=new_dir},unlink:function(parent,name){delete parent.contents[name];parent.timestamp=Date.now()},rmdir:function(parent,name){var node=FS.lookupNode(parent,name);for(var i in node.contents){throw new FS.ErrnoError(55)}delete parent.contents[name];parent.timestamp=Date.now()},readdir:function(node){var entries=[".",".."];for(var key in node.contents){if(!node.contents.hasOwnProperty(key)){continue}entries.push(key)}return entries},symlink:function(parent,newname,oldpath){var node=MEMFS.createNode(parent,newname,511|40960,0);node.link=oldpath;return node},readlink:function(node){if(!FS.isLink(node.mode)){throw new FS.ErrnoError(28)}return node.link}},stream_ops:{read:function(stream,buffer,offset,length,position){var contents=stream.node.contents;if(position>=stream.node.usedBytes)return 0;var size=Math.min(stream.node.usedBytes-position,length);if(size>8&&contents.subarray){buffer.set(contents.subarray(position,position+size),offset)}else{for(var i=0;i0||position+length8){throw new FS.ErrnoError(32)}var parts=PATH.normalizeArray(path.split("/").filter(function(p){return!!p}),false);var current=FS.root;var current_path="/";for(var i=0;i40){throw new FS.ErrnoError(32)}}}}return{path:current_path,node:current}},getPath:function(node){var path;while(true){if(FS.isRoot(node)){var mount=node.mount.mountpoint;if(!path)return mount;return mount[mount.length-1]!=="/"?mount+"/"+path:mount+path}path=path?node.name+"/"+path:node.name;node=node.parent}},hashName:function(parentid,name){var hash=0;for(var i=0;i>>0)%FS.nameTable.length},hashAddNode:function(node){var hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node},hashRemoveNode:function(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.name_next}else{var current=FS.nameTable[hash];while(current){if(current.name_next===node){current.name_next=node.name_next;break}current=current.name_next}}},lookupNode:function(parent,name){var errCode=FS.mayLookup(parent);if(errCode){throw new FS.ErrnoError(errCode,parent)}var hash=FS.hashName(parent.id,name);for(var node=FS.nameTable[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id===parent.id&&nodeName===name){return node}}return FS.lookup(parent,name)},createNode:function(parent,name,mode,rdev){var node=new FS.FSNode(parent,name,mode,rdev);FS.hashAddNode(node);return node},destroyNode:function(node){FS.hashRemoveNode(node)},isRoot:function(node){return node===node.parent},isMountpoint:function(node){return!!node.mounted},isFile:function(mode){return(mode&61440)===32768},isDir:function(mode){return(mode&61440)===16384},isLink:function(mode){return(mode&61440)===40960},isChrdev:function(mode){return(mode&61440)===8192},isBlkdev:function(mode){return(mode&61440)===24576},isFIFO:function(mode){return(mode&61440)===4096},isSocket:function(mode){return(mode&49152)===49152},flagModes:{"r":0,"r+":2,"w":577,"w+":578,"a":1089,"a+":1090},modeStringToFlags:function(str){var flags=FS.flagModes[str];if(typeof flags==="undefined"){throw new Error("Unknown file open mode: "+str)}return flags},flagsToPermissionString:function(flag){var perms=["r","w","rw"][flag&3];if(flag&512){perms+="w"}return perms},nodePermissions:function(node,perms){if(FS.ignorePermissions){return 0}if(perms.indexOf("r")!==-1&&!(node.mode&292)){return 2}else if(perms.indexOf("w")!==-1&&!(node.mode&146)){return 2}else if(perms.indexOf("x")!==-1&&!(node.mode&73)){return 2}return 0},mayLookup:function(dir){var errCode=FS.nodePermissions(dir,"x");if(errCode)return errCode;if(!dir.node_ops.lookup)return 2;return 0},mayCreate:function(dir,name){try{var node=FS.lookupNode(dir,name);return 20}catch(e){}return FS.nodePermissions(dir,"wx")},mayDelete:function(dir,name,isdir){var node;try{node=FS.lookupNode(dir,name)}catch(e){return e.errno}var errCode=FS.nodePermissions(dir,"wx");if(errCode){return errCode}if(isdir){if(!FS.isDir(node.mode)){return 54}if(FS.isRoot(node)||FS.getPath(node)===FS.cwd()){return 10}}else{if(FS.isDir(node.mode)){return 31}}return 0},mayOpen:function(node,flags){if(!node){return 44}if(FS.isLink(node.mode)){return 32}else if(FS.isDir(node.mode)){if(FS.flagsToPermissionString(flags)!=="r"||flags&512){return 31}}return FS.nodePermissions(node,FS.flagsToPermissionString(flags))},MAX_OPEN_FDS:4096,nextfd:function(fd_start,fd_end){fd_start=fd_start||0;fd_end=fd_end||FS.MAX_OPEN_FDS;for(var fd=fd_start;fd<=fd_end;fd++){if(!FS.streams[fd]){return fd}}throw new FS.ErrnoError(33)},getStream:function(fd){return FS.streams[fd]},createStream:function(stream,fd_start,fd_end){if(!FS.FSStream){FS.FSStream=function(){};FS.FSStream.prototype={object:{get:function(){return this.node},set:function(val){this.node=val}},isRead:{get:function(){return(this.flags&2097155)!==1}},isWrite:{get:function(){return(this.flags&2097155)!==0}},isAppend:{get:function(){return this.flags&1024}}}}var newStream=new FS.FSStream;for(var p in stream){newStream[p]=stream[p]}stream=newStream;var fd=FS.nextfd(fd_start,fd_end);stream.fd=fd;FS.streams[fd]=stream;return stream},closeStream:function(fd){FS.streams[fd]=null},chrdev_stream_ops:{open:function(stream){var device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;if(stream.stream_ops.open){stream.stream_ops.open(stream)}},llseek:function(){throw new FS.ErrnoError(70)}},major:function(dev){return dev>>8},minor:function(dev){return dev&255},makedev:function(ma,mi){return ma<<8|mi},registerDevice:function(dev,ops){FS.devices[dev]={stream_ops:ops}},getDevice:function(dev){return FS.devices[dev]},getMounts:function(mount){var mounts=[];var check=[mount];while(check.length){var m=check.pop();mounts.push(m);check.push.apply(check,m.mounts)}return mounts},syncfs:function(populate,callback){if(typeof populate==="function"){callback=populate;populate=false}FS.syncFSRequests++;if(FS.syncFSRequests>1){err("warning: "+FS.syncFSRequests+" FS.syncfs operations in flight at once, probably just doing extra work")}var mounts=FS.getMounts(FS.root.mount);var completed=0;function doCallback(errCode){FS.syncFSRequests--;return callback(errCode)}function done(errCode){if(errCode){if(!done.errored){done.errored=true;return doCallback(errCode)}return}if(++completed>=mounts.length){doCallback(null)}}mounts.forEach(function(mount){if(!mount.type.syncfs){return done(null)}mount.type.syncfs(mount,populate,done)})},mount:function(type,opts,mountpoint){var root=mountpoint==="/";var pseudo=!mountpoint;var node;if(root&&FS.root){throw new FS.ErrnoError(10)}else if(!root&&!pseudo){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});mountpoint=lookup.path;node=lookup.node;if(FS.isMountpoint(node)){throw new FS.ErrnoError(10)}if(!FS.isDir(node.mode)){throw new FS.ErrnoError(54)}}var mount={type:type,opts:opts,mountpoint:mountpoint,mounts:[]};var mountRoot=type.mount(mount);mountRoot.mount=mount;mount.root=mountRoot;if(root){FS.root=mountRoot}else if(node){node.mounted=mount;if(node.mount){node.mount.mounts.push(mount)}}return mountRoot},unmount:function(mountpoint){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});if(!FS.isMountpoint(lookup.node)){throw new FS.ErrnoError(28)}var node=lookup.node;var mount=node.mounted;var mounts=FS.getMounts(mount);Object.keys(FS.nameTable).forEach(function(hash){var current=FS.nameTable[hash];while(current){var next=current.name_next;if(mounts.indexOf(current.mount)!==-1){FS.destroyNode(current)}current=next}});node.mounted=null;var idx=node.mount.mounts.indexOf(mount);node.mount.mounts.splice(idx,1)},lookup:function(parent,name){return parent.node_ops.lookup(parent,name)},mknod:function(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);if(!name||name==="."||name===".."){throw new FS.ErrnoError(28)}var errCode=FS.mayCreate(parent,name);if(errCode){throw new FS.ErrnoError(errCode)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(63)}return parent.node_ops.mknod(parent,name,mode,dev)},create:function(path,mode){mode=mode!==undefined?mode:438;mode&=4095;mode|=32768;return FS.mknod(path,mode,0)},mkdir:function(path,mode){mode=mode!==undefined?mode:511;mode&=511|512;mode|=16384;return FS.mknod(path,mode,0)},mkdirTree:function(path,mode){var dirs=path.split("/");var d="";for(var i=0;ithis.length-1||idx<0){return undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOffset]};LazyUint8Array.prototype.setDataGetter=function LazyUint8Array_setDataGetter(getter){this.getter=getter};LazyUint8Array.prototype.cacheLength=function LazyUint8Array_cacheLength(){var xhr=new XMLHttpRequest;xhr.open("HEAD",url,false);xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);var datalength=Number(xhr.getResponseHeader("Content-length"));var header;var hasByteServing=(header=xhr.getResponseHeader("Accept-Ranges"))&&header==="bytes";var usesGzip=(header=xhr.getResponseHeader("Content-Encoding"))&&header==="gzip";var chunkSize=1024*1024;if(!hasByteServing)chunkSize=datalength;var doXHR=function(from,to){if(from>to)throw new Error("invalid range ("+from+", "+to+") or no bytes requested!");if(to>datalength-1)throw new Error("only "+datalength+" bytes available! programmer error!");var xhr=new XMLHttpRequest;xhr.open("GET",url,false);if(datalength!==chunkSize)xhr.setRequestHeader("Range","bytes="+from+"-"+to);if(typeof Uint8Array!="undefined")xhr.responseType="arraybuffer";if(xhr.overrideMimeType){xhr.overrideMimeType("text/plain; charset=x-user-defined")}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response||[])}else{return intArrayFromString(xhr.responseText||"",true)}};var lazyArray=this;lazyArray.setDataGetter(function(chunkNum){var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]==="undefined"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]==="undefined")throw new Error("doXHR failed!");return lazyArray.chunks[chunkNum]});if(usesGzip||!datalength){chunkSize=datalength=1;datalength=this.getter(0).length;chunkSize=datalength;out("LazyFiles on gzip forces download of the whole file when length is accessed")}this._length=datalength;this._chunkSize=chunkSize;this.lengthKnown=true};if(typeof XMLHttpRequest!=="undefined"){if(!ENVIRONMENT_IS_WORKER)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var lazyArray=new LazyUint8Array;Object.defineProperties(lazyArray,{length:{get:function(){if(!this.lengthKnown){this.cacheLength()}return this._length}},chunkSize:{get:function(){if(!this.lengthKnown){this.cacheLength()}return this._chunkSize}}});var properties={isDevice:false,contents:lazyArray}}else{var properties={isDevice:false,url:url}}var node=FS.createFile(parent,name,properties,canRead,canWrite);if(properties.contents){node.contents=properties.contents}else if(properties.url){node.contents=null;node.url=properties.url}Object.defineProperties(node,{usedBytes:{get:function(){return this.contents.length}}});var stream_ops={};var keys=Object.keys(node.stream_ops);keys.forEach(function(key){var fn=node.stream_ops[key];stream_ops[key]=function forceLoadLazyFile(){FS.forceLoadFile(node);return fn.apply(null,arguments)}});stream_ops.read=function stream_ops_read(stream,buffer,offset,length,position){FS.forceLoadFile(node);var contents=stream.node.contents;if(position>=contents.length)return 0;var size=Math.min(contents.length-position,length);if(contents.slice){for(var i=0;i>2]=stat.dev;HEAP32[buf+4>>2]=0;HEAP32[buf+8>>2]=stat.ino;HEAP32[buf+12>>2]=stat.mode;HEAP32[buf+16>>2]=stat.nlink;HEAP32[buf+20>>2]=stat.uid;HEAP32[buf+24>>2]=stat.gid;HEAP32[buf+28>>2]=stat.rdev;HEAP32[buf+32>>2]=0;tempI64=[stat.size>>>0,(tempDouble=stat.size,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[buf+40>>2]=tempI64[0],HEAP32[buf+44>>2]=tempI64[1];HEAP32[buf+48>>2]=4096;HEAP32[buf+52>>2]=stat.blocks;HEAP32[buf+56>>2]=stat.atime.getTime()/1e3|0;HEAP32[buf+60>>2]=0;HEAP32[buf+64>>2]=stat.mtime.getTime()/1e3|0;HEAP32[buf+68>>2]=0;HEAP32[buf+72>>2]=stat.ctime.getTime()/1e3|0;HEAP32[buf+76>>2]=0;tempI64=[stat.ino>>>0,(tempDouble=stat.ino,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[buf+80>>2]=tempI64[0],HEAP32[buf+84>>2]=tempI64[1];return 0},doMsync:function(addr,stream,len,flags,offset){var buffer=HEAPU8.slice(addr,addr+len);FS.msync(stream,buffer,offset,len,flags)},doMkdir:function(path,mode){path=PATH.normalize(path);if(path[path.length-1]==="/")path=path.substr(0,path.length-1);FS.mkdir(path,mode,0);return 0},doMknod:function(path,mode,dev){switch(mode&61440){case 32768:case 8192:case 24576:case 4096:case 49152:break;default:return-28}FS.mknod(path,mode,dev);return 0},doReadlink:function(path,buf,bufsize){if(bufsize<=0)return-28;var ret=FS.readlink(path);var len=Math.min(bufsize,lengthBytesUTF8(ret));var endChar=HEAP8[buf+len];stringToUTF8(ret,buf,bufsize+1);HEAP8[buf+len]=endChar;return len},doAccess:function(path,amode){if(amode&~7){return-28}var node;var lookup=FS.lookupPath(path,{follow:true});node=lookup.node;if(!node){return-44}var perms="";if(amode&4)perms+="r";if(amode&2)perms+="w";if(amode&1)perms+="x";if(perms&&FS.nodePermissions(node,perms)){return-2}return 0},doDup:function(path,flags,suggestFD){var suggest=FS.getStream(suggestFD);if(suggest)FS.close(suggest);return FS.open(path,flags,0,suggestFD,suggestFD).fd},doReadv:function(stream,iov,iovcnt,offset){var ret=0;for(var i=0;i>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.read(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.write(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr}return ret},varargs:undefined,get:function(){SYSCALLS.varargs+=4;var ret=HEAP32[SYSCALLS.varargs-4>>2];return ret},getStr:function(ptr){var ret=UTF8ToString(ptr);return ret},getStreamFromFD:function(fd){var stream=FS.getStream(fd);if(!stream)throw new FS.ErrnoError(8);return stream},get64:function(low,high){return low}};function ___sys__newselect(nfds,readfds,writefds,exceptfds,timeout){try{var total=0;var srcReadLow=readfds?HEAP32[readfds>>2]:0,srcReadHigh=readfds?HEAP32[readfds+4>>2]:0;var srcWriteLow=writefds?HEAP32[writefds>>2]:0,srcWriteHigh=writefds?HEAP32[writefds+4>>2]:0;var srcExceptLow=exceptfds?HEAP32[exceptfds>>2]:0,srcExceptHigh=exceptfds?HEAP32[exceptfds+4>>2]:0;var dstReadLow=0,dstReadHigh=0;var dstWriteLow=0,dstWriteHigh=0;var dstExceptLow=0,dstExceptHigh=0;var allLow=(readfds?HEAP32[readfds>>2]:0)|(writefds?HEAP32[writefds>>2]:0)|(exceptfds?HEAP32[exceptfds>>2]:0);var allHigh=(readfds?HEAP32[readfds+4>>2]:0)|(writefds?HEAP32[writefds+4>>2]:0)|(exceptfds?HEAP32[exceptfds+4>>2]:0);var check=function(fd,low,high,val){return fd<32?low&val:high&val};for(var fd=0;fd>2]=dstReadLow;HEAP32[readfds+4>>2]=dstReadHigh}if(writefds){HEAP32[writefds>>2]=dstWriteLow;HEAP32[writefds+4>>2]=dstWriteHigh}if(exceptfds){HEAP32[exceptfds>>2]=dstExceptLow;HEAP32[exceptfds+4>>2]=dstExceptHigh}return total}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}var ERRNO_CODES={EPERM:63,ENOENT:44,ESRCH:71,EINTR:27,EIO:29,ENXIO:60,E2BIG:1,ENOEXEC:45,EBADF:8,ECHILD:12,EAGAIN:6,EWOULDBLOCK:6,ENOMEM:48,EACCES:2,EFAULT:21,ENOTBLK:105,EBUSY:10,EEXIST:20,EXDEV:75,ENODEV:43,ENOTDIR:54,EISDIR:31,EINVAL:28,ENFILE:41,EMFILE:33,ENOTTY:59,ETXTBSY:74,EFBIG:22,ENOSPC:51,ESPIPE:70,EROFS:69,EMLINK:34,EPIPE:64,EDOM:18,ERANGE:68,ENOMSG:49,EIDRM:24,ECHRNG:106,EL2NSYNC:156,EL3HLT:107,EL3RST:108,ELNRNG:109,EUNATCH:110,ENOCSI:111,EL2HLT:112,EDEADLK:16,ENOLCK:46,EBADE:113,EBADR:114,EXFULL:115,ENOANO:104,EBADRQC:103,EBADSLT:102,EDEADLOCK:16,EBFONT:101,ENOSTR:100,ENODATA:116,ETIME:117,ENOSR:118,ENONET:119,ENOPKG:120,EREMOTE:121,ENOLINK:47,EADV:122,ESRMNT:123,ECOMM:124,EPROTO:65,EMULTIHOP:36,EDOTDOT:125,EBADMSG:9,ENOTUNIQ:126,EBADFD:127,EREMCHG:128,ELIBACC:129,ELIBBAD:130,ELIBSCN:131,ELIBMAX:132,ELIBEXEC:133,ENOSYS:52,ENOTEMPTY:55,ENAMETOOLONG:37,ELOOP:32,EOPNOTSUPP:138,EPFNOSUPPORT:139,ECONNRESET:15,ENOBUFS:42,EAFNOSUPPORT:5,EPROTOTYPE:67,ENOTSOCK:57,ENOPROTOOPT:50,ESHUTDOWN:140,ECONNREFUSED:14,EADDRINUSE:3,ECONNABORTED:13,ENETUNREACH:40,ENETDOWN:38,ETIMEDOUT:73,EHOSTDOWN:142,EHOSTUNREACH:23,EINPROGRESS:26,EALREADY:7,EDESTADDRREQ:17,EMSGSIZE:35,EPROTONOSUPPORT:66,ESOCKTNOSUPPORT:137,EADDRNOTAVAIL:4,ENETRESET:39,EISCONN:30,ENOTCONN:53,ETOOMANYREFS:141,EUSERS:136,EDQUOT:19,ESTALE:72,ENOTSUP:138,ENOMEDIUM:148,EILSEQ:25,EOVERFLOW:61,ECANCELED:11,ENOTRECOVERABLE:56,EOWNERDEAD:62,ESTRPIPE:135};var SOCKFS={mount:function(mount){Module["websocket"]=Module["websocket"]&&"object"===typeof Module["websocket"]?Module["websocket"]:{};Module["websocket"]._callbacks={};Module["websocket"]["on"]=function(event,callback){if("function"===typeof callback){this._callbacks[event]=callback}return this};Module["websocket"].emit=function(event,param){if("function"===typeof this._callbacks[event]){this._callbacks[event].call(this,param)}};return FS.createNode(null,"/",16384|511,0)},createSocket:function(family,type,protocol){type&=~526336;var streaming=type==1;if(protocol){assert(streaming==(protocol==6))}var sock={family:family,type:type,protocol:protocol,server:null,error:null,peers:{},pending:[],recv_queue:[],sock_ops:SOCKFS.websocket_sock_ops};var name=SOCKFS.nextname();var node=FS.createNode(SOCKFS.root,name,49152,0);node.sock=sock;var stream=FS.createStream({path:name,node:node,flags:2,seekable:false,stream_ops:SOCKFS.stream_ops});sock.stream=stream;return sock},getSocket:function(fd){var stream=FS.getStream(fd);if(!stream||!FS.isSocket(stream.node.mode)){return null}return stream.node.sock},stream_ops:{poll:function(stream){var sock=stream.node.sock;return sock.sock_ops.poll(sock)},ioctl:function(stream,request,varargs){var sock=stream.node.sock;return sock.sock_ops.ioctl(sock,request,varargs)},read:function(stream,buffer,offset,length,position){var sock=stream.node.sock;var msg=sock.sock_ops.recvmsg(sock,length);if(!msg){return 0}buffer.set(msg.buffer,offset);return msg.buffer.length},write:function(stream,buffer,offset,length,position){var sock=stream.node.sock;return sock.sock_ops.sendmsg(sock,buffer,offset,length)},close:function(stream){var sock=stream.node.sock;sock.sock_ops.close(sock)}},nextname:function(){if(!SOCKFS.nextname.current){SOCKFS.nextname.current=0}return"socket["+SOCKFS.nextname.current+++"]"},websocket_sock_ops:{createPeer:function(sock,addr,port){var ws;if(typeof addr==="object"){ws=addr;addr=null;port=null}if(ws){if(ws._socket){addr=ws._socket.remoteAddress;port=ws._socket.remotePort}else{var result=/ws[s]?:\/\/([^:]+):(\d+)/.exec(ws.url);if(!result){throw new Error("WebSocket URL must be in the format ws(s)://address:port")}addr=result[1];port=parseInt(result[2],10)}}else{try{var runtimeConfig=Module["websocket"]&&"object"===typeof Module["websocket"];var url="ws:#".replace("#","//");if(runtimeConfig){if("string"===typeof Module["websocket"]["url"]){url=Module["websocket"]["url"]}}if(url==="ws://"||url==="wss://"){var parts=addr.split("/");url=url+parts[0]+":"+port+"/"+parts.slice(1).join("/")}var subProtocols="binary";if(runtimeConfig){if("string"===typeof Module["websocket"]["subprotocol"]){subProtocols=Module["websocket"]["subprotocol"]}}var opts=undefined;if(subProtocols!=="null"){subProtocols=subProtocols.replace(/^ +| +$/g,"").split(/ *, */);opts=ENVIRONMENT_IS_NODE?{"protocol":subProtocols.toString()}:subProtocols}if(runtimeConfig&&null===Module["websocket"]["subprotocol"]){subProtocols="null";opts=undefined}var WebSocketConstructor;{WebSocketConstructor=WebSocket}ws=new WebSocketConstructor(url,opts);ws.binaryType="arraybuffer"}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EHOSTUNREACH)}}var peer={addr:addr,port:port,socket:ws,dgram_send_queue:[]};SOCKFS.websocket_sock_ops.addPeer(sock,peer);SOCKFS.websocket_sock_ops.handlePeerEvents(sock,peer);if(sock.type===2&&typeof sock.sport!=="undefined"){peer.dgram_send_queue.push(new Uint8Array([255,255,255,255,"p".charCodeAt(0),"o".charCodeAt(0),"r".charCodeAt(0),"t".charCodeAt(0),(sock.sport&65280)>>8,sock.sport&255]))}return peer},getPeer:function(sock,addr,port){return sock.peers[addr+":"+port]},addPeer:function(sock,peer){sock.peers[peer.addr+":"+peer.port]=peer},removePeer:function(sock,peer){delete sock.peers[peer.addr+":"+peer.port]},handlePeerEvents:function(sock,peer){var first=true;var handleOpen=function(){Module["websocket"].emit("open",sock.stream.fd);try{var queued=peer.dgram_send_queue.shift();while(queued){peer.socket.send(queued);queued=peer.dgram_send_queue.shift()}}catch(e){peer.socket.close()}};function handleMessage(data){if(typeof data==="string"){var encoder=new TextEncoder;data=encoder.encode(data)}else{assert(data.byteLength!==undefined);if(data.byteLength==0){return}else{data=new Uint8Array(data)}}var wasfirst=first;first=false;if(wasfirst&&data.length===10&&data[0]===255&&data[1]===255&&data[2]===255&&data[3]===255&&data[4]==="p".charCodeAt(0)&&data[5]==="o".charCodeAt(0)&&data[6]==="r".charCodeAt(0)&&data[7]==="t".charCodeAt(0)){var newport=data[8]<<8|data[9];SOCKFS.websocket_sock_ops.removePeer(sock,peer);peer.port=newport;SOCKFS.websocket_sock_ops.addPeer(sock,peer);return}sock.recv_queue.push({addr:peer.addr,port:peer.port,data:data});Module["websocket"].emit("message",sock.stream.fd)}if(ENVIRONMENT_IS_NODE){peer.socket.on("open",handleOpen);peer.socket.on("message",function(data,flags){if(!flags.binary){return}handleMessage(new Uint8Array(data).buffer)});peer.socket.on("close",function(){Module["websocket"].emit("close",sock.stream.fd)});peer.socket.on("error",function(error){sock.error=ERRNO_CODES.ECONNREFUSED;Module["websocket"].emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])})}else{peer.socket.onopen=handleOpen;peer.socket.onclose=function(){Module["websocket"].emit("close",sock.stream.fd)};peer.socket.onmessage=function peer_socket_onmessage(event){handleMessage(event.data)};peer.socket.onerror=function(error){sock.error=ERRNO_CODES.ECONNREFUSED;Module["websocket"].emit("error",[sock.stream.fd,sock.error,"ECONNREFUSED: Connection refused"])}}},poll:function(sock){if(sock.type===1&&sock.server){return sock.pending.length?64|1:0}var mask=0;var dest=sock.type===1?SOCKFS.websocket_sock_ops.getPeer(sock,sock.daddr,sock.dport):null;if(sock.recv_queue.length||!dest||dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){mask|=64|1}if(!dest||dest&&dest.socket.readyState===dest.socket.OPEN){mask|=4}if(dest&&dest.socket.readyState===dest.socket.CLOSING||dest&&dest.socket.readyState===dest.socket.CLOSED){mask|=16}return mask},ioctl:function(sock,request,arg){switch(request){case 21531:var bytes=0;if(sock.recv_queue.length){bytes=sock.recv_queue[0].data.length}HEAP32[arg>>2]=bytes;return 0;default:return ERRNO_CODES.EINVAL}},close:function(sock){if(sock.server){try{sock.server.close()}catch(e){}sock.server=null}var peers=Object.keys(sock.peers);for(var i=0;i>2]=value;return value}function inetPton4(str){var b=str.split(".");for(var i=0;i<4;i++){var tmp=Number(b[i]);if(isNaN(tmp))return null;b[i]=tmp}return(b[0]|b[1]<<8|b[2]<<16|b[3]<<24)>>>0}function jstoi_q(str){return parseInt(str)}function inetPton6(str){var words;var w,offset,z;var valid6regx=/^((?=.*::)(?!.*::.+::)(::)?([\dA-F]{1,4}:(:|\b)|){5}|([\dA-F]{1,4}:){6})((([\dA-F]{1,4}((?!\3)::|:\b|$))|(?!\2\3)){2}|(((2[0-4]|1\d|[1-9])?\d|25[0-5])\.?\b){4})$/i;var parts=[];if(!valid6regx.test(str)){return null}if(str==="::"){return[0,0,0,0,0,0,0,0]}if(str.indexOf("::")===0){str=str.replace("::","Z:")}else{str=str.replace("::",":Z:")}if(str.indexOf(".")>0){str=str.replace(new RegExp("[.]","g"),":");words=str.split(":");words[words.length-4]=jstoi_q(words[words.length-4])+jstoi_q(words[words.length-3])*256;words[words.length-3]=jstoi_q(words[words.length-2])+jstoi_q(words[words.length-1])*256;words=words.slice(0,words.length-2)}else{words=str.split(":")}offset=0;z=0;for(w=0;w>2]=16}HEAP16[sa>>1]=family;HEAP32[sa+4>>2]=addr;HEAP16[sa+2>>1]=_htons(port);tempI64=[0>>>0,(tempDouble=0,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[sa+8>>2]=tempI64[0],HEAP32[sa+12>>2]=tempI64[1];break;case 10:addr=inetPton6(addr);if(addrlen){HEAP32[addrlen>>2]=28}HEAP32[sa>>2]=family;HEAP32[sa+8>>2]=addr[0];HEAP32[sa+12>>2]=addr[1];HEAP32[sa+16>>2]=addr[2];HEAP32[sa+20>>2]=addr[3];HEAP16[sa+2>>1]=_htons(port);HEAP32[sa+4>>2]=0;HEAP32[sa+24>>2]=0;break;default:return 5}return 0}var DNS={address_map:{id:1,addrs:{},names:{}},lookup_name:function(name){var res=inetPton4(name);if(res!==null){return name}res=inetPton6(name);if(res!==null){return name}var addr;if(DNS.address_map.addrs[name]){addr=DNS.address_map.addrs[name]}else{var id=DNS.address_map.id++;assert(id<65535,"exceeded max address mappings of 65535");addr="172.29."+(id&255)+"."+(id&65280);DNS.address_map.names[addr]=name;DNS.address_map.addrs[name]=addr}return addr},lookup_addr:function(addr){if(DNS.address_map.names[addr]){return DNS.address_map.names[addr]}return null}};function ___sys_accept4(fd,addr,addrlen,flags){try{var sock=getSocketFromFD(fd);var newsock=sock.sock_ops.accept(sock);if(addr){var errno=writeSockaddr(addr,newsock.family,DNS.lookup_name(newsock.daddr),newsock.dport,addrlen)}return newsock.stream.fd}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_access(path,amode){try{path=SYSCALLS.getStr(path);return SYSCALLS.doAccess(path,amode)}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function inetNtop4(addr){return(addr&255)+"."+(addr>>8&255)+"."+(addr>>16&255)+"."+(addr>>24&255)}function inetNtop6(ints){var str="";var word=0;var longest=0;var lastzero=0;var zstart=0;var len=0;var i=0;var parts=[ints[0]&65535,ints[0]>>16,ints[1]&65535,ints[1]>>16,ints[2]&65535,ints[2]>>16,ints[3]&65535,ints[3]>>16];var hasipv4=true;var v4part="";for(i=0;i<5;i++){if(parts[i]!==0){hasipv4=false;break}}if(hasipv4){v4part=inetNtop4(parts[6]|parts[7]<<16);if(parts[5]===-1){str="::ffff:";str+=v4part;return str}if(parts[5]===0){str="::";if(v4part==="0.0.0.0")v4part="";if(v4part==="0.0.0.1")v4part="1";str+=v4part;return str}}for(word=0;word<8;word++){if(parts[word]===0){if(word-lastzero>1){len=0}lastzero=word;len++}if(len>longest){longest=len;zstart=word-longest+1}}for(word=0;word<8;word++){if(longest>1){if(parts[word]===0&&word>=zstart&&word>1];var port=_ntohs(HEAPU16[sa+2>>1]);var addr;switch(family){case 2:if(salen!==16){return{errno:28}}addr=HEAP32[sa+4>>2];addr=inetNtop4(addr);break;case 10:if(salen!==28){return{errno:28}}addr=[HEAP32[sa+8>>2],HEAP32[sa+12>>2],HEAP32[sa+16>>2],HEAP32[sa+20>>2]];addr=inetNtop6(addr);break;default:return{errno:5}}return{family:family,addr:addr,port:port}}function getSocketAddress(addrp,addrlen,allowNull){if(allowNull&&addrp===0)return null;var info=readSockaddr(addrp,addrlen);if(info.errno)throw new FS.ErrnoError(info.errno);info.addr=DNS.lookup_addr(info.addr)||info.addr;return info}function ___sys_bind(fd,addr,addrlen){try{var sock=getSocketFromFD(fd);var info=getSocketAddress(addr,addrlen);sock.sock_ops.bind(sock,info.addr,info.port);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_chdir(path){try{path=SYSCALLS.getStr(path);FS.chdir(path);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_chmod(path,mode){try{path=SYSCALLS.getStr(path);FS.chmod(path,mode);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_connect(fd,addr,addrlen){try{var sock=getSocketFromFD(fd);var info=getSocketAddress(addr,addrlen);sock.sock_ops.connect(sock,info.addr,info.port);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_fcntl64(fd,cmd,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(fd);switch(cmd){case 0:{var arg=SYSCALLS.get();if(arg<0){return-28}var newStream;newStream=FS.open(stream.path,stream.flags,0,arg);return newStream.fd}case 1:case 2:return 0;case 3:return stream.flags;case 4:{var arg=SYSCALLS.get();stream.flags|=arg;return 0}case 12:{var arg=SYSCALLS.get();var offset=0;HEAP16[arg+offset>>1]=2;return 0}case 13:case 14:return 0;case 16:case 8:return-28;case 9:setErrNo(28);return-1;default:{return-28}}}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_getcwd(buf,size){try{if(size===0)return-28;var cwd=FS.cwd();var cwdLengthInBytes=lengthBytesUTF8(cwd);if(size>>0,(tempDouble=id,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[dirp+pos>>2]=tempI64[0],HEAP32[dirp+pos+4>>2]=tempI64[1];tempI64=[(idx+1)*struct_size>>>0,(tempDouble=(idx+1)*struct_size,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[dirp+pos+8>>2]=tempI64[0],HEAP32[dirp+pos+12>>2]=tempI64[1];HEAP16[dirp+pos+16>>1]=280;HEAP8[dirp+pos+18>>0]=type;stringToUTF8(name,dirp+pos+19,256);pos+=struct_size;idx+=1}FS.llseek(stream,idx*struct_size,0);return pos}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_getpid(){return 42}function ___sys_getsockname(fd,addr,addrlen){try{err("__sys_getsockname "+fd);var sock=getSocketFromFD(fd);var errno=writeSockaddr(addr,sock.family,DNS.lookup_name(sock.saddr||"0.0.0.0"),sock.sport,addrlen);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_getsockopt(fd,level,optname,optval,optlen){try{var sock=getSocketFromFD(fd);if(level===1){if(optname===4){HEAP32[optval>>2]=sock.error;HEAP32[optlen>>2]=4;sock.error=null;return 0}}return-50}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_ioctl(fd,op,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(fd);switch(op){case 21509:case 21505:{if(!stream.tty)return-59;return 0}case 21510:case 21511:case 21512:case 21506:case 21507:case 21508:{if(!stream.tty)return-59;return 0}case 21519:{if(!stream.tty)return-59;var argp=SYSCALLS.get();HEAP32[argp>>2]=0;return 0}case 21520:{if(!stream.tty)return-59;return-28}case 21531:{var argp=SYSCALLS.get();return FS.ioctl(stream,op,argp)}case 21523:{if(!stream.tty)return-59;return 0}case 21524:{if(!stream.tty)return-59;return 0}default:abort("bad ioctl syscall "+op)}}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_listen(fd,backlog){try{var sock=getSocketFromFD(fd);sock.sock_ops.listen(sock,backlog);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_mkdir(path,mode){try{path=SYSCALLS.getStr(path);return SYSCALLS.doMkdir(path,mode)}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_open(path,flags,varargs){SYSCALLS.varargs=varargs;try{var pathname=SYSCALLS.getStr(path);var mode=varargs?SYSCALLS.get():0;var stream=FS.open(pathname,flags,mode);return stream.fd}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_poll(fds,nfds,timeout){try{var nonzero=0;for(var i=0;i>2];var events=HEAP16[pollfd+4>>1];var mask=32;var stream=FS.getStream(fd);if(stream){mask=SYSCALLS.DEFAULT_POLLMASK;if(stream.stream_ops.poll){mask=stream.stream_ops.poll(stream)}}mask&=events|8|16;if(mask)nonzero++;HEAP16[pollfd+6>>1]=mask}return nonzero}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_recvfrom(fd,buf,len,flags,addr,addrlen){try{var sock=getSocketFromFD(fd);var msg=sock.sock_ops.recvmsg(sock,len);if(!msg)return 0;if(addr){var errno=writeSockaddr(addr,sock.family,DNS.lookup_name(msg.addr),msg.port,addrlen)}HEAPU8.set(msg.buffer,buf);return msg.buffer.byteLength}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_rename(old_path,new_path){try{old_path=SYSCALLS.getStr(old_path);new_path=SYSCALLS.getStr(new_path);FS.rename(old_path,new_path);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_rmdir(path){try{path=SYSCALLS.getStr(path);FS.rmdir(path);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_sendto(fd,message,length,flags,addr,addr_len){try{var sock=getSocketFromFD(fd);var dest=getSocketAddress(addr,addr_len,true);if(!dest){return FS.write(sock.stream,HEAP8,message,length)}else{return sock.sock_ops.sendmsg(sock,HEAP8,message,length,dest.addr,dest.port)}}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_setsockopt(fd){try{return-50}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_socket(domain,type,protocol){try{var sock=SOCKFS.createSocket(domain,type,protocol);return sock.stream.fd}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_stat64(path,buf){try{path=SYSCALLS.getStr(path);return SYSCALLS.doStat(FS.stat,path,buf)}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_statfs64(path,size,buf){try{path=SYSCALLS.getStr(path);HEAP32[buf+4>>2]=4096;HEAP32[buf+40>>2]=4096;HEAP32[buf+8>>2]=1e6;HEAP32[buf+12>>2]=5e5;HEAP32[buf+16>>2]=5e5;HEAP32[buf+20>>2]=FS.nextInode;HEAP32[buf+24>>2]=1e6;HEAP32[buf+28>>2]=42;HEAP32[buf+44>>2]=2;HEAP32[buf+36>>2]=255;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_unlink(path){try{path=SYSCALLS.getStr(path);FS.unlink(path);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___sys_wait4(pid,wstart,options,rusage){try{return-52}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function _abort(){abort()}var _emscripten_get_now;_emscripten_get_now=function(){return performance.now()};var _emscripten_get_now_is_monotonic=true;function _clock_gettime(clk_id,tp){var now;if(clk_id===0){now=Date.now()}else if((clk_id===1||clk_id===4)&&_emscripten_get_now_is_monotonic){now=_emscripten_get_now()}else{setErrNo(28);return-1}HEAP32[tp>>2]=now/1e3|0;HEAP32[tp+4>>2]=now%1e3*1e3*1e3|0;return 0}function _dlclose(handle){abort("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function _dlerror(){abort("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function _dlopen(filename,flag){abort("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function _dlsym(handle,symbol){abort("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function _emscripten_asm_const_int(code,sigPtr,argbuf){var args=readAsmConstArgs(sigPtr,argbuf);return ASM_CONSTS[code].apply(null,args)}function _emscripten_set_main_loop_timing(mode,value){Browser.mainLoop.timingMode=mode;Browser.mainLoop.timingValue=value;if(!Browser.mainLoop.func){return 1}if(mode==0){Browser.mainLoop.scheduler=function Browser_mainLoop_scheduler_setTimeout(){var timeUntilNextTick=Math.max(0,Browser.mainLoop.tickStartTime+value-_emscripten_get_now())|0;setTimeout(Browser.mainLoop.runner,timeUntilNextTick)};Browser.mainLoop.method="timeout"}else if(mode==1){Browser.mainLoop.scheduler=function Browser_mainLoop_scheduler_rAF(){Browser.requestAnimationFrame(Browser.mainLoop.runner)};Browser.mainLoop.method="rAF"}else if(mode==2){if(typeof setImmediate==="undefined"){var setImmediates=[];var emscriptenMainLoopMessageId="setimmediate";var Browser_setImmediate_messageHandler=function(event){if(event.data===emscriptenMainLoopMessageId||event.data.target===emscriptenMainLoopMessageId){event.stopPropagation();setImmediates.shift()()}};addEventListener("message",Browser_setImmediate_messageHandler,true);setImmediate=function Browser_emulated_setImmediate(func){setImmediates.push(func);if(ENVIRONMENT_IS_WORKER){if(Module["setImmediates"]===undefined)Module["setImmediates"]=[];Module["setImmediates"].push(func);postMessage({target:emscriptenMainLoopMessageId})}else postMessage(emscriptenMainLoopMessageId,"*")}}Browser.mainLoop.scheduler=function Browser_mainLoop_scheduler_setImmediate(){setImmediate(Browser.mainLoop.runner)};Browser.mainLoop.method="immediate"}return 0}function _emscripten_webgl_do_commit_frame(){if(!GL.currentContext||!GL.currentContext.GLctx){return-3}if(GL.currentContext.defaultFbo){GL.blitOffscreenFramebuffer(GL.currentContext);return 0}if(!GL.currentContext.attributes.explicitSwapControl){return-3}return 0}function _emscripten_webgl_commit_frame(){return _emscripten_webgl_do_commit_frame()}function setMainLoop(browserIterationFunc,fps,simulateInfiniteLoop,arg,noSetTiming){noExitRuntime=true;assert(!Browser.mainLoop.func,"emscripten_set_main_loop: there can only be one main loop function at once: call emscripten_cancel_main_loop to cancel the previous one before setting a new one with different parameters.");Browser.mainLoop.func=browserIterationFunc;Browser.mainLoop.arg=arg;var thisMainLoopId=Browser.mainLoop.currentlyRunningMainloop;Browser.mainLoop.runner=function Browser_mainLoop_runner(){if(ABORT)return;if(Browser.mainLoop.queue.length>0){var start=Date.now();var blocker=Browser.mainLoop.queue.shift();blocker.func(blocker.arg);if(Browser.mainLoop.remainingBlockers){var remaining=Browser.mainLoop.remainingBlockers;var next=remaining%1==0?remaining-1:Math.floor(remaining);if(blocker.counted){Browser.mainLoop.remainingBlockers=next}else{next=next+.5;Browser.mainLoop.remainingBlockers=(8*remaining+next)/9}}console.log('main loop blocker "'+blocker.name+'" took '+(Date.now()-start)+" ms");Browser.mainLoop.updateStatus();if(thisMainLoopId1&&Browser.mainLoop.currentFrameNumber%Browser.mainLoop.timingValue!=0){Browser.mainLoop.scheduler();return}else if(Browser.mainLoop.timingMode==0){Browser.mainLoop.tickStartTime=_emscripten_get_now()}Browser.mainLoop.runIter(browserIterationFunc);if(thisMainLoopId0)_emscripten_set_main_loop_timing(0,1e3/fps);else _emscripten_set_main_loop_timing(1,1);Browser.mainLoop.scheduler()}if(simulateInfiniteLoop){throw"unwind"}}var Browser={mainLoop:{scheduler:null,method:"",currentlyRunningMainloop:0,func:null,arg:0,timingMode:0,timingValue:0,currentFrameNumber:0,queue:[],pause:function(){Browser.mainLoop.scheduler=null;Browser.mainLoop.currentlyRunningMainloop++},resume:function(){Browser.mainLoop.currentlyRunningMainloop++;var timingMode=Browser.mainLoop.timingMode;var timingValue=Browser.mainLoop.timingValue;var func=Browser.mainLoop.func;Browser.mainLoop.func=null;setMainLoop(func,0,false,Browser.mainLoop.arg,true);_emscripten_set_main_loop_timing(timingMode,timingValue);Browser.mainLoop.scheduler()},updateStatus:function(){if(Module["setStatus"]){var message=Module["statusMessage"]||"Please wait...";var remaining=Browser.mainLoop.remainingBlockers;var expected=Browser.mainLoop.expectedBlockers;if(remaining){if(remaining=6){var curr=leftchar>>leftbits-6&63;leftbits-=6;ret+=BASE[curr]}}if(leftbits==2){ret+=BASE[(leftchar&3)<<4];ret+=PAD+PAD}else if(leftbits==4){ret+=BASE[(leftchar&15)<<2];ret+=PAD}return ret}audio.src="data:audio/x-"+name.substr(-3)+";base64,"+encode64(byteArray);finish(audio)};audio.src=url;Browser.safeSetTimeout(function(){finish(audio)},1e4)}else{return fail()}};Module["preloadPlugins"].push(audioPlugin);function pointerLockChange(){Browser.pointerLock=document["pointerLockElement"]===Module["canvas"]||document["mozPointerLockElement"]===Module["canvas"]||document["webkitPointerLockElement"]===Module["canvas"]||document["msPointerLockElement"]===Module["canvas"]}var canvas=Module["canvas"];if(canvas){canvas.requestPointerLock=canvas["requestPointerLock"]||canvas["mozRequestPointerLock"]||canvas["webkitRequestPointerLock"]||canvas["msRequestPointerLock"]||function(){};canvas.exitPointerLock=document["exitPointerLock"]||document["mozExitPointerLock"]||document["webkitExitPointerLock"]||document["msExitPointerLock"]||function(){};canvas.exitPointerLock=canvas.exitPointerLock.bind(document);document.addEventListener("pointerlockchange",pointerLockChange,false);document.addEventListener("mozpointerlockchange",pointerLockChange,false);document.addEventListener("webkitpointerlockchange",pointerLockChange,false);document.addEventListener("mspointerlockchange",pointerLockChange,false);if(Module["elementPointerLock"]){canvas.addEventListener("click",function(ev){if(!Browser.pointerLock&&Module["canvas"].requestPointerLock){Module["canvas"].requestPointerLock();ev.preventDefault()}},false)}}},createContext:function(canvas,useWebGL,setInModule,webGLContextAttributes){if(useWebGL&&Module.ctx&&canvas==Module.canvas)return Module.ctx;var ctx;var contextHandle;if(useWebGL){var contextAttributes={antialias:false,alpha:false,majorVersion:typeof WebGL2RenderingContext!=="undefined"?2:1};if(webGLContextAttributes){for(var attribute in webGLContextAttributes){contextAttributes[attribute]=webGLContextAttributes[attribute]}}if(typeof GL!=="undefined"){contextHandle=GL.createContext(canvas,contextAttributes);if(contextHandle){ctx=GL.getContext(contextHandle).GLctx}}}else{ctx=canvas.getContext("2d")}if(!ctx)return null;if(setInModule){if(!useWebGL)assert(typeof GLctx==="undefined","cannot set in module if GLctx is used, but we are a non-GL context that would replace it");Module.ctx=ctx;if(useWebGL)GL.makeContextCurrent(contextHandle);Module.useWebGL=useWebGL;Browser.moduleContextCreatedCallbacks.forEach(function(callback){callback()});Browser.init()}return ctx},destroyContext:function(canvas,useWebGL,setInModule){},fullscreenHandlersInstalled:false,lockPointer:undefined,resizeCanvas:undefined,requestFullscreen:function(lockPointer,resizeCanvas){Browser.lockPointer=lockPointer;Browser.resizeCanvas=resizeCanvas;if(typeof Browser.lockPointer==="undefined")Browser.lockPointer=true;if(typeof Browser.resizeCanvas==="undefined")Browser.resizeCanvas=false;var canvas=Module["canvas"];function fullscreenChange(){Browser.isFullscreen=false;var canvasContainer=canvas.parentNode;if((document["fullscreenElement"]||document["mozFullScreenElement"]||document["msFullscreenElement"]||document["webkitFullscreenElement"]||document["webkitCurrentFullScreenElement"])===canvasContainer){canvas.exitFullscreen=Browser.exitFullscreen;if(Browser.lockPointer)canvas.requestPointerLock();Browser.isFullscreen=true;if(Browser.resizeCanvas){Browser.setFullscreenCanvasSize()}else{Browser.updateCanvasDimensions(canvas)}}else{canvasContainer.parentNode.insertBefore(canvas,canvasContainer);canvasContainer.parentNode.removeChild(canvasContainer);if(Browser.resizeCanvas){Browser.setWindowedCanvasSize()}else{Browser.updateCanvasDimensions(canvas)}}if(Module["onFullScreen"])Module["onFullScreen"](Browser.isFullscreen);if(Module["onFullscreen"])Module["onFullscreen"](Browser.isFullscreen)}if(!Browser.fullscreenHandlersInstalled){Browser.fullscreenHandlersInstalled=true;document.addEventListener("fullscreenchange",fullscreenChange,false);document.addEventListener("mozfullscreenchange",fullscreenChange,false);document.addEventListener("webkitfullscreenchange",fullscreenChange,false);document.addEventListener("MSFullscreenChange",fullscreenChange,false)}var canvasContainer=document.createElement("div");canvas.parentNode.insertBefore(canvasContainer,canvas);canvasContainer.appendChild(canvas);canvasContainer.requestFullscreen=canvasContainer["requestFullscreen"]||canvasContainer["mozRequestFullScreen"]||canvasContainer["msRequestFullscreen"]||(canvasContainer["webkitRequestFullscreen"]?function(){canvasContainer["webkitRequestFullscreen"](Element["ALLOW_KEYBOARD_INPUT"])}:null)||(canvasContainer["webkitRequestFullScreen"]?function(){canvasContainer["webkitRequestFullScreen"](Element["ALLOW_KEYBOARD_INPUT"])}:null);canvasContainer.requestFullscreen()},exitFullscreen:function(){if(!Browser.isFullscreen){return false}var CFS=document["exitFullscreen"]||document["cancelFullScreen"]||document["mozCancelFullScreen"]||document["msExitFullscreen"]||document["webkitCancelFullScreen"]||function(){};CFS.apply(document,[]);return true},nextRAF:0,fakeRequestAnimationFrame:function(func){var now=Date.now();if(Browser.nextRAF===0){Browser.nextRAF=now+1e3/60}else{while(now+2>=Browser.nextRAF){Browser.nextRAF+=1e3/60}}var delay=Math.max(Browser.nextRAF-now,0);setTimeout(func,delay)},requestAnimationFrame:function(func){if(typeof requestAnimationFrame==="function"){requestAnimationFrame(func);return}var RAF=Browser.fakeRequestAnimationFrame;RAF(func)},safeRequestAnimationFrame:function(func){return Browser.requestAnimationFrame(function(){if(ABORT)return;func()})},safeSetTimeout:function(func,timeout){noExitRuntime=true;return setTimeout(function(){if(ABORT)return;func()},timeout)},getMimetype:function(name){return{"jpg":"image/jpeg","jpeg":"image/jpeg","png":"image/png","bmp":"image/bmp","ogg":"audio/ogg","wav":"audio/wav","mp3":"audio/mpeg"}[name.substr(name.lastIndexOf(".")+1)]},getUserMedia:function(func){if(!window.getUserMedia){window.getUserMedia=navigator["getUserMedia"]||navigator["mozGetUserMedia"]}window.getUserMedia(func)},getMovementX:function(event){return event["movementX"]||event["mozMovementX"]||event["webkitMovementX"]||0},getMovementY:function(event){return event["movementY"]||event["mozMovementY"]||event["webkitMovementY"]||0},getMouseWheelDelta:function(event){var delta=0;switch(event.type){case"DOMMouseScroll":delta=event.detail/3;break;case"mousewheel":delta=event.wheelDelta/120;break;case"wheel":delta=event.deltaY;switch(event.deltaMode){case 0:delta/=100;break;case 1:delta/=3;break;case 2:delta*=80;break;default:throw"unrecognized mouse wheel delta mode: "+event.deltaMode}break;default:throw"unrecognized mouse wheel event: "+event.type}return delta},mouseX:0,mouseY:0,mouseMovementX:0,mouseMovementY:0,touches:{},lastTouches:{},calculateMouseEvent:function(event){if(Browser.pointerLock){if(event.type!="mousemove"&&"mozMovementX"in event){Browser.mouseMovementX=Browser.mouseMovementY=0}else{Browser.mouseMovementX=Browser.getMovementX(event);Browser.mouseMovementY=Browser.getMovementY(event)}if(typeof SDL!="undefined"){Browser.mouseX=SDL.mouseX+Browser.mouseMovementX;Browser.mouseY=SDL.mouseY+Browser.mouseMovementY}else{Browser.mouseX+=Browser.mouseMovementX;Browser.mouseY+=Browser.mouseMovementY}}else{var rect=Module["canvas"].getBoundingClientRect();var cw=Module["canvas"].width;var ch=Module["canvas"].height;var scrollX=typeof window.scrollX!=="undefined"?window.scrollX:window.pageXOffset;var scrollY=typeof window.scrollY!=="undefined"?window.scrollY:window.pageYOffset;if(event.type==="touchstart"||event.type==="touchend"||event.type==="touchmove"){var touch=event.touch;if(touch===undefined){return}var adjustedX=touch.pageX-(scrollX+rect.left);var adjustedY=touch.pageY-(scrollY+rect.top);adjustedX=adjustedX*(cw/rect.width);adjustedY=adjustedY*(ch/rect.height);var coords={x:adjustedX,y:adjustedY};if(event.type==="touchstart"){Browser.lastTouches[touch.identifier]=coords;Browser.touches[touch.identifier]=coords}else if(event.type==="touchend"||event.type==="touchmove"){var last=Browser.touches[touch.identifier];if(!last)last=coords;Browser.lastTouches[touch.identifier]=last;Browser.touches[touch.identifier]=coords}return}var x=event.pageX-(scrollX+rect.left);var y=event.pageY-(scrollY+rect.top);x=x*(cw/rect.width);y=y*(ch/rect.height);Browser.mouseMovementX=x-Browser.mouseX;Browser.mouseMovementY=y-Browser.mouseY;Browser.mouseX=x;Browser.mouseY=y}},asyncLoad:function(url,onload,onerror,noRunDep){var dep=!noRunDep?getUniqueRunDependency("al "+url):"";readAsync(url,function(arrayBuffer){assert(arrayBuffer,'Loading data file "'+url+'" failed (no arrayBuffer).');onload(new Uint8Array(arrayBuffer));if(dep)removeRunDependency(dep)},function(event){if(onerror){onerror()}else{throw'Loading data file "'+url+'" failed.'}});if(dep)addRunDependency(dep)},resizeListeners:[],updateResizeListeners:function(){var canvas=Module["canvas"];Browser.resizeListeners.forEach(function(listener){listener(canvas.width,canvas.height)})},setCanvasSize:function(width,height,noUpdates){var canvas=Module["canvas"];Browser.updateCanvasDimensions(canvas,width,height);if(!noUpdates)Browser.updateResizeListeners()},windowedWidth:0,windowedHeight:0,setFullscreenCanvasSize:function(){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen>>2];flags=flags|8388608;HEAP32[SDL.screen>>2]=flags}Browser.updateCanvasDimensions(Module["canvas"]);Browser.updateResizeListeners()},setWindowedCanvasSize:function(){if(typeof SDL!="undefined"){var flags=HEAPU32[SDL.screen>>2];flags=flags&~8388608;HEAP32[SDL.screen>>2]=flags}Browser.updateCanvasDimensions(Module["canvas"]);Browser.updateResizeListeners()},updateCanvasDimensions:function(canvas,wNative,hNative){if(wNative&&hNative){canvas.widthNative=wNative;canvas.heightNative=hNative}else{wNative=canvas.widthNative;hNative=canvas.heightNative}var w=wNative;var h=hNative;if(Module["forcedAspectRatio"]&&Module["forcedAspectRatio"]>0){if(w/h=0;--i){JSEvents._removeHandler(i)}JSEvents.eventHandlers=[];JSEvents.deferredCalls=[]},registerRemoveEventListeners:function(){if(!JSEvents.removeEventListenersRegistered){__ATEXIT__.push(JSEvents.removeAllEventListeners);JSEvents.removeEventListenersRegistered=true}},deferredCalls:[],deferCall:function(targetFunction,precedence,argsList){function arraysHaveEqualContent(arrA,arrB){if(arrA.length!=arrB.length)return false;for(var i in arrA){if(arrA[i]!=arrB[i])return false}return true}for(var i in JSEvents.deferredCalls){var call=JSEvents.deferredCalls[i];if(call.targetFunction==targetFunction&&arraysHaveEqualContent(call.argsList,argsList)){return}}JSEvents.deferredCalls.push({targetFunction:targetFunction,precedence:precedence,argsList:argsList});JSEvents.deferredCalls.sort(function(x,y){return x.precedence2?UTF8ToString(cString):cString}var specialHTMLTargets=[0,typeof document!=="undefined"?document:0,typeof window!=="undefined"?window:0];function findEventTarget(target){target=maybeCStringToJsString(target);var domElement=specialHTMLTargets[target]||(typeof document!=="undefined"?document.querySelector(target):undefined);return domElement}function findCanvasEventTarget(target){return findEventTarget(target)}function _emscripten_get_canvas_element_size(target,width,height){var canvas=findCanvasEventTarget(target);if(!canvas)return-4;HEAP32[width>>2]=canvas.width;HEAP32[height>>2]=canvas.height}function getCanvasElementSize(target){var stackTop=stackSave();var w=stackAlloc(8);var h=w+4;var targetInt=stackAlloc(target.id.length+1);stringToUTF8(target.id,targetInt,target.id.length+1);var ret=_emscripten_get_canvas_element_size(targetInt,w,h);var size=[HEAP32[w>>2],HEAP32[h>>2]];stackRestore(stackTop);return size}function _emscripten_set_canvas_element_size(target,width,height){var canvas=findCanvasEventTarget(target);if(!canvas)return-4;canvas.width=width;canvas.height=height;if(canvas.GLctxObject)GL.resizeOffscreenFramebuffer(canvas.GLctxObject);return 0}function setCanvasElementSize(target,width,height){if(!target.controlTransferredOffscreen){target.width=width;target.height=height}else{var stackTop=stackSave();var targetInt=stackAlloc(target.id.length+1);stringToUTF8(target.id,targetInt,target.id.length+1);_emscripten_set_canvas_element_size(targetInt,width,height);stackRestore(stackTop)}}function registerRestoreOldStyle(canvas){var canvasSize=getCanvasElementSize(canvas);var oldWidth=canvasSize[0];var oldHeight=canvasSize[1];var oldCssWidth=canvas.style.width;var oldCssHeight=canvas.style.height;var oldBackgroundColor=canvas.style.backgroundColor;var oldDocumentBackgroundColor=document.body.style.backgroundColor;var oldPaddingLeft=canvas.style.paddingLeft;var oldPaddingRight=canvas.style.paddingRight;var oldPaddingTop=canvas.style.paddingTop;var oldPaddingBottom=canvas.style.paddingBottom;var oldMarginLeft=canvas.style.marginLeft;var oldMarginRight=canvas.style.marginRight;var oldMarginTop=canvas.style.marginTop;var oldMarginBottom=canvas.style.marginBottom;var oldDocumentBodyMargin=document.body.style.margin;var oldDocumentOverflow=document.documentElement.style.overflow;var oldDocumentScroll=document.body.scroll;var oldImageRendering=canvas.style.imageRendering;function restoreOldStyle(){var fullscreenElement=document.fullscreenElement||document.webkitFullscreenElement||document.msFullscreenElement;if(!fullscreenElement){document.removeEventListener("fullscreenchange",restoreOldStyle);document.removeEventListener("webkitfullscreenchange",restoreOldStyle);setCanvasElementSize(canvas,oldWidth,oldHeight);canvas.style.width=oldCssWidth;canvas.style.height=oldCssHeight;canvas.style.backgroundColor=oldBackgroundColor;if(!oldDocumentBackgroundColor)document.body.style.backgroundColor="white";document.body.style.backgroundColor=oldDocumentBackgroundColor;canvas.style.paddingLeft=oldPaddingLeft;canvas.style.paddingRight=oldPaddingRight;canvas.style.paddingTop=oldPaddingTop;canvas.style.paddingBottom=oldPaddingBottom;canvas.style.marginLeft=oldMarginLeft;canvas.style.marginRight=oldMarginRight;canvas.style.marginTop=oldMarginTop;canvas.style.marginBottom=oldMarginBottom;document.body.style.margin=oldDocumentBodyMargin;document.documentElement.style.overflow=oldDocumentOverflow;document.body.scroll=oldDocumentScroll;canvas.style.imageRendering=oldImageRendering;if(canvas.GLctxObject)canvas.GLctxObject.GLctx.viewport(0,0,oldWidth,oldHeight);if(currentFullscreenStrategy.canvasResizedCallback){wasmTable.get(currentFullscreenStrategy.canvasResizedCallback)(37,0,currentFullscreenStrategy.canvasResizedCallbackUserData)}}}document.addEventListener("fullscreenchange",restoreOldStyle);document.addEventListener("webkitfullscreenchange",restoreOldStyle);return restoreOldStyle}function restoreHiddenElements(hiddenElements){for(var i=0;ix*h)w=h*x/y|0;topMargin=(screenHeight-h)/2|0}if(inPixelPerfectFullscreenMode){setCanvasElementSize(canvas,w,h);if(canvas.GLctxObject)canvas.GLctxObject.GLctx.viewport(0,0,w,h)}if(inHiDPIFullscreenMode){topMargin/=dpr;w/=dpr;h/=dpr;w=Math.round(w*1e4)/1e4;h=Math.round(h*1e4)/1e4;topMargin=Math.round(topMargin*1e4)/1e4}if(inCenteredWithoutScalingFullscreenMode){var t=(innerHeight-jstoi_q(canvas.style.height))/2;var b=(innerWidth-jstoi_q(canvas.style.width))/2;setLetterbox(canvas,t,b)}else{canvas.style.width=w+"px";canvas.style.height=h+"px";var b=(innerWidth-w)/2;setLetterbox(canvas,topMargin,b)}if(!inCenteredWithoutScalingFullscreenMode&¤tFullscreenStrategy.canvasResizedCallback){wasmTable.get(currentFullscreenStrategy.canvasResizedCallback)(37,0,currentFullscreenStrategy.canvasResizedCallbackUserData)}}function getBoundingClientRect(e){return specialHTMLTargets.indexOf(e)<0?e.getBoundingClientRect():{"left":0,"top":0}}function _JSEvents_resizeCanvasForFullscreen(target,strategy){var restoreOldStyle=registerRestoreOldStyle(target);var cssWidth=strategy.softFullscreen?innerWidth:screen.width;var cssHeight=strategy.softFullscreen?innerHeight:screen.height;var rect=getBoundingClientRect(target);var windowedCssWidth=rect.width;var windowedCssHeight=rect.height;var canvasSize=getCanvasElementSize(target);var windowedRttWidth=canvasSize[0];var windowedRttHeight=canvasSize[1];if(strategy.scaleMode==3){setLetterbox(target,(cssHeight-windowedCssHeight)/2,(cssWidth-windowedCssWidth)/2);cssWidth=windowedCssWidth;cssHeight=windowedCssHeight}else if(strategy.scaleMode==2){if(cssWidth*windowedRttHeight>2],canvasResolutionScaleMode:HEAP32[fullscreenStrategy+4>>2],filteringMode:HEAP32[fullscreenStrategy+8>>2],canvasResizedCallback:HEAP32[fullscreenStrategy+12>>2],canvasResizedCallbackUserData:HEAP32[fullscreenStrategy+16>>2],target:target,softFullscreen:true};var restoreOldStyle=_JSEvents_resizeCanvasForFullscreen(target,strategy);document.documentElement.style.overflow="hidden";document.body.scroll="no";document.body.style.margin="0px";var hiddenElements=hideEverythingExceptGivenElement(target);function restoreWindowedState(){restoreOldStyle();restoreHiddenElements(hiddenElements);removeEventListener("resize",softFullscreenResizeWebGLRenderTarget);if(strategy.canvasResizedCallback){wasmTable.get(strategy.canvasResizedCallback)(37,0,strategy.canvasResizedCallbackUserData)}currentFullscreenStrategy=0}restoreOldWindowedStyle=restoreWindowedState;currentFullscreenStrategy=strategy;addEventListener("resize",softFullscreenResizeWebGLRenderTarget);if(strategy.canvasResizedCallback){wasmTable.get(strategy.canvasResizedCallback)(37,0,strategy.canvasResizedCallbackUserData)}return 0}function requestPointerLock(target){if(target.requestPointerLock){target.requestPointerLock()}else if(target.msRequestPointerLock){target.msRequestPointerLock()}else{if(document.body.requestPointerLock||document.body.msRequestPointerLock){return-3}else{return-1}}return 0}function _emscripten_exit_pointerlock(){JSEvents.removeDeferredCalls(requestPointerLock);if(document.exitPointerLock){document.exitPointerLock()}else if(document.msExitPointerLock){document.msExitPointerLock()}else{return-1}return 0}function _emscripten_exit_soft_fullscreen(){if(restoreOldWindowedStyle)restoreOldWindowedStyle();restoreOldWindowedStyle=null;return 0}function _emscripten_force_exit(status){noExitRuntime=false;exit(status)}function fillPointerlockChangeEventData(eventStruct){var pointerLockElement=document.pointerLockElement||document.mozPointerLockElement||document.webkitPointerLockElement||document.msPointerLockElement;var isPointerlocked=!!pointerLockElement;HEAP32[eventStruct>>2]=isPointerlocked;var nodeName=JSEvents.getNodeNameForTarget(pointerLockElement);var id=pointerLockElement&&pointerLockElement.id?pointerLockElement.id:"";stringToUTF8(nodeName,eventStruct+4,128);stringToUTF8(id,eventStruct+132,128)}function _emscripten_get_pointerlock_status(pointerlockStatus){if(pointerlockStatus)fillPointerlockChangeEventData(pointerlockStatus);if(!document.body||!document.body.requestPointerLock&&!document.body.mozRequestPointerLock&&!document.body.webkitRequestPointerLock&&!document.body.msRequestPointerLock){return-1}return 0}function __webgl_enable_ANGLE_instanced_arrays(ctx){var ext=ctx.getExtension("ANGLE_instanced_arrays");if(ext){ctx["vertexAttribDivisor"]=function(index,divisor){ext["vertexAttribDivisorANGLE"](index,divisor)};ctx["drawArraysInstanced"]=function(mode,first,count,primcount){ext["drawArraysInstancedANGLE"](mode,first,count,primcount)};ctx["drawElementsInstanced"]=function(mode,count,type,indices,primcount){ext["drawElementsInstancedANGLE"](mode,count,type,indices,primcount)};return 1}}function __webgl_enable_OES_vertex_array_object(ctx){var ext=ctx.getExtension("OES_vertex_array_object");if(ext){ctx["createVertexArray"]=function(){return ext["createVertexArrayOES"]()};ctx["deleteVertexArray"]=function(vao){ext["deleteVertexArrayOES"](vao)};ctx["bindVertexArray"]=function(vao){ext["bindVertexArrayOES"](vao)};ctx["isVertexArray"]=function(vao){return ext["isVertexArrayOES"](vao)};return 1}}function __webgl_enable_WEBGL_draw_buffers(ctx){var ext=ctx.getExtension("WEBGL_draw_buffers");if(ext){ctx["drawBuffers"]=function(n,bufs){ext["drawBuffersWEBGL"](n,bufs)};return 1}}function __webgl_enable_WEBGL_draw_instanced_base_vertex_base_instance(ctx){return!!(ctx.dibvbi=ctx.getExtension("WEBGL_draw_instanced_base_vertex_base_instance"))}function __webgl_enable_WEBGL_multi_draw_instanced_base_vertex_base_instance(ctx){return!!(ctx.mdibvbi=ctx.getExtension("WEBGL_multi_draw_instanced_base_vertex_base_instance"))}function __webgl_enable_WEBGL_multi_draw(ctx){return!!(ctx.multiDrawWebgl=ctx.getExtension("WEBGL_multi_draw"))}var GL={counter:1,buffers:[],programs:[],framebuffers:[],renderbuffers:[],textures:[],uniforms:[],shaders:[],vaos:[],contexts:[],offscreenCanvases:{},timerQueriesEXT:[],queries:[],samplers:[],transformFeedbacks:[],syncs:[],programInfos:{},stringCache:{},stringiCache:{},unpackAlignment:4,recordError:function recordError(errorCode){if(!GL.lastError){GL.lastError=errorCode}},getNewId:function(table){var ret=GL.counter++;for(var i=table.length;i>2]:-1;source+=UTF8ToString(HEAP32[string+i*4>>2],len<0?undefined:len)}return source},createContext:function(canvas,webGLContextAttributes){if(webGLContextAttributes.renderViaOffscreenBackBuffer)webGLContextAttributes["preserveDrawingBuffer"]=true;var ctx=webGLContextAttributes.majorVersion>1?canvas.getContext("webgl2",webGLContextAttributes):canvas.getContext("webgl",webGLContextAttributes);if(!ctx)return 0;var handle=GL.registerContext(ctx,webGLContextAttributes);return handle},enableOffscreenFramebufferAttributes:function(webGLContextAttributes){webGLContextAttributes.renderViaOffscreenBackBuffer=true;webGLContextAttributes.preserveDrawingBuffer=true},createOffscreenFramebuffer:function(context){var gl=context.GLctx;var fbo=gl.createFramebuffer();gl.bindFramebuffer(36160,fbo);context.defaultFbo=fbo;context.defaultFboForbidBlitFramebuffer=false;if(gl.getContextAttributes().antialias){context.defaultFboForbidBlitFramebuffer=true}else{var firefoxMatch=navigator.userAgent.toLowerCase().match(/firefox\/(\d\d)/);if(firefoxMatch!=null){var firefoxVersion=firefoxMatch[1];context.defaultFboForbidBlitFramebuffer=firefoxVersion<67}}context.defaultColorTarget=gl.createTexture();context.defaultDepthTarget=gl.createRenderbuffer();GL.resizeOffscreenFramebuffer(context);gl.bindTexture(3553,context.defaultColorTarget);gl.texParameteri(3553,10241,9728);gl.texParameteri(3553,10240,9728);gl.texParameteri(3553,10242,33071);gl.texParameteri(3553,10243,33071);gl.texImage2D(3553,0,6408,gl.canvas.width,gl.canvas.height,0,6408,5121,null);gl.framebufferTexture2D(36160,36064,3553,context.defaultColorTarget,0);gl.bindTexture(3553,null);var depthTarget=gl.createRenderbuffer();gl.bindRenderbuffer(36161,context.defaultDepthTarget);gl.renderbufferStorage(36161,33189,gl.canvas.width,gl.canvas.height);gl.framebufferRenderbuffer(36160,36096,36161,context.defaultDepthTarget);gl.bindRenderbuffer(36161,null);var vertices=[-1,-1,-1,1,1,-1,1,1];var vb=gl.createBuffer();gl.bindBuffer(34962,vb);gl.bufferData(34962,new Float32Array(vertices),35044);gl.bindBuffer(34962,null);context.blitVB=vb;var vsCode="attribute vec2 pos;"+"varying lowp vec2 tex;"+"void main() { tex = pos * 0.5 + vec2(0.5,0.5); gl_Position = vec4(pos, 0.0, 1.0); }";var vs=gl.createShader(35633);gl.shaderSource(vs,vsCode);gl.compileShader(vs);var fsCode="varying lowp vec2 tex;"+"uniform sampler2D sampler;"+"void main() { gl_FragColor = texture2D(sampler, tex); }";var fs=gl.createShader(35632);gl.shaderSource(fs,fsCode);gl.compileShader(fs);var blitProgram=gl.createProgram();gl.attachShader(blitProgram,vs);gl.attachShader(blitProgram,fs);gl.linkProgram(blitProgram);context.blitProgram=blitProgram;context.blitPosLoc=gl.getAttribLocation(blitProgram,"pos");gl.useProgram(blitProgram);gl.uniform1i(gl.getUniformLocation(blitProgram,"sampler"),0);gl.useProgram(null);context.defaultVao=undefined;if(gl.createVertexArray){context.defaultVao=gl.createVertexArray();gl.bindVertexArray(context.defaultVao);gl.enableVertexAttribArray(context.blitPosLoc);gl.bindVertexArray(null)}},resizeOffscreenFramebuffer:function(context){var gl=context.GLctx;if(context.defaultColorTarget){var prevTextureBinding=gl.getParameter(32873);gl.bindTexture(3553,context.defaultColorTarget);gl.texImage2D(3553,0,6408,gl.drawingBufferWidth,gl.drawingBufferHeight,0,6408,5121,null);gl.bindTexture(3553,prevTextureBinding)}if(context.defaultDepthTarget){var prevRenderBufferBinding=gl.getParameter(36007);gl.bindRenderbuffer(36161,context.defaultDepthTarget);gl.renderbufferStorage(36161,33189,gl.drawingBufferWidth,gl.drawingBufferHeight);gl.bindRenderbuffer(36161,prevRenderBufferBinding)}},blitOffscreenFramebuffer:function(context){var gl=context.GLctx;var prevScissorTest=gl.getParameter(3089);if(prevScissorTest)gl.disable(3089);var prevFbo=gl.getParameter(36006);if(gl.blitFramebuffer&&!context.defaultFboForbidBlitFramebuffer){gl.bindFramebuffer(36008,context.defaultFbo);gl.bindFramebuffer(36009,null);gl.blitFramebuffer(0,0,gl.canvas.width,gl.canvas.height,0,0,gl.canvas.width,gl.canvas.height,16384,9728)}else{gl.bindFramebuffer(36160,null);var prevProgram=gl.getParameter(35725);gl.useProgram(context.blitProgram);var prevVB=gl.getParameter(34964);gl.bindBuffer(34962,context.blitVB);var prevActiveTexture=gl.getParameter(34016);gl.activeTexture(33984);var prevTextureBinding=gl.getParameter(32873);gl.bindTexture(3553,context.defaultColorTarget);var prevBlend=gl.getParameter(3042);if(prevBlend)gl.disable(3042);var prevCullFace=gl.getParameter(2884);if(prevCullFace)gl.disable(2884);var prevDepthTest=gl.getParameter(2929);if(prevDepthTest)gl.disable(2929);var prevStencilTest=gl.getParameter(2960);if(prevStencilTest)gl.disable(2960);function draw(){gl.vertexAttribPointer(context.blitPosLoc,2,5126,false,0,0);gl.drawArrays(5,0,4)}if(context.defaultVao){var prevVAO=gl.getParameter(34229);gl.bindVertexArray(context.defaultVao);draw();gl.bindVertexArray(prevVAO)}else{var prevVertexAttribPointer={buffer:gl.getVertexAttrib(context.blitPosLoc,34975),size:gl.getVertexAttrib(context.blitPosLoc,34339),stride:gl.getVertexAttrib(context.blitPosLoc,34340),type:gl.getVertexAttrib(context.blitPosLoc,34341),normalized:gl.getVertexAttrib(context.blitPosLoc,34922),pointer:gl.getVertexAttribOffset(context.blitPosLoc,34373)};var maxVertexAttribs=gl.getParameter(34921);var prevVertexAttribEnables=[];for(var i=0;i=2){if(data){GLctx.bufferData(target,HEAPU8,usage,data,size)}else{GLctx.bufferData(target,size,usage)}}else{GLctx.bufferData(target,data?HEAPU8.subarray(data,data+size):size,usage)}}function _emscripten_glBufferSubData(target,offset,size,data){if(GL.currentContext.version>=2){GLctx.bufferSubData(target,offset,HEAPU8,data,size);return}GLctx.bufferSubData(target,offset,HEAPU8.subarray(data,data+size))}function _emscripten_glCheckFramebufferStatus(x0){return GLctx["checkFramebufferStatus"](x0)}function _emscripten_glClear(x0){GLctx["clear"](x0)}function _emscripten_glClearBufferfi(x0,x1,x2,x3){GLctx["clearBufferfi"](x0,x1,x2,x3)}function _emscripten_glClearBufferfv(buffer,drawbuffer,value){GLctx["clearBufferfv"](buffer,drawbuffer,HEAPF32,value>>2)}function _emscripten_glClearBufferiv(buffer,drawbuffer,value){GLctx["clearBufferiv"](buffer,drawbuffer,HEAP32,value>>2)}function _emscripten_glClearBufferuiv(buffer,drawbuffer,value){GLctx["clearBufferuiv"](buffer,drawbuffer,HEAPU32,value>>2)}function _emscripten_glClearColor(x0,x1,x2,x3){GLctx["clearColor"](x0,x1,x2,x3)}function _emscripten_glClearDepthf(x0){GLctx["clearDepth"](x0)}function _emscripten_glClearStencil(x0){GLctx["clearStencil"](x0)}function convertI32PairToI53(lo,hi){return(lo>>>0)+hi*4294967296}function _emscripten_glClientWaitSync(sync,flags,timeoutLo,timeoutHi){return GLctx.clientWaitSync(GL.syncs[sync],flags,convertI32PairToI53(timeoutLo,timeoutHi))}function _emscripten_glColorMask(red,green,blue,alpha){GLctx.colorMask(!!red,!!green,!!blue,!!alpha)}function _emscripten_glCompileShader(shader){GLctx.compileShader(GL.shaders[shader])}function _emscripten_glCompressedTexImage2D(target,level,internalFormat,width,height,border,imageSize,data){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,imageSize,data)}else{GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,HEAPU8,data,imageSize)}return}GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,data?HEAPU8.subarray(data,data+imageSize):null)}function _emscripten_glCompressedTexImage3D(target,level,internalFormat,width,height,depth,border,imageSize,data){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexImage3D"](target,level,internalFormat,width,height,depth,border,imageSize,data)}else{GLctx["compressedTexImage3D"](target,level,internalFormat,width,height,depth,border,HEAPU8,data,imageSize)}}function _emscripten_glCompressedTexSubImage2D(target,level,xoffset,yoffset,width,height,format,imageSize,data){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,imageSize,data)}else{GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,HEAPU8,data,imageSize)}return}GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,data?HEAPU8.subarray(data,data+imageSize):null)}function _emscripten_glCompressedTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data)}else{GLctx["compressedTexSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,HEAPU8,data,imageSize)}}function _emscripten_glCopyBufferSubData(x0,x1,x2,x3,x4){GLctx["copyBufferSubData"](x0,x1,x2,x3,x4)}function _emscripten_glCopyTexImage2D(x0,x1,x2,x3,x4,x5,x6,x7){GLctx["copyTexImage2D"](x0,x1,x2,x3,x4,x5,x6,x7)}function _emscripten_glCopyTexSubImage2D(x0,x1,x2,x3,x4,x5,x6,x7){GLctx["copyTexSubImage2D"](x0,x1,x2,x3,x4,x5,x6,x7)}function _emscripten_glCopyTexSubImage3D(x0,x1,x2,x3,x4,x5,x6,x7,x8){GLctx["copyTexSubImage3D"](x0,x1,x2,x3,x4,x5,x6,x7,x8)}function _emscripten_glCreateProgram(){var id=GL.getNewId(GL.programs);var program=GLctx.createProgram();program.name=id;GL.programs[id]=program;return id}function _emscripten_glCreateShader(shaderType){var id=GL.getNewId(GL.shaders);GL.shaders[id]=GLctx.createShader(shaderType);return id}function _emscripten_glCullFace(x0){GLctx["cullFace"](x0)}function _emscripten_glDeleteBuffers(n,buffers){for(var i=0;i>2];var buffer=GL.buffers[id];if(!buffer)continue;GLctx.deleteBuffer(buffer);buffer.name=0;GL.buffers[id]=null;if(id==GLctx.currentPixelPackBufferBinding)GLctx.currentPixelPackBufferBinding=0;if(id==GLctx.currentPixelUnpackBufferBinding)GLctx.currentPixelUnpackBufferBinding=0}}function _emscripten_glDeleteFramebuffers(n,framebuffers){for(var i=0;i>2];var framebuffer=GL.framebuffers[id];if(!framebuffer)continue;GLctx.deleteFramebuffer(framebuffer);framebuffer.name=0;GL.framebuffers[id]=null}}function _emscripten_glDeleteProgram(id){if(!id)return;var program=GL.programs[id];if(!program){GL.recordError(1281);return}GLctx.deleteProgram(program);program.name=0;GL.programs[id]=null;GL.programInfos[id]=null}function _emscripten_glDeleteQueries(n,ids){for(var i=0;i>2];var query=GL.queries[id];if(!query)continue;GLctx["deleteQuery"](query);GL.queries[id]=null}}function _emscripten_glDeleteQueriesEXT(n,ids){for(var i=0;i>2];var query=GL.timerQueriesEXT[id];if(!query)continue;GLctx.disjointTimerQueryExt["deleteQueryEXT"](query);GL.timerQueriesEXT[id]=null}}function _emscripten_glDeleteRenderbuffers(n,renderbuffers){for(var i=0;i>2];var renderbuffer=GL.renderbuffers[id];if(!renderbuffer)continue;GLctx.deleteRenderbuffer(renderbuffer);renderbuffer.name=0;GL.renderbuffers[id]=null}}function _emscripten_glDeleteSamplers(n,samplers){for(var i=0;i>2];var sampler=GL.samplers[id];if(!sampler)continue;GLctx["deleteSampler"](sampler);sampler.name=0;GL.samplers[id]=null}}function _emscripten_glDeleteShader(id){if(!id)return;var shader=GL.shaders[id];if(!shader){GL.recordError(1281);return}GLctx.deleteShader(shader);GL.shaders[id]=null}function _emscripten_glDeleteSync(id){if(!id)return;var sync=GL.syncs[id];if(!sync){GL.recordError(1281);return}GLctx.deleteSync(sync);sync.name=0;GL.syncs[id]=null}function _emscripten_glDeleteTextures(n,textures){for(var i=0;i>2];var texture=GL.textures[id];if(!texture)continue;GLctx.deleteTexture(texture);texture.name=0;GL.textures[id]=null}}function _emscripten_glDeleteTransformFeedbacks(n,ids){for(var i=0;i>2];var transformFeedback=GL.transformFeedbacks[id];if(!transformFeedback)continue;GLctx["deleteTransformFeedback"](transformFeedback);transformFeedback.name=0;GL.transformFeedbacks[id]=null}}function _emscripten_glDeleteVertexArrays(n,vaos){for(var i=0;i>2];GLctx["deleteVertexArray"](GL.vaos[id]);GL.vaos[id]=null}}function _emscripten_glDeleteVertexArraysOES(n,vaos){for(var i=0;i>2];GLctx["deleteVertexArray"](GL.vaos[id]);GL.vaos[id]=null}}function _emscripten_glDepthFunc(x0){GLctx["depthFunc"](x0)}function _emscripten_glDepthMask(flag){GLctx.depthMask(!!flag)}function _emscripten_glDepthRangef(x0,x1){GLctx["depthRange"](x0,x1)}function _emscripten_glDetachShader(program,shader){GLctx.detachShader(GL.programs[program],GL.shaders[shader])}function _emscripten_glDisable(x0){GLctx["disable"](x0)}function _emscripten_glDisableVertexAttribArray(index){GLctx.disableVertexAttribArray(index)}function _emscripten_glDrawArrays(mode,first,count){GLctx.drawArrays(mode,first,count)}function _emscripten_glDrawArraysInstanced(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}function _emscripten_glDrawArraysInstancedANGLE(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}function _emscripten_glDrawArraysInstancedARB(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}function _emscripten_glDrawArraysInstancedEXT(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}function _emscripten_glDrawArraysInstancedNV(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}var tempFixedLengthArray=[];function _emscripten_glDrawBuffers(n,bufs){var bufArray=tempFixedLengthArray[n];for(var i=0;i>2]}GLctx["drawBuffers"](bufArray)}function _emscripten_glDrawBuffersEXT(n,bufs){var bufArray=tempFixedLengthArray[n];for(var i=0;i>2]}GLctx["drawBuffers"](bufArray)}function _emscripten_glDrawBuffersWEBGL(n,bufs){var bufArray=tempFixedLengthArray[n];for(var i=0;i>2]}GLctx["drawBuffers"](bufArray)}function _emscripten_glDrawElements(mode,count,type,indices){GLctx.drawElements(mode,count,type,indices)}function _emscripten_glDrawElementsInstanced(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _emscripten_glDrawElementsInstancedANGLE(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _emscripten_glDrawElementsInstancedARB(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _emscripten_glDrawElementsInstancedEXT(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _emscripten_glDrawElementsInstancedNV(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _glDrawElements(mode,count,type,indices){GLctx.drawElements(mode,count,type,indices)}function _emscripten_glDrawRangeElements(mode,start,end,count,type,indices){_glDrawElements(mode,count,type,indices)}function _emscripten_glEnable(x0){GLctx["enable"](x0)}function _emscripten_glEnableVertexAttribArray(index){GLctx.enableVertexAttribArray(index)}function _emscripten_glEndQuery(x0){GLctx["endQuery"](x0)}function _emscripten_glEndQueryEXT(target){GLctx.disjointTimerQueryExt["endQueryEXT"](target)}function _emscripten_glEndTransformFeedback(){GLctx["endTransformFeedback"]()}function _emscripten_glFenceSync(condition,flags){var sync=GLctx.fenceSync(condition,flags);if(sync){var id=GL.getNewId(GL.syncs);sync.name=id;GL.syncs[id]=sync;return id}else{return 0}}function _emscripten_glFinish(){GLctx["finish"]()}function _emscripten_glFlush(){GLctx["flush"]()}function _emscripten_glFramebufferRenderbuffer(target,attachment,renderbuffertarget,renderbuffer){GLctx.framebufferRenderbuffer(target,attachment,renderbuffertarget,GL.renderbuffers[renderbuffer])}function _emscripten_glFramebufferTexture2D(target,attachment,textarget,texture,level){GLctx.framebufferTexture2D(target,attachment,textarget,GL.textures[texture],level)}function _emscripten_glFramebufferTextureLayer(target,attachment,texture,level,layer){GLctx.framebufferTextureLayer(target,attachment,GL.textures[texture],level,layer)}function _emscripten_glFrontFace(x0){GLctx["frontFace"](x0)}function __glGenObject(n,buffers,createFunction,objectTable){for(var i=0;i>2]=id}}function _emscripten_glGenBuffers(n,buffers){__glGenObject(n,buffers,"createBuffer",GL.buffers)}function _emscripten_glGenFramebuffers(n,ids){__glGenObject(n,ids,"createFramebuffer",GL.framebuffers)}function _emscripten_glGenQueries(n,ids){__glGenObject(n,ids,"createQuery",GL.queries)}function _emscripten_glGenQueriesEXT(n,ids){for(var i=0;i>2]=0;return}var id=GL.getNewId(GL.timerQueriesEXT);query.name=id;GL.timerQueriesEXT[id]=query;HEAP32[ids+i*4>>2]=id}}function _emscripten_glGenRenderbuffers(n,renderbuffers){__glGenObject(n,renderbuffers,"createRenderbuffer",GL.renderbuffers)}function _emscripten_glGenSamplers(n,samplers){__glGenObject(n,samplers,"createSampler",GL.samplers)}function _emscripten_glGenTextures(n,textures){__glGenObject(n,textures,"createTexture",GL.textures)}function _emscripten_glGenTransformFeedbacks(n,ids){__glGenObject(n,ids,"createTransformFeedback",GL.transformFeedbacks)}function _emscripten_glGenVertexArrays(n,arrays){__glGenObject(n,arrays,"createVertexArray",GL.vaos)}function _emscripten_glGenVertexArraysOES(n,arrays){__glGenObject(n,arrays,"createVertexArray",GL.vaos)}function _emscripten_glGenerateMipmap(x0){GLctx["generateMipmap"](x0)}function __glGetActiveAttribOrUniform(funcName,program,index,bufSize,length,size,type,name){program=GL.programs[program];var info=GLctx[funcName](program,index);if(info){var numBytesWrittenExclNull=name&&stringToUTF8(info.name,name,bufSize);if(length)HEAP32[length>>2]=numBytesWrittenExclNull;if(size)HEAP32[size>>2]=info.size;if(type)HEAP32[type>>2]=info.type}}function _emscripten_glGetActiveAttrib(program,index,bufSize,length,size,type,name){__glGetActiveAttribOrUniform("getActiveAttrib",program,index,bufSize,length,size,type,name)}function _emscripten_glGetActiveUniform(program,index,bufSize,length,size,type,name){__glGetActiveAttribOrUniform("getActiveUniform",program,index,bufSize,length,size,type,name)}function _emscripten_glGetActiveUniformBlockName(program,uniformBlockIndex,bufSize,length,uniformBlockName){program=GL.programs[program];var result=GLctx["getActiveUniformBlockName"](program,uniformBlockIndex);if(!result)return;if(uniformBlockName&&bufSize>0){var numBytesWrittenExclNull=stringToUTF8(result,uniformBlockName,bufSize);if(length)HEAP32[length>>2]=numBytesWrittenExclNull}else{if(length)HEAP32[length>>2]=0}}function _emscripten_glGetActiveUniformBlockiv(program,uniformBlockIndex,pname,params){if(!params){GL.recordError(1281);return}program=GL.programs[program];switch(pname){case 35393:var name=GLctx["getActiveUniformBlockName"](program,uniformBlockIndex);HEAP32[params>>2]=name.length+1;return;default:var result=GLctx["getActiveUniformBlockParameter"](program,uniformBlockIndex,pname);if(!result)return;if(typeof result=="number"){HEAP32[params>>2]=result}else{for(var i=0;i>2]=result[i]}}}}function _emscripten_glGetActiveUniformsiv(program,uniformCount,uniformIndices,pname,params){if(!params){GL.recordError(1281);return}if(uniformCount>0&&uniformIndices==0){GL.recordError(1281);return}program=GL.programs[program];var ids=[];for(var i=0;i>2])}var result=GLctx["getActiveUniforms"](program,ids,pname);if(!result)return;var len=result.length;for(var i=0;i>2]=result[i]}}function _emscripten_glGetAttachedShaders(program,maxCount,count,shaders){var result=GLctx.getAttachedShaders(GL.programs[program]);var len=result.length;if(len>maxCount){len=maxCount}HEAP32[count>>2]=len;for(var i=0;i>2]=id}}function _emscripten_glGetAttribLocation(program,name){return GLctx.getAttribLocation(GL.programs[program],UTF8ToString(name))}function writeI53ToI64(ptr,num){HEAPU32[ptr>>2]=num;HEAPU32[ptr+4>>2]=(num-HEAPU32[ptr>>2])/4294967296}function emscriptenWebGLGet(name_,p,type){if(!p){GL.recordError(1281);return}var ret=undefined;switch(name_){case 36346:ret=1;break;case 36344:if(type!=0&&type!=1){GL.recordError(1280)}return;case 34814:case 36345:ret=0;break;case 34466:var formats=GLctx.getParameter(34467);ret=formats?formats.length:0;break;case 33309:if(GL.currentContext.version<2){GL.recordError(1282);return}var exts=GLctx.getSupportedExtensions()||[];ret=2*exts.length;break;case 33307:case 33308:if(GL.currentContext.version<2){GL.recordError(1280);return}ret=name_==33307?3:0;break}if(ret===undefined){var result=GLctx.getParameter(name_);switch(typeof result){case"number":ret=result;break;case"boolean":ret=result?1:0;break;case"string":GL.recordError(1280);return;case"object":if(result===null){switch(name_){case 34964:case 35725:case 34965:case 36006:case 36007:case 32873:case 34229:case 36662:case 36663:case 35053:case 35055:case 36010:case 35097:case 35869:case 32874:case 36389:case 35983:case 35368:case 34068:{ret=0;break}default:{GL.recordError(1280);return}}}else if(result instanceof Float32Array||result instanceof Uint32Array||result instanceof Int32Array||result instanceof Array){for(var i=0;i>2]=result[i];break;case 2:HEAPF32[p+i*4>>2]=result[i];break;case 4:HEAP8[p+i>>0]=result[i]?1:0;break}}return}else{try{ret=result.name|0}catch(e){GL.recordError(1280);err("GL_INVALID_ENUM in glGet"+type+"v: Unknown object returned from WebGL getParameter("+name_+")! (error: "+e+")");return}}break;default:GL.recordError(1280);err("GL_INVALID_ENUM in glGet"+type+"v: Native code calling glGet"+type+"v("+name_+") and it returns "+result+" of type "+typeof result+"!");return}}switch(type){case 1:writeI53ToI64(p,ret);break;case 0:HEAP32[p>>2]=ret;break;case 2:HEAPF32[p>>2]=ret;break;case 4:HEAP8[p>>0]=ret?1:0;break}}function _emscripten_glGetBooleanv(name_,p){emscriptenWebGLGet(name_,p,4)}function _emscripten_glGetBufferParameteri64v(target,value,data){if(!data){GL.recordError(1281);return}writeI53ToI64(data,GLctx.getBufferParameter(target,value))}function _emscripten_glGetBufferParameteriv(target,value,data){if(!data){GL.recordError(1281);return}HEAP32[data>>2]=GLctx.getBufferParameter(target,value)}function _emscripten_glGetError(){var error=GLctx.getError()||GL.lastError;GL.lastError=0;return error}function _emscripten_glGetFloatv(name_,p){emscriptenWebGLGet(name_,p,2)}function _emscripten_glGetFragDataLocation(program,name){return GLctx["getFragDataLocation"](GL.programs[program],UTF8ToString(name))}function _emscripten_glGetFramebufferAttachmentParameteriv(target,attachment,pname,params){var result=GLctx.getFramebufferAttachmentParameter(target,attachment,pname);if(result instanceof WebGLRenderbuffer||result instanceof WebGLTexture){result=result.name|0}HEAP32[params>>2]=result}function emscriptenWebGLGetIndexed(target,index,data,type){if(!data){GL.recordError(1281);return}var result=GLctx["getIndexedParameter"](target,index);var ret;switch(typeof result){case"boolean":ret=result?1:0;break;case"number":ret=result;break;case"object":if(result===null){switch(target){case 35983:case 35368:ret=0;break;default:{GL.recordError(1280);return}}}else if(result instanceof WebGLBuffer){ret=result.name|0}else{GL.recordError(1280);return}break;default:GL.recordError(1280);return}switch(type){case 1:writeI53ToI64(data,ret);break;case 0:HEAP32[data>>2]=ret;break;case 2:HEAPF32[data>>2]=ret;break;case 4:HEAP8[data>>0]=ret?1:0;break;default:throw"internal emscriptenWebGLGetIndexed() error, bad type: "+type}}function _emscripten_glGetInteger64i_v(target,index,data){emscriptenWebGLGetIndexed(target,index,data,1)}function _emscripten_glGetInteger64v(name_,p){emscriptenWebGLGet(name_,p,1)}function _emscripten_glGetIntegeri_v(target,index,data){emscriptenWebGLGetIndexed(target,index,data,0)}function _emscripten_glGetIntegerv(name_,p){emscriptenWebGLGet(name_,p,0)}function _emscripten_glGetInternalformativ(target,internalformat,pname,bufSize,params){if(bufSize<0){GL.recordError(1281);return}if(!params){GL.recordError(1281);return}var ret=GLctx["getInternalformatParameter"](target,internalformat,pname);if(ret===null)return;for(var i=0;i>2]=ret[i]}}function _emscripten_glGetProgramBinary(program,bufSize,length,binaryFormat,binary){GL.recordError(1282)}function _emscripten_glGetProgramInfoLog(program,maxLength,length,infoLog){var log=GLctx.getProgramInfoLog(GL.programs[program]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>2]=numBytesWrittenExclNull}function _emscripten_glGetProgramiv(program,pname,p){if(!p){GL.recordError(1281);return}if(program>=GL.counter){GL.recordError(1281);return}var ptable=GL.programInfos[program];if(!ptable){GL.recordError(1282);return}if(pname==35716){var log=GLctx.getProgramInfoLog(GL.programs[program]);if(log===null)log="(unknown error)";HEAP32[p>>2]=log.length+1}else if(pname==35719){HEAP32[p>>2]=ptable.maxUniformLength}else if(pname==35722){if(ptable.maxAttributeLength==-1){program=GL.programs[program];var numAttribs=GLctx.getProgramParameter(program,35721);ptable.maxAttributeLength=0;for(var i=0;i>2]=ptable.maxAttributeLength}else if(pname==35381){if(ptable.maxUniformBlockNameLength==-1){program=GL.programs[program];var numBlocks=GLctx.getProgramParameter(program,35382);ptable.maxUniformBlockNameLength=0;for(var i=0;i>2]=ptable.maxUniformBlockNameLength}else{HEAP32[p>>2]=GLctx.getProgramParameter(GL.programs[program],pname)}}function _emscripten_glGetQueryObjecti64vEXT(id,pname,params){if(!params){GL.recordError(1281);return}var query=GL.timerQueriesEXT[id];var param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}writeI53ToI64(params,ret)}function _emscripten_glGetQueryObjectivEXT(id,pname,params){if(!params){GL.recordError(1281);return}var query=GL.timerQueriesEXT[id];var param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}HEAP32[params>>2]=ret}function _emscripten_glGetQueryObjectui64vEXT(id,pname,params){if(!params){GL.recordError(1281);return}var query=GL.timerQueriesEXT[id];var param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}writeI53ToI64(params,ret)}function _emscripten_glGetQueryObjectuiv(id,pname,params){if(!params){GL.recordError(1281);return}var query=GL.queries[id];var param=GLctx["getQueryParameter"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}HEAP32[params>>2]=ret}function _emscripten_glGetQueryObjectuivEXT(id,pname,params){if(!params){GL.recordError(1281);return}var query=GL.timerQueriesEXT[id];var param=GLctx.disjointTimerQueryExt["getQueryObjectEXT"](query,pname);var ret;if(typeof param=="boolean"){ret=param?1:0}else{ret=param}HEAP32[params>>2]=ret}function _emscripten_glGetQueryiv(target,pname,params){if(!params){GL.recordError(1281);return}HEAP32[params>>2]=GLctx["getQuery"](target,pname)}function _emscripten_glGetQueryivEXT(target,pname,params){if(!params){GL.recordError(1281);return}HEAP32[params>>2]=GLctx.disjointTimerQueryExt["getQueryEXT"](target,pname)}function _emscripten_glGetRenderbufferParameteriv(target,pname,params){if(!params){GL.recordError(1281);return}HEAP32[params>>2]=GLctx.getRenderbufferParameter(target,pname)}function _emscripten_glGetSamplerParameterfv(sampler,pname,params){if(!params){GL.recordError(1281);return}sampler=GL.samplers[sampler];HEAPF32[params>>2]=GLctx["getSamplerParameter"](sampler,pname)}function _emscripten_glGetSamplerParameteriv(sampler,pname,params){if(!params){GL.recordError(1281);return}sampler=GL.samplers[sampler];HEAP32[params>>2]=GLctx["getSamplerParameter"](sampler,pname)}function _emscripten_glGetShaderInfoLog(shader,maxLength,length,infoLog){var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>2]=numBytesWrittenExclNull}function _emscripten_glGetShaderPrecisionFormat(shaderType,precisionType,range,precision){var result=GLctx.getShaderPrecisionFormat(shaderType,precisionType);HEAP32[range>>2]=result.rangeMin;HEAP32[range+4>>2]=result.rangeMax;HEAP32[precision>>2]=result.precision}function _emscripten_glGetShaderSource(shader,bufSize,length,source){var result=GLctx.getShaderSource(GL.shaders[shader]);if(!result)return;var numBytesWrittenExclNull=bufSize>0&&source?stringToUTF8(result,source,bufSize):0;if(length)HEAP32[length>>2]=numBytesWrittenExclNull}function _emscripten_glGetShaderiv(shader,pname,p){if(!p){GL.recordError(1281);return}if(pname==35716){var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var logLength=log?log.length+1:0;HEAP32[p>>2]=logLength}else if(pname==35720){var source=GLctx.getShaderSource(GL.shaders[shader]);var sourceLength=source?source.length+1:0;HEAP32[p>>2]=sourceLength}else{HEAP32[p>>2]=GLctx.getShaderParameter(GL.shaders[shader],pname)}}function stringToNewUTF8(jsString){var length=lengthBytesUTF8(jsString)+1;var cString=_malloc(length);stringToUTF8(jsString,cString,length);return cString}function _emscripten_glGetString(name_){if(GL.stringCache[name_])return GL.stringCache[name_];var ret;switch(name_){case 7939:var exts=GLctx.getSupportedExtensions()||[];exts=exts.concat(exts.map(function(e){return"GL_"+e}));ret=stringToNewUTF8(exts.join(" "));break;case 7936:case 7937:case 37445:case 37446:var s=GLctx.getParameter(name_);if(!s){GL.recordError(1280)}ret=stringToNewUTF8(s);break;case 7938:var glVersion=GLctx.getParameter(7938);if(GL.currentContext.version>=2)glVersion="OpenGL ES 3.0 ("+glVersion+")";else{glVersion="OpenGL ES 2.0 ("+glVersion+")"}ret=stringToNewUTF8(glVersion);break;case 35724:var glslVersion=GLctx.getParameter(35724);var ver_re=/^WebGL GLSL ES ([0-9]\.[0-9][0-9]?)(?:$| .*)/;var ver_num=glslVersion.match(ver_re);if(ver_num!==null){if(ver_num[1].length==3)ver_num[1]=ver_num[1]+"0";glslVersion="OpenGL ES GLSL ES "+ver_num[1]+" ("+glslVersion+")"}ret=stringToNewUTF8(glslVersion);break;default:GL.recordError(1280);return 0}GL.stringCache[name_]=ret;return ret}function _emscripten_glGetStringi(name,index){if(GL.currentContext.version<2){GL.recordError(1282);return 0}var stringiCache=GL.stringiCache[name];if(stringiCache){if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index]}switch(name){case 7939:var exts=GLctx.getSupportedExtensions()||[];exts=exts.concat(exts.map(function(e){return"GL_"+e}));exts=exts.map(function(e){return stringToNewUTF8(e)});stringiCache=GL.stringiCache[name]=exts;if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index];default:GL.recordError(1280);return 0}}function _emscripten_glGetSynciv(sync,pname,bufSize,length,values){if(bufSize<0){GL.recordError(1281);return}if(!values){GL.recordError(1281);return}var ret=GLctx.getSyncParameter(GL.syncs[sync],pname);if(ret!==null){HEAP32[values>>2]=ret;if(length)HEAP32[length>>2]=1}}function _emscripten_glGetTexParameterfv(target,pname,params){if(!params){GL.recordError(1281);return}HEAPF32[params>>2]=GLctx.getTexParameter(target,pname)}function _emscripten_glGetTexParameteriv(target,pname,params){if(!params){GL.recordError(1281);return}HEAP32[params>>2]=GLctx.getTexParameter(target,pname)}function _emscripten_glGetTransformFeedbackVarying(program,index,bufSize,length,size,type,name){program=GL.programs[program];var info=GLctx["getTransformFeedbackVarying"](program,index);if(!info)return;if(name&&bufSize>0){var numBytesWrittenExclNull=stringToUTF8(info.name,name,bufSize);if(length)HEAP32[length>>2]=numBytesWrittenExclNull}else{if(length)HEAP32[length>>2]=0}if(size)HEAP32[size>>2]=info.size;if(type)HEAP32[type>>2]=info.type}function _emscripten_glGetUniformBlockIndex(program,uniformBlockName){return GLctx["getUniformBlockIndex"](GL.programs[program],UTF8ToString(uniformBlockName))}function _emscripten_glGetUniformIndices(program,uniformCount,uniformNames,uniformIndices){if(!uniformIndices){GL.recordError(1281);return}if(uniformCount>0&&(uniformNames==0||uniformIndices==0)){GL.recordError(1281);return}program=GL.programs[program];var names=[];for(var i=0;i>2]));var result=GLctx["getUniformIndices"](program,names);if(!result)return;var len=result.length;for(var i=0;i>2]=result[i]}}function _emscripten_glGetUniformLocation(program,name){name=UTF8ToString(name);var arrayIndex=0;if(name[name.length-1]=="]"){var leftBrace=name.lastIndexOf("[");arrayIndex=name[leftBrace+1]!="]"?jstoi_q(name.slice(leftBrace+1)):0;name=name.slice(0,leftBrace)}var uniformInfo=GL.programInfos[program]&&GL.programInfos[program].uniforms[name];if(uniformInfo&&arrayIndex>=0&&arrayIndex>2]=data;break;case 2:HEAPF32[params>>2]=data;break}}else{for(var i=0;i>2]=data[i];break;case 2:HEAPF32[params+i*4>>2]=data[i];break}}}}function _emscripten_glGetUniformfv(program,location,params){emscriptenWebGLGetUniform(program,location,params,2)}function _emscripten_glGetUniformiv(program,location,params){emscriptenWebGLGetUniform(program,location,params,0)}function _emscripten_glGetUniformuiv(program,location,params){emscriptenWebGLGetUniform(program,location,params,0)}function emscriptenWebGLGetVertexAttrib(index,pname,params,type){if(!params){GL.recordError(1281);return}var data=GLctx.getVertexAttrib(index,pname);if(pname==34975){HEAP32[params>>2]=data&&data["name"]}else if(typeof data=="number"||typeof data=="boolean"){switch(type){case 0:HEAP32[params>>2]=data;break;case 2:HEAPF32[params>>2]=data;break;case 5:HEAP32[params>>2]=Math.fround(data);break}}else{for(var i=0;i>2]=data[i];break;case 2:HEAPF32[params+i*4>>2]=data[i];break;case 5:HEAP32[params+i*4>>2]=Math.fround(data[i]);break}}}}function _emscripten_glGetVertexAttribIiv(index,pname,params){emscriptenWebGLGetVertexAttrib(index,pname,params,0)}function _emscripten_glGetVertexAttribIuiv(index,pname,params){emscriptenWebGLGetVertexAttrib(index,pname,params,0)}function _emscripten_glGetVertexAttribPointerv(index,pname,pointer){if(!pointer){GL.recordError(1281);return}HEAP32[pointer>>2]=GLctx.getVertexAttribOffset(index,pname)}function _emscripten_glGetVertexAttribfv(index,pname,params){emscriptenWebGLGetVertexAttrib(index,pname,params,2)}function _emscripten_glGetVertexAttribiv(index,pname,params){emscriptenWebGLGetVertexAttrib(index,pname,params,5)}function _emscripten_glHint(x0,x1){GLctx["hint"](x0,x1)}function _emscripten_glInvalidateFramebuffer(target,numAttachments,attachments){var list=tempFixedLengthArray[numAttachments];for(var i=0;i>2]}GLctx["invalidateFramebuffer"](target,list)}function _emscripten_glInvalidateSubFramebuffer(target,numAttachments,attachments,x,y,width,height){var list=tempFixedLengthArray[numAttachments];for(var i=0;i>2]}GLctx["invalidateSubFramebuffer"](target,list,x,y,width,height)}function _emscripten_glIsBuffer(buffer){var b=GL.buffers[buffer];if(!b)return 0;return GLctx.isBuffer(b)}function _emscripten_glIsEnabled(x0){return GLctx["isEnabled"](x0)}function _emscripten_glIsFramebuffer(framebuffer){var fb=GL.framebuffers[framebuffer];if(!fb)return 0;return GLctx.isFramebuffer(fb)}function _emscripten_glIsProgram(program){program=GL.programs[program];if(!program)return 0;return GLctx.isProgram(program)}function _emscripten_glIsQuery(id){var query=GL.queries[id];if(!query)return 0;return GLctx["isQuery"](query)}function _emscripten_glIsQueryEXT(id){var query=GL.timerQueriesEXT[id];if(!query)return 0;return GLctx.disjointTimerQueryExt["isQueryEXT"](query)}function _emscripten_glIsRenderbuffer(renderbuffer){var rb=GL.renderbuffers[renderbuffer];if(!rb)return 0;return GLctx.isRenderbuffer(rb)}function _emscripten_glIsSampler(id){var sampler=GL.samplers[id];if(!sampler)return 0;return GLctx["isSampler"](sampler)}function _emscripten_glIsShader(shader){var s=GL.shaders[shader];if(!s)return 0;return GLctx.isShader(s)}function _emscripten_glIsSync(sync){return GLctx.isSync(GL.syncs[sync])}function _emscripten_glIsTexture(id){var texture=GL.textures[id];if(!texture)return 0;return GLctx.isTexture(texture)}function _emscripten_glIsTransformFeedback(id){return GLctx["isTransformFeedback"](GL.transformFeedbacks[id])}function _emscripten_glIsVertexArray(array){var vao=GL.vaos[array];if(!vao)return 0;return GLctx["isVertexArray"](vao)}function _emscripten_glIsVertexArrayOES(array){var vao=GL.vaos[array];if(!vao)return 0;return GLctx["isVertexArray"](vao)}function _emscripten_glLineWidth(x0){GLctx["lineWidth"](x0)}function _emscripten_glLinkProgram(program){GLctx.linkProgram(GL.programs[program]);GL.populateUniformTable(program)}function _emscripten_glPauseTransformFeedback(){GLctx["pauseTransformFeedback"]()}function _emscripten_glPixelStorei(pname,param){if(pname==3317){GL.unpackAlignment=param}GLctx.pixelStorei(pname,param)}function _emscripten_glPolygonOffset(x0,x1){GLctx["polygonOffset"](x0,x1)}function _emscripten_glProgramBinary(program,binaryFormat,binary,length){GL.recordError(1280)}function _emscripten_glProgramParameteri(program,pname,value){GL.recordError(1280)}function _emscripten_glQueryCounterEXT(id,target){GLctx.disjointTimerQueryExt["queryCounterEXT"](GL.timerQueriesEXT[id],target)}function _emscripten_glReadBuffer(x0){GLctx["readBuffer"](x0)}function computeUnpackAlignedImageSize(width,height,sizePerPixel,alignment){function roundedToNextMultipleOf(x,y){return x+y-1&-y}var plainRowSize=width*sizePerPixel;var alignedRowSize=roundedToNextMultipleOf(plainRowSize,alignment);return height*alignedRowSize}function __colorChannelsInGlTextureFormat(format){var colorChannels={5:3,6:4,8:2,29502:3,29504:4,26917:2,26918:2,29846:3,29847:4};return colorChannels[format-6402]||1}function heapObjectForWebGLType(type){type-=5120;if(type==0)return HEAP8;if(type==1)return HEAPU8;if(type==2)return HEAP16;if(type==4)return HEAP32;if(type==6)return HEAPF32;if(type==5||type==28922||type==28520||type==30779||type==30782)return HEAPU32;return HEAPU16}function heapAccessShiftForWebGLHeap(heap){return 31-Math.clz32(heap.BYTES_PER_ELEMENT)}function emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,internalFormat){var heap=heapObjectForWebGLType(type);var shift=heapAccessShiftForWebGLHeap(heap);var byteSize=1<>shift,pixels+bytes>>shift)}function _emscripten_glReadPixels(x,y,width,height,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelPackBufferBinding){GLctx.readPixels(x,y,width,height,format,type,pixels)}else{var heap=heapObjectForWebGLType(type);GLctx.readPixels(x,y,width,height,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}return}var pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,format);if(!pixelData){GL.recordError(1280);return}GLctx.readPixels(x,y,width,height,format,type,pixelData)}function _emscripten_glReleaseShaderCompiler(){}function _emscripten_glRenderbufferStorage(x0,x1,x2,x3){GLctx["renderbufferStorage"](x0,x1,x2,x3)}function _emscripten_glRenderbufferStorageMultisample(x0,x1,x2,x3,x4){GLctx["renderbufferStorageMultisample"](x0,x1,x2,x3,x4)}function _emscripten_glResumeTransformFeedback(){GLctx["resumeTransformFeedback"]()}function _emscripten_glSampleCoverage(value,invert){GLctx.sampleCoverage(value,!!invert)}function _emscripten_glSamplerParameterf(sampler,pname,param){GLctx["samplerParameterf"](GL.samplers[sampler],pname,param)}function _emscripten_glSamplerParameterfv(sampler,pname,params){var param=HEAPF32[params>>2];GLctx["samplerParameterf"](GL.samplers[sampler],pname,param)}function _emscripten_glSamplerParameteri(sampler,pname,param){GLctx["samplerParameteri"](GL.samplers[sampler],pname,param)}function _emscripten_glSamplerParameteriv(sampler,pname,params){var param=HEAP32[params>>2];GLctx["samplerParameteri"](GL.samplers[sampler],pname,param)}function _emscripten_glScissor(x0,x1,x2,x3){GLctx["scissor"](x0,x1,x2,x3)}function _emscripten_glShaderBinary(){GL.recordError(1280)}function _emscripten_glShaderSource(shader,count,string,length){var source=GL.getSource(shader,count,string,length);GLctx.shaderSource(GL.shaders[shader],source)}function _emscripten_glStencilFunc(x0,x1,x2){GLctx["stencilFunc"](x0,x1,x2)}function _emscripten_glStencilFuncSeparate(x0,x1,x2,x3){GLctx["stencilFuncSeparate"](x0,x1,x2,x3)}function _emscripten_glStencilMask(x0){GLctx["stencilMask"](x0)}function _emscripten_glStencilMaskSeparate(x0,x1){GLctx["stencilMaskSeparate"](x0,x1)}function _emscripten_glStencilOp(x0,x1,x2){GLctx["stencilOp"](x0,x1,x2)}function _emscripten_glStencilOpSeparate(x0,x1,x2,x3){GLctx["stencilOpSeparate"](x0,x1,x2,x3)}function _emscripten_glTexImage2D(target,level,internalFormat,width,height,border,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,null)}return}GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixels?emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,internalFormat):null)}function _emscripten_glTexImage3D(target,level,internalFormat,width,height,depth,border,format,type,pixels){if(GLctx.currentPixelUnpackBufferBinding){GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,null)}}function _emscripten_glTexParameterf(x0,x1,x2){GLctx["texParameterf"](x0,x1,x2)}function _emscripten_glTexParameterfv(target,pname,params){var param=HEAPF32[params>>2];GLctx.texParameterf(target,pname,param)}function _emscripten_glTexParameteri(x0,x1,x2){GLctx["texParameteri"](x0,x1,x2)}function _emscripten_glTexParameteriv(target,pname,params){var param=HEAP32[params>>2];GLctx.texParameteri(target,pname,param)}function _emscripten_glTexStorage2D(x0,x1,x2,x3,x4){GLctx["texStorage2D"](x0,x1,x2,x3,x4)}function _emscripten_glTexStorage3D(x0,x1,x2,x3,x4,x5){GLctx["texStorage3D"](x0,x1,x2,x3,x4,x5)}function _emscripten_glTexSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,null)}return}var pixelData=null;if(pixels)pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,0);GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixelData)}function _emscripten_glTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels){if(GLctx.currentPixelUnpackBufferBinding){GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,null)}}function _emscripten_glTransformFeedbackVaryings(program,count,varyings,bufferMode){program=GL.programs[program];var vars=[];for(var i=0;i>2]));GLctx["transformFeedbackVaryings"](program,vars,bufferMode)}function _emscripten_glUniform1f(location,v0){GLctx.uniform1f(GL.uniforms[location],v0)}var miniTempWebGLFloatBuffers=[];function _emscripten_glUniform1fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform1fv(GL.uniforms[location],HEAPF32,value>>2,count);return}if(count<=288){var view=miniTempWebGLFloatBuffers[count-1];for(var i=0;i>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*4>>2)}GLctx.uniform1fv(GL.uniforms[location],view)}function _emscripten_glUniform1i(location,v0){GLctx.uniform1i(GL.uniforms[location],v0)}var __miniTempWebGLIntBuffers=[];function _emscripten_glUniform1iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform1iv(GL.uniforms[location],HEAP32,value>>2,count);return}if(count<=288){var view=__miniTempWebGLIntBuffers[count-1];for(var i=0;i>2]}}else{var view=HEAP32.subarray(value>>2,value+count*4>>2)}GLctx.uniform1iv(GL.uniforms[location],view)}function _emscripten_glUniform1ui(location,v0){GLctx.uniform1ui(GL.uniforms[location],v0)}function _emscripten_glUniform1uiv(location,count,value){GLctx.uniform1uiv(GL.uniforms[location],HEAPU32,value>>2,count)}function _emscripten_glUniform2f(location,v0,v1){GLctx.uniform2f(GL.uniforms[location],v0,v1)}function _emscripten_glUniform2fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform2fv(GL.uniforms[location],HEAPF32,value>>2,count*2);return}if(count<=144){var view=miniTempWebGLFloatBuffers[2*count-1];for(var i=0;i<2*count;i+=2){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*8>>2)}GLctx.uniform2fv(GL.uniforms[location],view)}function _emscripten_glUniform2i(location,v0,v1){GLctx.uniform2i(GL.uniforms[location],v0,v1)}function _emscripten_glUniform2iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform2iv(GL.uniforms[location],HEAP32,value>>2,count*2);return}if(count<=144){var view=__miniTempWebGLIntBuffers[2*count-1];for(var i=0;i<2*count;i+=2){view[i]=HEAP32[value+4*i>>2];view[i+1]=HEAP32[value+(4*i+4)>>2]}}else{var view=HEAP32.subarray(value>>2,value+count*8>>2)}GLctx.uniform2iv(GL.uniforms[location],view)}function _emscripten_glUniform2ui(location,v0,v1){GLctx.uniform2ui(GL.uniforms[location],v0,v1)}function _emscripten_glUniform2uiv(location,count,value){GLctx.uniform2uiv(GL.uniforms[location],HEAPU32,value>>2,count*2)}function _emscripten_glUniform3f(location,v0,v1,v2){GLctx.uniform3f(GL.uniforms[location],v0,v1,v2)}function _emscripten_glUniform3fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform3fv(GL.uniforms[location],HEAPF32,value>>2,count*3);return}if(count<=96){var view=miniTempWebGLFloatBuffers[3*count-1];for(var i=0;i<3*count;i+=3){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*12>>2)}GLctx.uniform3fv(GL.uniforms[location],view)}function _emscripten_glUniform3i(location,v0,v1,v2){GLctx.uniform3i(GL.uniforms[location],v0,v1,v2)}function _emscripten_glUniform3iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform3iv(GL.uniforms[location],HEAP32,value>>2,count*3);return}if(count<=96){var view=__miniTempWebGLIntBuffers[3*count-1];for(var i=0;i<3*count;i+=3){view[i]=HEAP32[value+4*i>>2];view[i+1]=HEAP32[value+(4*i+4)>>2];view[i+2]=HEAP32[value+(4*i+8)>>2]}}else{var view=HEAP32.subarray(value>>2,value+count*12>>2)}GLctx.uniform3iv(GL.uniforms[location],view)}function _emscripten_glUniform3ui(location,v0,v1,v2){GLctx.uniform3ui(GL.uniforms[location],v0,v1,v2)}function _emscripten_glUniform3uiv(location,count,value){GLctx.uniform3uiv(GL.uniforms[location],HEAPU32,value>>2,count*3)}function _emscripten_glUniform4f(location,v0,v1,v2,v3){GLctx.uniform4f(GL.uniforms[location],v0,v1,v2,v3)}function _emscripten_glUniform4fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform4fv(GL.uniforms[location],HEAPF32,value>>2,count*4);return}if(count<=72){var view=miniTempWebGLFloatBuffers[4*count-1];var heap=HEAPF32;value>>=2;for(var i=0;i<4*count;i+=4){var dst=value+i;view[i]=heap[dst];view[i+1]=heap[dst+1];view[i+2]=heap[dst+2];view[i+3]=heap[dst+3]}}else{var view=HEAPF32.subarray(value>>2,value+count*16>>2)}GLctx.uniform4fv(GL.uniforms[location],view)}function _emscripten_glUniform4i(location,v0,v1,v2,v3){GLctx.uniform4i(GL.uniforms[location],v0,v1,v2,v3)}function _emscripten_glUniform4iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform4iv(GL.uniforms[location],HEAP32,value>>2,count*4);return}if(count<=72){var view=__miniTempWebGLIntBuffers[4*count-1];for(var i=0;i<4*count;i+=4){view[i]=HEAP32[value+4*i>>2];view[i+1]=HEAP32[value+(4*i+4)>>2];view[i+2]=HEAP32[value+(4*i+8)>>2];view[i+3]=HEAP32[value+(4*i+12)>>2]}}else{var view=HEAP32.subarray(value>>2,value+count*16>>2)}GLctx.uniform4iv(GL.uniforms[location],view)}function _emscripten_glUniform4ui(location,v0,v1,v2,v3){GLctx.uniform4ui(GL.uniforms[location],v0,v1,v2,v3)}function _emscripten_glUniform4uiv(location,count,value){GLctx.uniform4uiv(GL.uniforms[location],HEAPU32,value>>2,count*4)}function _emscripten_glUniformBlockBinding(program,uniformBlockIndex,uniformBlockBinding){program=GL.programs[program];GLctx["uniformBlockBinding"](program,uniformBlockIndex,uniformBlockBinding)}function _emscripten_glUniformMatrix2fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix2fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*4);return}if(count<=72){var view=miniTempWebGLFloatBuffers[4*count-1];for(var i=0;i<4*count;i+=4){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2];view[i+3]=HEAPF32[value+(4*i+12)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*16>>2)}GLctx.uniformMatrix2fv(GL.uniforms[location],!!transpose,view)}function _emscripten_glUniformMatrix2x3fv(location,count,transpose,value){GLctx.uniformMatrix2x3fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*6)}function _emscripten_glUniformMatrix2x4fv(location,count,transpose,value){GLctx.uniformMatrix2x4fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*8)}function _emscripten_glUniformMatrix3fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix3fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*9);return}if(count<=32){var view=miniTempWebGLFloatBuffers[9*count-1];for(var i=0;i<9*count;i+=9){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2];view[i+3]=HEAPF32[value+(4*i+12)>>2];view[i+4]=HEAPF32[value+(4*i+16)>>2];view[i+5]=HEAPF32[value+(4*i+20)>>2];view[i+6]=HEAPF32[value+(4*i+24)>>2];view[i+7]=HEAPF32[value+(4*i+28)>>2];view[i+8]=HEAPF32[value+(4*i+32)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*36>>2)}GLctx.uniformMatrix3fv(GL.uniforms[location],!!transpose,view)}function _emscripten_glUniformMatrix3x2fv(location,count,transpose,value){GLctx.uniformMatrix3x2fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*6)}function _emscripten_glUniformMatrix3x4fv(location,count,transpose,value){GLctx.uniformMatrix3x4fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*12)}function _emscripten_glUniformMatrix4fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix4fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*16);return}if(count<=18){var view=miniTempWebGLFloatBuffers[16*count-1];var heap=HEAPF32;value>>=2;for(var i=0;i<16*count;i+=16){var dst=value+i;view[i]=heap[dst];view[i+1]=heap[dst+1];view[i+2]=heap[dst+2];view[i+3]=heap[dst+3];view[i+4]=heap[dst+4];view[i+5]=heap[dst+5];view[i+6]=heap[dst+6];view[i+7]=heap[dst+7];view[i+8]=heap[dst+8];view[i+9]=heap[dst+9];view[i+10]=heap[dst+10];view[i+11]=heap[dst+11];view[i+12]=heap[dst+12];view[i+13]=heap[dst+13];view[i+14]=heap[dst+14];view[i+15]=heap[dst+15]}}else{var view=HEAPF32.subarray(value>>2,value+count*64>>2)}GLctx.uniformMatrix4fv(GL.uniforms[location],!!transpose,view)}function _emscripten_glUniformMatrix4x2fv(location,count,transpose,value){GLctx.uniformMatrix4x2fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*8)}function _emscripten_glUniformMatrix4x3fv(location,count,transpose,value){GLctx.uniformMatrix4x3fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*12)}function _emscripten_glUseProgram(program){GLctx.useProgram(GL.programs[program])}function _emscripten_glValidateProgram(program){GLctx.validateProgram(GL.programs[program])}function _emscripten_glVertexAttrib1f(x0,x1){GLctx["vertexAttrib1f"](x0,x1)}function _emscripten_glVertexAttrib1fv(index,v){GLctx.vertexAttrib1f(index,HEAPF32[v>>2])}function _emscripten_glVertexAttrib2f(x0,x1,x2){GLctx["vertexAttrib2f"](x0,x1,x2)}function _emscripten_glVertexAttrib2fv(index,v){GLctx.vertexAttrib2f(index,HEAPF32[v>>2],HEAPF32[v+4>>2])}function _emscripten_glVertexAttrib3f(x0,x1,x2,x3){GLctx["vertexAttrib3f"](x0,x1,x2,x3)}function _emscripten_glVertexAttrib3fv(index,v){GLctx.vertexAttrib3f(index,HEAPF32[v>>2],HEAPF32[v+4>>2],HEAPF32[v+8>>2])}function _emscripten_glVertexAttrib4f(x0,x1,x2,x3,x4){GLctx["vertexAttrib4f"](x0,x1,x2,x3,x4)}function _emscripten_glVertexAttrib4fv(index,v){GLctx.vertexAttrib4f(index,HEAPF32[v>>2],HEAPF32[v+4>>2],HEAPF32[v+8>>2],HEAPF32[v+12>>2])}function _emscripten_glVertexAttribDivisor(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _emscripten_glVertexAttribDivisorANGLE(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _emscripten_glVertexAttribDivisorARB(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _emscripten_glVertexAttribDivisorEXT(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _emscripten_glVertexAttribDivisorNV(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _emscripten_glVertexAttribI4i(x0,x1,x2,x3,x4){GLctx["vertexAttribI4i"](x0,x1,x2,x3,x4)}function _emscripten_glVertexAttribI4iv(index,v){GLctx.vertexAttribI4i(index,HEAP32[v>>2],HEAP32[v+4>>2],HEAP32[v+8>>2],HEAP32[v+12>>2])}function _emscripten_glVertexAttribI4ui(x0,x1,x2,x3,x4){GLctx["vertexAttribI4ui"](x0,x1,x2,x3,x4)}function _emscripten_glVertexAttribI4uiv(index,v){GLctx.vertexAttribI4ui(index,HEAPU32[v>>2],HEAPU32[v+4>>2],HEAPU32[v+8>>2],HEAPU32[v+12>>2])}function _emscripten_glVertexAttribIPointer(index,size,type,stride,ptr){GLctx["vertexAttribIPointer"](index,size,type,stride,ptr)}function _emscripten_glVertexAttribPointer(index,size,type,normalized,stride,ptr){GLctx.vertexAttribPointer(index,size,type,!!normalized,stride,ptr)}function _emscripten_glViewport(x0,x1,x2,x3){GLctx["viewport"](x0,x1,x2,x3)}function _emscripten_glWaitSync(sync,flags,timeoutLo,timeoutHi){GLctx.waitSync(GL.syncs[sync],flags,convertI32PairToI53(timeoutLo,timeoutHi))}function _longjmp(env,value){_setThrew(env,value||1);throw"longjmp"}function _emscripten_longjmp(a0,a1){return _longjmp(a0,a1)}function _emscripten_memcpy_big(dest,src,num){HEAPU8.copyWithin(dest,src,src+num)}function _emscripten_request_pointerlock(target,deferUntilInEventHandler){target=findEventTarget(target);if(!target)return-4;if(!target.requestPointerLock&&!target.msRequestPointerLock){return-1}var canPerformRequests=JSEvents.canPerformEventHandlerRequests();if(!canPerformRequests){if(deferUntilInEventHandler){JSEvents.deferCall(requestPointerLock,2,[target]);return 1}else{return-2}}return requestPointerLock(target)}function _emscripten_get_heap_size(){return HEAPU8.length}function emscripten_realloc_buffer(size){try{wasmMemory.grow(size-buffer.byteLength+65535>>>16);updateGlobalBufferAndViews(wasmMemory.buffer);return 1}catch(e){}}function _emscripten_resize_heap(requestedSize){var oldSize=_emscripten_get_heap_size();var maxHeapSize=2147483648;if(requestedSize>maxHeapSize){return false}for(var cutDown=1;cutDown<=4;cutDown*=2){var overGrownHeapSize=oldSize*(1+.2/cutDown);overGrownHeapSize=Math.min(overGrownHeapSize,requestedSize+100663296);var newSize=Math.min(maxHeapSize,alignUp(Math.max(requestedSize,overGrownHeapSize),65536));var replacement=emscripten_realloc_buffer(newSize);if(replacement){return true}}return false}function fillFullscreenChangeEventData(eventStruct){var fullscreenElement=document.fullscreenElement||document.mozFullScreenElement||document.webkitFullscreenElement||document.msFullscreenElement;var isFullscreen=!!fullscreenElement;HEAP32[eventStruct>>2]=isFullscreen;HEAP32[eventStruct+4>>2]=JSEvents.fullscreenEnabled();var reportedElement=isFullscreen?fullscreenElement:JSEvents.previousFullscreenElement;var nodeName=JSEvents.getNodeNameForTarget(reportedElement);var id=reportedElement&&reportedElement.id?reportedElement.id:"";stringToUTF8(nodeName,eventStruct+8,128);stringToUTF8(id,eventStruct+136,128);HEAP32[eventStruct+264>>2]=reportedElement?reportedElement.clientWidth:0;HEAP32[eventStruct+268>>2]=reportedElement?reportedElement.clientHeight:0;HEAP32[eventStruct+272>>2]=screen.width;HEAP32[eventStruct+276>>2]=screen.height;if(isFullscreen){JSEvents.previousFullscreenElement=fullscreenElement}}function registerFullscreenChangeEventCallback(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread){if(!JSEvents.fullscreenChangeEvent)JSEvents.fullscreenChangeEvent=_malloc(280);var fullscreenChangeEventhandlerFunc=function(ev){var e=ev||event;var fullscreenChangeEvent=JSEvents.fullscreenChangeEvent;fillFullscreenChangeEventData(fullscreenChangeEvent);if(wasmTable.get(callbackfunc)(eventTypeId,fullscreenChangeEvent,userData))e.preventDefault()};var eventHandler={target:target,eventTypeString:eventTypeString,callbackfunc:callbackfunc,handlerFunc:fullscreenChangeEventhandlerFunc,useCapture:useCapture};JSEvents.registerOrRemoveHandler(eventHandler)}function _emscripten_set_fullscreenchange_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){if(!JSEvents.fullscreenEnabled())return-1;target=findEventTarget(target);if(!target)return-4;registerFullscreenChangeEventCallback(target,userData,useCapture,callbackfunc,19,"fullscreenchange",targetThread);registerFullscreenChangeEventCallback(target,userData,useCapture,callbackfunc,19,"webkitfullscreenchange",targetThread);return 0}function registerKeyEventCallback(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread){if(!JSEvents.keyEvent)JSEvents.keyEvent=_malloc(164);var keyEventHandlerFunc=function(e){var keyEventData=JSEvents.keyEvent;var idx=keyEventData>>2;HEAP32[idx+0]=e.location;HEAP32[idx+1]=e.ctrlKey;HEAP32[idx+2]=e.shiftKey;HEAP32[idx+3]=e.altKey;HEAP32[idx+4]=e.metaKey;HEAP32[idx+5]=e.repeat;HEAP32[idx+6]=e.charCode;HEAP32[idx+7]=e.keyCode;HEAP32[idx+8]=e.which;stringToUTF8(e.key||"",keyEventData+36,32);stringToUTF8(e.code||"",keyEventData+68,32);stringToUTF8(e.char||"",keyEventData+100,32);stringToUTF8(e.locale||"",keyEventData+132,32);if(wasmTable.get(callbackfunc)(eventTypeId,keyEventData,userData))e.preventDefault()};var eventHandler={target:findEventTarget(target),allowsDeferredCalls:true,eventTypeString:eventTypeString,callbackfunc:callbackfunc,handlerFunc:keyEventHandlerFunc,useCapture:useCapture};JSEvents.registerOrRemoveHandler(eventHandler)}function _emscripten_set_keydown_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerKeyEventCallback(target,userData,useCapture,callbackfunc,2,"keydown",targetThread);return 0}function _emscripten_set_keypress_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerKeyEventCallback(target,userData,useCapture,callbackfunc,1,"keypress",targetThread);return 0}function _emscripten_set_keyup_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerKeyEventCallback(target,userData,useCapture,callbackfunc,3,"keyup",targetThread);return 0}function _emscripten_set_main_loop(func,fps,simulateInfiniteLoop){var browserIterationFunc=wasmTable.get(func);setMainLoop(browserIterationFunc,fps,simulateInfiniteLoop)}function fillMouseEventData(eventStruct,e,target){var idx=eventStruct>>2;HEAP32[idx+0]=e.screenX;HEAP32[idx+1]=e.screenY;HEAP32[idx+2]=e.clientX;HEAP32[idx+3]=e.clientY;HEAP32[idx+4]=e.ctrlKey;HEAP32[idx+5]=e.shiftKey;HEAP32[idx+6]=e.altKey;HEAP32[idx+7]=e.metaKey;HEAP16[idx*2+16]=e.button;HEAP16[idx*2+17]=e.buttons;HEAP32[idx+9]=e["movementX"];HEAP32[idx+10]=e["movementY"];var rect=getBoundingClientRect(target);HEAP32[idx+11]=e.clientX-rect.left;HEAP32[idx+12]=e.clientY-rect.top}function registerMouseEventCallback(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread){if(!JSEvents.mouseEvent)JSEvents.mouseEvent=_malloc(64);target=findEventTarget(target);var mouseEventHandlerFunc=function(ev){var e=ev||event;fillMouseEventData(JSEvents.mouseEvent,e,target);if(wasmTable.get(callbackfunc)(eventTypeId,JSEvents.mouseEvent,userData))e.preventDefault()};var eventHandler={target:target,allowsDeferredCalls:eventTypeString!="mousemove"&&eventTypeString!="mouseenter"&&eventTypeString!="mouseleave",eventTypeString:eventTypeString,callbackfunc:callbackfunc,handlerFunc:mouseEventHandlerFunc,useCapture:useCapture};JSEvents.registerOrRemoveHandler(eventHandler)}function _emscripten_set_mousedown_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerMouseEventCallback(target,userData,useCapture,callbackfunc,5,"mousedown",targetThread);return 0}function _emscripten_set_mousemove_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerMouseEventCallback(target,userData,useCapture,callbackfunc,8,"mousemove",targetThread);return 0}function _emscripten_set_mouseup_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerMouseEventCallback(target,userData,useCapture,callbackfunc,6,"mouseup",targetThread);return 0}function registerTouchEventCallback(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread){if(!JSEvents.touchEvent)JSEvents.touchEvent=_malloc(1684);target=findEventTarget(target);var touchEventHandlerFunc=function(e){var touches={};var et=e.touches;for(var i=0;i>2;HEAP32[idx+1]=e.ctrlKey;HEAP32[idx+2]=e.shiftKey;HEAP32[idx+3]=e.altKey;HEAP32[idx+4]=e.metaKey;idx+=5;var targetRect=getBoundingClientRect(target);var numTouches=0;for(var i in touches){var t=touches[i];HEAP32[idx+0]=t.identifier;HEAP32[idx+1]=t.screenX;HEAP32[idx+2]=t.screenY;HEAP32[idx+3]=t.clientX;HEAP32[idx+4]=t.clientY;HEAP32[idx+5]=t.pageX;HEAP32[idx+6]=t.pageY;HEAP32[idx+7]=t.isChanged;HEAP32[idx+8]=t.onTarget;HEAP32[idx+9]=t.clientX-targetRect.left;HEAP32[idx+10]=t.clientY-targetRect.top;idx+=13;if(++numTouches>31){break}}HEAP32[touchEvent>>2]=numTouches;if(wasmTable.get(callbackfunc)(eventTypeId,touchEvent,userData))e.preventDefault()};var eventHandler={target:target,allowsDeferredCalls:eventTypeString=="touchstart"||eventTypeString=="touchend",eventTypeString:eventTypeString,callbackfunc:callbackfunc,handlerFunc:touchEventHandlerFunc,useCapture:useCapture};JSEvents.registerOrRemoveHandler(eventHandler)}function _emscripten_set_touchcancel_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerTouchEventCallback(target,userData,useCapture,callbackfunc,25,"touchcancel",targetThread);return 0}function _emscripten_set_touchend_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerTouchEventCallback(target,userData,useCapture,callbackfunc,23,"touchend",targetThread);return 0}function _emscripten_set_touchmove_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerTouchEventCallback(target,userData,useCapture,callbackfunc,24,"touchmove",targetThread);return 0}function _emscripten_set_touchstart_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){registerTouchEventCallback(target,userData,useCapture,callbackfunc,22,"touchstart",targetThread);return 0}function registerWheelEventCallback(target,userData,useCapture,callbackfunc,eventTypeId,eventTypeString,targetThread){if(!JSEvents.wheelEvent)JSEvents.wheelEvent=_malloc(96);var wheelHandlerFunc=function(ev){var e=ev||event;var wheelEvent=JSEvents.wheelEvent;fillMouseEventData(wheelEvent,e,target);HEAPF64[wheelEvent+64>>3]=e["deltaX"];HEAPF64[wheelEvent+72>>3]=e["deltaY"];HEAPF64[wheelEvent+80>>3]=e["deltaZ"];HEAP32[wheelEvent+88>>2]=e["deltaMode"];if(wasmTable.get(callbackfunc)(eventTypeId,wheelEvent,userData))e.preventDefault()};var eventHandler={target:target,allowsDeferredCalls:true,eventTypeString:eventTypeString,callbackfunc:callbackfunc,handlerFunc:wheelHandlerFunc,useCapture:useCapture};JSEvents.registerOrRemoveHandler(eventHandler)}function _emscripten_set_wheel_callback_on_thread(target,userData,useCapture,callbackfunc,targetThread){target=findEventTarget(target);if(typeof target.onwheel!=="undefined"){registerWheelEventCallback(target,userData,useCapture,callbackfunc,9,"wheel",targetThread);return 0}else{return-1}}function _emscripten_thread_sleep(msecs){var start=_emscripten_get_now();while(_emscripten_get_now()-start>2;var powerPreference=HEAP32[a+(24>>2)];var contextAttributes={"alpha":!!HEAP32[a+(0>>2)],"depth":!!HEAP32[a+(4>>2)],"stencil":!!HEAP32[a+(8>>2)],"antialias":!!HEAP32[a+(12>>2)],"premultipliedAlpha":!!HEAP32[a+(16>>2)],"preserveDrawingBuffer":!!HEAP32[a+(20>>2)],"powerPreference":__emscripten_webgl_power_preferences[powerPreference],"failIfMajorPerformanceCaveat":!!HEAP32[a+(28>>2)],majorVersion:HEAP32[a+(32>>2)],minorVersion:HEAP32[a+(36>>2)],enableExtensionsByDefault:HEAP32[a+(40>>2)],explicitSwapControl:HEAP32[a+(44>>2)],proxyContextToMainThread:HEAP32[a+(48>>2)],renderViaOffscreenBackBuffer:HEAP32[a+(52>>2)]};var canvas=findCanvasEventTarget(target);if(!canvas){return 0}if(contextAttributes.explicitSwapControl&&!contextAttributes.renderViaOffscreenBackBuffer){contextAttributes.renderViaOffscreenBackBuffer=true}var contextHandle=GL.createContext(canvas,contextAttributes);return contextHandle}function _emscripten_webgl_create_context(a0,a1){return _emscripten_webgl_do_create_context(a0,a1)}function _emscripten_webgl_do_get_current_context(){return GL.currentContext?GL.currentContext.handle:0}function _emscripten_webgl_get_current_context(){return _emscripten_webgl_do_get_current_context()}Module["_emscripten_webgl_get_current_context"]=_emscripten_webgl_get_current_context;function _emscripten_webgl_make_context_current(contextHandle){var success=GL.makeContextCurrent(contextHandle);return success?0:-5}Module["_emscripten_webgl_make_context_current"]=_emscripten_webgl_make_context_current;function _emscripten_webgl_destroy_context(contextHandle){if(GL.currentContext==contextHandle)GL.currentContext=0;GL.deleteContext(contextHandle)}function _emscripten_webgl_init_context_attributes(attributes){var a=attributes>>2;for(var i=0;i<56>>2;++i){HEAP32[a+i]=0}HEAP32[a+(0>>2)]=HEAP32[a+(4>>2)]=HEAP32[a+(12>>2)]=HEAP32[a+(16>>2)]=HEAP32[a+(32>>2)]=HEAP32[a+(40>>2)]=1}var ENV={};function getExecutableName(){return thisProgram||"./this.program"}function getEnvStrings(){if(!getEnvStrings.strings){var lang=(typeof navigator==="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8";var env={"USER":"web_user","LOGNAME":"web_user","PATH":"/","PWD":"/","HOME":"/home/web_user","LANG":lang,"_":getExecutableName()};for(var x in ENV){env[x]=ENV[x]}var strings=[];for(var x in env){strings.push(x+"="+env[x])}getEnvStrings.strings=strings}return getEnvStrings.strings}function _environ_get(__environ,environ_buf){try{var bufSize=0;getEnvStrings().forEach(function(string,i){var ptr=environ_buf+bufSize;HEAP32[__environ+i*4>>2]=ptr;writeAsciiToMemory(string,ptr);bufSize+=string.length+1});return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _environ_sizes_get(penviron_count,penviron_buf_size){try{var strings=getEnvStrings();HEAP32[penviron_count>>2]=strings.length;var bufSize=0;strings.forEach(function(string){bufSize+=string.length+1});HEAP32[penviron_buf_size>>2]=bufSize;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _fd_close(fd){try{var stream=SYSCALLS.getStreamFromFD(fd);FS.close(stream);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _fd_fdstat_get(fd,pbuf){try{var stream=SYSCALLS.getStreamFromFD(fd);var type=stream.tty?2:FS.isDir(stream.mode)?3:FS.isLink(stream.mode)?7:4;HEAP8[pbuf>>0]=type;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _fd_read(fd,iov,iovcnt,pnum){try{var stream=SYSCALLS.getStreamFromFD(fd);var num=SYSCALLS.doReadv(stream,iov,iovcnt);HEAP32[pnum>>2]=num;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _fd_seek(fd,offset_low,offset_high,whence,newOffset){try{var stream=SYSCALLS.getStreamFromFD(fd);var HIGH_OFFSET=4294967296;var offset=offset_high*HIGH_OFFSET+(offset_low>>>0);var DOUBLE_LIMIT=9007199254740992;if(offset<=-DOUBLE_LIMIT||offset>=DOUBLE_LIMIT){return-61}FS.llseek(stream,offset,whence);tempI64=[stream.position>>>0,(tempDouble=stream.position,+Math.abs(tempDouble)>=1?tempDouble>0?(Math.min(+Math.floor(tempDouble/4294967296),4294967295)|0)>>>0:~~+Math.ceil((tempDouble-+(~~tempDouble>>>0))/4294967296)>>>0:0)],HEAP32[newOffset>>2]=tempI64[0],HEAP32[newOffset+4>>2]=tempI64[1];if(stream.getdents&&offset===0&&whence===0)stream.getdents=null;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}function _fd_write(fd,iov,iovcnt,pnum){try{var stream=SYSCALLS.getStreamFromFD(fd);var num=SYSCALLS.doWritev(stream,iov,iovcnt);HEAP32[pnum>>2]=num;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return e.errno}}var GAI_ERRNO_MESSAGES={};function _gai_strerror(val){var buflen=256;if(!_gai_strerror.buffer){_gai_strerror.buffer=_malloc(buflen);GAI_ERRNO_MESSAGES["0"]="Success";GAI_ERRNO_MESSAGES[""+-1]="Invalid value for 'ai_flags' field";GAI_ERRNO_MESSAGES[""+-2]="NAME or SERVICE is unknown";GAI_ERRNO_MESSAGES[""+-3]="Temporary failure in name resolution";GAI_ERRNO_MESSAGES[""+-4]="Non-recoverable failure in name res";GAI_ERRNO_MESSAGES[""+-6]="'ai_family' not supported";GAI_ERRNO_MESSAGES[""+-7]="'ai_socktype' not supported";GAI_ERRNO_MESSAGES[""+-8]="SERVICE not supported for 'ai_socktype'";GAI_ERRNO_MESSAGES[""+-10]="Memory allocation failure";GAI_ERRNO_MESSAGES[""+-11]="System error returned in 'errno'";GAI_ERRNO_MESSAGES[""+-12]="Argument buffer overflow"}var msg="Unknown error";if(val in GAI_ERRNO_MESSAGES){if(GAI_ERRNO_MESSAGES[val].length>buflen-1){msg="Message too long"}else{msg=GAI_ERRNO_MESSAGES[val]}}writeAsciiToMemory(msg,_gai_strerror.buffer);return _gai_strerror.buffer}function _getTempRet0(){return getTempRet0()|0}function _getaddrinfo(node,service,hint,out){var addr=0;var port=0;var flags=0;var family=0;var type=0;var proto=0;var ai;function allocaddrinfo(family,type,proto,canon,addr,port){var sa,salen,ai;var errno;salen=family===10?28:16;addr=family===10?inetNtop6(addr):inetNtop4(addr);sa=_malloc(salen);errno=writeSockaddr(sa,family,addr,port);assert(!errno);ai=_malloc(32);HEAP32[ai+4>>2]=family;HEAP32[ai+8>>2]=type;HEAP32[ai+12>>2]=proto;HEAP32[ai+24>>2]=canon;HEAP32[ai+20>>2]=sa;if(family===10){HEAP32[ai+16>>2]=28}else{HEAP32[ai+16>>2]=16}HEAP32[ai+28>>2]=0;return ai}if(hint){flags=HEAP32[hint>>2];family=HEAP32[hint+4>>2];type=HEAP32[hint+8>>2];proto=HEAP32[hint+12>>2]}if(type&&!proto){proto=type===2?17:6}if(!type&&proto){type=proto===17?2:1}if(proto===0){proto=6}if(type===0){type=1}if(!node&&!service){return-2}if(flags&~(1|2|4|1024|8|16|32)){return-1}if(hint!==0&&HEAP32[hint>>2]&2&&!node){return-1}if(flags&32){return-2}if(type!==0&&type!==1&&type!==2){return-7}if(family!==0&&family!==2&&family!==10){return-6}if(service){service=UTF8ToString(service);port=parseInt(service,10);if(isNaN(port)){if(flags&1024){return-2}return-8}}if(!node){if(family===0){family=2}if((flags&1)===0){if(family===2){addr=_htonl(2130706433)}else{addr=[0,0,0,1]}}ai=allocaddrinfo(family,type,proto,null,addr,port);HEAP32[out>>2]=ai;return 0}node=UTF8ToString(node);addr=inetPton4(node);if(addr!==null){if(family===0||family===2){family=2}else if(family===10&&flags&8){addr=[0,0,_htonl(65535),addr];family=10}else{return-2}}else{addr=inetPton6(node);if(addr!==null){if(family===0||family===10){family=10}else{return-2}}}if(addr!=null){ai=allocaddrinfo(family,type,proto,node,addr,port);HEAP32[out>>2]=ai;return 0}if(flags&4){return-2}node=DNS.lookup_name(node);addr=inetPton4(node);if(family===0){family=2}else if(family===10){addr=[0,0,_htonl(65535),addr]}ai=allocaddrinfo(family,type,proto,null,addr,port);HEAP32[out>>2]=ai;return 0}function _getnameinfo(sa,salen,node,nodelen,serv,servlen,flags){var info=readSockaddr(sa,salen);if(info.errno){return-6}var port=info.port;var addr=info.addr;var overflowed=false;if(node&&nodelen){var lookup;if(flags&1||!(lookup=DNS.lookup_addr(addr))){if(flags&8){return-2}}else{addr=lookup}var numBytesWrittenExclNull=stringToUTF8(addr,node,nodelen);if(numBytesWrittenExclNull+1>=nodelen){overflowed=true}}if(serv&&servlen){port=""+port;var numBytesWrittenExclNull=stringToUTF8(port,serv,servlen);if(numBytesWrittenExclNull+1>=servlen){overflowed=true}}if(overflowed){return-12}return 0}function _gettimeofday(ptr){var now=Date.now();HEAP32[ptr>>2]=now/1e3|0;HEAP32[ptr+4>>2]=now%1e3*1e3|0;return 0}function _glActiveTexture(x0){GLctx["activeTexture"](x0)}function _glAttachShader(program,shader){GLctx.attachShader(GL.programs[program],GL.shaders[shader])}function _glBeginTransformFeedback(x0){GLctx["beginTransformFeedback"](x0)}function _glBindAttribLocation(program,index,name){GLctx.bindAttribLocation(GL.programs[program],index,UTF8ToString(name))}function _glBindBuffer(target,buffer){if(target==35051){GLctx.currentPixelPackBufferBinding=buffer}else if(target==35052){GLctx.currentPixelUnpackBufferBinding=buffer}GLctx.bindBuffer(target,GL.buffers[buffer])}function _glBindBufferBase(target,index,buffer){GLctx["bindBufferBase"](target,index,GL.buffers[buffer])}function _glBindFramebuffer(target,framebuffer){GLctx.bindFramebuffer(target,framebuffer?GL.framebuffers[framebuffer]:GL.currentContext.defaultFbo)}function _glBindRenderbuffer(target,renderbuffer){GLctx.bindRenderbuffer(target,GL.renderbuffers[renderbuffer])}function _glBindTexture(target,texture){GLctx.bindTexture(target,GL.textures[texture])}function _glBindVertexArray(vao){GLctx["bindVertexArray"](GL.vaos[vao])}function _glBlendEquation(x0){GLctx["blendEquation"](x0)}function _glBlendFunc(x0,x1){GLctx["blendFunc"](x0,x1)}function _glBlendFuncSeparate(x0,x1,x2,x3){GLctx["blendFuncSeparate"](x0,x1,x2,x3)}function _glBlitFramebuffer(x0,x1,x2,x3,x4,x5,x6,x7,x8,x9){GLctx["blitFramebuffer"](x0,x1,x2,x3,x4,x5,x6,x7,x8,x9)}function _glBufferData(target,size,data,usage){if(GL.currentContext.version>=2){if(data){GLctx.bufferData(target,HEAPU8,usage,data,size)}else{GLctx.bufferData(target,size,usage)}}else{GLctx.bufferData(target,data?HEAPU8.subarray(data,data+size):size,usage)}}function _glBufferSubData(target,offset,size,data){if(GL.currentContext.version>=2){GLctx.bufferSubData(target,offset,HEAPU8,data,size);return}GLctx.bufferSubData(target,offset,HEAPU8.subarray(data,data+size))}function _glCheckFramebufferStatus(x0){return GLctx["checkFramebufferStatus"](x0)}function _glClear(x0){GLctx["clear"](x0)}function _glClearBufferfv(buffer,drawbuffer,value){GLctx["clearBufferfv"](buffer,drawbuffer,HEAPF32,value>>2)}function _glClearColor(x0,x1,x2,x3){GLctx["clearColor"](x0,x1,x2,x3)}function _glClearDepthf(x0){GLctx["clearDepth"](x0)}function _glColorMask(red,green,blue,alpha){GLctx.colorMask(!!red,!!green,!!blue,!!alpha)}function _glCompileShader(shader){GLctx.compileShader(GL.shaders[shader])}function _glCompressedTexImage2D(target,level,internalFormat,width,height,border,imageSize,data){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,imageSize,data)}else{GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,HEAPU8,data,imageSize)}return}GLctx["compressedTexImage2D"](target,level,internalFormat,width,height,border,data?HEAPU8.subarray(data,data+imageSize):null)}function _glCompressedTexImage3D(target,level,internalFormat,width,height,depth,border,imageSize,data){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexImage3D"](target,level,internalFormat,width,height,depth,border,imageSize,data)}else{GLctx["compressedTexImage3D"](target,level,internalFormat,width,height,depth,border,HEAPU8,data,imageSize)}}function _glCompressedTexSubImage2D(target,level,xoffset,yoffset,width,height,format,imageSize,data){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,imageSize,data)}else{GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,HEAPU8,data,imageSize)}return}GLctx["compressedTexSubImage2D"](target,level,xoffset,yoffset,width,height,format,data?HEAPU8.subarray(data,data+imageSize):null)}function _glCompressedTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data){if(GLctx.currentPixelUnpackBufferBinding){GLctx["compressedTexSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,imageSize,data)}else{GLctx["compressedTexSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,HEAPU8,data,imageSize)}}function _glCopyBufferSubData(x0,x1,x2,x3,x4){GLctx["copyBufferSubData"](x0,x1,x2,x3,x4)}function _glCopyTexSubImage2D(x0,x1,x2,x3,x4,x5,x6,x7){GLctx["copyTexSubImage2D"](x0,x1,x2,x3,x4,x5,x6,x7)}function _glCreateProgram(){var id=GL.getNewId(GL.programs);var program=GLctx.createProgram();program.name=id;GL.programs[id]=program;return id}function _glCreateShader(shaderType){var id=GL.getNewId(GL.shaders);GL.shaders[id]=GLctx.createShader(shaderType);return id}function _glCullFace(x0){GLctx["cullFace"](x0)}function _glDeleteBuffers(n,buffers){for(var i=0;i>2];var buffer=GL.buffers[id];if(!buffer)continue;GLctx.deleteBuffer(buffer);buffer.name=0;GL.buffers[id]=null;if(id==GLctx.currentPixelPackBufferBinding)GLctx.currentPixelPackBufferBinding=0;if(id==GLctx.currentPixelUnpackBufferBinding)GLctx.currentPixelUnpackBufferBinding=0}}function _glDeleteFramebuffers(n,framebuffers){for(var i=0;i>2];var framebuffer=GL.framebuffers[id];if(!framebuffer)continue;GLctx.deleteFramebuffer(framebuffer);framebuffer.name=0;GL.framebuffers[id]=null}}function _glDeleteProgram(id){if(!id)return;var program=GL.programs[id];if(!program){GL.recordError(1281);return}GLctx.deleteProgram(program);program.name=0;GL.programs[id]=null;GL.programInfos[id]=null}function _glDeleteRenderbuffers(n,renderbuffers){for(var i=0;i>2];var renderbuffer=GL.renderbuffers[id];if(!renderbuffer)continue;GLctx.deleteRenderbuffer(renderbuffer);renderbuffer.name=0;GL.renderbuffers[id]=null}}function _glDeleteShader(id){if(!id)return;var shader=GL.shaders[id];if(!shader){GL.recordError(1281);return}GLctx.deleteShader(shader);GL.shaders[id]=null}function _glDeleteTextures(n,textures){for(var i=0;i>2];var texture=GL.textures[id];if(!texture)continue;GLctx.deleteTexture(texture);texture.name=0;GL.textures[id]=null}}function _glDeleteVertexArrays(n,vaos){for(var i=0;i>2];GLctx["deleteVertexArray"](GL.vaos[id]);GL.vaos[id]=null}}function _glDepthFunc(x0){GLctx["depthFunc"](x0)}function _glDepthMask(flag){GLctx.depthMask(!!flag)}function _glDisable(x0){GLctx["disable"](x0)}function _glDisableVertexAttribArray(index){GLctx.disableVertexAttribArray(index)}function _glDrawArrays(mode,first,count){GLctx.drawArrays(mode,first,count)}function _glDrawArraysInstanced(mode,first,count,primcount){GLctx["drawArraysInstanced"](mode,first,count,primcount)}function _glDrawBuffers(n,bufs){var bufArray=tempFixedLengthArray[n];for(var i=0;i>2]}GLctx["drawBuffers"](bufArray)}function _glDrawElementsInstanced(mode,count,type,indices,primcount){GLctx["drawElementsInstanced"](mode,count,type,indices,primcount)}function _glEnable(x0){GLctx["enable"](x0)}function _glEnableVertexAttribArray(index){GLctx.enableVertexAttribArray(index)}function _glEndTransformFeedback(){GLctx["endTransformFeedback"]()}function _glFinish(){GLctx["finish"]()}function _glFramebufferRenderbuffer(target,attachment,renderbuffertarget,renderbuffer){GLctx.framebufferRenderbuffer(target,attachment,renderbuffertarget,GL.renderbuffers[renderbuffer])}function _glFramebufferTexture2D(target,attachment,textarget,texture,level){GLctx.framebufferTexture2D(target,attachment,textarget,GL.textures[texture],level)}function _glFramebufferTextureLayer(target,attachment,texture,level,layer){GLctx.framebufferTextureLayer(target,attachment,GL.textures[texture],level,layer)}function _glFrontFace(x0){GLctx["frontFace"](x0)}function _glGenBuffers(n,buffers){__glGenObject(n,buffers,"createBuffer",GL.buffers)}function _glGenFramebuffers(n,ids){__glGenObject(n,ids,"createFramebuffer",GL.framebuffers)}function _glGenRenderbuffers(n,renderbuffers){__glGenObject(n,renderbuffers,"createRenderbuffer",GL.renderbuffers)}function _glGenTextures(n,textures){__glGenObject(n,textures,"createTexture",GL.textures)}function _glGenVertexArrays(n,arrays){__glGenObject(n,arrays,"createVertexArray",GL.vaos)}function _glGenerateMipmap(x0){GLctx["generateMipmap"](x0)}function _glGetError(){var error=GLctx.getError()||GL.lastError;GL.lastError=0;return error}function _glGetFloatv(name_,p){emscriptenWebGLGet(name_,p,2)}function _glGetIntegerv(name_,p){emscriptenWebGLGet(name_,p,0)}function _glGetProgramInfoLog(program,maxLength,length,infoLog){var log=GLctx.getProgramInfoLog(GL.programs[program]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>2]=numBytesWrittenExclNull}function _glGetProgramiv(program,pname,p){if(!p){GL.recordError(1281);return}if(program>=GL.counter){GL.recordError(1281);return}var ptable=GL.programInfos[program];if(!ptable){GL.recordError(1282);return}if(pname==35716){var log=GLctx.getProgramInfoLog(GL.programs[program]);if(log===null)log="(unknown error)";HEAP32[p>>2]=log.length+1}else if(pname==35719){HEAP32[p>>2]=ptable.maxUniformLength}else if(pname==35722){if(ptable.maxAttributeLength==-1){program=GL.programs[program];var numAttribs=GLctx.getProgramParameter(program,35721);ptable.maxAttributeLength=0;for(var i=0;i>2]=ptable.maxAttributeLength}else if(pname==35381){if(ptable.maxUniformBlockNameLength==-1){program=GL.programs[program];var numBlocks=GLctx.getProgramParameter(program,35382);ptable.maxUniformBlockNameLength=0;for(var i=0;i>2]=ptable.maxUniformBlockNameLength}else{HEAP32[p>>2]=GLctx.getProgramParameter(GL.programs[program],pname)}}function _glGetShaderInfoLog(shader,maxLength,length,infoLog){var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var numBytesWrittenExclNull=maxLength>0&&infoLog?stringToUTF8(log,infoLog,maxLength):0;if(length)HEAP32[length>>2]=numBytesWrittenExclNull}function _glGetShaderiv(shader,pname,p){if(!p){GL.recordError(1281);return}if(pname==35716){var log=GLctx.getShaderInfoLog(GL.shaders[shader]);if(log===null)log="(unknown error)";var logLength=log?log.length+1:0;HEAP32[p>>2]=logLength}else if(pname==35720){var source=GLctx.getShaderSource(GL.shaders[shader]);var sourceLength=source?source.length+1:0;HEAP32[p>>2]=sourceLength}else{HEAP32[p>>2]=GLctx.getShaderParameter(GL.shaders[shader],pname)}}function _glGetString(name_){if(GL.stringCache[name_])return GL.stringCache[name_];var ret;switch(name_){case 7939:var exts=GLctx.getSupportedExtensions()||[];exts=exts.concat(exts.map(function(e){return"GL_"+e}));ret=stringToNewUTF8(exts.join(" "));break;case 7936:case 7937:case 37445:case 37446:var s=GLctx.getParameter(name_);if(!s){GL.recordError(1280)}ret=stringToNewUTF8(s);break;case 7938:var glVersion=GLctx.getParameter(7938);if(GL.currentContext.version>=2)glVersion="OpenGL ES 3.0 ("+glVersion+")";else{glVersion="OpenGL ES 2.0 ("+glVersion+")"}ret=stringToNewUTF8(glVersion);break;case 35724:var glslVersion=GLctx.getParameter(35724);var ver_re=/^WebGL GLSL ES ([0-9]\.[0-9][0-9]?)(?:$| .*)/;var ver_num=glslVersion.match(ver_re);if(ver_num!==null){if(ver_num[1].length==3)ver_num[1]=ver_num[1]+"0";glslVersion="OpenGL ES GLSL ES "+ver_num[1]+" ("+glslVersion+")"}ret=stringToNewUTF8(glslVersion);break;default:GL.recordError(1280);return 0}GL.stringCache[name_]=ret;return ret}function _glGetStringi(name,index){if(GL.currentContext.version<2){GL.recordError(1282);return 0}var stringiCache=GL.stringiCache[name];if(stringiCache){if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index]}switch(name){case 7939:var exts=GLctx.getSupportedExtensions()||[];exts=exts.concat(exts.map(function(e){return"GL_"+e}));exts=exts.map(function(e){return stringToNewUTF8(e)});stringiCache=GL.stringiCache[name]=exts;if(index<0||index>=stringiCache.length){GL.recordError(1281);return 0}return stringiCache[index];default:GL.recordError(1280);return 0}}function _glGetUniformBlockIndex(program,uniformBlockName){return GLctx["getUniformBlockIndex"](GL.programs[program],UTF8ToString(uniformBlockName))}function _glGetUniformLocation(program,name){name=UTF8ToString(name);var arrayIndex=0;if(name[name.length-1]=="]"){var leftBrace=name.lastIndexOf("[");arrayIndex=name[leftBrace+1]!="]"?jstoi_q(name.slice(leftBrace+1)):0;name=name.slice(0,leftBrace)}var uniformInfo=GL.programInfos[program]&&GL.programInfos[program].uniforms[name];if(uniformInfo&&arrayIndex>=0&&arrayIndex>2]}GLctx["invalidateFramebuffer"](target,list)}function _glLinkProgram(program){GLctx.linkProgram(GL.programs[program]);GL.populateUniformTable(program)}function _glPixelStorei(pname,param){if(pname==3317){GL.unpackAlignment=param}GLctx.pixelStorei(pname,param)}function _glReadBuffer(x0){GLctx["readBuffer"](x0)}function _glReadPixels(x,y,width,height,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelPackBufferBinding){GLctx.readPixels(x,y,width,height,format,type,pixels)}else{var heap=heapObjectForWebGLType(type);GLctx.readPixels(x,y,width,height,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}return}var pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,format);if(!pixelData){GL.recordError(1280);return}GLctx.readPixels(x,y,width,height,format,type,pixelData)}function _glRenderbufferStorage(x0,x1,x2,x3){GLctx["renderbufferStorage"](x0,x1,x2,x3)}function _glRenderbufferStorageMultisample(x0,x1,x2,x3,x4){GLctx["renderbufferStorageMultisample"](x0,x1,x2,x3,x4)}function _glScissor(x0,x1,x2,x3){GLctx["scissor"](x0,x1,x2,x3)}function _glShaderSource(shader,count,string,length){var source=GL.getSource(shader,count,string,length);GLctx.shaderSource(GL.shaders[shader],source)}function _glTexImage2D(target,level,internalFormat,width,height,border,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,null)}return}GLctx.texImage2D(target,level,internalFormat,width,height,border,format,type,pixels?emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,internalFormat):null)}function _glTexImage3D(target,level,internalFormat,width,height,depth,border,format,type,pixels){if(GLctx.currentPixelUnpackBufferBinding){GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx["texImage3D"](target,level,internalFormat,width,height,depth,border,format,type,null)}}function _glTexParameterf(x0,x1,x2){GLctx["texParameterf"](x0,x1,x2)}function _glTexParameteri(x0,x1,x2){GLctx["texParameteri"](x0,x1,x2)}function _glTexStorage2D(x0,x1,x2,x3,x4){GLctx["texStorage2D"](x0,x1,x2,x3,x4)}function _glTexSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels){if(GL.currentContext.version>=2){if(GLctx.currentPixelUnpackBufferBinding){GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,null)}return}var pixelData=null;if(pixels)pixelData=emscriptenWebGLGetTexPixelData(type,format,width,height,pixels,0);GLctx.texSubImage2D(target,level,xoffset,yoffset,width,height,format,type,pixelData)}function _glTexSubImage3D(target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels){if(GLctx.currentPixelUnpackBufferBinding){GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,pixels)}else if(pixels){var heap=heapObjectForWebGLType(type);GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,heap,pixels>>heapAccessShiftForWebGLHeap(heap))}else{GLctx["texSubImage3D"](target,level,xoffset,yoffset,zoffset,width,height,depth,format,type,null)}}function _glTransformFeedbackVaryings(program,count,varyings,bufferMode){program=GL.programs[program];var vars=[];for(var i=0;i>2]));GLctx["transformFeedbackVaryings"](program,vars,bufferMode)}function _glUniform1f(location,v0){GLctx.uniform1f(GL.uniforms[location],v0)}function _glUniform1i(location,v0){GLctx.uniform1i(GL.uniforms[location],v0)}function _glUniform1iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform1iv(GL.uniforms[location],HEAP32,value>>2,count);return}if(count<=288){var view=__miniTempWebGLIntBuffers[count-1];for(var i=0;i>2]}}else{var view=HEAP32.subarray(value>>2,value+count*4>>2)}GLctx.uniform1iv(GL.uniforms[location],view)}function _glUniform1ui(location,v0){GLctx.uniform1ui(GL.uniforms[location],v0)}function _glUniform2f(location,v0,v1){GLctx.uniform2f(GL.uniforms[location],v0,v1)}function _glUniform2fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform2fv(GL.uniforms[location],HEAPF32,value>>2,count*2);return}if(count<=144){var view=miniTempWebGLFloatBuffers[2*count-1];for(var i=0;i<2*count;i+=2){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*8>>2)}GLctx.uniform2fv(GL.uniforms[location],view)}function _glUniform2i(location,v0,v1){GLctx.uniform2i(GL.uniforms[location],v0,v1)}function _glUniform2iv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform2iv(GL.uniforms[location],HEAP32,value>>2,count*2);return}if(count<=144){var view=__miniTempWebGLIntBuffers[2*count-1];for(var i=0;i<2*count;i+=2){view[i]=HEAP32[value+4*i>>2];view[i+1]=HEAP32[value+(4*i+4)>>2]}}else{var view=HEAP32.subarray(value>>2,value+count*8>>2)}GLctx.uniform2iv(GL.uniforms[location],view)}function _glUniform3f(location,v0,v1,v2){GLctx.uniform3f(GL.uniforms[location],v0,v1,v2)}function _glUniform3fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform3fv(GL.uniforms[location],HEAPF32,value>>2,count*3);return}if(count<=96){var view=miniTempWebGLFloatBuffers[3*count-1];for(var i=0;i<3*count;i+=3){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*12>>2)}GLctx.uniform3fv(GL.uniforms[location],view)}function _glUniform3i(location,v0,v1,v2){GLctx.uniform3i(GL.uniforms[location],v0,v1,v2)}function _glUniform4f(location,v0,v1,v2,v3){GLctx.uniform4f(GL.uniforms[location],v0,v1,v2,v3)}function _glUniform4fv(location,count,value){if(GL.currentContext.version>=2){GLctx.uniform4fv(GL.uniforms[location],HEAPF32,value>>2,count*4);return}if(count<=72){var view=miniTempWebGLFloatBuffers[4*count-1];var heap=HEAPF32;value>>=2;for(var i=0;i<4*count;i+=4){var dst=value+i;view[i]=heap[dst];view[i+1]=heap[dst+1];view[i+2]=heap[dst+2];view[i+3]=heap[dst+3]}}else{var view=HEAPF32.subarray(value>>2,value+count*16>>2)}GLctx.uniform4fv(GL.uniforms[location],view)}function _glUniform4i(location,v0,v1,v2,v3){GLctx.uniform4i(GL.uniforms[location],v0,v1,v2,v3)}function _glUniformBlockBinding(program,uniformBlockIndex,uniformBlockBinding){program=GL.programs[program];GLctx["uniformBlockBinding"](program,uniformBlockIndex,uniformBlockBinding)}function _glUniformMatrix2fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix2fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*4);return}if(count<=72){var view=miniTempWebGLFloatBuffers[4*count-1];for(var i=0;i<4*count;i+=4){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2];view[i+3]=HEAPF32[value+(4*i+12)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*16>>2)}GLctx.uniformMatrix2fv(GL.uniforms[location],!!transpose,view)}function _glUniformMatrix3fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix3fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*9);return}if(count<=32){var view=miniTempWebGLFloatBuffers[9*count-1];for(var i=0;i<9*count;i+=9){view[i]=HEAPF32[value+4*i>>2];view[i+1]=HEAPF32[value+(4*i+4)>>2];view[i+2]=HEAPF32[value+(4*i+8)>>2];view[i+3]=HEAPF32[value+(4*i+12)>>2];view[i+4]=HEAPF32[value+(4*i+16)>>2];view[i+5]=HEAPF32[value+(4*i+20)>>2];view[i+6]=HEAPF32[value+(4*i+24)>>2];view[i+7]=HEAPF32[value+(4*i+28)>>2];view[i+8]=HEAPF32[value+(4*i+32)>>2]}}else{var view=HEAPF32.subarray(value>>2,value+count*36>>2)}GLctx.uniformMatrix3fv(GL.uniforms[location],!!transpose,view)}function _glUniformMatrix4fv(location,count,transpose,value){if(GL.currentContext.version>=2){GLctx.uniformMatrix4fv(GL.uniforms[location],!!transpose,HEAPF32,value>>2,count*16);return}if(count<=18){var view=miniTempWebGLFloatBuffers[16*count-1];var heap=HEAPF32;value>>=2;for(var i=0;i<16*count;i+=16){var dst=value+i;view[i]=heap[dst];view[i+1]=heap[dst+1];view[i+2]=heap[dst+2];view[i+3]=heap[dst+3];view[i+4]=heap[dst+4];view[i+5]=heap[dst+5];view[i+6]=heap[dst+6];view[i+7]=heap[dst+7];view[i+8]=heap[dst+8];view[i+9]=heap[dst+9];view[i+10]=heap[dst+10];view[i+11]=heap[dst+11];view[i+12]=heap[dst+12];view[i+13]=heap[dst+13];view[i+14]=heap[dst+14];view[i+15]=heap[dst+15]}}else{var view=HEAPF32.subarray(value>>2,value+count*64>>2)}GLctx.uniformMatrix4fv(GL.uniforms[location],!!transpose,view)}function _glUseProgram(program){GLctx.useProgram(GL.programs[program])}function _glVertexAttrib4f(x0,x1,x2,x3,x4){GLctx["vertexAttrib4f"](x0,x1,x2,x3,x4)}function _glVertexAttrib4fv(index,v){GLctx.vertexAttrib4f(index,HEAPF32[v>>2],HEAPF32[v+4>>2],HEAPF32[v+8>>2],HEAPF32[v+12>>2])}function _glVertexAttribDivisor(index,divisor){GLctx["vertexAttribDivisor"](index,divisor)}function _glVertexAttribI4ui(x0,x1,x2,x3,x4){GLctx["vertexAttribI4ui"](x0,x1,x2,x3,x4)}function _glVertexAttribIPointer(index,size,type,stride,ptr){GLctx["vertexAttribIPointer"](index,size,type,stride,ptr)}function _glVertexAttribPointer(index,size,type,normalized,stride,ptr){GLctx.vertexAttribPointer(index,size,type,!!normalized,stride,ptr)}function _glViewport(x0,x1,x2,x3){GLctx["viewport"](x0,x1,x2,x3)}function _gmtime_r(time,tmPtr){var date=new Date(HEAP32[time>>2]*1e3);HEAP32[tmPtr>>2]=date.getUTCSeconds();HEAP32[tmPtr+4>>2]=date.getUTCMinutes();HEAP32[tmPtr+8>>2]=date.getUTCHours();HEAP32[tmPtr+12>>2]=date.getUTCDate();HEAP32[tmPtr+16>>2]=date.getUTCMonth();HEAP32[tmPtr+20>>2]=date.getUTCFullYear()-1900;HEAP32[tmPtr+24>>2]=date.getUTCDay();HEAP32[tmPtr+36>>2]=0;HEAP32[tmPtr+32>>2]=0;var start=Date.UTC(date.getUTCFullYear(),0,1,0,0,0,0);var yday=(date.getTime()-start)/(1e3*60*60*24)|0;HEAP32[tmPtr+28>>2]=yday;if(!_gmtime_r.GMTString)_gmtime_r.GMTString=allocateUTF8("GMT");HEAP32[tmPtr+40>>2]=_gmtime_r.GMTString;return tmPtr}var GodotRuntime={get_func:function(ptr){return wasmTable.get(ptr)},error:function(){err.apply(null,Array.from(arguments))},print:function(){out.apply(null,Array.from(arguments))},malloc:function(p_size){return _malloc(p_size)},free:function(p_ptr){_free(p_ptr)},getHeapValue:function(p_ptr,p_type){return getValue(p_ptr,p_type)},setHeapValue:function(p_ptr,p_value,p_type){setValue(p_ptr,p_value,p_type)},heapSub:function(p_heap,p_ptr,p_len){const bytes=p_heap.BYTES_PER_ELEMENT;return p_heap.subarray(p_ptr/bytes,p_ptr/bytes+p_len)},heapSlice:function(p_heap,p_ptr,p_len){const bytes=p_heap.BYTES_PER_ELEMENT;return p_heap.slice(p_ptr/bytes,p_ptr/bytes+p_len)},heapCopy:function(p_dst,p_src,p_ptr){const bytes=p_src.BYTES_PER_ELEMENT;return p_dst.set(p_src,p_ptr/bytes)},parseString:function(p_ptr){return UTF8ToString(p_ptr)},parseStringArray:function(p_ptr,p_size){const strings=[];const ptrs=GodotRuntime.heapSub(HEAP32,p_ptr,p_size);ptrs.forEach(function(ptr){strings.push(GodotRuntime.parseString(ptr))});return strings},strlen:function(p_str){return lengthBytesUTF8(p_str)},allocString:function(p_str){const length=GodotRuntime.strlen(p_str)+1;const c_str=GodotRuntime.malloc(length);stringToUTF8(p_str,c_str,length);return c_str},allocStringArray:function(p_strings){const size=p_strings.length;const c_ptr=GodotRuntime.malloc(size*4);for(let i=0;i>2)+i]=GodotRuntime.allocString(p_strings[i])}return c_ptr},freeStringArray:function(p_ptr,p_len){for(let i=0;i>2)+i])}GodotRuntime.free(p_ptr)},stringToHeap:function(p_str,p_ptr,p_len){return stringToUTF8Array(p_str,HEAP8,p_ptr,p_len)}};var GodotConfig={canvas:null,locale:"en",canvas_resize_policy:2,virtual_keyboard:false,persistent_drops:false,on_execute:null,on_exit:null,init_config:function(p_opts){GodotConfig.canvas_resize_policy=p_opts["canvasResizePolicy"];GodotConfig.canvas=p_opts["canvas"];GodotConfig.locale=p_opts["locale"]||GodotConfig.locale;GodotConfig.virtual_keyboard=p_opts["virtualKeyboard"];GodotConfig.persistent_drops=!!p_opts["persistentDrops"];GodotConfig.on_execute=p_opts["onExecute"];GodotConfig.on_exit=p_opts["onExit"]},locate_file:function(file){return Module["locateFile"](file)},clear:function(){GodotConfig.canvas=null;GodotConfig.locale="en";GodotConfig.canvas_resize_policy=2;GodotConfig.virtual_keyboard=false;GodotConfig.persistent_drops=false;GodotConfig.on_execute=null;GodotConfig.on_exit=null}};var GodotFS={_idbfs:false,_syncing:false,_mount_points:[],is_persistent:function(){return GodotFS._idbfs?1:0},init:function(persistentPaths){GodotFS._idbfs=false;if(!Array.isArray(persistentPaths)){return Promise.reject(new Error("Persistent paths must be an array"))}if(!persistentPaths.length){return Promise.resolve()}GodotFS._mount_points=persistentPaths.slice();function createRecursive(dir){try{FS.stat(dir)}catch(e){if(e.errno!==ERRNO_CODES.ENOENT){throw e}FS.mkdirTree(dir)}}GodotFS._mount_points.forEach(function(path){createRecursive(path);FS.mount(IDBFS,{},path)});return new Promise(function(resolve,reject){FS.syncfs(true,function(err){if(err){GodotFS._mount_points=[];GodotFS._idbfs=false;GodotRuntime.print(`IndexedDB not available: ${err.message}`)}else{GodotFS._idbfs=true}resolve(err)})})},deinit:function(){GodotFS._mount_points.forEach(function(path){try{FS.unmount(path)}catch(e){GodotRuntime.print("Already unmounted",e)}if(GodotFS._idbfs&&IDBFS.dbs[path]){IDBFS.dbs[path].close();delete IDBFS.dbs[path]}});GodotFS._mount_points=[];GodotFS._idbfs=false;GodotFS._syncing=false},sync:function(){if(GodotFS._syncing){GodotRuntime.error("Already syncing!");return Promise.resolve()}GodotFS._syncing=true;return new Promise(function(resolve,reject){FS.syncfs(false,function(error){if(error){GodotRuntime.error(`Failed to save IDB file system: ${error.message}`)}GodotFS._syncing=false;resolve(error)})})},copy_to_fs:function(path,buffer){const idx=path.lastIndexOf("/");let dir="/";if(idx>0){dir=path.slice(0,idx)}try{FS.stat(dir)}catch(e){if(e.errno!==ERRNO_CODES.ENOENT){throw e}FS.mkdirTree(dir)}FS.writeFile(path,new Uint8Array(buffer))}};var GodotOS={request_quit:function(){},_async_cbs:[],_fs_sync_promise:null,atexit:function(p_promise_cb){GodotOS._async_cbs.push(p_promise_cb)},cleanup:function(exit_code){const cb=GodotConfig.on_exit;GodotFS.deinit();GodotConfig.clear();if(cb){cb(exit_code)}},finish_async:function(callback){GodotOS._fs_sync_promise.then(function(err){const promises=[];GodotOS._async_cbs.forEach(function(cb){promises.push(new Promise(cb))});return Promise.all(promises)}).then(function(){return GodotFS.sync()}).then(function(err){setTimeout(function(){callback()},0)})}};var GodotAudio={ctx:null,input:null,driver:null,interval:0,init:function(mix_rate,latency,onstatechange,onlatencyupdate){const ctx=new(window.AudioContext||window.webkitAudioContext)({sampleRate:mix_rate});GodotAudio.ctx=ctx;ctx.onstatechange=function(){let state=0;switch(ctx.state){case"suspended":state=0;break;case"running":state=1;break;case"closed":state=2;break}onstatechange(state)};ctx.onstatechange();GodotAudio.interval=setInterval(function(){let computed_latency=0;if(ctx.baseLatency){computed_latency+=GodotAudio.ctx.baseLatency}if(ctx.outputLatency){computed_latency+=GodotAudio.ctx.outputLatency}onlatencyupdate(computed_latency)},1e3);GodotOS.atexit(GodotAudio.close_async);return ctx.destination.channelCount},create_input:function(callback){if(GodotAudio.input){return 0}function gotMediaInput(stream){try{GodotAudio.input=GodotAudio.ctx.createMediaStreamSource(stream);callback(GodotAudio.input)}catch(e){GodotRuntime.error("Failed creaating input.",e)}}if(navigator.mediaDevices&&navigator.mediaDevices.getUserMedia){navigator.mediaDevices.getUserMedia({"audio":true}).then(gotMediaInput,function(e){GodotRuntime.error("Error getting user media.",e)})}else{if(!navigator.getUserMedia){navigator.getUserMedia=navigator.webkitGetUserMedia||navigator.mozGetUserMedia}if(!navigator.getUserMedia){GodotRuntime.error("getUserMedia not available.");return 1}navigator.getUserMedia({"audio":true},gotMediaInput,function(e){GodotRuntime.print(e)})}return 0},close_async:function(resolve,reject){const ctx=GodotAudio.ctx;GodotAudio.ctx=null;if(!ctx){resolve();return}if(GodotAudio.interval){clearInterval(GodotAudio.interval);GodotAudio.interval=0}if(GodotAudio.input){GodotAudio.input.disconnect();GodotAudio.input=null}let closed=Promise.resolve();if(GodotAudio.driver){closed=GodotAudio.driver.close()}closed.then(function(){return ctx.close()}).then(function(){ctx.onstatechange=null;resolve()}).catch(function(e){ctx.onstatechange=null;GodotRuntime.error("Error closing AudioContext",e);resolve()})}};function _godot_audio_capture_start(){return GodotAudio.create_input(function(input){input.connect(GodotAudio.driver.get_node())})}function _godot_audio_capture_stop(){if(GodotAudio.input){const tracks=GodotAudio.input["mediaStream"]["getTracks"]();for(let i=0;i{const path=elem["path"];GodotFS.copy_to_fs(DROP+path,elem["data"]);let idx=path.indexOf("/");if(idx===-1){drops.push(DROP+path)}else{const sub=path.substr(0,idx);idx=sub.indexOf("/");if(idx<0&&drops.indexOf(DROP+sub)===-1){drops.push(DROP+sub)}}files.push(DROP+path)});GodotDisplayDragDrop.promises=[];GodotDisplayDragDrop.pending_files=[];callback(drops);if(GodotConfig.persistent_drops){GodotOS.atexit(function(resolve,reject){GodotDisplayDragDrop.remove_drop(files,DROP);resolve()})}else{GodotDisplayDragDrop.remove_drop(files,DROP)}})},remove_drop:function(files,drop_path){const dirs=[drop_path.substr(0,drop_path.length-1)];files.forEach(function(file){FS.unlink(file);let dir=file.replace(drop_path,"");let idx=dir.lastIndexOf("/");while(idx>0){dir=dir.substr(0,idx);if(dirs.indexOf(drop_path+dir)===-1){dirs.push(drop_path+dir)}idx=dir.lastIndexOf("/")}});dirs.sort(function(a,b){const al=(a.match(/\//g)||[]).length;const bl=(b.match(/\//g)||[]).length;if(al>bl){return-1}else if(al=0){os="Android"}else if(ua.indexOf("Linux")>=0){os="Linux"}else if(ua.indexOf("iPhone")>=0){os="iOS"}else if(ua.indexOf("Macintosh")>=0){os="MacOSX"}else if(ua.indexOf("Windows")>=0){os="Windows"}const id=pad.id;const exp1=/vendor: ([0-9a-f]{4}) product: ([0-9a-f]{4})/i;const exp2=/^([0-9a-f]+)-([0-9a-f]+)-/i;let vendor="";let product="";if(exp1.test(id)){const match=exp1.exec(id);vendor=match[1].padStart(4,"0");product=match[2].padStart(4,"0")}else if(exp2.test(id)){const match=exp2.exec(id);vendor=match[1].padStart(4,"0");product=match[2].padStart(4,"0")}if(!vendor||!product){return`${os}Unknown`}return os+vendor+product}};var GodotDisplayScreen={desired_size:[0,0],hidpi:true,getPixelRatio:function(){return GodotDisplayScreen.hidpi?window.devicePixelRatio||1:1},isFullscreen:function(){const elem=document.fullscreenElement||document.mozFullscreenElement||document.webkitFullscreenElement||document.msFullscreenElement;if(elem){return elem===GodotConfig.canvas}return document.fullscreen||document.mozFullScreen||document.webkitIsFullscreen},hasFullscreen:function(){return document.fullscreenEnabled||document.mozFullScreenEnabled||document.webkitFullscreenEnabled},requestFullscreen:function(){if(!GodotDisplayScreen.hasFullscreen()){return 1}const canvas=GodotConfig.canvas;try{const promise=(canvas.requestFullscreen||canvas.msRequestFullscreen||canvas.mozRequestFullScreen||canvas.mozRequestFullscreen||canvas.webkitRequestFullscreen).call(canvas);if(promise){promise.catch(function(){})}}catch(e){return 1}return 0},exitFullscreen:function(){if(!GodotDisplayScreen.isFullscreen()){return 0}try{const promise=document.exitFullscreen();if(promise){promise.catch(function(){})}}catch(e){return 1}return 0},_updateGL:function(){const gl_context_handle=_emscripten_webgl_get_current_context();const gl=GL.getContext(gl_context_handle);if(gl){GL.resizeOffscreenFramebuffer(gl)}},updateSize:function(){const isFullscreen=GodotDisplayScreen.isFullscreen();const wantsFullWindow=GodotConfig.canvas_resize_policy===2;const noResize=GodotConfig.canvas_resize_policy===0;const wwidth=GodotDisplayScreen.desired_size[0];const wheight=GodotDisplayScreen.desired_size[1];const canvas=GodotConfig.canvas;let width=wwidth;let height=wheight;if(noResize){if(canvas.width!==width||canvas.height!==height){GodotDisplayScreen.desired_size=[canvas.width,canvas.height];GodotDisplayScreen._updateGL();return 1}return 0}const scale=GodotDisplayScreen.getPixelRatio();if(isFullscreen||wantsFullWindow){width=window.innerWidth*scale;height=window.innerHeight*scale}const csw=`${width/scale}px`;const csh=`${height/scale}px`;if(canvas.style.width!==csw||canvas.style.height!==csh||canvas.width!==width||canvas.height!==height){canvas.width=width;canvas.height=height;canvas.style.width=csw;canvas.style.height=csh;GodotDisplayScreen._updateGL();return 1}return 0}};var GodotDisplayVK={textinput:null,textarea:null,available:function(){return GodotConfig.virtual_keyboard&&"ontouchstart"in window},init:function(input_cb){function create(what){const elem=document.createElement(what);elem.style.display="none";elem.style.position="absolute";elem.style.zIndex="-1";elem.style.background="transparent";elem.style.padding="0px";elem.style.margin="0px";elem.style.overflow="hidden";elem.style.width="0px";elem.style.height="0px";elem.style.border="0px";elem.style.outline="none";elem.readonly=true;elem.disabled=true;GodotDisplayListeners.add(elem,"input",function(evt){const c_str=GodotRuntime.allocString(elem.value);input_cb(c_str,elem.selectionEnd);GodotRuntime.free(c_str)},false);GodotDisplayListeners.add(elem,"blur",function(evt){elem.style.display="none";elem.readonly=true;elem.disabled=true},false);GodotConfig.canvas.insertAdjacentElement("beforebegin",elem);return elem}GodotDisplayVK.textinput=create("input");GodotDisplayVK.textarea=create("textarea");GodotDisplayVK.updateSize()},show:function(text,multiline,start,end){if(!GodotDisplayVK.textinput||!GodotDisplayVK.textarea){return}if(GodotDisplayVK.textinput.style.display!==""||GodotDisplayVK.textarea.style.display!==""){GodotDisplayVK.hide()}GodotDisplayVK.updateSize();const elem=multiline?GodotDisplayVK.textarea:GodotDisplayVK.textinput;elem.readonly=false;elem.disabled=false;elem.value=text;elem.style.display="block";elem.focus();elem.setSelectionRange(start,end)},hide:function(){if(!GodotDisplayVK.textinput||!GodotDisplayVK.textarea){return}[GodotDisplayVK.textinput,GodotDisplayVK.textarea].forEach(function(elem){elem.blur();elem.style.display="none";elem.value=""})},updateSize:function(){if(!GodotDisplayVK.textinput||!GodotDisplayVK.textarea){return}const rect=GodotConfig.canvas.getBoundingClientRect();function update(elem){elem.style.left=`${rect.left}px`;elem.style.top=`${rect.top}px`;elem.style.width=`${rect.width}px`;elem.style.height=`${rect.height}px`}update(GodotDisplayVK.textinput);update(GodotDisplayVK.textarea)},clear:function(){if(GodotDisplayVK.textinput){GodotDisplayVK.textinput.remove();GodotDisplayVK.textinput=null}if(GodotDisplayVK.textarea){GodotDisplayVK.textarea.remove();GodotDisplayVK.textarea=null}}};var GodotDisplay={window_icon:"",findDPI:function(){function testDPI(dpi){return window.matchMedia(`(max-resolution: ${dpi}dpi)`).matches}function bisect(low,high,func){const mid=parseInt((high-low)/2+low,10);if(high-low<=1){return func(high)?high:low}if(func(mid)){return bisect(low,mid,func)}return bisect(mid,high,func)}try{const dpi=bisect(0,800,testDPI);return dpi>=96?dpi:96}catch(e){return 96}}};function _godot_js_display_alert(p_text){window.alert(GodotRuntime.parseString(p_text))}function _godot_js_display_canvas_focus(){GodotConfig.canvas.focus()}function _godot_js_display_canvas_is_focused(){return document.activeElement===GodotConfig.canvas}function _godot_js_display_clipboard_get(callback){const func=GodotRuntime.get_func(callback);try{navigator.clipboard.readText().then(function(result){const ptr=GodotRuntime.allocString(result);func(ptr);GodotRuntime.free(ptr)}).catch(function(e){})}catch(e){}}function _godot_js_display_clipboard_set(p_text){const text=GodotRuntime.parseString(p_text);if(!navigator.clipboard||!navigator.clipboard.writeText){return 1}navigator.clipboard.writeText(text).catch(function(e){GodotRuntime.error("Setting OS clipboard is only possible from an input callback for the HTML5 plafrom. Exception:",e)});return 0}function _godot_js_display_compute_position(x,y,r_x,r_y){const canvas=GodotConfig.canvas;const rect=canvas.getBoundingClientRect();const rw=canvas.width/rect.width;const rh=canvas.height/rect.height;GodotRuntime.setHeapValue(r_x,(x-rect.x)*rw,"i32");GodotRuntime.setHeapValue(r_y,(y-rect.y)*rh,"i32")}function _godot_js_display_cursor_is_hidden(){return!GodotDisplayCursor.visible}function _godot_js_display_cursor_set_custom_shape(p_shape,p_ptr,p_len,p_hotspot_x,p_hotspot_y){const shape=GodotRuntime.parseString(p_shape);const old_shape=GodotDisplayCursor.cursors[shape];if(p_len>0){const png=new Blob([GodotRuntime.heapSlice(HEAPU8,p_ptr,p_len)],{type:"image/png"});const url=URL.createObjectURL(png);GodotDisplayCursor.cursors[shape]={url:url,x:p_hotspot_x,y:p_hotspot_y}}else{delete GodotDisplayCursor.cursors[shape]}if(shape===GodotDisplayCursor.shape){GodotDisplayCursor.set_shape(GodotDisplayCursor.shape)}if(old_shape){URL.revokeObjectURL(old_shape.url)}}function _godot_js_display_cursor_set_shape(p_string){GodotDisplayCursor.set_shape(GodotRuntime.parseString(p_string))}function _godot_js_display_cursor_set_visible(p_visible){const visible=p_visible!==0;if(visible===GodotDisplayCursor.visible){return}GodotDisplayCursor.visible=visible;if(visible){GodotDisplayCursor.set_shape(GodotDisplayCursor.shape)}else{GodotDisplayCursor.set_style("none")}}function _godot_js_display_desired_size_set(width,height){GodotDisplayScreen.desired_size=[width,height];GodotDisplayScreen.updateSize()}function _godot_js_display_drop_files_cb(callback){const func=GodotRuntime.get_func(callback);const dropFiles=function(files){const args=files||[];if(!args.length){return}const argc=args.length;const argv=GodotRuntime.allocStringArray(args);func(argv,argc);GodotRuntime.freeStringArray(argv,argc)};const canvas=GodotConfig.canvas;GodotDisplayListeners.add(canvas,"dragover",function(ev){ev.preventDefault()},false);GodotDisplayListeners.add(canvas,"drop",GodotDisplayDragDrop.handler(dropFiles))}function _godot_js_display_fullscreen_exit(){return GodotDisplayScreen.exitFullscreen()}function _godot_js_display_fullscreen_request(){return GodotDisplayScreen.requestFullscreen()}function _godot_js_display_gamepad_cb(change_cb){const onchange=GodotRuntime.get_func(change_cb);GodotDisplayGamepads.init(onchange)}function _godot_js_display_gamepad_sample(){GodotDisplayGamepads.sample();return 0}function _godot_js_display_gamepad_sample_count(){return GodotDisplayGamepads.get_samples().length}function _godot_js_display_gamepad_sample_get(p_index,r_btns,r_btns_num,r_axes,r_axes_num,r_standard){const sample=GodotDisplayGamepads.get_sample(p_index);if(!sample||!sample.connected){return 1}const btns=sample.buttons;const btns_len=btns.length<16?btns.length:16;for(let i=0;i0?p_start:0;const end=p_end>0?p_end:start;GodotDisplayVK.show(text,p_multiline,start,end)}function _godot_js_display_window_icon_set(p_ptr,p_len){let link=document.getElementById("-gd-engine-icon");if(link===null){link=document.createElement("link");link.rel="icon";link.id="-gd-engine-icon";document.head.appendChild(link)}const old_icon=GodotDisplay.window_icon;const png=new Blob([GodotRuntime.heapSlice(HEAPU8,p_ptr,p_len)],{type:"image/png"});GodotDisplay.window_icon=URL.createObjectURL(png);link.href=GodotDisplay.window_icon;if(old_icon){URL.revokeObjectURL(old_icon)}}function _godot_js_display_window_size_get(p_width,p_height){GodotRuntime.setHeapValue(p_width,GodotConfig.canvas.width,"i32");GodotRuntime.setHeapValue(p_height,GodotConfig.canvas.height,"i32")}function _godot_js_display_window_title_set(p_data){document.title=GodotRuntime.parseString(p_data)}function _godot_js_eval(p_js,p_use_global_ctx,p_union_ptr,p_byte_arr,p_byte_arr_write,p_callback){const js_code=GodotRuntime.parseString(p_js);let eval_ret=null;try{if(p_use_global_ctx){const global_eval=eval;eval_ret=global_eval(js_code)}else{eval_ret=eval(js_code)}}catch(e){GodotRuntime.error(e)}switch(typeof eval_ret){case"boolean":GodotRuntime.setHeapValue(p_union_ptr,eval_ret,"i32");return 1;case"number":GodotRuntime.setHeapValue(p_union_ptr,eval_ret,"double");return 3;case"string":GodotRuntime.setHeapValue(p_union_ptr,GodotRuntime.allocString(eval_ret),"*");return 4;case"object":if(eval_ret===null){break}if(ArrayBuffer.isView(eval_ret)&&!(eval_ret instanceof Uint8Array)){eval_ret=new Uint8Array(eval_ret.buffer)}else if(eval_ret instanceof ArrayBuffer){eval_ret=new Uint8Array(eval_ret)}if(eval_ret instanceof Uint8Array){const func=GodotRuntime.get_func(p_callback);const bytes_ptr=func(p_byte_arr,p_byte_arr_write,eval_ret.length);HEAPU8.set(eval_ret,bytes_ptr);return 20}break}return 0}var GodotFetch={onread:function(id,result){const obj=IDHandler.get(id);if(!obj){return}if(result.value){obj.chunks.push(result.value)}obj.reading=false;obj.done=result.done},onresponse:function(id,response){const obj=IDHandler.get(id);if(!obj){return}let chunked=false;response.headers.forEach(function(value,header){const v=value.toLowerCase().trim();const h=header.toLowerCase().trim();if(h==="transfer-encoding"&&v==="chunked"){chunked=true}});obj.status=response.status;obj.response=response;obj.reader=response.body.getReader();obj.chunked=chunked},onerror:function(id,err){GodotRuntime.error(err);const obj=IDHandler.get(id);if(!obj){return}obj.error=err},create:function(method,url,headers,body){const obj={request:null,response:null,reader:null,error:null,done:false,reading:false,status:0,chunks:[],bodySize:-1};const id=IDHandler.add(obj);const init={method:method,headers:headers,body:body};obj.request=fetch(url,init);obj.request.then(GodotFetch.onresponse.bind(null,id)).catch(GodotFetch.onerror.bind(null,id));return id},free:function(id){const obj=IDHandler.get(id);if(!obj){return}IDHandler.remove(id);if(!obj.request){return}obj.request.then(function(response){response.abort()}).catch(function(e){})},read:function(id){const obj=IDHandler.get(id);if(!obj){return}if(obj.reader&&!obj.reading){if(obj.done){obj.reader=null;return}obj.reading=true;obj.reader.read().then(GodotFetch.onread.bind(null,id)).catch(GodotFetch.onerror.bind(null,id))}}};function _godot_js_fetch_body_length_get(p_id){const obj=IDHandler.get(p_id);if(!obj||!obj.response){return-1}return obj.bodySize}function _godot_js_fetch_create(p_method,p_url,p_headers,p_headers_size,p_body,p_body_size){const method=GodotRuntime.parseString(p_method);const url=GodotRuntime.parseString(p_url);const headers=GodotRuntime.parseStringArray(p_headers,p_headers_size);const body=p_body_size?GodotRuntime.heapSlice(HEAP8,p_body,p_body_size):null;return GodotFetch.create(method,url,headers.map(function(hv){const idx=hv.indexOf(":");if(idx<=0){return[]}return[hv.slice(0,idx).trim(),hv.slice(idx+1).trim()]}).filter(function(v){return v.length===2}),body)}function _godot_js_fetch_free(id){GodotFetch.free(id)}function _godot_js_fetch_http_status_get(p_id){const obj=IDHandler.get(p_id);if(!obj||!obj.response){return 0}return obj.status}function _godot_js_fetch_is_chunked(p_id){const obj=IDHandler.get(p_id);if(!obj||!obj.response){return-1}return obj.chunked?1:0}function _godot_js_fetch_read_chunk(p_id,p_buf,p_buf_size){const obj=IDHandler.get(p_id);if(!obj||!obj.response){return 0}let to_read=p_buf_size;const chunks=obj.chunks;while(to_read&&chunks.length){const chunk=obj.chunks[0];if(chunk.length>to_read){GodotRuntime.heapCopy(HEAP8,chunk.slice(0,to_read),p_buf);chunks[0]=chunk.slice(to_read);to_read=0}else{GodotRuntime.heapCopy(HEAP8,chunk,p_buf);to_read-=chunk.length;chunks.pop()}}if(!chunks.length){GodotFetch.read(p_id)}return p_buf_size-to_read}function _godot_js_fetch_read_headers(p_id,p_parse_cb,p_ref){const obj=IDHandler.get(p_id);if(!obj||!obj.response){return 1}const cb=GodotRuntime.get_func(p_parse_cb);const arr=[];obj.response.headers.forEach(function(v,h){arr.push(`${h}:${v}`)});const c_ptr=GodotRuntime.allocStringArray(arr);cb(arr.length,c_ptr,p_ref);GodotRuntime.freeStringArray(c_ptr,arr.length);return 0}function _godot_js_fetch_state_get(p_id){const obj=IDHandler.get(p_id);if(!obj){return-1}if(obj.error){return-1}if(!obj.response){return 0}if(obj.reader){return 1}if(obj.done){return 2}return-1}function _godot_js_os_execute(p_json){const json_args=GodotRuntime.parseString(p_json);const args=JSON.parse(json_args);if(GodotConfig.on_execute){GodotConfig.on_execute(args);return 0}return 1}function _godot_js_os_finish_async(p_callback){const func=GodotRuntime.get_func(p_callback);GodotOS.finish_async(func)}function _godot_js_os_fs_is_persistent(){return GodotFS.is_persistent()}function _godot_js_os_fs_sync(callback){const func=GodotRuntime.get_func(callback);GodotOS._fs_sync_promise=GodotFS.sync();GodotOS._fs_sync_promise.then(function(err){func()})}function _godot_js_os_hw_concurrency_get(){return navigator.hardwareConcurrency||1}function _godot_js_os_request_quit_cb(p_callback){GodotOS.request_quit=GodotRuntime.get_func(p_callback)}function _godot_js_os_shell_open(p_uri){window.open(GodotRuntime.parseString(p_uri),"_blank")}var IDHandler={_last_id:0,_references:{},get:function(p_id){return IDHandler._references[p_id]},add:function(p_data){const id=++IDHandler._last_id;IDHandler._references[id]=p_data;return id},remove:function(p_id){delete IDHandler._references[p_id]}};var GodotRTCDataChannel={connect:function(p_id,p_on_open,p_on_message,p_on_error,p_on_close){const ref=IDHandler.get(p_id);if(!ref){return}ref.binaryType="arraybuffer";ref.onopen=function(event){p_on_open()};ref.onclose=function(event){p_on_close()};ref.onerror=function(event){p_on_error()};ref.onmessage=function(event){let buffer;let is_string=0;if(event.data instanceof ArrayBuffer){buffer=new Uint8Array(event.data)}else if(event.data instanceof Blob){GodotRuntime.error("Blob type not supported");return}else if(typeof event.data==="string"){is_string=1;const enc=new TextEncoder("utf-8");buffer=new Uint8Array(enc.encode(event.data))}else{GodotRuntime.error("Unknown message type");return}const len=buffer.length*buffer.BYTES_PER_ELEMENT;const out=GodotRuntime.malloc(len);HEAPU8.set(buffer,out);p_on_message(out,len,is_string);GodotRuntime.free(out)}},close:function(p_id){const ref=IDHandler.get(p_id);if(!ref){return}ref.onopen=null;ref.onmessage=null;ref.onerror=null;ref.onclose=null;ref.close()},get_prop:function(p_id,p_prop,p_def){const ref=IDHandler.get(p_id);return ref&&ref[p_prop]!==undefined?ref[p_prop]:p_def}};function _godot_js_rtc_datachannel_close(p_id){const ref=IDHandler.get(p_id);if(!ref){return}GodotRTCDataChannel.close(p_id)}function _godot_js_rtc_datachannel_connect(p_id,p_ref,p_on_open,p_on_message,p_on_error,p_on_close){const onopen=GodotRuntime.get_func(p_on_open).bind(null,p_ref);const onmessage=GodotRuntime.get_func(p_on_message).bind(null,p_ref);const onerror=GodotRuntime.get_func(p_on_error).bind(null,p_ref);const onclose=GodotRuntime.get_func(p_on_close).bind(null,p_ref);GodotRTCDataChannel.connect(p_id,onopen,onmessage,onerror,onclose)}function _godot_js_rtc_datachannel_destroy(p_id){GodotRTCDataChannel.close(p_id);IDHandler.remove(p_id)}function _godot_js_rtc_datachannel_id_get(p_id){return IDHandler.get_prop(p_id,"id",65535)}function _godot_js_rtc_datachannel_is_negotiated(p_id){return IDHandler.get_prop(p_id,"negotiated",65535)}function _godot_js_rtc_datachannel_is_ordered(p_id){return IDHandler.get_prop(p_id,"ordered",true)}function _godot_js_rtc_datachannel_label_get(p_id){const ref=IDHandler.get(p_id);if(!ref||!ref.label){return 0}return GodotRuntime.allocString(ref.label)}function _godot_js_rtc_datachannel_max_packet_lifetime_get(p_id){const ref=IDHandler.get(p_id);if(!ref){return 65535}if(ref["maxPacketLifeTime"]!==undefined){return ref["maxPacketLifeTime"]}else if(ref["maxRetransmitTime"]!==undefined){return ref["maxRetransmitTime"]}return 65535}function _godot_js_rtc_datachannel_max_retransmits_get(p_id){return IDHandler.get_prop(p_id,"maxRetransmits",65535)}function _godot_js_rtc_datachannel_protocol_get(p_id){const ref=IDHandler.get(p_id);if(!ref||!ref.protocol){return 0}return GodotRuntime.allocString(ref.protocol)}function _godot_js_rtc_datachannel_ready_state_get(p_id){const ref=IDHandler.get(p_id);if(!ref){return 3}switch(ref.readyState){case"connecting":return 0;case"open":return 1;case"closing":return 2;case"closed":default:return 3}}function _godot_js_rtc_datachannel_send(p_id,p_buffer,p_length,p_raw){const ref=IDHandler.get(p_id);if(!ref){return 1}const bytes_array=new Uint8Array(p_length);for(let i=0;i{if(GodotWebXR.session&&GodotWebXR.space){const onFrame=function(time,frame){GodotWebXR.frame=frame;GodotWebXR.pose=frame.getViewerPose(GodotWebXR.space);callback(time);GodotWebXR.frame=null;GodotWebXR.pose=null};GodotWebXR.session.requestAnimationFrame(onFrame)}else{GodotWebXR.orig_requestAnimationFrame(callback)}},monkeyPatchRequestAnimationFrame:enable=>{if(GodotWebXR.orig_requestAnimationFrame===null){GodotWebXR.orig_requestAnimationFrame=Browser.requestAnimationFrame}Browser.requestAnimationFrame=enable?GodotWebXR.requestAnimationFrame:GodotWebXR.orig_requestAnimationFrame},pauseResumeMainLoop:()=>{Browser.mainLoop.pause();window.setTimeout(function(){Browser.mainLoop.resume()},0)},shaderProgram:null,programInfo:null,buffer:null,vsSource:"\n\t\t\tconst vec2 scale = vec2(0.5, 0.5);\n\t\t\tattribute vec4 aVertexPosition;\n\n\t\t\tvarying highp vec2 vTextureCoord;\n\n\t\t\tvoid main () {\n\t\t\t\tgl_Position = aVertexPosition;\n\t\t\t\tvTextureCoord = aVertexPosition.xy * scale + scale;\n\t\t\t}\n\t\t",fsSource:"\n\t\t\tvarying highp vec2 vTextureCoord;\n\n\t\t\tuniform sampler2D uSampler;\n\n\t\t\tvoid main() {\n\t\t\t\tgl_FragColor = texture2D(uSampler, vTextureCoord);\n\t\t\t}\n\t\t",initShaderProgram:(gl,vsSource,fsSource)=>{const vertexShader=GodotWebXR.loadShader(gl,gl.VERTEX_SHADER,vsSource);const fragmentShader=GodotWebXR.loadShader(gl,gl.FRAGMENT_SHADER,fsSource);const shaderProgram=gl.createProgram();gl.attachShader(shaderProgram,vertexShader);gl.attachShader(shaderProgram,fragmentShader);gl.linkProgram(shaderProgram);if(!gl.getProgramParameter(shaderProgram,gl.LINK_STATUS)){GodotRuntime.error(`Unable to initialize the shader program: ${gl.getProgramInfoLog(shaderProgram)}`);return null}return shaderProgram},loadShader:(gl,type,source)=>{const shader=gl.createShader(type);gl.shaderSource(shader,source);gl.compileShader(shader);if(!gl.getShaderParameter(shader,gl.COMPILE_STATUS)){GodotRuntime.error(`An error occurred compiling the shader: ${gl.getShaderInfoLog(shader)}`);gl.deleteShader(shader);return null}return shader},initBuffer:gl=>{const positionBuffer=gl.createBuffer();gl.bindBuffer(gl.ARRAY_BUFFER,positionBuffer);const positions=[-1,-1,1,-1,-1,1,1,1];gl.bufferData(gl.ARRAY_BUFFER,new Float32Array(positions),gl.STATIC_DRAW);return positionBuffer},blitTexture:(gl,texture)=>{if(GodotWebXR.shaderProgram===null){GodotWebXR.shaderProgram=GodotWebXR.initShaderProgram(gl,GodotWebXR.vsSource,GodotWebXR.fsSource);GodotWebXR.programInfo={program:GodotWebXR.shaderProgram,attribLocations:{vertexPosition:gl.getAttribLocation(GodotWebXR.shaderProgram,"aVertexPosition")},uniformLocations:{uSampler:gl.getUniformLocation(GodotWebXR.shaderProgram,"uSampler")}};GodotWebXR.buffer=GodotWebXR.initBuffer(gl)}const orig_program=gl.getParameter(gl.CURRENT_PROGRAM);gl.useProgram(GodotWebXR.shaderProgram);gl.bindBuffer(gl.ARRAY_BUFFER,GodotWebXR.buffer);gl.vertexAttribPointer(GodotWebXR.programInfo.attribLocations.vertexPosition,2,gl.FLOAT,false,0,0);gl.enableVertexAttribArray(GodotWebXR.programInfo.attribLocations.vertexPosition);gl.activeTexture(gl.TEXTURE0);gl.bindTexture(gl.TEXTURE_2D,texture);gl.uniform1i(GodotWebXR.programInfo.uniformLocations.uSampler,0);gl.drawArrays(gl.TRIANGLE_STRIP,0,4);gl.bindTexture(gl.TEXTURE_2D,null);gl.disableVertexAttribArray(GodotWebXR.programInfo.attribLocations.vertexPosition);gl.bindBuffer(gl.ARRAY_BUFFER,null);gl.useProgram(orig_program)},controllers:[],sampleControllers:()=>{if(!GodotWebXR.session||!GodotWebXR.frame){return}let other_index=2;const controllers=[];GodotWebXR.session.inputSources.forEach(input_source=>{if(input_source.targetRayMode==="tracked-pointer"){if(input_source.handedness==="right"){controllers[1]=input_source}else if(input_source.handedness==="left"||!controllers[0]){controllers[0]=input_source}}else{controllers[other_index++]=input_source}});GodotWebXR.controllers=controllers},getControllerId:input_source=>GodotWebXR.controllers.indexOf(input_source)};function _godot_webxr_commit_for_eye(p_eye){if(!GodotWebXR.session||!GodotWebXR.pose){return}const view_index=p_eye===2?1:0;const glLayer=GodotWebXR.session.renderState.baseLayer;const view=GodotWebXR.pose.views[view_index];const viewport=glLayer.getViewport(view);const gl=GodotWebXR.gl;const orig_framebuffer=gl.getParameter(gl.FRAMEBUFFER_BINDING);const orig_viewport=gl.getParameter(gl.VIEWPORT);gl.bindFramebuffer(gl.FRAMEBUFFER,glLayer.framebuffer);gl.viewport(viewport.x,viewport.y,viewport.width,viewport.height);GodotWebXR.blitTexture(gl,GodotWebXR.textures[view_index]);gl.bindFramebuffer(gl.FRAMEBUFFER,orig_framebuffer);gl.viewport(orig_viewport[0],orig_viewport[1],orig_viewport[2],orig_viewport[3])}function _godot_webxr_get_bounds_geometry(){if(!GodotWebXR.space||!GodotWebXR.space.boundsGeometry){return 0}const point_count=GodotWebXR.space.boundsGeometry.length;if(point_count===0){return 0}const buf=GodotRuntime.malloc((point_count*3+1)*4);GodotRuntime.setHeapValue(buf,point_count,"i32");for(let i=0;is.trim()).filter(s=>s!=="");const optional_features=GodotRuntime.parseString(p_optional_features).split(",").map(s=>s.trim()).filter(s=>s!=="");const requested_reference_space_types=GodotRuntime.parseString(p_requested_reference_spaces).split(",").map(s=>s.trim());const onstarted=GodotRuntime.get_func(p_on_session_started);const onended=GodotRuntime.get_func(p_on_session_ended);const onfailed=GodotRuntime.get_func(p_on_session_failed);const oncontroller=GodotRuntime.get_func(p_on_controller_changed);const oninputevent=GodotRuntime.get_func(p_on_input_event);const onsimpleevent=GodotRuntime.get_func(p_on_simple_event);const session_init={};if(required_features.length>0){session_init["requiredFeatures"]=required_features}if(optional_features.length>0){session_init["optionalFeatures"]=optional_features}navigator.xr.requestSession(session_mode,session_init).then(function(session){GodotWebXR.session=session;session.addEventListener("end",function(evt){onended()});session.addEventListener("inputsourceschange",function(evt){let controller_changed=false;[evt.added,evt.removed].forEach(lst=>{lst.forEach(input_source=>{if(input_source.targetRayMode==="tracked-pointer"){controller_changed=true}})});if(controller_changed){oncontroller()}});["selectstart","select","selectend","squeezestart","squeeze","squeezeend"].forEach(input_event=>{session.addEventListener(input_event,function(evt){const c_str=GodotRuntime.allocString(input_event);oninputevent(c_str,GodotWebXR.getControllerId(evt.inputSource));GodotRuntime.free(c_str)})});session.addEventListener("visibilitychange",function(evt){const c_str=GodotRuntime.allocString("visibility_state_changed");onsimpleevent(c_str);GodotRuntime.free(c_str)});const gl_context_handle=_emscripten_webgl_get_current_context();const gl=GL.getContext(gl_context_handle).GLctx;GodotWebXR.gl=gl;gl.makeXRCompatible().then(function(){session.updateRenderState({baseLayer:new XRWebGLLayer(session,gl)});function onReferenceSpaceSuccess(reference_space,reference_space_type){GodotWebXR.space=reference_space;reference_space.onreset=function(evt){const c_str=GodotRuntime.allocString("reference_space_reset");onsimpleevent(c_str);GodotRuntime.free(c_str)};GodotWebXR.pauseResumeMainLoop();window.setTimeout(function(){const c_str=GodotRuntime.allocString(reference_space_type);onstarted(c_str);GodotRuntime.free(c_str)},0)}function requestReferenceSpace(){const reference_space_type=requested_reference_space_types.shift();session.requestReferenceSpace(reference_space_type).then(refSpace=>{onReferenceSpaceSuccess(refSpace,reference_space_type)}).catch(()=>{if(requested_reference_space_types.length===0){const c_str=GodotRuntime.allocString("Unable to get any of the requested reference space types");onfailed(c_str);GodotRuntime.free(c_str)}else{requestReferenceSpace()}})}requestReferenceSpace()}).catch(function(error){const c_str=GodotRuntime.allocString(`Unable to make WebGL context compatible with WebXR: ${error}`);onfailed(c_str);GodotRuntime.free(c_str)})}).catch(function(error){const c_str=GodotRuntime.allocString(`Unable to start session: ${error}`);onfailed(c_str);GodotRuntime.free(c_str)})}function _godot_webxr_is_controller_connected(p_controller){if(!GodotWebXR.session||!GodotWebXR.frame){return false}return!!GodotWebXR.controllers[p_controller]}function _godot_webxr_is_session_supported(p_session_mode,p_callback){const session_mode=GodotRuntime.parseString(p_session_mode);const cb=GodotRuntime.get_func(p_callback);if(navigator.xr){navigator.xr.isSessionSupported(session_mode).then(function(supported){const c_str=GodotRuntime.allocString(session_mode);cb(c_str,supported?1:0);GodotRuntime.free(c_str)})}else{const c_str=GodotRuntime.allocString(session_mode);cb(c_str,0);GodotRuntime.free(c_str)}}function _godot_webxr_is_supported(){return!!navigator.xr}function _godot_webxr_sample_controller_data(){GodotWebXR.sampleControllers()}function _godot_webxr_uninitialize(){if(GodotWebXR.session){GodotWebXR.session.end().catch(e=>{})}const gl=GodotWebXR.gl;for(let i=0;i>2]=stdTimezoneOffset*60;HEAP32[__get_daylight()>>2]=Number(winterOffset!=summerOffset);function extractZone(date){var match=date.toTimeString().match(/\(([A-Za-z ]+)\)$/);return match?match[1]:"GMT"}var winterName=extractZone(winter);var summerName=extractZone(summer);var winterNamePtr=allocateUTF8(winterName);var summerNamePtr=allocateUTF8(summerName);if(summerOffset>2]=winterNamePtr;HEAP32[__get_tzname()+4>>2]=summerNamePtr}else{HEAP32[__get_tzname()>>2]=summerNamePtr;HEAP32[__get_tzname()+4>>2]=winterNamePtr}}function _localtime_r(time,tmPtr){_tzset();var date=new Date(HEAP32[time>>2]*1e3);HEAP32[tmPtr>>2]=date.getSeconds();HEAP32[tmPtr+4>>2]=date.getMinutes();HEAP32[tmPtr+8>>2]=date.getHours();HEAP32[tmPtr+12>>2]=date.getDate();HEAP32[tmPtr+16>>2]=date.getMonth();HEAP32[tmPtr+20>>2]=date.getFullYear()-1900;HEAP32[tmPtr+24>>2]=date.getDay();var start=new Date(date.getFullYear(),0,1);var yday=(date.getTime()-start.getTime())/(1e3*60*60*24)|0;HEAP32[tmPtr+28>>2]=yday;HEAP32[tmPtr+36>>2]=-(date.getTimezoneOffset()*60);var summerOffset=new Date(date.getFullYear(),6,1).getTimezoneOffset();var winterOffset=start.getTimezoneOffset();var dst=(summerOffset!=winterOffset&&date.getTimezoneOffset()==Math.min(winterOffset,summerOffset))|0;HEAP32[tmPtr+32>>2]=dst;var zonePtr=HEAP32[__get_tzname()+(dst?4:0)>>2];HEAP32[tmPtr+40>>2]=zonePtr;return tmPtr}function _setTempRet0($i){setTempRet0($i|0)}function _sigaction(signum,act,oldact){return 0}function __isLeapYear(year){return year%4===0&&(year%100!==0||year%400===0)}function __arraySum(array,index){var sum=0;for(var i=0;i<=index;sum+=array[i++]){}return sum}var __MONTH_DAYS_LEAP=[31,29,31,30,31,30,31,31,30,31,30,31];var __MONTH_DAYS_REGULAR=[31,28,31,30,31,30,31,31,30,31,30,31];function __addDays(date,days){var newDate=new Date(date.getTime());while(days>0){var leap=__isLeapYear(newDate.getFullYear());var currentMonth=newDate.getMonth();var daysInCurrentMonth=(leap?__MONTH_DAYS_LEAP:__MONTH_DAYS_REGULAR)[currentMonth];if(days>daysInCurrentMonth-newDate.getDate()){days-=daysInCurrentMonth-newDate.getDate()+1;newDate.setDate(1);if(currentMonth<11){newDate.setMonth(currentMonth+1)}else{newDate.setMonth(0);newDate.setFullYear(newDate.getFullYear()+1)}}else{newDate.setDate(newDate.getDate()+days);return newDate}}return newDate}function _strftime(s,maxsize,format,tm){var tm_zone=HEAP32[tm+40>>2];var date={tm_sec:HEAP32[tm>>2],tm_min:HEAP32[tm+4>>2],tm_hour:HEAP32[tm+8>>2],tm_mday:HEAP32[tm+12>>2],tm_mon:HEAP32[tm+16>>2],tm_year:HEAP32[tm+20>>2],tm_wday:HEAP32[tm+24>>2],tm_yday:HEAP32[tm+28>>2],tm_isdst:HEAP32[tm+32>>2],tm_gmtoff:HEAP32[tm+36>>2],tm_zone:tm_zone?UTF8ToString(tm_zone):""};var pattern=UTF8ToString(format);var EXPANSION_RULES_1={"%c":"%a %b %d %H:%M:%S %Y","%D":"%m/%d/%y","%F":"%Y-%m-%d","%h":"%b","%r":"%I:%M:%S %p","%R":"%H:%M","%T":"%H:%M:%S","%x":"%m/%d/%y","%X":"%H:%M:%S","%Ec":"%c","%EC":"%C","%Ex":"%m/%d/%y","%EX":"%H:%M:%S","%Ey":"%y","%EY":"%Y","%Od":"%d","%Oe":"%e","%OH":"%H","%OI":"%I","%Om":"%m","%OM":"%M","%OS":"%S","%Ou":"%u","%OU":"%U","%OV":"%V","%Ow":"%w","%OW":"%W","%Oy":"%y"};for(var rule in EXPANSION_RULES_1){pattern=pattern.replace(new RegExp(rule,"g"),EXPANSION_RULES_1[rule])}var WEEKDAYS=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"];var MONTHS=["January","February","March","April","May","June","July","August","September","October","November","December"];function leadingSomething(value,digits,character){var str=typeof value==="number"?value.toString():value||"";while(str.length0?1:0}var compare;if((compare=sgn(date1.getFullYear()-date2.getFullYear()))===0){if((compare=sgn(date1.getMonth()-date2.getMonth()))===0){compare=sgn(date1.getDate()-date2.getDate())}}return compare}function getFirstWeekStartDate(janFourth){switch(janFourth.getDay()){case 0:return new Date(janFourth.getFullYear()-1,11,29);case 1:return janFourth;case 2:return new Date(janFourth.getFullYear(),0,3);case 3:return new Date(janFourth.getFullYear(),0,2);case 4:return new Date(janFourth.getFullYear(),0,1);case 5:return new Date(janFourth.getFullYear()-1,11,31);case 6:return new Date(janFourth.getFullYear()-1,11,30)}}function getWeekBasedYear(date){var thisDate=__addDays(new Date(date.tm_year+1900,0,1),date.tm_yday);var janFourthThisYear=new Date(thisDate.getFullYear(),0,4);var janFourthNextYear=new Date(thisDate.getFullYear()+1,0,4);var firstWeekStartThisYear=getFirstWeekStartDate(janFourthThisYear);var firstWeekStartNextYear=getFirstWeekStartDate(janFourthNextYear);if(compareByDay(firstWeekStartThisYear,thisDate)<=0){if(compareByDay(firstWeekStartNextYear,thisDate)<=0){return thisDate.getFullYear()+1}else{return thisDate.getFullYear()}}else{return thisDate.getFullYear()-1}}var EXPANSION_RULES_2={"%a":function(date){return WEEKDAYS[date.tm_wday].substring(0,3)},"%A":function(date){return WEEKDAYS[date.tm_wday]},"%b":function(date){return MONTHS[date.tm_mon].substring(0,3)},"%B":function(date){return MONTHS[date.tm_mon]},"%C":function(date){var year=date.tm_year+1900;return leadingNulls(year/100|0,2)},"%d":function(date){return leadingNulls(date.tm_mday,2)},"%e":function(date){return leadingSomething(date.tm_mday,2," ")},"%g":function(date){return getWeekBasedYear(date).toString().substring(2)},"%G":function(date){return getWeekBasedYear(date)},"%H":function(date){return leadingNulls(date.tm_hour,2)},"%I":function(date){var twelveHour=date.tm_hour;if(twelveHour==0)twelveHour=12;else if(twelveHour>12)twelveHour-=12;return leadingNulls(twelveHour,2)},"%j":function(date){return leadingNulls(date.tm_mday+__arraySum(__isLeapYear(date.tm_year+1900)?__MONTH_DAYS_LEAP:__MONTH_DAYS_REGULAR,date.tm_mon-1),3)},"%m":function(date){return leadingNulls(date.tm_mon+1,2)},"%M":function(date){return leadingNulls(date.tm_min,2)},"%n":function(){return"\n"},"%p":function(date){if(date.tm_hour>=0&&date.tm_hour<12){return"AM"}else{return"PM"}},"%S":function(date){return leadingNulls(date.tm_sec,2)},"%t":function(){return"\t"},"%u":function(date){return date.tm_wday||7},"%U":function(date){var janFirst=new Date(date.tm_year+1900,0,1);var firstSunday=janFirst.getDay()===0?janFirst:__addDays(janFirst,7-janFirst.getDay());var endDate=new Date(date.tm_year+1900,date.tm_mon,date.tm_mday);if(compareByDay(firstSunday,endDate)<0){var februaryFirstUntilEndMonth=__arraySum(__isLeapYear(endDate.getFullYear())?__MONTH_DAYS_LEAP:__MONTH_DAYS_REGULAR,endDate.getMonth()-1)-31;var firstSundayUntilEndJanuary=31-firstSunday.getDate();var days=firstSundayUntilEndJanuary+februaryFirstUntilEndMonth+endDate.getDate();return leadingNulls(Math.ceil(days/7),2)}return compareByDay(firstSunday,janFirst)===0?"01":"00"},"%V":function(date){var janFourthThisYear=new Date(date.tm_year+1900,0,4);var janFourthNextYear=new Date(date.tm_year+1901,0,4);var firstWeekStartThisYear=getFirstWeekStartDate(janFourthThisYear);var firstWeekStartNextYear=getFirstWeekStartDate(janFourthNextYear);var endDate=__addDays(new Date(date.tm_year+1900,0,1),date.tm_yday);if(compareByDay(endDate,firstWeekStartThisYear)<0){return"53"}if(compareByDay(firstWeekStartNextYear,endDate)<=0){return"01"}var daysDifference;if(firstWeekStartThisYear.getFullYear()=0;off=Math.abs(off)/60;off=off/60*100+off%60;return(ahead?"+":"-")+String("0000"+off).slice(-4)},"%Z":function(date){return date.tm_zone},"%%":function(){return"%"}};for(var rule in EXPANSION_RULES_2){if(pattern.indexOf(rule)>=0){pattern=pattern.replace(new RegExp(rule,"g"),EXPANSION_RULES_2[rule](date))}}var bytes=intArrayFromString(pattern,false);if(bytes.length>maxsize){return 0}writeArrayToMemory(bytes,s);return bytes.length-1}function _strftime_l(s,maxsize,format,tm){return _strftime(s,maxsize,format,tm)}function _sysconf(name){switch(name){case 30:return 16384;case 85:var maxHeapSize=2147483648;return maxHeapSize/16384;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:case 80:case 81:case 79:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator==="object")return navigator["hardwareConcurrency"]||1;return 1}}setErrNo(28);return-1}function _time(ptr){var ret=Date.now()/1e3|0;if(ptr){HEAP32[ptr>>2]=ret}return ret}var readAsmConstArgsArray=[];function readAsmConstArgs(sigPtr,buf){readAsmConstArgsArray.length=0;var ch;buf>>=2;while(ch=HEAPU8[sigPtr++]){var double=ch<105;if(double&&buf&1)buf++;readAsmConstArgsArray.push(double?HEAPF64[buf++>>1]:HEAP32[buf]);++buf}return readAsmConstArgsArray}var FSNode=function(parent,name,mode,rdev){if(!parent){parent=this}this.parent=parent;this.mount=parent.mount;this.mounted=null;this.id=FS.nextInode++;this.name=name;this.mode=mode;this.node_ops={};this.stream_ops={};this.rdev=rdev};var readMode=292|73;var writeMode=146;Object.defineProperties(FSNode.prototype,{read:{get:function(){return(this.mode&readMode)===readMode},set:function(val){val?this.mode|=readMode:this.mode&=~readMode}},write:{get:function(){return(this.mode&writeMode)===writeMode},set:function(val){val?this.mode|=writeMode:this.mode&=~writeMode}},isFolder:{get:function(){return FS.isDir(this.mode)}},isDevice:{get:function(){return FS.isChrdev(this.mode)}}});FS.FSNode=FSNode;FS.staticInit();Module["requestFullscreen"]=function Module_requestFullscreen(lockPointer,resizeCanvas){Browser.requestFullscreen(lockPointer,resizeCanvas)};Module["requestAnimationFrame"]=function Module_requestAnimationFrame(func){Browser.requestAnimationFrame(func)};Module["setCanvasSize"]=function Module_setCanvasSize(width,height,noUpdates){Browser.setCanvasSize(width,height,noUpdates)};Module["pauseMainLoop"]=function Module_pauseMainLoop(){Browser.mainLoop.pause()};Module["resumeMainLoop"]=function Module_resumeMainLoop(){Browser.mainLoop.resume()};Module["getUserMedia"]=function Module_getUserMedia(){Browser.getUserMedia()};Module["createContext"]=function Module_createContext(canvas,useWebGL,setInModule,webGLContextAttributes){return Browser.createContext(canvas,useWebGL,setInModule,webGLContextAttributes)};var GLctx;for(var i=0;i<32;++i)tempFixedLengthArray.push(new Array(i));var miniTempWebGLFloatBuffersStorage=new Float32Array(288);for(var i=0;i<288;++i){miniTempWebGLFloatBuffers[i]=miniTempWebGLFloatBuffersStorage.subarray(0,i+1)}var __miniTempWebGLIntBuffersStorage=new Int32Array(288);for(var i=0;i<288;++i){__miniTempWebGLIntBuffers[i]=__miniTempWebGLIntBuffersStorage.subarray(0,i+1)}Module["request_quit"]=function(){GodotOS.request_quit()};Module["onExit"]=GodotOS.cleanup;GodotOS._fs_sync_promise=Promise.resolve();Module["initConfig"]=GodotConfig.init_config;Module["initFS"]=GodotFS.init;Module["copyToFS"]=GodotFS.copy_to_fs;GodotOS.atexit(function(resolve,reject){GodotDisplayCursor.clear();resolve()});GodotOS.atexit(function(resolve,reject){GodotDisplayListeners.clear();resolve()});GodotOS.atexit(function(resolve,reject){GodotDisplayVK.clear();resolve()});function intArrayFromString(stringy,dontAddNull,length){var len=length>0?length:lengthBytesUTF8(stringy)+1;var u8array=new Array(len);var numBytesWritten=stringToUTF8Array(stringy,u8array,0,u8array.length);if(dontAddNull)u8array.length=numBytesWritten;return u8array}var asmLibraryArg={"m":___cxa_atexit,"hd":___sys__newselect,"Mc":___sys_accept4,"_c":___sys_access,"Pc":___sys_bind,"Zc":___sys_chdir,"gd":___sys_chmod,"Oc":___sys_connect,"Fa":___sys_fcntl64,"Yc":___sys_getcwd,"ld":___sys_getdents64,"Xc":___sys_getpid,"Lc":___sys_getsockname,"Hc":___sys_getsockopt,"qb":___sys_ioctl,"Nc":___sys_listen,"fd":___sys_mkdir,"rb":___sys_open,"id":___sys_poll,"Jc":___sys_recvfrom,"$c":___sys_rename,"bd":___sys_rmdir,"Kc":___sys_sendto,"Gc":___sys_setsockopt,"nb":___sys_socket,"ed":___sys_stat64,"dd":___sys_statfs64,"cd":___sys_unlink,"kd":___sys_wait4,"la":_abort,"Ea":_clock_gettime,"ij":_dlclose,"Lb":_dlerror,"jb":_dlopen,"hj":_dlsym,"Yi":_emscripten_asm_const_int,"Kb":_emscripten_cancel_main_loop,"wb":_emscripten_enter_soft_fullscreen,"tb":_emscripten_exit_pointerlock,"ab":_emscripten_exit_soft_fullscreen,"dj":_emscripten_force_exit,"Zh":_emscripten_get_now,"vg":_emscripten_get_pointerlock_status,"ri":_emscripten_glActiveTexture,"qi":_emscripten_glAttachShader,"ef":_emscripten_glBeginQuery,"Ii":_emscripten_glBeginQueryEXT,"Le":_emscripten_glBeginTransformFeedback,"pi":_emscripten_glBindAttribLocation,"oi":_emscripten_glBindBuffer,"Ie":_emscripten_glBindBufferBase,"Je":_emscripten_glBindBufferRange,"ni":_emscripten_glBindFramebuffer,"mi":_emscripten_glBindRenderbuffer,"Ld":_emscripten_glBindSampler,"li":_emscripten_glBindTexture,"Dd":_emscripten_glBindTransformFeedback,"Re":_emscripten_glBindVertexArray,"Ai":_emscripten_glBindVertexArrayOES,"ki":_emscripten_glBlendColor,"ii":_emscripten_glBlendEquation,"hi":_emscripten_glBlendEquationSeparate,"gi":_emscripten_glBlendFunc,"fi":_emscripten_glBlendFuncSeparate,"Ue":_emscripten_glBlitFramebuffer,"ei":_emscripten_glBufferData,"di":_emscripten_glBufferSubData,"ci":_emscripten_glCheckFramebufferStatus,"bi":_emscripten_glClear,"ke":_emscripten_glClearBufferfi,"le":_emscripten_glClearBufferfv,"ne":_emscripten_glClearBufferiv,"me":_emscripten_glClearBufferuiv,"ai":_emscripten_glClearColor,"$h":_emscripten_glClearDepthf,"Yh":_emscripten_glClearStencil,"Vd":_emscripten_glClientWaitSync,"Xh":_emscripten_glColorMask,"Wh":_emscripten_glCompileShader,"Vh":_emscripten_glCompressedTexImage2D,"lf":_emscripten_glCompressedTexImage3D,"Uh":_emscripten_glCompressedTexSubImage2D,"kf":_emscripten_glCompressedTexSubImage3D,"ie":_emscripten_glCopyBufferSubData,"Th":_emscripten_glCopyTexImage2D,"Sh":_emscripten_glCopyTexSubImage2D,"mf":_emscripten_glCopyTexSubImage3D,"Rh":_emscripten_glCreateProgram,"Qh":_emscripten_glCreateShader,"Ph":_emscripten_glCullFace,"Oh":_emscripten_glDeleteBuffers,"Nh":_emscripten_glDeleteFramebuffers,"Mh":_emscripten_glDeleteProgram,"gf":_emscripten_glDeleteQueries,"Ki":_emscripten_glDeleteQueriesEXT,"Lh":_emscripten_glDeleteRenderbuffers,"Od":_emscripten_glDeleteSamplers,"Kh":_emscripten_glDeleteShader,"Wd":_emscripten_glDeleteSync,"Jh":_emscripten_glDeleteTextures,"Cd":_emscripten_glDeleteTransformFeedbacks,"Qe":_emscripten_glDeleteVertexArrays,"zi":_emscripten_glDeleteVertexArraysOES,"Ih":_emscripten_glDepthFunc,"Hh":_emscripten_glDepthMask,"Gh":_emscripten_glDepthRangef,"Fh":_emscripten_glDetachShader,"Dh":_emscripten_glDisable,"Ch":_emscripten_glDisableVertexAttribArray,"Bh":_emscripten_glDrawArrays,"ae":_emscripten_glDrawArraysInstanced,"vi":_emscripten_glDrawArraysInstancedANGLE,"wf":_emscripten_glDrawArraysInstancedARB,"xf":_emscripten_glDrawArraysInstancedEXT,"md":_emscripten_glDrawArraysInstancedNV,"af":_emscripten_glDrawBuffers,"rf":_emscripten_glDrawBuffersEXT,"wi":_emscripten_glDrawBuffersWEBGL,"Ah":_emscripten_glDrawElements,"$d":_emscripten_glDrawElementsInstanced,"ti":_emscripten_glDrawElementsInstancedANGLE,"sf":_emscripten_glDrawElementsInstancedARB,"uf":_emscripten_glDrawElementsInstancedEXT,"vf":_emscripten_glDrawElementsInstancedNV,"pf":_emscripten_glDrawRangeElements,"zh":_emscripten_glEnable,"yh":_emscripten_glEnableVertexAttribArray,"df":_emscripten_glEndQuery,"Hi":_emscripten_glEndQueryEXT,"Ke":_emscripten_glEndTransformFeedback,"_d":_emscripten_glFenceSync,"xh":_emscripten_glFinish,"wh":_emscripten_glFlush,"vh":_emscripten_glFramebufferRenderbuffer,"uh":_emscripten_glFramebufferTexture2D,"Se":_emscripten_glFramebufferTextureLayer,"th":_emscripten_glFrontFace,"sh":_emscripten_glGenBuffers,"qh":_emscripten_glGenFramebuffers,"jf":_emscripten_glGenQueries,"Li":_emscripten_glGenQueriesEXT,"ph":_emscripten_glGenRenderbuffers,"Pd":_emscripten_glGenSamplers,"oh":_emscripten_glGenTextures,"Ad":_emscripten_glGenTransformFeedbacks,"Pe":_emscripten_glGenVertexArrays,"yi":_emscripten_glGenVertexArraysOES,"rh":_emscripten_glGenerateMipmap,"nh":_emscripten_glGetActiveAttrib,"mh":_emscripten_glGetActiveUniform,"ce":_emscripten_glGetActiveUniformBlockName,"de":_emscripten_glGetActiveUniformBlockiv,"fe":_emscripten_glGetActiveUniformsiv,"lh":_emscripten_glGetAttachedShaders,"kh":_emscripten_glGetAttribLocation,"jh":_emscripten_glGetBooleanv,"Qd":_emscripten_glGetBufferParameteri64v,"ih":_emscripten_glGetBufferParameteriv,"hh":_emscripten_glGetError,"gh":_emscripten_glGetFloatv,"we":_emscripten_glGetFragDataLocation,"fh":_emscripten_glGetFramebufferAttachmentParameteriv,"Rd":_emscripten_glGetInteger64i_v,"Td":_emscripten_glGetInteger64v,"Me":_emscripten_glGetIntegeri_v,"eh":_emscripten_glGetIntegerv,"od":_emscripten_glGetInternalformativ,"wd":_emscripten_glGetProgramBinary,"ch":_emscripten_glGetProgramInfoLog,"dh":_emscripten_glGetProgramiv,"Ci":_emscripten_glGetQueryObjecti64vEXT,"Ei":_emscripten_glGetQueryObjectivEXT,"Bi":_emscripten_glGetQueryObjectui64vEXT,"bf":_emscripten_glGetQueryObjectuiv,"Di":_emscripten_glGetQueryObjectuivEXT,"cf":_emscripten_glGetQueryiv,"Fi":_emscripten_glGetQueryivEXT,"bh":_emscripten_glGetRenderbufferParameteriv,"Fd":_emscripten_glGetSamplerParameterfv,"Gd":_emscripten_glGetSamplerParameteriv,"$g":_emscripten_glGetShaderInfoLog,"_g":_emscripten_glGetShaderPrecisionFormat,"Zg":_emscripten_glGetShaderSource,"ah":_emscripten_glGetShaderiv,"Yg":_emscripten_glGetString,"je":_emscripten_glGetStringi,"Sd":_emscripten_glGetSynciv,"Xg":_emscripten_glGetTexParameterfv,"Wg":_emscripten_glGetTexParameteriv,"Ge":_emscripten_glGetTransformFeedbackVarying,"ee":_emscripten_glGetUniformBlockIndex,"ge":_emscripten_glGetUniformIndices,"Tg":_emscripten_glGetUniformLocation,"Vg":_emscripten_glGetUniformfv,"Ug":_emscripten_glGetUniformiv,"xe":_emscripten_glGetUniformuiv,"Ee":_emscripten_glGetVertexAttribIiv,"De":_emscripten_glGetVertexAttribIuiv,"Pg":_emscripten_glGetVertexAttribPointerv,"Sg":_emscripten_glGetVertexAttribfv,"Qg":_emscripten_glGetVertexAttribiv,"Og":_emscripten_glHint,"td":_emscripten_glInvalidateFramebuffer,"sd":_emscripten_glInvalidateSubFramebuffer,"Ng":_emscripten_glIsBuffer,"Mg":_emscripten_glIsEnabled,"Lg":_emscripten_glIsFramebuffer,"Kg":_emscripten_glIsProgram,"ff":_emscripten_glIsQuery,"Ji":_emscripten_glIsQueryEXT,"Jg":_emscripten_glIsRenderbuffer,"Nd":_emscripten_glIsSampler,"Ig":_emscripten_glIsShader,"Zd":_emscripten_glIsSync,"Hg":_emscripten_glIsTexture,"zd":_emscripten_glIsTransformFeedback,"Oe":_emscripten_glIsVertexArray,"xi":_emscripten_glIsVertexArrayOES,"Fg":_emscripten_glLineWidth,"Eg":_emscripten_glLinkProgram,"yd":_emscripten_glPauseTransformFeedback,"Dg":_emscripten_glPixelStorei,"Cg":_emscripten_glPolygonOffset,"vd":_emscripten_glProgramBinary,"ud":_emscripten_glProgramParameteri,"Gi":_emscripten_glQueryCounterEXT,"qf":_emscripten_glReadBuffer,"Bg":_emscripten_glReadPixels,"Ag":_emscripten_glReleaseShaderCompiler,"zg":_emscripten_glRenderbufferStorage,"Te":_emscripten_glRenderbufferStorageMultisample,"xd":_emscripten_glResumeTransformFeedback,"yg":_emscripten_glSampleCoverage,"Id":_emscripten_glSamplerParameterf,"Hd":_emscripten_glSamplerParameterfv,"Kd":_emscripten_glSamplerParameteri,"Jd":_emscripten_glSamplerParameteriv,"xg":_emscripten_glScissor,"wg":_emscripten_glShaderBinary,"ug":_emscripten_glShaderSource,"tg":_emscripten_glStencilFunc,"sg":_emscripten_glStencilFuncSeparate,"rg":_emscripten_glStencilMask,"qg":_emscripten_glStencilMaskSeparate,"pg":_emscripten_glStencilOp,"og":_emscripten_glStencilOpSeparate,"ng":_emscripten_glTexImage2D,"of":_emscripten_glTexImage3D,"mg":_emscripten_glTexParameterf,"lg":_emscripten_glTexParameterfv,"jg":_emscripten_glTexParameteri,"ig":_emscripten_glTexParameteriv,"rd":_emscripten_glTexStorage2D,"pd":_emscripten_glTexStorage3D,"hg":_emscripten_glTexSubImage2D,"nf":_emscripten_glTexSubImage3D,"He":_emscripten_glTransformFeedbackVaryings,"gg":_emscripten_glUniform1f,"fg":_emscripten_glUniform1fv,"eg":_emscripten_glUniform1i,"dg":_emscripten_glUniform1iv,"ve":_emscripten_glUniform1ui,"re":_emscripten_glUniform1uiv,"cg":_emscripten_glUniform2f,"bg":_emscripten_glUniform2fv,"ag":_emscripten_glUniform2i,"Zf":_emscripten_glUniform2iv,"ue":_emscripten_glUniform2ui,"qe":_emscripten_glUniform2uiv,"Yf":_emscripten_glUniform3f,"Xf":_emscripten_glUniform3fv,"Wf":_emscripten_glUniform3i,"Vf":_emscripten_glUniform3iv,"te":_emscripten_glUniform3ui,"pe":_emscripten_glUniform3uiv,"Uf":_emscripten_glUniform4f,"Tf":_emscripten_glUniform4fv,"Sf":_emscripten_glUniform4i,"Rf":_emscripten_glUniform4iv,"se":_emscripten_glUniform4ui,"oe":_emscripten_glUniform4uiv,"be":_emscripten_glUniformBlockBinding,"Qf":_emscripten_glUniformMatrix2fv,"$e":_emscripten_glUniformMatrix2x3fv,"Ze":_emscripten_glUniformMatrix2x4fv,"Of":_emscripten_glUniformMatrix3fv,"_e":_emscripten_glUniformMatrix3x2fv,"We":_emscripten_glUniformMatrix3x4fv,"Nf":_emscripten_glUniformMatrix4fv,"Xe":_emscripten_glUniformMatrix4x2fv,"Ve":_emscripten_glUniformMatrix4x3fv,"Mf":_emscripten_glUseProgram,"Lf":_emscripten_glValidateProgram,"Kf":_emscripten_glVertexAttrib1f,"Jf":_emscripten_glVertexAttrib1fv,"If":_emscripten_glVertexAttrib2f,"Hf":_emscripten_glVertexAttrib2fv,"Gf":_emscripten_glVertexAttrib3f,"Ff":_emscripten_glVertexAttrib3fv,"Df":_emscripten_glVertexAttrib4f,"Cf":_emscripten_glVertexAttrib4fv,"Ed":_emscripten_glVertexAttribDivisor,"si":_emscripten_glVertexAttribDivisorANGLE,"yf":_emscripten_glVertexAttribDivisorARB,"zf":_emscripten_glVertexAttribDivisorEXT,"nd":_emscripten_glVertexAttribDivisorNV,"Be":_emscripten_glVertexAttribI4i,"ze":_emscripten_glVertexAttribI4iv,"Ae":_emscripten_glVertexAttribI4ui,"ye":_emscripten_glVertexAttribI4uiv,"Fe":_emscripten_glVertexAttribIPointer,"Bf":_emscripten_glVertexAttribPointer,"Af":_emscripten_glViewport,"Ud":_emscripten_glWaitSync,"F":_emscripten_longjmp,"Qc":_emscripten_memcpy_big,"Rg":_emscripten_request_pointerlock,"va":_emscripten_resize_heap,"vc":_emscripten_set_fullscreenchange_callback_on_thread,"zc":_emscripten_set_keydown_callback_on_thread,"xc":_emscripten_set_keypress_callback_on_thread,"wc":_emscripten_set_keyup_callback_on_thread,"Jb":_emscripten_set_main_loop,"Md":_emscripten_set_mousedown_callback_on_thread,"Bd":_emscripten_set_mousemove_callback_on_thread,"qd":_emscripten_set_mouseup_callback_on_thread,"Fc":_emscripten_set_touchcancel_callback_on_thread,"Ic":_emscripten_set_touchend_callback_on_thread,"Rc":_emscripten_set_touchmove_callback_on_thread,"ad":_emscripten_set_touchstart_callback_on_thread,"jd":_emscripten_set_wheel_callback_on_thread,"Vc":_emscripten_thread_sleep,"kb":_emscripten_webgl_commit_frame,"he":_emscripten_webgl_create_context,"ic":_emscripten_webgl_destroy_context,"Ce":_emscripten_webgl_init_context_attributes,"Xd":_emscripten_webgl_make_context_current,"Tc":_environ_get,"Uc":_environ_sizes_get,"wa":_fd_close,"Wc":_fd_fdstat_get,"pb":_fd_read,"Bc":_fd_seek,"ob":_fd_write,"Wa":_gai_strerror,"k":_getTempRet0,"Xa":_getaddrinfo,"Yb":_getnameinfo,"ib":_gettimeofday,"c":_glActiveTexture,"Oa":_glAttachShader,"cb":_glBeginTransformFeedback,"Bb":_glBindAttribLocation,"b":_glBindBuffer,"P":_glBindBufferBase,"e":_glBindFramebuffer,"ba":_glBindRenderbuffer,"a":_glBindTexture,"n":_glBindVertexArray,"E":_glBlendEquation,"T":_glBlendFunc,"x":_glBlendFuncSeparate,"ja":_glBlitFramebuffer,"r":_glBufferData,"M":_glBufferSubData,"O":_glCheckFramebufferStatus,"L":_glClear,"ra":_glClearBufferfv,"R":_glClearColor,"da":_glClearDepthf,"Q":_glColorMask,"Qa":_glCompileShader,"Gb":_glCompressedTexImage2D,"Ui":_glCompressedTexImage3D,"Wi":_glCompressedTexSubImage2D,"eb":_glCompressedTexSubImage3D,"Ti":_glCopyBufferSubData,"Za":_glCopyTexSubImage2D,"Cb":_glCreateProgram,"Sa":_glCreateShader,"sa":_glCullFace,"N":_glDeleteBuffers,"I":_glDeleteFramebuffers,"S":_glDeleteProgram,"X":_glDeleteRenderbuffers,"K":_glDeleteShader,"D":_glDeleteTextures,"ga":_glDeleteVertexArrays,"_":_glDepthFunc,"J":_glDepthMask,"i":_glDisable,"q":_glDisableVertexAttribArray,"A":_glDrawArrays,"za":_glDrawArraysInstanced,"Ja":_glDrawBuffers,"ea":_glDrawElements,"Ka":_glDrawElementsInstanced,"s":_glEnable,"j":_glEnableVertexAttribArray,"bb":_glEndTransformFeedback,"bj":_glFinish,"aa":_glFramebufferRenderbuffer,"y":_glFramebufferTexture2D,"Vi":_glFramebufferTextureLayer,"Hb":_glFrontFace,"C":_glGenBuffers,"G":_glGenFramebuffers,"ia":_glGenRenderbuffers,"w":_glGenTextures,"Y":_glGenVertexArrays,"U":_glGenerateMipmap,"Ib":_glGetError,"Db":_glGetFloatv,"ca":_glGetIntegerv,"zb":_glGetProgramInfoLog,"Na":_glGetProgramiv,"Pa":_glGetShaderInfoLog,"qa":_glGetShaderiv,"Ta":_glGetString,"Ri":_glGetStringi,"Oi":_glGetUniformBlockIndex,"xa":_glGetUniformLocation,"_i":_glInvalidateFramebuffer,"Ab":_glLinkProgram,"na":_glPixelStorei,"ka":_glReadBuffer,"db":_glReadPixels,"ha":_glRenderbufferStorage,"Ga":_glRenderbufferStorageMultisample,"W":_glScissor,"Ra":_glShaderSource,"t":_glTexImage2D,"Ia":_glTexImage3D,"g":_glTexParameterf,"d":_glTexParameteri,"Xi":_glTexStorage2D,"Ha":_glTexSubImage2D,"Ua":_glTexSubImage3D,"Qi":_glTransformFeedbackVaryings,"f":_glUniform1f,"v":_glUniform1i,"fb":_glUniform1iv,"Eb":_glUniform1ui,"$a":_glUniform2f,"o":_glUniform2fv,"Da":_glUniform2i,"oa":_glUniform2iv,"_a":_glUniform3f,"Z":_glUniform3fv,"Ca":_glUniform3i,"ya":_glUniform4f,"z":_glUniform4fv,"Ba":_glUniform4i,"Ni":_glUniformBlockBinding,"yb":_glUniformMatrix2fv,"xb":_glUniformMatrix3fv,"p":_glUniformMatrix4fv,"fa":_glUseProgram,"B":_glVertexAttrib4f,"V":_glVertexAttrib4fv,"H":_glVertexAttribDivisor,"ej":_glVertexAttribI4ui,"La":_glVertexAttribIPointer,"h":_glVertexAttribPointer,"u":_glViewport,"Nb":_gmtime_r,"_h":_godot_audio_capture_start,"$f":_godot_audio_capture_stop,"Vj":_godot_audio_init,"Wj":_godot_audio_is_available,"aj":_godot_audio_resume,"Yd":_godot_audio_script_create,"yc":_godot_audio_script_start,"$b":_godot_js_config_canvas_id_get,"$i":_godot_js_config_locale_get,"fc":_godot_js_display_alert,"vb":_godot_js_display_canvas_focus,"kg":_godot_js_display_canvas_is_focused,"hf":_godot_js_display_clipboard_get,"tf":_godot_js_display_clipboard_set,"Zi":_godot_js_display_compute_position,"Gg":_godot_js_display_cursor_is_hidden,"ub":_godot_js_display_cursor_set_custom_shape,"Eh":_godot_js_display_cursor_set_shape,"Ya":_godot_js_display_cursor_set_visible,"Pi":_godot_js_display_desired_size_set,"sc":_godot_js_display_drop_files_cb,"ji":_godot_js_display_fullscreen_exit,"ui":_godot_js_display_fullscreen_request,"rc":_godot_js_display_gamepad_cb,"lc":_godot_js_display_gamepad_sample,"Pf":_godot_js_display_gamepad_sample_count,"Ef":_godot_js_display_gamepad_sample_get,"sb":_godot_js_display_has_webgl,"Ne":_godot_js_display_is_swap_ok_cancel,"uc":_godot_js_display_notification_cb,"tc":_godot_js_display_paste_cb,"jc":_godot_js_display_pixel_ratio_get,"kc":_godot_js_display_screen_dpi_get,"Si":_godot_js_display_screen_size_get,"Ye":_godot_js_display_setup_canvas,"Fb":_godot_js_display_size_update,"_f":_godot_js_display_touchscreen_is_available,"pc":_godot_js_display_vk_available,"qc":_godot_js_display_vk_cb,"nc":_godot_js_display_vk_hide,"oc":_godot_js_display_vk_show,"cc":_godot_js_display_window_icon_set,"Mi":_godot_js_display_window_size_get,"dc":_godot_js_display_window_title_set,"fj":_godot_js_eval,"Uj":_godot_js_fetch_body_length_get,"ec":_godot_js_fetch_create,"lb":_godot_js_fetch_free,"qj":_godot_js_fetch_http_status_get,"Zb":_godot_js_fetch_is_chunked,"Jj":_godot_js_fetch_read_chunk,"kj":_godot_js_fetch_read_headers,"hb":_godot_js_fetch_state_get,"hc":_godot_js_os_execute,"cj":_godot_js_os_finish_async,"_b":_godot_js_os_fs_is_persistent,"mc":_godot_js_os_fs_sync,"gc":_godot_js_os_hw_concurrency_get,"ac":_godot_js_os_request_quit_cb,"bc":_godot_js_os_shell_open,"Xb":_godot_js_rtc_datachannel_close,"Rj":_godot_js_rtc_datachannel_connect,"Oj":_godot_js_rtc_datachannel_destroy,"Tb":_godot_js_rtc_datachannel_id_get,"Sj":_godot_js_rtc_datachannel_is_negotiated,"Ub":_godot_js_rtc_datachannel_is_ordered,"Qj":_godot_js_rtc_datachannel_label_get,"Sb":_godot_js_rtc_datachannel_max_packet_lifetime_get,"Tj":_godot_js_rtc_datachannel_max_retransmits_get,"Pj":_godot_js_rtc_datachannel_protocol_get,"Wb":_godot_js_rtc_datachannel_ready_state_get,"Vb":_godot_js_rtc_datachannel_send,"Nj":_godot_js_rtc_pc_close,"Hj":_godot_js_rtc_pc_create,"Gj":_godot_js_rtc_pc_datachannel_create,"Rb":_godot_js_rtc_pc_destroy,"Ij":_godot_js_rtc_pc_ice_candidate_add,"Lj":_godot_js_rtc_pc_local_description_set,"Mj":_godot_js_rtc_pc_offer_create,"Kj":_godot_js_rtc_pc_remote_description_set,"Ej":_godot_js_websocket_close,"Dj":_godot_js_websocket_create,"Qb":_godot_js_websocket_destroy,"Fj":_godot_js_websocket_send,"rj":_godot_webxr_commit_for_eye,"Aj":_godot_webxr_get_bounds_geometry,"mj":_godot_webxr_get_controller_axes,"nj":_godot_webxr_get_controller_buttons,"pj":_godot_webxr_get_controller_count,"oj":_godot_webxr_get_controller_transform,"sj":_godot_webxr_get_external_texture_for_eye,"tj":_godot_webxr_get_projection_for_eye,"vj":_godot_webxr_get_render_targetsize,"uj":_godot_webxr_get_transform_for_eye,"zj":_godot_webxr_get_view_count,"Bj":_godot_webxr_get_visibility_state,"xj":_godot_webxr_initialize,"Ob":_godot_webxr_is_controller_connected,"Cj":_godot_webxr_is_session_supported,"yj":_godot_webxr_is_supported,"Pb":_godot_webxr_sample_controller_data,"wj":_godot_webxr_uninitialize,"Aa":invoke_ii,"ma":invoke_iii,"Dc":invoke_iiii,"mb":invoke_iiiii,"Ec":invoke_iiiiii,"Cc":invoke_iiiiiii,"Ac":invoke_iij,"$":invoke_vi,"pa":invoke_vii,"ua":invoke_viii,"ta":invoke_viiii,"Ma":invoke_viiiiiii,"jj":_kill,"gb":_localtime_r,"l":_setTempRet0,"lj":_sigaction,"Mb":_strftime,"Sc":_strftime_l,"gj":_sysconf,"Va":_time};var asm=createWasm();var ___wasm_call_ctors=Module["___wasm_call_ctors"]=function(){return(___wasm_call_ctors=Module["___wasm_call_ctors"]=Module["asm"]["Yj"]).apply(null,arguments)};var _free=Module["_free"]=function(){return(_free=Module["_free"]=Module["asm"]["Zj"]).apply(null,arguments)};var __Z13godot_js_mainiPPc=Module["__Z13godot_js_mainiPPc"]=function(){return(__Z13godot_js_mainiPPc=Module["__Z13godot_js_mainiPPc"]=Module["asm"]["_j"]).apply(null,arguments)};var _main=Module["_main"]=function(){return(_main=Module["_main"]=Module["asm"]["$j"]).apply(null,arguments)};var _malloc=Module["_malloc"]=function(){return(_malloc=Module["_malloc"]=Module["asm"]["ak"]).apply(null,arguments)};var _fflush=Module["_fflush"]=function(){return(_fflush=Module["_fflush"]=Module["asm"]["bk"]).apply(null,arguments)};var _htonl=Module["_htonl"]=function(){return(_htonl=Module["_htonl"]=Module["asm"]["ck"]).apply(null,arguments)};var _htons=Module["_htons"]=function(){return(_htons=Module["_htons"]=Module["asm"]["dk"]).apply(null,arguments)};var _ntohs=Module["_ntohs"]=function(){return(_ntohs=Module["_ntohs"]=Module["asm"]["ek"]).apply(null,arguments)};var ___errno_location=Module["___errno_location"]=function(){return(___errno_location=Module["___errno_location"]=Module["asm"]["fk"]).apply(null,arguments)};var __emwebxr_on_input_event=Module["__emwebxr_on_input_event"]=function(){return(__emwebxr_on_input_event=Module["__emwebxr_on_input_event"]=Module["asm"]["gk"]).apply(null,arguments)};var __emwebxr_on_simple_event=Module["__emwebxr_on_simple_event"]=function(){return(__emwebxr_on_simple_event=Module["__emwebxr_on_simple_event"]=Module["asm"]["hk"]).apply(null,arguments)};var __get_tzname=Module["__get_tzname"]=function(){return(__get_tzname=Module["__get_tzname"]=Module["asm"]["ik"]).apply(null,arguments)};var __get_daylight=Module["__get_daylight"]=function(){return(__get_daylight=Module["__get_daylight"]=Module["asm"]["jk"]).apply(null,arguments)};var __get_timezone=Module["__get_timezone"]=function(){return(__get_timezone=Module["__get_timezone"]=Module["asm"]["kk"]).apply(null,arguments)};var stackSave=Module["stackSave"]=function(){return(stackSave=Module["stackSave"]=Module["asm"]["lk"]).apply(null,arguments)};var stackRestore=Module["stackRestore"]=function(){return(stackRestore=Module["stackRestore"]=Module["asm"]["mk"]).apply(null,arguments)};var stackAlloc=Module["stackAlloc"]=function(){return(stackAlloc=Module["stackAlloc"]=Module["asm"]["nk"]).apply(null,arguments)};var _setThrew=Module["_setThrew"]=function(){return(_setThrew=Module["_setThrew"]=Module["asm"]["ok"]).apply(null,arguments)};var dynCall_iij=Module["dynCall_iij"]=function(){return(dynCall_iij=Module["dynCall_iij"]=Module["asm"]["qk"]).apply(null,arguments)};function invoke_vii(index,a1,a2){var sp=stackSave();try{wasmTable.get(index)(a1,a2)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_vi(index,a1){var sp=stackSave();try{wasmTable.get(index)(a1)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_viii(index,a1,a2,a3){var sp=stackSave();try{wasmTable.get(index)(a1,a2,a3)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_ii(index,a1){var sp=stackSave();try{return wasmTable.get(index)(a1)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iii(index,a1,a2){var sp=stackSave();try{return wasmTable.get(index)(a1,a2)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iiiii(index,a1,a2,a3,a4){var sp=stackSave();try{return wasmTable.get(index)(a1,a2,a3,a4)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iiiiii(index,a1,a2,a3,a4,a5){var sp=stackSave();try{return wasmTable.get(index)(a1,a2,a3,a4,a5)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_viiii(index,a1,a2,a3,a4){var sp=stackSave();try{wasmTable.get(index)(a1,a2,a3,a4)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iiii(index,a1,a2,a3){var sp=stackSave();try{return wasmTable.get(index)(a1,a2,a3)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_viiiiiii(index,a1,a2,a3,a4,a5,a6,a7){var sp=stackSave();try{wasmTable.get(index)(a1,a2,a3,a4,a5,a6,a7)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iiiiiii(index,a1,a2,a3,a4,a5,a6){var sp=stackSave();try{return wasmTable.get(index)(a1,a2,a3,a4,a5,a6)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}function invoke_iij(index,a1,a2,a3){var sp=stackSave();try{return dynCall_iij(index,a1,a2,a3)}catch(e){stackRestore(sp);if(e!==e+0&&e!=="longjmp")throw e;_setThrew(1,0)}}Module["cwrap"]=cwrap;Module["callMain"]=callMain;var calledRun;function ExitStatus(status){this.name="ExitStatus";this.message="Program terminated with exit("+status+")";this.status=status}var calledMain=false;dependenciesFulfilled=function runCaller(){if(!calledRun)run();if(!calledRun)dependenciesFulfilled=runCaller};function callMain(args){var entryFunction=Module["_main"];args=args||[];var argc=args.length+1;var argv=stackAlloc((argc+1)*4);HEAP32[argv>>2]=allocateUTF8OnStack(thisProgram);for(var i=1;i>2)+i]=allocateUTF8OnStack(args[i-1])}HEAP32[(argv>>2)+argc]=0;try{var ret=entryFunction(argc,argv);exit(ret,true)}catch(e){if(e instanceof ExitStatus){return}else if(e=="unwind"){noExitRuntime=true;return}else{var toLog=e;if(e&&typeof e==="object"&&e.stack){toLog=[e,e.stack]}err("exception thrown: "+toLog);quit_(1,e)}}finally{calledMain=true}}function run(args){args=args||arguments_;if(runDependencies>0){return}preRun();if(runDependencies>0){return}function doRun(){if(calledRun)return;calledRun=true;Module["calledRun"]=true;if(ABORT)return;initRuntime();preMain();readyPromiseResolve(Module);if(Module["onRuntimeInitialized"])Module["onRuntimeInitialized"]();if(shouldRunNow)callMain(args);postRun()}if(Module["setStatus"]){Module["setStatus"]("Running...");setTimeout(function(){setTimeout(function(){Module["setStatus"]("")},1);doRun()},1)}else{doRun()}}Module["run"]=run;function exit(status,implicit){if(implicit&&noExitRuntime&&status===0){return}if(noExitRuntime){}else{EXITSTATUS=status;exitRuntime();if(Module["onExit"])Module["onExit"](status);ABORT=true}quit_(status,new ExitStatus(status))}if(Module["preInit"]){if(typeof Module["preInit"]=="function")Module["preInit"]=[Module["preInit"]];while(Module["preInit"].length>0){Module["preInit"].pop()()}}var shouldRunNow=false;if(Module["noInitialRun"])shouldRunNow=false;run(); + + + return Godot.ready +} +); +})(); +if (typeof exports === 'object' && typeof module === 'object') + module.exports = Godot; +else if (typeof define === 'function' && define['amd']) + define([], function() { return Godot; }); +else if (typeof exports === 'object') + exports["Godot"] = Godot; + +const Preloader = /** @constructor */ function () { // eslint-disable-line no-unused-vars + function getTrackedResponse(response, load_status) { + function onloadprogress(reader, controller) { + return reader.read().then(function (result) { + if (load_status.done) { + return Promise.resolve(); + } + if (result.value) { + controller.enqueue(result.value); + load_status.loaded += result.value.length; + } + if (!result.done) { + return onloadprogress(reader, controller); + } + load_status.done = true; + return Promise.resolve(); + }); + } + const reader = response.body.getReader(); + return new Response(new ReadableStream({ + start: function (controller) { + onloadprogress(reader, controller).then(function () { + controller.close(); + }); + }, + }), { headers: response.headers }); + } + + function loadFetch(file, tracker, fileSize, raw) { + tracker[file] = { + total: fileSize || 0, + loaded: 0, + done: false, + }; + return fetch(file).then(function (response) { + if (!response.ok) { + return Promise.reject(new Error(`Failed loading file '${file}'`)); + } + const tr = getTrackedResponse(response, tracker[file]); + if (raw) { + return Promise.resolve(tr); + } + return tr.arrayBuffer(); + }); + } + + function retry(func, attempts = 1) { + function onerror(err) { + if (attempts <= 1) { + return Promise.reject(err); + } + return new Promise(function (resolve, reject) { + setTimeout(function () { + retry(func, attempts - 1).then(resolve).catch(reject); + }, 1000); + }); + } + return func().catch(onerror); + } + + const DOWNLOAD_ATTEMPTS_MAX = 4; + const loadingFiles = {}; + const lastProgress = { loaded: 0, total: 0 }; + let progressFunc = null; + + const animateProgress = function () { + let loaded = 0; + let total = 0; + let totalIsValid = true; + let progressIsFinal = true; + + Object.keys(loadingFiles).forEach(function (file) { + const stat = loadingFiles[file]; + if (!stat.done) { + progressIsFinal = false; + } + if (!totalIsValid || stat.total === 0) { + totalIsValid = false; + total = 0; + } else { + total += stat.total; + } + loaded += stat.loaded; + }); + if (loaded !== lastProgress.loaded || total !== lastProgress.total) { + lastProgress.loaded = loaded; + lastProgress.total = total; + if (typeof progressFunc === 'function') { + progressFunc(loaded, total); + } + } + if (!progressIsFinal) { + requestAnimationFrame(animateProgress); + } + }; + + this.animateProgress = animateProgress; + + this.setProgressFunc = function (callback) { + progressFunc = callback; + }; + + this.loadPromise = function (file, fileSize, raw = false) { + return retry(loadFetch.bind(null, file, loadingFiles, fileSize, raw), DOWNLOAD_ATTEMPTS_MAX); + }; + + this.preloadedFiles = []; + this.preload = function (pathOrBuffer, destPath, fileSize) { + let buffer = null; + if (typeof pathOrBuffer === 'string') { + const me = this; + return this.loadPromise(pathOrBuffer, fileSize).then(function (buf) { + me.preloadedFiles.push({ + path: destPath || pathOrBuffer, + buffer: buf, + }); + return Promise.resolve(); + }); + } else if (pathOrBuffer instanceof ArrayBuffer) { + buffer = new Uint8Array(pathOrBuffer); + } else if (ArrayBuffer.isView(pathOrBuffer)) { + buffer = new Uint8Array(pathOrBuffer.buffer); + } + if (buffer) { + this.preloadedFiles.push({ + path: destPath, + buffer: pathOrBuffer, + }); + return Promise.resolve(); + } + return Promise.reject(new Error('Invalid object for preloading')); + }; +}; + +/** + * An object used to configure the Engine instance based on godot export options, and to override those in custom HTML + * templates if needed. + * + * @header Engine configuration + * @summary The Engine configuration object. This is just a typedef, create it like a regular object, e.g.: + * + * ``const MyConfig = { executable: 'godot', unloadAfterInit: false }`` + * + * @typedef {Object} EngineConfig + */ +const EngineConfig = {}; // eslint-disable-line no-unused-vars + +/** + * @struct + * @constructor + * @ignore + */ +const InternalConfig = function (initConfig) { // eslint-disable-line no-unused-vars + const cfg = /** @lends {InternalConfig.prototype} */ { + /** + * Whether the unload the engine automatically after the instance is initialized. + * + * @memberof EngineConfig + * @default + * @type {boolean} + */ + unloadAfterInit: true, + /** + * The HTML DOM Canvas object to use. + * + * By default, the first canvas element in the document will be used is none is specified. + * + * @memberof EngineConfig + * @default + * @type {?HTMLCanvasElement} + */ + canvas: null, + /** + * The name of the WASM file without the extension. (Set by Godot Editor export process). + * + * @memberof EngineConfig + * @default + * @type {string} + */ + executable: '', + /** + * An alternative name for the game pck to load. The executable name is used otherwise. + * + * @memberof EngineConfig + * @default + * @type {?string} + */ + mainPack: null, + /** + * Specify a language code to select the proper localization for the game. + * + * The browser locale will be used if none is specified. See complete list of + * :ref:`supported locales `. + * + * @memberof EngineConfig + * @type {?string} + * @default + */ + locale: null, + /** + * The canvas resize policy determines how the canvas should be resized by Godot. + * + * ``0`` means Godot won't do any resizing. This is useful if you want to control the canvas size from + * javascript code in your template. + * + * ``1`` means Godot will resize the canvas on start, and when changing window size via engine functions. + * + * ``2`` means Godot will adapt the canvas size to match the whole browser window. + * + * @memberof EngineConfig + * @type {number} + * @default + */ + canvasResizePolicy: 2, + /** + * The arguments to be passed as command line arguments on startup. + * + * See :ref:`command line tutorial `. + * + * **Note**: :js:meth:`startGame ` will always add the ``--main-pack`` argument. + * + * @memberof EngineConfig + * @type {Array} + * @default + */ + args: [], + /** + * When enabled, this will turn on experimental virtual keyboard support on mobile. + * + * @memberof EngineConfig + * @type {boolean} + * @default + */ + experimentalVK: false, + /** + * @ignore + * @type {Array.} + */ + persistentPaths: ['/userfs'], + /** + * @ignore + * @type {boolean} + */ + persistentDrops: false, + /** + * @ignore + * @type {Array.} + */ + gdnativeLibs: [], + /** + * @ignore + * @type {Array.} + */ + fileSizes: [], + /** + * A callback function for handling Godot's ``OS.execute`` calls. + * + * This is for example used in the Web Editor template to switch between project manager and editor, and for running the game. + * + * @callback EngineConfig.onExecute + * @param {string} path The path that Godot's wants executed. + * @param {Array.} args The arguments of the "command" to execute. + */ + /** + * @ignore + * @type {?function(string, Array.)} + */ + onExecute: null, + /** + * A callback function for being notified when the Godot instance quits. + * + * **Note**: This function will not be called if the engine crashes or become unresponsive. + * + * @callback EngineConfig.onExit + * @param {number} status_code The status code returned by Godot on exit. + */ + /** + * @ignore + * @type {?function(number)} + */ + onExit: null, + /** + * A callback function for displaying download progress. + * + * The function is called once per frame while downloading files, so the usage of ``requestAnimationFrame()`` + * is not necessary. + * + * If the callback function receives a total amount of bytes as 0, this means that it is impossible to calculate. + * Possible reasons include: + * + * - Files are delivered with server-side chunked compression + * - Files are delivered with server-side compression on Chromium + * - Not all file downloads have started yet (usually on servers without multi-threading) + * + * @callback EngineConfig.onProgress + * @param {number} current The current amount of downloaded bytes so far. + * @param {number} total The total amount of bytes to be downloaded. + */ + /** + * @ignore + * @type {?function(number, number)} + */ + onProgress: null, + /** + * A callback function for handling the standard output stream. This method should usually only be used in debug pages. + * + * By default, ``console.log()`` is used. + * + * @callback EngineConfig.onPrint + * @param {...*} [var_args] A variadic number of arguments to be printed. + */ + /** + * @ignore + * @type {?function(...*)} + */ + onPrint: function () { + console.log.apply(console, Array.from(arguments)); // eslint-disable-line no-console + }, + /** + * A callback function for handling the standard error stream. This method should usually only be used in debug pages. + * + * By default, ``console.error()`` is used. + * + * @callback EngineConfig.onPrintError + * @param {...*} [var_args] A variadic number of arguments to be printed as errors. + */ + /** + * @ignore + * @type {?function(...*)} + */ + onPrintError: function (var_args) { + console.error.apply(console, Array.from(arguments)); // eslint-disable-line no-console + }, + }; + + /** + * @ignore + * @struct + * @constructor + * @param {EngineConfig} opts + */ + function Config(opts) { + this.update(opts); + } + + Config.prototype = cfg; + + /** + * @ignore + * @param {EngineConfig} opts + */ + Config.prototype.update = function (opts) { + const config = opts || {}; + function parse(key, def) { + if (typeof (config[key]) === 'undefined') { + return def; + } + return config[key]; + } + // Module config + this.unloadAfterInit = parse('unloadAfterInit', this.unloadAfterInit); + this.onPrintError = parse('onPrintError', this.onPrintError); + this.onPrint = parse('onPrint', this.onPrint); + this.onProgress = parse('onProgress', this.onProgress); + + // Godot config + this.canvas = parse('canvas', this.canvas); + this.executable = parse('executable', this.executable); + this.mainPack = parse('mainPack', this.mainPack); + this.locale = parse('locale', this.locale); + this.canvasResizePolicy = parse('canvasResizePolicy', this.canvasResizePolicy); + this.persistentPaths = parse('persistentPaths', this.persistentPaths); + this.persistentDrops = parse('persistentDrops', this.persistentDrops); + this.experimentalVK = parse('experimentalVK', this.experimentalVK); + this.gdnativeLibs = parse('gdnativeLibs', this.gdnativeLibs); + this.fileSizes = parse('fileSizes', this.fileSizes); + this.args = parse('args', this.args); + this.onExecute = parse('onExecute', this.onExecute); + this.onExit = parse('onExit', this.onExit); + }; + + /** + * @ignore + * @param {string} loadPath + * @param {Response} response + */ + Config.prototype.getModuleConfig = function (loadPath, response) { + let r = response; + return { + 'print': this.onPrint, + 'printErr': this.onPrintError, + 'thisProgram': this.executable, + 'noExitRuntime': true, + 'dynamicLibraries': [`${loadPath}.side.wasm`], + 'instantiateWasm': function (imports, onSuccess) { + function done(result) { + onSuccess(result['instance'], result['module']); + } + if (typeof (WebAssembly.instantiateStreaming) !== 'undefined') { + WebAssembly.instantiateStreaming(Promise.resolve(r), imports).then(done); + } else { + r.arrayBuffer().then(function (buffer) { + WebAssembly.instantiate(buffer, imports).then(done); + }); + } + r = null; + return {}; + }, + 'locateFile': function (path) { + if (path.endsWith('.worker.js')) { + return `${loadPath}.worker.js`; + } else if (path.endsWith('.audio.worklet.js')) { + return `${loadPath}.audio.worklet.js`; + } else if (path.endsWith('.js')) { + return `${loadPath}.js`; + } else if (path.endsWith('.side.wasm')) { + return `${loadPath}.side.wasm`; + } else if (path.endsWith('.wasm')) { + return `${loadPath}.wasm`; + } + return path; + }, + }; + }; + + /** + * @ignore + * @param {function()} cleanup + */ + Config.prototype.getGodotConfig = function (cleanup) { + // Try to find a canvas + if (!(this.canvas instanceof HTMLCanvasElement)) { + const nodes = document.getElementsByTagName('canvas'); + if (nodes.length && nodes[0] instanceof HTMLCanvasElement) { + this.canvas = nodes[0]; + } + if (!this.canvas) { + throw new Error('No canvas found in page'); + } + } + // Canvas can grab focus on click, or key events won't work. + if (this.canvas.tabIndex < 0) { + this.canvas.tabIndex = 0; + } + + // Browser locale, or custom one if defined. + let locale = this.locale; + if (!locale) { + locale = navigator.languages ? navigator.languages[0] : navigator.language; + locale = locale.split('.')[0]; + } + const onExit = this.onExit; + + // Godot configuration. + return { + 'canvas': this.canvas, + 'canvasResizePolicy': this.canvasResizePolicy, + 'locale': locale, + 'persistentDrops': this.persistentDrops, + 'virtualKeyboard': this.experimentalVK, + 'onExecute': this.onExecute, + 'onExit': function (p_code) { + cleanup(); // We always need to call the cleanup callback to free memory. + if (typeof (onExit) === 'function') { + onExit(p_code); + } + }, + }; + }; + return new Config(initConfig); +}; + +/** + * Projects exported for the Web expose the :js:class:`Engine` class to the JavaScript environment, that allows + * fine control over the engine's start-up process. + * + * This API is built in an asynchronous manner and requires basic understanding + * of `Promises `__. + * + * @module Engine + * @header HTML5 shell class reference + */ +const Engine = (function () { + const preloader = new Preloader(); + + let loadPromise = null; + let loadPath = ''; + let initPromise = null; + + /** + * @classdesc The ``Engine`` class provides methods for loading and starting exported projects on the Web. For default export + * settings, this is already part of the exported HTML page. To understand practical use of the ``Engine`` class, + * see :ref:`Custom HTML page for Web export `. + * + * @description Create a new Engine instance with the given configuration. + * + * @global + * @constructor + * @param {EngineConfig} initConfig The initial config for this instance. + */ + function Engine(initConfig) { // eslint-disable-line no-shadow + this.config = new InternalConfig(initConfig); + this.rtenv = null; + } + + /** + * Load the engine from the specified base path. + * + * @param {string} basePath Base path of the engine to load. + * @param {number=} [size=0] The file size if known. + * @returns {Promise} A Promise that resolves once the engine is loaded. + * + * @function Engine.load + */ + Engine.load = function (basePath, size) { + if (loadPromise == null) { + loadPath = basePath; + loadPromise = preloader.loadPromise(`${loadPath}.wasm`, size, true); + requestAnimationFrame(preloader.animateProgress); + } + return loadPromise; + }; + + /** + * Unload the engine to free memory. + * + * This method will be called automatically depending on the configuration. See :js:attr:`unloadAfterInit`. + * + * @function Engine.unload + */ + Engine.unload = function () { + loadPromise = null; + }; + + /** + * Check whether WebGL is available. Optionally, specify a particular version of WebGL to check for. + * + * @param {number=} [majorVersion=1] The major WebGL version to check for. + * @returns {boolean} If the given major version of WebGL is available. + * @function Engine.isWebGLAvailable + */ + Engine.isWebGLAvailable = function (majorVersion = 1) { + try { + return !!document.createElement('canvas').getContext(['webgl', 'webgl2'][majorVersion - 1]); + } catch (e) { /* Not available */ } + return false; + }; + + /** + * Safe Engine constructor, creates a new prototype for every new instance to avoid prototype pollution. + * @ignore + * @constructor + */ + function SafeEngine(initConfig) { + const proto = /** @lends Engine.prototype */ { + /** + * Initialize the engine instance. Optionally, pass the base path to the engine to load it, + * if it hasn't been loaded yet. See :js:meth:`Engine.load`. + * + * @param {string=} basePath Base path of the engine to load. + * @return {Promise} A ``Promise`` that resolves once the engine is loaded and initialized. + */ + init: function (basePath) { + if (initPromise) { + return initPromise; + } + if (loadPromise == null) { + if (!basePath) { + initPromise = Promise.reject(new Error('A base path must be provided when calling `init` and the engine is not loaded.')); + return initPromise; + } + Engine.load(basePath, this.config.fileSizes[`${basePath}.wasm`]); + } + const me = this; + function doInit(promise) { + // Care! Promise chaining is bogus with old emscripten versions. + // This caused a regression with the Mono build (which uses an older emscripten version). + // Make sure to test that when refactoring. + return new Promise(function (resolve, reject) { + promise.then(function (response) { + const cloned = new Response(response.clone().body, { 'headers': [['content-type', 'application/wasm']] }); + Godot(me.config.getModuleConfig(loadPath, cloned)).then(function (module) { + const paths = me.config.persistentPaths; + module['initFS'](paths).then(function (err) { + me.rtenv = module; + if (me.config.unloadAfterInit) { + Engine.unload(); + } + resolve(); + }); + }); + }); + }); + } + preloader.setProgressFunc(this.config.onProgress); + initPromise = doInit(loadPromise); + return initPromise; + }, + + /** + * Load a file so it is available in the instance's file system once it runs. Must be called **before** starting the + * instance. + * + * If not provided, the ``path`` is derived from the URL of the loaded file. + * + * @param {string|ArrayBuffer} file The file to preload. + * + * If a ``string`` the file will be loaded from that path. + * + * If an ``ArrayBuffer`` or a view on one, the buffer will used as the content of the file. + * + * @param {string=} path Path by which the file will be accessible. Required, if ``file`` is not a string. + * + * @returns {Promise} A Promise that resolves once the file is loaded. + */ + preloadFile: function (file, path) { + return preloader.preload(file, path, this.config.fileSizes[file]); + }, + + /** + * Start the engine instance using the given override configuration (if any). + * :js:meth:`startGame ` can be used in typical cases instead. + * + * This will initialize the instance if it is not initialized. For manual initialization, see :js:meth:`init `. + * The engine must be loaded beforehand. + * + * Fails if a canvas cannot be found on the page, or not specified in the configuration. + * + * @param {EngineConfig} override An optional configuration override. + * @return {Promise} Promise that resolves once the engine started. + */ + start: function (override) { + this.config.update(override); + const me = this; + return me.init().then(function () { + if (!me.rtenv) { + return Promise.reject(new Error('The engine must be initialized before it can be started')); + } + + let config = {}; + try { + config = me.config.getGodotConfig(function () { + me.rtenv = null; + }); + } catch (e) { + return Promise.reject(e); + } + // Godot configuration. + me.rtenv['initConfig'](config); + + // Preload GDNative libraries. + const libs = []; + me.config.gdnativeLibs.forEach(function (lib) { + libs.push(me.rtenv['loadDynamicLibrary'](lib, { 'loadAsync': true })); + }); + return Promise.all(libs).then(function () { + return new Promise(function (resolve, reject) { + preloader.preloadedFiles.forEach(function (file) { + me.rtenv['copyToFS'](file.path, file.buffer); + }); + preloader.preloadedFiles.length = 0; // Clear memory + me.rtenv['callMain'](me.config.args); + initPromise = null; + resolve(); + }); + }); + }); + }, + + /** + * Start the game instance using the given configuration override (if any). + * + * This will initialize the instance if it is not initialized. For manual initialization, see :js:meth:`init `. + * + * This will load the engine if it is not loaded, and preload the main pck. + * + * This method expects the initial config (or the override) to have both the :js:attr:`executable` and :js:attr:`mainPack` + * properties set (normally done by the editor during export). + * + * @param {EngineConfig} override An optional configuration override. + * @return {Promise} Promise that resolves once the game started. + */ + startGame: function (override) { + this.config.update(override); + // Add main-pack argument. + const exe = this.config.executable; + const pack = this.config.mainPack || `${exe}.pck`; + this.config.args = ['--main-pack', pack].concat(this.config.args); + // Start and init with execName as loadPath if not inited. + const me = this; + return Promise.all([ + this.init(exe), + this.preloadFile(pack, pack), + ]).then(function () { + return me.start.apply(me); + }); + }, + + /** + * Create a file at the specified ``path`` with the passed as ``buffer`` in the instance's file system. + * + * @param {string} path The location where the file will be created. + * @param {ArrayBuffer} buffer The content of the file. + */ + copyToFS: function (path, buffer) { + if (this.rtenv == null) { + throw new Error('Engine must be inited before copying files'); + } + this.rtenv['copyToFS'](path, buffer); + }, + + /** + * Request that the current instance quit. + * + * This is akin the user pressing the close button in the window manager, and will + * have no effect if the engine has crashed, or is stuck in a loop. + * + */ + requestQuit: function () { + if (this.rtenv) { + this.rtenv['request_quit'](); + } + }, + }; + + Engine.prototype = proto; + // Closure compiler exported instance methods. + Engine.prototype['init'] = Engine.prototype.init; + Engine.prototype['preloadFile'] = Engine.prototype.preloadFile; + Engine.prototype['start'] = Engine.prototype.start; + Engine.prototype['startGame'] = Engine.prototype.startGame; + Engine.prototype['copyToFS'] = Engine.prototype.copyToFS; + Engine.prototype['requestQuit'] = Engine.prototype.requestQuit; + // Also expose static methods as instance methods + Engine.prototype['load'] = Engine.load; + Engine.prototype['unload'] = Engine.unload; + Engine.prototype['isWebGLAvailable'] = Engine.isWebGLAvailable; + return new Engine(initConfig); + } + + // Closure compiler exported static methods. + SafeEngine['load'] = Engine.load; + SafeEngine['unload'] = Engine.unload; + SafeEngine['isWebGLAvailable'] = Engine.isWebGLAvailable; + + return SafeEngine; +}()); +if (typeof window !== 'undefined') { + window['Engine'] = Engine; +} diff --git a/release/web/runner.pck b/release/web/runner.pck new file mode 100644 index 0000000..5e22c19 Binary files /dev/null and b/release/web/runner.pck differ diff --git a/release/web/runner.png b/release/web/runner.png new file mode 100644 index 0000000..ffb19ce Binary files /dev/null and b/release/web/runner.png differ diff --git a/release/web/runner.png.import b/release/web/runner.png.import new file mode 100644 index 0000000..e863142 --- /dev/null +++ b/release/web/runner.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://release/web/runner.png" +dest_files=[ "res://.import/runner.png-6bdf8e07948df6a62d9942b89a06a07d.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/release/web/runner.wasm b/release/web/runner.wasm new file mode 100644 index 0000000..90486bf Binary files /dev/null and b/release/web/runner.wasm differ diff --git a/release/windows/runner.exe b/release/windows/runner.exe new file mode 100644 index 0000000..ea21b9b Binary files /dev/null and b/release/windows/runner.exe differ diff --git a/release/windows/runner.pck b/release/windows/runner.pck new file mode 100644 index 0000000..5e22c19 Binary files /dev/null and b/release/windows/runner.pck differ diff --git a/samagri/MagoryNET-VISIONS8.mp3.import b/samagri/MagoryNET-VISIONS8.mp3.import new file mode 100644 index 0000000..5a5a62b --- /dev/null +++ b/samagri/MagoryNET-VISIONS8.mp3.import @@ -0,0 +1,15 @@ +[remap] + +importer="mp3" +type="AudioStreamMP3" +path="res://.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.mp3str" + +[deps] + +source_file="res://samagri/MagoryNET-VISIONS8.mp3" +dest_files=[ "res://.import/MagoryNET-VISIONS8.mp3-ed0164558580829bc8a59ce7aa5d3a2e.mp3str" ] + +[params] + +loop=true +loop_offset=0 diff --git a/samagri/Player_MainMenu.png b/samagri/Player_MainMenu.png new file mode 100644 index 0000000..b7ee2ea Binary files /dev/null and b/samagri/Player_MainMenu.png differ diff --git a/samagri/Player_MainMenu.png.import b/samagri/Player_MainMenu.png.import new file mode 100644 index 0000000..978d06f --- /dev/null +++ b/samagri/Player_MainMenu.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/Player_MainMenu.png" +dest_files=[ "res://.import/Player_MainMenu.png-d785bc181bbab2aa48ab35f04390c974.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/back-home.wav b/samagri/back-home.wav new file mode 100644 index 0000000..4999bc4 Binary files /dev/null and b/samagri/back-home.wav differ diff --git a/samagri/back-home.wav.import b/samagri/back-home.wav.import new file mode 100644 index 0000000..cd96460 --- /dev/null +++ b/samagri/back-home.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.sample" + +[deps] + +source_file="res://samagri/back-home.wav" +dest_files=[ "res://.import/back-home.wav-16d485626c6c4f9e87677a62d7b6dce2.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=false +edit/normalize=false +edit/loop=true +compress/mode=0 diff --git a/samagri/back.png.import b/samagri/back.png.import new file mode 100644 index 0000000..2bfe42d --- /dev/null +++ b/samagri/back.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/back.png-dff1cd8076833f0221eee3db86f61783.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/back.png" +dest_files=[ "res://.import/back.png-dff1cd8076833f0221eee3db86f61783.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 1.png b/samagri/background/Clouds/Cloud 1.png new file mode 100644 index 0000000..923f710 Binary files /dev/null and b/samagri/background/Clouds/Cloud 1.png differ diff --git a/samagri/background/Clouds/Cloud 1.png.import b/samagri/background/Clouds/Cloud 1.png.import new file mode 100644 index 0000000..63383c5 --- /dev/null +++ b/samagri/background/Clouds/Cloud 1.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 1.png" +dest_files=[ "res://.import/Cloud 1.png-c0fe19c0d252a277fff9137e88b6a18e.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 10.png b/samagri/background/Clouds/Cloud 10.png new file mode 100644 index 0000000..6ee8455 Binary files /dev/null and b/samagri/background/Clouds/Cloud 10.png differ diff --git a/samagri/background/Clouds/Cloud 10.png.import b/samagri/background/Clouds/Cloud 10.png.import new file mode 100644 index 0000000..6e3cf44 --- /dev/null +++ b/samagri/background/Clouds/Cloud 10.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 10.png" +dest_files=[ "res://.import/Cloud 10.png-5e8cb9d92ec9a9e1a06a0af5239a5b46.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 11.png b/samagri/background/Clouds/Cloud 11.png new file mode 100644 index 0000000..fa48ae7 Binary files /dev/null and b/samagri/background/Clouds/Cloud 11.png differ diff --git a/samagri/background/Clouds/Cloud 11.png.import b/samagri/background/Clouds/Cloud 11.png.import new file mode 100644 index 0000000..fc364bc --- /dev/null +++ b/samagri/background/Clouds/Cloud 11.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 11.png" +dest_files=[ "res://.import/Cloud 11.png-07dc960a131ed0d8e05d5bcc12106bb7.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 12.png b/samagri/background/Clouds/Cloud 12.png new file mode 100644 index 0000000..7ad8abf Binary files /dev/null and b/samagri/background/Clouds/Cloud 12.png differ diff --git a/samagri/background/Clouds/Cloud 12.png.import b/samagri/background/Clouds/Cloud 12.png.import new file mode 100644 index 0000000..8431ec4 --- /dev/null +++ b/samagri/background/Clouds/Cloud 12.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 12.png" +dest_files=[ "res://.import/Cloud 12.png-0f7756b507857fb548e80b6568992a20.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 13.png b/samagri/background/Clouds/Cloud 13.png new file mode 100644 index 0000000..bb4b4ea Binary files /dev/null and b/samagri/background/Clouds/Cloud 13.png differ diff --git a/samagri/background/Clouds/Cloud 13.png.import b/samagri/background/Clouds/Cloud 13.png.import new file mode 100644 index 0000000..f47f04a --- /dev/null +++ b/samagri/background/Clouds/Cloud 13.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 13.png" +dest_files=[ "res://.import/Cloud 13.png-844ac0b09ca7ae3242d59667a3831373.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 14.png b/samagri/background/Clouds/Cloud 14.png new file mode 100644 index 0000000..00a17f9 Binary files /dev/null and b/samagri/background/Clouds/Cloud 14.png differ diff --git a/samagri/background/Clouds/Cloud 14.png.import b/samagri/background/Clouds/Cloud 14.png.import new file mode 100644 index 0000000..bd342c5 --- /dev/null +++ b/samagri/background/Clouds/Cloud 14.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 14.png" +dest_files=[ "res://.import/Cloud 14.png-d33a7547b0ffb84f0cc985f14bdf0fdf.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 15.png b/samagri/background/Clouds/Cloud 15.png new file mode 100644 index 0000000..6714440 Binary files /dev/null and b/samagri/background/Clouds/Cloud 15.png differ diff --git a/samagri/background/Clouds/Cloud 15.png.import b/samagri/background/Clouds/Cloud 15.png.import new file mode 100644 index 0000000..61c9aa2 --- /dev/null +++ b/samagri/background/Clouds/Cloud 15.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 15.png" +dest_files=[ "res://.import/Cloud 15.png-b6e121344a98a3c9b596b649fd19b806.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 16.png b/samagri/background/Clouds/Cloud 16.png new file mode 100644 index 0000000..fd5c712 Binary files /dev/null and b/samagri/background/Clouds/Cloud 16.png differ diff --git a/samagri/background/Clouds/Cloud 16.png.import b/samagri/background/Clouds/Cloud 16.png.import new file mode 100644 index 0000000..a88bd37 --- /dev/null +++ b/samagri/background/Clouds/Cloud 16.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 16.png" +dest_files=[ "res://.import/Cloud 16.png-158eab855865e30b75daa4fb070ce23b.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 17.png b/samagri/background/Clouds/Cloud 17.png new file mode 100644 index 0000000..26c63b6 Binary files /dev/null and b/samagri/background/Clouds/Cloud 17.png differ diff --git a/samagri/background/Clouds/Cloud 17.png.import b/samagri/background/Clouds/Cloud 17.png.import new file mode 100644 index 0000000..e16156b --- /dev/null +++ b/samagri/background/Clouds/Cloud 17.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 17.png" +dest_files=[ "res://.import/Cloud 17.png-4cc9acaedffbe121c85a1f320ac7d2c2.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 18.png b/samagri/background/Clouds/Cloud 18.png new file mode 100644 index 0000000..e5eca65 Binary files /dev/null and b/samagri/background/Clouds/Cloud 18.png differ diff --git a/samagri/background/Clouds/Cloud 18.png.import b/samagri/background/Clouds/Cloud 18.png.import new file mode 100644 index 0000000..0b366d4 --- /dev/null +++ b/samagri/background/Clouds/Cloud 18.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 18.png" +dest_files=[ "res://.import/Cloud 18.png-61c72ac28454d15b4df35fccb22cdead.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 19.png b/samagri/background/Clouds/Cloud 19.png new file mode 100644 index 0000000..21585bd Binary files /dev/null and b/samagri/background/Clouds/Cloud 19.png differ diff --git a/samagri/background/Clouds/Cloud 19.png.import b/samagri/background/Clouds/Cloud 19.png.import new file mode 100644 index 0000000..c328c61 --- /dev/null +++ b/samagri/background/Clouds/Cloud 19.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 19.png" +dest_files=[ "res://.import/Cloud 19.png-696e9d5146d70336a2ca2313e7c25d2f.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 2.png b/samagri/background/Clouds/Cloud 2.png new file mode 100644 index 0000000..bd2ddb7 Binary files /dev/null and b/samagri/background/Clouds/Cloud 2.png differ diff --git a/samagri/background/Clouds/Cloud 2.png.import b/samagri/background/Clouds/Cloud 2.png.import new file mode 100644 index 0000000..2913f80 --- /dev/null +++ b/samagri/background/Clouds/Cloud 2.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 2.png" +dest_files=[ "res://.import/Cloud 2.png-f4382fbede087145e0489bea3d5594f0.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 20.png b/samagri/background/Clouds/Cloud 20.png new file mode 100644 index 0000000..a823e1c Binary files /dev/null and b/samagri/background/Clouds/Cloud 20.png differ diff --git a/samagri/background/Clouds/Cloud 20.png.import b/samagri/background/Clouds/Cloud 20.png.import new file mode 100644 index 0000000..5bd6f77 --- /dev/null +++ b/samagri/background/Clouds/Cloud 20.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 20.png" +dest_files=[ "res://.import/Cloud 20.png-411a2f69807e4261384c1e4c64da3b16.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 3.png b/samagri/background/Clouds/Cloud 3.png new file mode 100644 index 0000000..a76d706 Binary files /dev/null and b/samagri/background/Clouds/Cloud 3.png differ diff --git a/samagri/background/Clouds/Cloud 3.png.import b/samagri/background/Clouds/Cloud 3.png.import new file mode 100644 index 0000000..b22ec02 --- /dev/null +++ b/samagri/background/Clouds/Cloud 3.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 3.png" +dest_files=[ "res://.import/Cloud 3.png-28296809451b2db08f5c45e17390f50c.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 4.png b/samagri/background/Clouds/Cloud 4.png new file mode 100644 index 0000000..9a3e948 Binary files /dev/null and b/samagri/background/Clouds/Cloud 4.png differ diff --git a/samagri/background/Clouds/Cloud 4.png.import b/samagri/background/Clouds/Cloud 4.png.import new file mode 100644 index 0000000..deb4d36 --- /dev/null +++ b/samagri/background/Clouds/Cloud 4.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 4.png" +dest_files=[ "res://.import/Cloud 4.png-15ddeeaf62af993d444f82f5b10057ed.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 5.png b/samagri/background/Clouds/Cloud 5.png new file mode 100644 index 0000000..e3dd003 Binary files /dev/null and b/samagri/background/Clouds/Cloud 5.png differ diff --git a/samagri/background/Clouds/Cloud 5.png.import b/samagri/background/Clouds/Cloud 5.png.import new file mode 100644 index 0000000..e0d1edd --- /dev/null +++ b/samagri/background/Clouds/Cloud 5.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 5.png" +dest_files=[ "res://.import/Cloud 5.png-be6c59ca2f46dfb1959ee8123de22a75.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 6.png b/samagri/background/Clouds/Cloud 6.png new file mode 100644 index 0000000..30c174a Binary files /dev/null and b/samagri/background/Clouds/Cloud 6.png differ diff --git a/samagri/background/Clouds/Cloud 6.png.import b/samagri/background/Clouds/Cloud 6.png.import new file mode 100644 index 0000000..f0ba8b9 --- /dev/null +++ b/samagri/background/Clouds/Cloud 6.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 6.png" +dest_files=[ "res://.import/Cloud 6.png-acc859a02a5b0b641fd229c64c7b4d8f.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 7.png b/samagri/background/Clouds/Cloud 7.png new file mode 100644 index 0000000..d51d2d0 Binary files /dev/null and b/samagri/background/Clouds/Cloud 7.png differ diff --git a/samagri/background/Clouds/Cloud 7.png.import b/samagri/background/Clouds/Cloud 7.png.import new file mode 100644 index 0000000..d1300a8 --- /dev/null +++ b/samagri/background/Clouds/Cloud 7.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 7.png" +dest_files=[ "res://.import/Cloud 7.png-2b732b0a6fc33f96d8d563430236ce42.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 8.png b/samagri/background/Clouds/Cloud 8.png new file mode 100644 index 0000000..01832ab Binary files /dev/null and b/samagri/background/Clouds/Cloud 8.png differ diff --git a/samagri/background/Clouds/Cloud 8.png.import b/samagri/background/Clouds/Cloud 8.png.import new file mode 100644 index 0000000..32d1f54 --- /dev/null +++ b/samagri/background/Clouds/Cloud 8.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 8.png" +dest_files=[ "res://.import/Cloud 8.png-1a5ee3314ac367625676f2c80ef151ca.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/Clouds/Cloud 9.png b/samagri/background/Clouds/Cloud 9.png new file mode 100644 index 0000000..ae44ddb Binary files /dev/null and b/samagri/background/Clouds/Cloud 9.png differ diff --git a/samagri/background/Clouds/Cloud 9.png.import b/samagri/background/Clouds/Cloud 9.png.import new file mode 100644 index 0000000..1232325 --- /dev/null +++ b/samagri/background/Clouds/Cloud 9.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/Clouds/Cloud 9.png" +dest_files=[ "res://.import/Cloud 9.png-594d419ff058f1ec30bf2ec708038039.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/back.png b/samagri/background/back.png new file mode 100644 index 0000000..5366151 Binary files /dev/null and b/samagri/background/back.png differ diff --git a/samagri/background/back.png.import b/samagri/background/back.png.import new file mode 100644 index 0000000..1f28ca9 --- /dev/null +++ b/samagri/background/back.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/back.png" +dest_files=[ "res://.import/back.png-462caa40aff04dfe7b9af4d7d2e29b13.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/Cloud 1.png b/samagri/background/hills/Cloud 1.png new file mode 100644 index 0000000..923f710 Binary files /dev/null and b/samagri/background/hills/Cloud 1.png differ diff --git a/samagri/background/hills/Cloud 1.png.import b/samagri/background/hills/Cloud 1.png.import new file mode 100644 index 0000000..87c9b5a --- /dev/null +++ b/samagri/background/hills/Cloud 1.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/Cloud 1.png" +dest_files=[ "res://.import/Cloud 1.png-10b64c88144e4a08a8b5bff928bf5bee.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/hill1.png b/samagri/background/hills/hill1.png new file mode 100644 index 0000000..f6917b6 Binary files /dev/null and b/samagri/background/hills/hill1.png differ diff --git a/samagri/background/hills/hill1.png.import b/samagri/background/hills/hill1.png.import new file mode 100644 index 0000000..64d5b77 --- /dev/null +++ b/samagri/background/hills/hill1.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/hill1.png" +dest_files=[ "res://.import/hill1.png-ad0ffc788d31e651dccc463297f1628b.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/hill2.png b/samagri/background/hills/hill2.png new file mode 100644 index 0000000..e748df9 Binary files /dev/null and b/samagri/background/hills/hill2.png differ diff --git a/samagri/background/hills/hill2.png.import b/samagri/background/hills/hill2.png.import new file mode 100644 index 0000000..d9ce76e --- /dev/null +++ b/samagri/background/hills/hill2.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/hill2.png" +dest_files=[ "res://.import/hill2.png-fe5117dd64391ed22f9d516c308edd9d.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/hill3.png b/samagri/background/hills/hill3.png new file mode 100644 index 0000000..f689904 Binary files /dev/null and b/samagri/background/hills/hill3.png differ diff --git a/samagri/background/hills/hill3.png.import b/samagri/background/hills/hill3.png.import new file mode 100644 index 0000000..40b2e8c --- /dev/null +++ b/samagri/background/hills/hill3.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/hill3.png" +dest_files=[ "res://.import/hill3.png-12d0cb40a10e1fbb8b3a62b3288ddacf.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/hill4.png b/samagri/background/hills/hill4.png new file mode 100644 index 0000000..202ace6 Binary files /dev/null and b/samagri/background/hills/hill4.png differ diff --git a/samagri/background/hills/hill4.png.import b/samagri/background/hills/hill4.png.import new file mode 100644 index 0000000..4f35cce --- /dev/null +++ b/samagri/background/hills/hill4.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/hill4.png" +dest_files=[ "res://.import/hill4.png-323e86b43cdc02773acc3d46f7b01ff5.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/background/hills/hill5.png b/samagri/background/hills/hill5.png new file mode 100644 index 0000000..5758e59 Binary files /dev/null and b/samagri/background/hills/hill5.png differ diff --git a/samagri/background/hills/hill5.png.import b/samagri/background/hills/hill5.png.import new file mode 100644 index 0000000..5ba6e5c --- /dev/null +++ b/samagri/background/hills/hill5.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/background/hills/hill5.png" +dest_files=[ "res://.import/hill5.png-e3af757c740d09426cbb07a36d3eeeb6.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/broke_brick/p1.png b/samagri/broke_brick/p1.png new file mode 100644 index 0000000..fd7e825 Binary files /dev/null and b/samagri/broke_brick/p1.png differ diff --git a/samagri/broke_brick/p1.png.import b/samagri/broke_brick/p1.png.import new file mode 100644 index 0000000..02a19e3 --- /dev/null +++ b/samagri/broke_brick/p1.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/p1.png-c1d994578c830421642f80b075591df2.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/broke_brick/p1.png" +dest_files=[ "res://.import/p1.png-c1d994578c830421642f80b075591df2.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/broke_brick/p2.png b/samagri/broke_brick/p2.png new file mode 100644 index 0000000..a08c14a Binary files /dev/null and b/samagri/broke_brick/p2.png differ diff --git a/samagri/broke_brick/p2.png.import b/samagri/broke_brick/p2.png.import new file mode 100644 index 0000000..a447ed8 --- /dev/null +++ b/samagri/broke_brick/p2.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/broke_brick/p2.png" +dest_files=[ "res://.import/p2.png-fdb35761fdaf07f922b5c004aa5137b6.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/broke_brick/p3.png b/samagri/broke_brick/p3.png new file mode 100644 index 0000000..4d0b027 Binary files /dev/null and b/samagri/broke_brick/p3.png differ diff --git a/samagri/broke_brick/p3.png.import b/samagri/broke_brick/p3.png.import new file mode 100644 index 0000000..fc4d94c --- /dev/null +++ b/samagri/broke_brick/p3.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/broke_brick/p3.png" +dest_files=[ "res://.import/p3.png-34d70b6ba29889304c0b4b7b3c1b332b.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/broke_brick/p4.png b/samagri/broke_brick/p4.png new file mode 100644 index 0000000..cff5826 Binary files /dev/null and b/samagri/broke_brick/p4.png differ diff --git a/samagri/broke_brick/p4.png.import b/samagri/broke_brick/p4.png.import new file mode 100644 index 0000000..b808829 --- /dev/null +++ b/samagri/broke_brick/p4.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/broke_brick/p4.png" +dest_files=[ "res://.import/p4.png-9c5f21689a2f5e39c5d2ce80fc741cf8.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/bullet.png b/samagri/bullet.png new file mode 100644 index 0000000..4aaa1ae Binary files /dev/null and b/samagri/bullet.png differ diff --git a/samagri/bullet.png.import b/samagri/bullet.png.import new file mode 100644 index 0000000..b9a96ce --- /dev/null +++ b/samagri/bullet.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/bullet.png" +dest_files=[ "res://.import/bullet.png-5c8d585f8f78b23a55ca9018727fbb33.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/clock.png b/samagri/clock.png new file mode 100644 index 0000000..2bc3eb2 Binary files /dev/null and b/samagri/clock.png differ diff --git a/samagri/clock.png.import b/samagri/clock.png.import new file mode 100644 index 0000000..a276e47 --- /dev/null +++ b/samagri/clock.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/clock.png-0b59f1864c2966e68f1301e328a381e5.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/clock.png" +dest_files=[ "res://.import/clock.png-0b59f1864c2966e68f1301e328a381e5.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/coin.png b/samagri/coin.png new file mode 100644 index 0000000..3288a57 Binary files /dev/null and b/samagri/coin.png differ diff --git a/samagri/coin.png.import b/samagri/coin.png.import new file mode 100644 index 0000000..cc639b7 --- /dev/null +++ b/samagri/coin.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/coin.png" +dest_files=[ "res://.import/coin.png-c05ea17b7082ac4b8d4f4ac794b0068e.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/pause-pressed.png.import b/samagri/pause-pressed.png.import new file mode 100644 index 0000000..3e57381 --- /dev/null +++ b/samagri/pause-pressed.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/pause-pressed.png" +dest_files=[ "res://.import/pause-pressed.png-8a3340c3721cf7926b14faf23e5cf1b5.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/pause.png b/samagri/pause.png new file mode 100644 index 0000000..61c0901 Binary files /dev/null and b/samagri/pause.png differ diff --git a/samagri/pause.png.import b/samagri/pause.png.import new file mode 100644 index 0000000..5a07c0f --- /dev/null +++ b/samagri/pause.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/pause.png" +dest_files=[ "res://.import/pause.png-2d0aa2bfe7b6473dd4c42e6c8b4f997b.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/pig/Dead.png b/samagri/pig/Dead.png new file mode 100644 index 0000000..0310194 Binary files /dev/null and b/samagri/pig/Dead.png differ diff --git a/samagri/pig/Dead.png.import b/samagri/pig/Dead.png.import new file mode 100644 index 0000000..6738788 --- /dev/null +++ b/samagri/pig/Dead.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/pig/Dead.png" +dest_files=[ "res://.import/Dead.png-380834b7e7cb399d5b280e17fb23252c.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/pig/Hit.png b/samagri/pig/Hit.png new file mode 100644 index 0000000..39922f7 Binary files /dev/null and b/samagri/pig/Hit.png differ diff --git a/samagri/pig/Hit.png.import b/samagri/pig/Hit.png.import new file mode 100644 index 0000000..b68ff0b --- /dev/null +++ b/samagri/pig/Hit.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/pig/Hit.png" +dest_files=[ "res://.import/Hit.png-3d340fa2af9d33197b6dfb024a5c2b25.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/pig/Run.png b/samagri/pig/Run.png new file mode 100644 index 0000000..a52042f Binary files /dev/null and b/samagri/pig/Run.png differ diff --git a/samagri/pig/Run.png.import b/samagri/pig/Run.png.import new file mode 100644 index 0000000..21dd161 --- /dev/null +++ b/samagri/pig/Run.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/pig/Run.png" +dest_files=[ "res://.import/Run.png-f5f51bd7ee7b08e5d9dc8ba62037f89f.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Fall.png b/samagri/player/Fall.png new file mode 100644 index 0000000..d31b217 Binary files /dev/null and b/samagri/player/Fall.png differ diff --git a/samagri/player/Fall.png.import b/samagri/player/Fall.png.import new file mode 100644 index 0000000..01c9a11 --- /dev/null +++ b/samagri/player/Fall.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Fall.png-a372164a20682200f80fa29d2daa12f5.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Fall.png" +dest_files=[ "res://.import/Fall.png-a372164a20682200f80fa29d2daa12f5.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Hit.png b/samagri/player/Hit.png new file mode 100644 index 0000000..b853ccd Binary files /dev/null and b/samagri/player/Hit.png differ diff --git a/samagri/player/Hit.png.import b/samagri/player/Hit.png.import new file mode 100644 index 0000000..3a0c8e9 --- /dev/null +++ b/samagri/player/Hit.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Hit.png" +dest_files=[ "res://.import/Hit.png-19628f12a8649d9753048edf3b80c7aa.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Idle.png b/samagri/player/Idle.png new file mode 100644 index 0000000..fc52941 Binary files /dev/null and b/samagri/player/Idle.png differ diff --git a/samagri/player/Idle.png.import b/samagri/player/Idle.png.import new file mode 100644 index 0000000..7b56337 --- /dev/null +++ b/samagri/player/Idle.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Idle.png" +dest_files=[ "res://.import/Idle.png-be8ea061a76ca0bdb0eee1f62ecf24c9.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Jump.png b/samagri/player/Jump.png new file mode 100644 index 0000000..7547f5b Binary files /dev/null and b/samagri/player/Jump.png differ diff --git a/samagri/player/Jump.png.import b/samagri/player/Jump.png.import new file mode 100644 index 0000000..12cc936 --- /dev/null +++ b/samagri/player/Jump.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Jump.png" +dest_files=[ "res://.import/Jump.png-8cf7c800da5d47062df4b6adb04b8876.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Player.tres b/samagri/player/Player.tres new file mode 100644 index 0000000..ca97761 --- /dev/null +++ b/samagri/player/Player.tres @@ -0,0 +1,206 @@ +[gd_resource type="SpriteFrames" load_steps=40 format=2] + +[ext_resource path="res://samagri/player/Hit.png" type="Texture" id=1] +[ext_resource path="res://samagri/player/Jump.png" type="Texture" id=2] +[ext_resource path="res://samagri/player/Fall.png" type="Texture" id=3] +[ext_resource path="res://samagri/player/Run.png" type="Texture" id=4] +[ext_resource path="res://samagri/player/Idle.png" type="Texture" id=5] +[ext_resource path="res://samagri/player/Shoot.png" type="Texture" id=6] + +[sub_resource type="AtlasTexture" id=1] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=2] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 64, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=3] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 128, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=4] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 192, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=5] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 256, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=6] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 320, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=7] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 384, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=8] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 448, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=9] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 512, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=10] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 576, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=11] +flags = 4 +atlas = ExtResource( 5 ) +region = Rect2( 640, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=12] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=13] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 64, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=14] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 128, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=15] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 192, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=16] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 256, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=17] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 320, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=18] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 384, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=19] +flags = 4 +atlas = ExtResource( 6 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=20] +flags = 4 +atlas = ExtResource( 2 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=21] +flags = 4 +atlas = ExtResource( 3 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=22] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 0, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=23] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 64, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=24] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 128, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=25] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 192, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=26] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 256, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=27] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 320, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=28] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 384, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=29] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 448, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=30] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 512, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=31] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 576, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=32] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 640, 0, 64, 64 ) + +[sub_resource type="AtlasTexture" id=33] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 704, 0, 64, 64 ) + +[resource] +animations = [ { +"frames": [ SubResource( 1 ), SubResource( 2 ), SubResource( 3 ), SubResource( 4 ), SubResource( 5 ), SubResource( 6 ), SubResource( 7 ), SubResource( 8 ), SubResource( 9 ), SubResource( 10 ), SubResource( 11 ) ], +"loop": true, +"name": "idle", +"speed": 10.0 +}, { +"frames": [ SubResource( 12 ), SubResource( 13 ), SubResource( 14 ), SubResource( 15 ), SubResource( 16 ), SubResource( 17 ), SubResource( 18 ) ], +"loop": false, +"name": "hit", +"speed": 10.0 +}, { +"frames": [ SubResource( 19 ) ], +"loop": true, +"name": "shoot", +"speed": 5.0 +}, { +"frames": [ SubResource( 20 ) ], +"loop": true, +"name": "jump", +"speed": 10.0 +}, { +"frames": [ SubResource( 21 ) ], +"loop": true, +"name": "fall", +"speed": 10.0 +}, { +"frames": [ SubResource( 22 ), SubResource( 23 ), SubResource( 24 ), SubResource( 25 ), SubResource( 26 ), SubResource( 27 ), SubResource( 28 ), SubResource( 29 ), SubResource( 30 ), SubResource( 31 ), SubResource( 32 ), SubResource( 33 ) ], +"loop": true, +"name": "run", +"speed": 20.0 +} ] diff --git a/samagri/player/Run.png b/samagri/player/Run.png new file mode 100644 index 0000000..8b32cf9 Binary files /dev/null and b/samagri/player/Run.png differ diff --git a/samagri/player/Run.png.import b/samagri/player/Run.png.import new file mode 100644 index 0000000..48ff157 --- /dev/null +++ b/samagri/player/Run.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Run.png-5667008b09d030d2656b5293577011cb.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Run.png" +dest_files=[ "res://.import/Run.png-5667008b09d030d2656b5293577011cb.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/player/Shoot.png b/samagri/player/Shoot.png new file mode 100644 index 0000000..1010095 Binary files /dev/null and b/samagri/player/Shoot.png differ diff --git a/samagri/player/Shoot.png.import b/samagri/player/Shoot.png.import new file mode 100644 index 0000000..4622683 --- /dev/null +++ b/samagri/player/Shoot.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/player/Shoot.png" +dest_files=[ "res://.import/Shoot.png-7f58be741585a945c9e0fa75c2657f02.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/sfx/coin_pickup.wav b/samagri/sfx/coin_pickup.wav new file mode 100644 index 0000000..e78579f Binary files /dev/null and b/samagri/sfx/coin_pickup.wav differ diff --git a/samagri/sfx/coin_pickup.wav.import b/samagri/sfx/coin_pickup.wav.import new file mode 100644 index 0000000..3f5ac29 --- /dev/null +++ b/samagri/sfx/coin_pickup.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.sample" + +[deps] + +source_file="res://samagri/sfx/coin_pickup.wav" +dest_files=[ "res://.import/coin_pickup.wav-e1d031476134d555c77bbdf6750c6c73.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=true +edit/normalize=true +edit/loop=false +compress/mode=0 diff --git a/samagri/sfx/explode.wav b/samagri/sfx/explode.wav new file mode 100644 index 0000000..229c853 Binary files /dev/null and b/samagri/sfx/explode.wav differ diff --git a/samagri/sfx/explode.wav.import b/samagri/sfx/explode.wav.import new file mode 100644 index 0000000..18cc2e2 --- /dev/null +++ b/samagri/sfx/explode.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/explode.wav-1427bde96c86e9944df6457780bdca97.sample" + +[deps] + +source_file="res://samagri/sfx/explode.wav" +dest_files=[ "res://.import/explode.wav-1427bde96c86e9944df6457780bdca97.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=true +edit/normalize=true +edit/loop=false +compress/mode=0 diff --git a/samagri/sfx/hit.wav b/samagri/sfx/hit.wav new file mode 100644 index 0000000..4fb3b13 Binary files /dev/null and b/samagri/sfx/hit.wav differ diff --git a/samagri/sfx/hit.wav.import b/samagri/sfx/hit.wav.import new file mode 100644 index 0000000..da4a14d --- /dev/null +++ b/samagri/sfx/hit.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.sample" + +[deps] + +source_file="res://samagri/sfx/hit.wav" +dest_files=[ "res://.import/hit.wav-b44bc42855f015b80479ac2ccbcf72d9.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=true +edit/normalize=true +edit/loop=false +compress/mode=0 diff --git a/samagri/sfx/jump.wav b/samagri/sfx/jump.wav new file mode 100644 index 0000000..e9942e6 Binary files /dev/null and b/samagri/sfx/jump.wav differ diff --git a/samagri/sfx/jump.wav.import b/samagri/sfx/jump.wav.import new file mode 100644 index 0000000..23ee804 --- /dev/null +++ b/samagri/sfx/jump.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.sample" + +[deps] + +source_file="res://samagri/sfx/jump.wav" +dest_files=[ "res://.import/jump.wav-0b21ec4fd00d435903b5f33eb53c60cf.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=true +edit/normalize=true +edit/loop=false +compress/mode=0 diff --git a/samagri/sfx/pain.wav b/samagri/sfx/pain.wav new file mode 100644 index 0000000..df711e8 Binary files /dev/null and b/samagri/sfx/pain.wav differ diff --git a/samagri/sfx/pain.wav.import b/samagri/sfx/pain.wav.import new file mode 100644 index 0000000..46e6dc9 --- /dev/null +++ b/samagri/sfx/pain.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.sample" + +[deps] + +source_file="res://samagri/sfx/pain.wav" +dest_files=[ "res://.import/pain.wav-5d16eb513e777572cc6c4ae1e1eb1319.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=false +edit/normalize=false +edit/loop=false +compress/mode=0 diff --git a/samagri/sfx/shoot.wav b/samagri/sfx/shoot.wav new file mode 100644 index 0000000..ad74f32 Binary files /dev/null and b/samagri/sfx/shoot.wav differ diff --git a/samagri/sfx/shoot.wav.import b/samagri/sfx/shoot.wav.import new file mode 100644 index 0000000..12a5cde --- /dev/null +++ b/samagri/sfx/shoot.wav.import @@ -0,0 +1,21 @@ +[remap] + +importer="wav" +type="AudioStreamSample" +path="res://.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.sample" + +[deps] + +source_file="res://samagri/sfx/shoot.wav" +dest_files=[ "res://.import/shoot.wav-a84d8c2f7d4cddbbfb795ed0f3a7a0ca.sample" ] + +[params] + +force/8_bit=false +force/mono=false +force/max_rate=false +force/max_rate_hz=44100 +edit/trim=true +edit/normalize=true +edit/loop=false +compress/mode=0 diff --git a/samagri/star.png b/samagri/star.png new file mode 100644 index 0000000..ac8521d Binary files /dev/null and b/samagri/star.png differ diff --git a/samagri/star.png.import b/samagri/star.png.import new file mode 100644 index 0000000..0da52bc --- /dev/null +++ b/samagri/star.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/star.png" +dest_files=[ "res://.import/star.png-e6fd4e7bb41c2ae1f33c1383d14b9f60.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/theme/fonts/kenney_mini_square.tres b/samagri/theme/fonts/kenney_mini_square.tres new file mode 100644 index 0000000..a449a1f --- /dev/null +++ b/samagri/theme/fonts/kenney_mini_square.tres @@ -0,0 +1,5 @@ +[gd_resource type="DynamicFontData" format=2] + +[resource] +antialiased = false +font_path = "res://samagri/theme/fonts/kenney_mini_square.ttf" diff --git a/samagri/theme/fonts/kenney_mini_square.ttf b/samagri/theme/fonts/kenney_mini_square.ttf new file mode 100644 index 0000000..5f2c5bb Binary files /dev/null and b/samagri/theme/fonts/kenney_mini_square.ttf differ diff --git a/samagri/theme/user_interface.tres b/samagri/theme/user_interface.tres new file mode 100644 index 0000000..16e87d9 --- /dev/null +++ b/samagri/theme/user_interface.tres @@ -0,0 +1,83 @@ +[gd_resource type="Theme" load_steps=8 format=2] + +[ext_resource path="res://samagri/theme/fonts/kenney_mini_square.tres" type="DynamicFontData" id=1] + +[sub_resource type="StyleBoxFlat" id=1] +content_margin_left = 6.0 +content_margin_right = 6.0 +content_margin_top = 4.0 +content_margin_bottom = 4.0 +bg_color = Color( 0.18, 0.207, 0.279, 1 ) +border_width_left = 1 +border_width_top = 1 +border_width_right = 1 +border_width_bottom = 1 +border_color = Color( 0.14, 0.161, 0.217, 1 ) + +[sub_resource type="StyleBoxFlat" id=2] +content_margin_left = 6.0 +content_margin_right = 6.0 +content_margin_top = 4.0 +content_margin_bottom = 4.0 +bg_color = Color( 0.15, 0.1725, 0.2325, 1 ) +border_width_left = 1 +border_width_top = 1 +border_width_right = 1 +border_width_bottom = 1 +border_color = Color( 0.41, 0.61, 0.91, 1 ) + +[sub_resource type="StyleBoxFlat" id=3] +content_margin_left = 6.0 +content_margin_right = 6.0 +content_margin_top = 4.0 +content_margin_bottom = 4.0 +bg_color = Color( 0.15, 0.1725, 0.2325, 1 ) +border_width_left = 1 +border_width_top = 1 +border_width_right = 1 +border_width_bottom = 1 +border_color = Color( 0.4, 0.4225, 0.4825, 1 ) + +[sub_resource type="StyleBoxFlat" id=4] +content_margin_left = 6.0 +content_margin_right = 6.0 +content_margin_top = 4.0 +content_margin_bottom = 4.0 +bg_color = Color( 0.15, 0.1725, 0.2325, 1 ) +border_width_left = 1 +border_width_top = 1 +border_width_right = 1 +border_width_bottom = 1 +border_color = Color( 0.125, 0.14375, 0.19375, 1 ) + +[sub_resource type="StyleBoxFlat" id=5] +content_margin_left = 6.0 +content_margin_right = 6.0 +content_margin_top = 4.0 +content_margin_bottom = 4.0 +bg_color = Color( 0.15, 0.1725, 0.2325, 1 ) +border_width_left = 1 +border_width_top = 1 +border_width_right = 1 +border_width_bottom = 1 +border_color = Color( 0.41, 0.61, 0.91, 1 ) + +[sub_resource type="DynamicFont" id=6] +size = 30 +font_data = ExtResource( 1 ) + +[resource] +default_font = SubResource( 6 ) +Button/colors/font_color = Color( 0.8, 0.8075, 0.8275, 1 ) +Button/colors/font_color_disabled = Color( 1, 1, 1, 0.3 ) +Button/colors/font_color_hover = Color( 0.88, 0.8845, 0.8965, 1 ) +Button/colors/font_color_pressed = Color( 0.411765, 0.611765, 0.909804, 1 ) +Button/colors/icon_color_hover = Color( 1.15, 1.15, 1.15, 1 ) +Button/colors/icon_color_pressed = Color( 0.4715, 0.7015, 1.0465, 1 ) +Button/constants/hseparation = 2 +Button/fonts/font = null +Button/styles/disabled = SubResource( 1 ) +Button/styles/focus = SubResource( 2 ) +Button/styles/hover = SubResource( 3 ) +Button/styles/normal = SubResource( 4 ) +Button/styles/pressed = SubResource( 5 ) diff --git a/samagri/tile.png b/samagri/tile.png new file mode 100644 index 0000000..fef6abe Binary files /dev/null and b/samagri/tile.png differ diff --git a/samagri/tile.png.import b/samagri/tile.png.import new file mode 100644 index 0000000..150ae4d --- /dev/null +++ b/samagri/tile.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/tile.png-801f14104a51997c7e2366d892ec377e.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/tile.png" +dest_files=[ "res://.import/tile.png-801f14104a51997c7e2366d892ec377e.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/samagri/tile.xcf b/samagri/tile.xcf new file mode 100644 index 0000000..f7167f4 Binary files /dev/null and b/samagri/tile.xcf differ diff --git a/samagri/ui/touch_button_fire.png b/samagri/ui/touch_button_fire.png new file mode 100644 index 0000000..1d7ed2d Binary files /dev/null and b/samagri/ui/touch_button_fire.png differ diff --git a/samagri/ui/touch_button_fire.png.import b/samagri/ui/touch_button_fire.png.import new file mode 100644 index 0000000..aece57a --- /dev/null +++ b/samagri/ui/touch_button_fire.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/ui/touch_button_fire.png" +dest_files=[ "res://.import/touch_button_fire.png-10fc39490516f535acfe6c1d59db598a.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=false +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=false +svg/scale=1.0 diff --git a/samagri/ui/touch_button_jump.png b/samagri/ui/touch_button_jump.png new file mode 100644 index 0000000..819ba61 Binary files /dev/null and b/samagri/ui/touch_button_jump.png differ diff --git a/samagri/ui/touch_button_jump.png.import b/samagri/ui/touch_button_jump.png.import new file mode 100644 index 0000000..d329995 --- /dev/null +++ b/samagri/ui/touch_button_jump.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/ui/touch_button_jump.png" +dest_files=[ "res://.import/touch_button_jump.png-09e3aee9402d4b19a35fd9ab90c5b081.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=false +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=false +svg/scale=1.0 diff --git a/samagri/ui/touch_button_left.png b/samagri/ui/touch_button_left.png new file mode 100644 index 0000000..60e48d6 Binary files /dev/null and b/samagri/ui/touch_button_left.png differ diff --git a/samagri/ui/touch_button_left.png.import b/samagri/ui/touch_button_left.png.import new file mode 100644 index 0000000..5707378 --- /dev/null +++ b/samagri/ui/touch_button_left.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/ui/touch_button_left.png" +dest_files=[ "res://.import/touch_button_left.png-a2f940ba53cae992f1b05ae46499fd6b.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=false +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=false +svg/scale=1.0 diff --git a/samagri/ui/touch_button_right.png b/samagri/ui/touch_button_right.png new file mode 100644 index 0000000..8f0c57c Binary files /dev/null and b/samagri/ui/touch_button_right.png differ diff --git a/samagri/ui/touch_button_right.png.import b/samagri/ui/touch_button_right.png.import new file mode 100644 index 0000000..a57c315 --- /dev/null +++ b/samagri/ui/touch_button_right.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://samagri/ui/touch_button_right.png" +dest_files=[ "res://.import/touch_button_right.png-b5e66ed908becbff2c94a9efe3144d63.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=false +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=false +svg/scale=1.0 diff --git a/splash.png b/splash.png new file mode 100644 index 0000000..66a5a8d Binary files /dev/null and b/splash.png differ diff --git a/splash.png.import b/splash.png.import new file mode 100644 index 0000000..9b827bd --- /dev/null +++ b/splash.png.import @@ -0,0 +1,34 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/splash.png-929ed8a00b89ba36c51789452f874c77.stex" +metadata={ +"vram_texture": false +} + +[deps] + +source_file="res://splash.png" +dest_files=[ "res://.import/splash.png-929ed8a00b89ba36c51789452f874c77.stex" ] + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/bptc_ldr=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +process/invert_color=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/splash.xcf b/splash.xcf new file mode 100644 index 0000000..4d10381 Binary files /dev/null and b/splash.xcf differ diff --git a/src/actors/Actor.gd b/src/actors/Actor.gd new file mode 100644 index 0000000..bd45c59 --- /dev/null +++ b/src/actors/Actor.gd @@ -0,0 +1,12 @@ +extends KinematicBody2D +class_name Actor + +export var speed: = Vector2(250,500) +export var gravity: float = ProjectSettings.get("physics/2d/default_gravity") + +const FLOOR_NORMAL = Vector2.UP + +var _velocity = Vector2.ZERO + +func _physics_process(delta: float) -> void: + _velocity.y += gravity * delta diff --git a/src/actors/Enemy.gd b/src/actors/Enemy.gd new file mode 100644 index 0000000..9e8e55e --- /dev/null +++ b/src/actors/Enemy.gd @@ -0,0 +1,91 @@ +extends 'res://src/actors/Actor.gd' +class_name Enemy + +onready var right_platform_detector = $RightPlatformDetector +onready var left_platform_detector = $LeftPlatformDetector +onready var sprite = $AnimatedSprite +onready var collision_shape = $CollisionShape2D +onready var shot_timer = $Shot +onready var destroy_timer = $Destroy +onready var die_audio = $AudioStreamPlayer2D +onready var left_right_collision_detector = $LeftRightCollisionDetector +onready var top_collision_detector = $TopCollisionDetector + +export var direction = -1 +var current_animation = 'run' +var self_destroy = false +var got_shot = false +var killed_player = false + +export var turn_back_on_fall = false + +func _physics_process(_delta: float) -> void: + if got_shot or self_destroy: + set_collision_mask_bit(0, false) + left_right_collision_detector.set_collision_mask_bit(0, false) + top_collision_detector.set_collision_mask_bit(0, false) + + _velocity.x = get_direction() * speed.x + _velocity = move_and_slide(_velocity, FLOOR_NORMAL) + + # Flip if needed + if direction > 0: + sprite.set_flip_h(true) + elif direction < 0: + sprite.set_flip_h(false) + + var animaton = get_animation() + if sprite.animation != animaton: + sprite.play(animaton) + +func get_direction() -> int: + if got_shot or self_destroy or killed_player: + return 0 + + if is_on_wall(): + direction *= -1 + + if !turn_back_on_fall: + return direction + + var right = right_platform_detector.is_colliding() + var left = left_platform_detector.is_colliding() + if right and !left: + direction = 1 + elif !right and left: + direction = -1 + elif !right and !left: + direction = 0 + return direction + +func get_animation() -> String: + if self_destroy: + return 'die' + elif got_shot: + return 'hit' + else: + return 'run' + +func kill_me(): + if !got_shot and !self_destroy: + Global.score += Global.SCORE_KILL + die_audio.play() + got_shot = true + shot_timer.start() + +func _on_Shot_timeout() -> void: + self_destroy = true + destroy_timer.start() + +func _destroy() -> void: + queue_free() + pass + +func _on_LeftRightCollisionDetector_body_entered(body: Node) -> void: + if body is Player: + killed_player = true + body.kill_me() + +func _on_TopCollisionDetector_body_entered(body: Node) -> void: + if body is Player: + kill_me() diff --git a/src/actors/Enemy.tscn b/src/actors/Enemy.tscn new file mode 100644 index 0000000..49da566 --- /dev/null +++ b/src/actors/Enemy.tscn @@ -0,0 +1,160 @@ +[gd_scene load_steps=22 format=2] + +[ext_resource path="res://samagri/pig/Dead.png" type="Texture" id=1] +[ext_resource path="res://samagri/pig/Hit.png" type="Texture" id=2] +[ext_resource path="res://src/actors/Enemy.gd" type="Script" id=3] +[ext_resource path="res://samagri/pig/Run.png" type="Texture" id=4] +[ext_resource path="res://samagri/sfx/pain.wav" type="AudioStream" id=5] + +[sub_resource type="AtlasTexture" id=1] +flags = 4 +atlas = ExtResource( 2 ) +region = Rect2( 0, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=2] +flags = 4 +atlas = ExtResource( 2 ) +region = Rect2( 77, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=3] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 0, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=4] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 77, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=5] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 154, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=6] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 231, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=7] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 308, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=8] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 385, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=9] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 0, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=10] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 77, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=11] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 154, 0, 77, 64 ) + +[sub_resource type="AtlasTexture" id=12] +flags = 4 +atlas = ExtResource( 1 ) +region = Rect2( 231, 0, 77, 64 ) + +[sub_resource type="SpriteFrames" id=13] +animations = [ { +"frames": [ SubResource( 1 ), SubResource( 2 ) ], +"loop": true, +"name": "hit", +"speed": 5.0 +}, { +"frames": [ SubResource( 3 ), SubResource( 4 ), SubResource( 5 ), SubResource( 6 ), SubResource( 7 ), SubResource( 8 ) ], +"loop": true, +"name": "run", +"speed": 10.0 +}, { +"frames": [ SubResource( 9 ), SubResource( 10 ), SubResource( 11 ), SubResource( 12 ) ], +"loop": false, +"name": "die", +"speed": 5.0 +} ] + +[sub_resource type="RectangleShape2D" id=14] +extents = Vector2( 21, 18 ) + +[sub_resource type="RectangleShape2D" id=15] +extents = Vector2( 22, 17 ) + +[sub_resource type="RectangleShape2D" id=16] +extents = Vector2( 22, 1 ) + +[node name="Enemy" type="KinematicBody2D"] +collision_layer = 2 +collision_mask = 93 +script = ExtResource( 3 ) +speed = Vector2( 240, 500 ) + +[node name="VisibilityEnabler2D" type="VisibilityEnabler2D" parent="."] +position = Vector2( -2.14577e-06, -19 ) +scale = Vector2( 2.9, 2.4 ) +process_parent = true +physics_process_parent = true + +[node name="AnimatedSprite" type="AnimatedSprite" parent="."] +position = Vector2( -9, -30 ) +frames = SubResource( 13 ) +animation = "run" +frame = 1 +playing = true + +[node name="CollisionShape2D" type="CollisionShape2D" parent="."] +position = Vector2( 0, -18 ) +shape = SubResource( 14 ) + +[node name="RightPlatformDetector" type="RayCast2D" parent="."] +position = Vector2( 16, 0 ) +enabled = true +cast_to = Vector2( 50, 50 ) +collision_mask = 8 + +[node name="LeftPlatformDetector" type="RayCast2D" parent="."] +position = Vector2( -16, 0 ) +enabled = true +cast_to = Vector2( -50, 50 ) +collision_mask = 8 + +[node name="Shot" type="Timer" parent="."] +wait_time = 0.5 +one_shot = true + +[node name="Destroy" type="Timer" parent="."] +wait_time = 2.0 + +[node name="LeftRightCollisionDetector" type="Area2D" parent="."] +collision_layer = 2 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="LeftRightCollisionDetector"] +position = Vector2( 0, -18 ) +shape = SubResource( 15 ) + +[node name="TopCollisionDetector" type="Area2D" parent="."] +collision_layer = 2 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TopCollisionDetector"] +position = Vector2( 0, -37 ) +shape = SubResource( 16 ) + +[node name="AudioStreamPlayer2D" type="AudioStreamPlayer2D" parent="."] +position = Vector2( 0, -7 ) +stream = ExtResource( 5 ) +volume_db = -10.0 + +[connection signal="timeout" from="Shot" to="." method="_on_Shot_timeout"] +[connection signal="timeout" from="Destroy" to="." method="_destroy"] +[connection signal="body_entered" from="LeftRightCollisionDetector" to="." method="_on_LeftRightCollisionDetector_body_entered"] +[connection signal="body_entered" from="TopCollisionDetector" to="." method="_on_TopCollisionDetector_body_entered"] diff --git a/src/actors/Player.gd b/src/actors/Player.gd new file mode 100644 index 0000000..c15d2ef --- /dev/null +++ b/src/actors/Player.gd @@ -0,0 +1,111 @@ +extends 'res://src/actors/Actor.gd' +class_name Player + +const FLOOR_DETECT_DISTANCE = 20 + +onready var platform_detector = $PlatformDetector +onready var sprite = $AnimatedSprite +onready var collision_shape = $CollisionPolygon2D +onready var die_timer = $Die +onready var camera = $Camera2D + +onready var jump_audio = $JumpAudio +onready var hit_audio = $HitAudio +onready var shoot_audio = $ShootAudio + +onready var gun_right = $GunRight +onready var gun_left = $GunLeft + +var current_animation = 'idle' +var self_distruct = false + +func _physics_process(_delta: float) -> void: + #calculate direction + var direction = get_direction() + + if Input.is_action_just_pressed('jump'): + jump_audio.play() + + var is_jump_interrupted = Input.is_action_just_released('jump') and _velocity.y < 0 + + # calculate velocity + _velocity = calculate_velocity(_velocity, speed, direction, is_jump_interrupted) + + # grown se paas hone pe non zero vector, zero hone par hi bas jump hota hai + var snap_vector = Vector2.ZERO + if direction.y == 0: + snap_vector = Vector2.DOWN * FLOOR_DETECT_DISTANCE + + var is_on_platform = platform_detector.is_colliding() + # move + _velocity = move_and_slide_with_snap(_velocity, snap_vector, FLOOR_NORMAL, !is_on_platform, 4, 0.9, false) + + # Flip if needed and shoot with respective gun + if direction.x > 0: + sprite.set_flip_h(false) + elif direction.x < 0: + sprite.set_flip_h(true) + + if Input.is_action_just_pressed('shoot') and !self_distruct: + shoot_audio.play() + if sprite.flip_h: + gun_left.shoot(-1) + else: + gun_right.shoot(1) + + # shoot + var is_shooting = Input.is_action_pressed('shoot') + + var animaton = get_animation(is_on_platform,is_shooting) + if sprite.animation != animaton: + sprite.play(animaton) + +func get_direction() -> Vector2: + if self_distruct: + return Vector2.ZERO + + return Vector2( + Input.get_action_strength('move_right') - Input.get_action_strength('move_left'), + -1 if Input.is_action_just_pressed('jump') and is_on_floor() else 0 + ) + +func calculate_velocity(linear_velocity, speed, direction, is_jump_interrupted) -> Vector2: + var velocity = linear_velocity + velocity.x = speed.x * direction.x + if direction.y != 0: + velocity.y = speed.y * direction.y + + if is_jump_interrupted: # slow down aagar jump cor diya + velocity.y *= 0.6 + return velocity + +func get_animation(is_on_platform: bool, is_shooting: bool) -> String: + if self_distruct: + return 'hit' + elif is_shooting: + return 'shoot' + elif !is_on_platform and _velocity.y > 0: + return 'jump' + elif !is_on_platform and _velocity.y < 0: + return 'fall' + elif _velocity.x != 0: + return 'run' + else: + return 'idle' + +func _on_VisibilityNotifier2D_screen_exited() -> void: + if global_position.y > camera.limit_bottom: + hit_audio.play() + if get_tree().change_scene("res://src/scenes/GameOver.tscn") != 0: + print('Failed to change scene') + get_tree().quit() + +func kill_me(): + hit_audio.play() + self_distruct = true + die_timer.start() + +func _on_Die_timeout() -> void: + if get_tree().change_scene("res://src/scenes/GameOver.tscn") != 0: + print('Failed to change scene') + get_tree().quit() diff --git a/src/actors/Player.tscn b/src/actors/Player.tscn new file mode 100644 index 0000000..2a44599 --- /dev/null +++ b/src/actors/Player.tscn @@ -0,0 +1,75 @@ +[gd_scene load_steps=8 format=2] + +[ext_resource path="res://samagri/player/Player.tres" type="SpriteFrames" id=1] +[ext_resource path="res://src/actors/Player.gd" type="Script" id=2] +[ext_resource path="res://src/objects/Gun.gd" type="Script" id=3] +[ext_resource path="res://samagri/sfx/jump.wav" type="AudioStream" id=4] +[ext_resource path="res://samagri/sfx/hit.wav" type="AudioStream" id=5] +[ext_resource path="res://samagri/sfx/shoot.wav" type="AudioStream" id=6] +[ext_resource path="res://samagri/back-home.wav" type="AudioStream" id=7] + +[node name="Player" type="KinematicBody2D"] +position = Vector2( 378, 303 ) +collision_mask = 28 +script = ExtResource( 2 ) +speed = Vector2( 200, 500 ) + +[node name="PlatformDetector" type="RayCast2D" parent="."] +enabled = true +collision_mask = 14 + +[node name="Camera2D" type="Camera2D" parent="."] +current = true +limit_left = 0 +limit_bottom = 600 +limit_smoothed = true +drag_margin_h_enabled = true +drag_margin_v_enabled = true +drag_margin_left = 0.4 +drag_margin_top = 0.75 +drag_margin_right = 0.4 +drag_margin_bottom = 0.75 +editor_draw_limits = true +editor_draw_drag_margin = true + +[node name="AnimatedSprite" type="AnimatedSprite" parent="."] +position = Vector2( 4.76837e-07, 3 ) +scale = Vector2( 0.8, 0.9 ) +frames = ExtResource( 1 ) +animation = "idle" + +[node name="CollisionPolygon2D" type="CollisionPolygon2D" parent="."] +polygon = PoolVector2Array( 12, 31, 12, -4, 2, -9, -9, -4, -9, 31 ) + +[node name="VisibilityNotifier2D" type="VisibilityNotifier2D" parent="."] +position = Vector2( 2, 10 ) +scale = Vector2( 0.3, 0.25 ) + +[node name="GunRight" type="Position2D" parent="."] +position = Vector2( 18, 12 ) +script = ExtResource( 3 ) + +[node name="GunLeft" type="Position2D" parent="."] +position = Vector2( -17, 12 ) +script = ExtResource( 3 ) + +[node name="Die" type="Timer" parent="."] + +[node name="JumpAudio" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 4 ) +volume_db = -10.0 + +[node name="HitAudio" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 5 ) +volume_db = -10.0 + +[node name="ShootAudio" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 6 ) +volume_db = -10.0 + +[node name="Music" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 7 ) +autoplay = true + +[connection signal="screen_exited" from="VisibilityNotifier2D" to="." method="_on_VisibilityNotifier2D_screen_exited"] +[connection signal="timeout" from="Die" to="." method="_on_Die_timeout"] diff --git a/src/controller/ControlTouch.tscn b/src/controller/ControlTouch.tscn new file mode 100644 index 0000000..11032eb --- /dev/null +++ b/src/controller/ControlTouch.tscn @@ -0,0 +1,47 @@ +[gd_scene load_steps=5 format=2] + +[ext_resource path="res://samagri/ui/touch_button_left.png" type="Texture" id=1] +[ext_resource path="res://samagri/ui/touch_button_right.png" type="Texture" id=2] +[ext_resource path="res://samagri/ui/touch_button_jump.png" type="Texture" id=3] +[ext_resource path="res://samagri/ui/touch_button_fire.png" type="Texture" id=4] + +[node name="ControlTouch" type="CanvasLayer"] + +[node name="Control" type="Control" parent="."] +margin_right = 1024.0 +margin_bottom = 600.0 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Left" type="TouchScreenButton" parent="Control"] +position = Vector2( 0, 439 ) +scale = Vector2( 2.5, 2.5 ) +normal = ExtResource( 1 ) +passby_press = true +action = "move_left" +visibility_mode = 1 + +[node name="Right" type="TouchScreenButton" parent="Control"] +position = Vector2( 160, 439 ) +scale = Vector2( 2.5, 2.5 ) +normal = ExtResource( 2 ) +passby_press = true +action = "move_right" +visibility_mode = 1 + +[node name="Jump" type="TouchScreenButton" parent="Control"] +position = Vector2( 863, 263 ) +scale = Vector2( 2.5, 2.5 ) +normal = ExtResource( 4 ) +passby_press = true +action = "shoot" +visibility_mode = 1 + +[node name="Fire" type="TouchScreenButton" parent="Control"] +position = Vector2( 863, 439 ) +scale = Vector2( 2.5, 2.5 ) +normal = ExtResource( 3 ) +passby_press = true +action = "jump" +visibility_mode = 1 diff --git a/src/global/Global.gd b/src/global/Global.gd new file mode 100644 index 0000000..b264a15 --- /dev/null +++ b/src/global/Global.gd @@ -0,0 +1,7 @@ +extends Node2D + +const SCORE_COIN = 5 +const SCORE_KILL = 10 + +var score = 0 +var coins = 0 diff --git a/src/global/Global.tscn b/src/global/Global.tscn new file mode 100644 index 0000000..9f2a554 --- /dev/null +++ b/src/global/Global.tscn @@ -0,0 +1,6 @@ +[gd_scene load_steps=2 format=2] + +[ext_resource path="res://src/global/Global.gd" type="Script" id=1] + +[node name="Global" type="Node2D"] +script = ExtResource( 1 ) diff --git a/src/layers/Background.tscn b/src/layers/Background.tscn new file mode 100644 index 0000000..ada70cc --- /dev/null +++ b/src/layers/Background.tscn @@ -0,0 +1,174 @@ +[gd_scene load_steps=27 format=2] + +[ext_resource path="res://samagri/background/back.png" type="Texture" id=1] +[ext_resource path="res://samagri/background/Clouds/Cloud 4.png" type="Texture" id=2] +[ext_resource path="res://samagri/background/Clouds/Cloud 5.png" type="Texture" id=3] +[ext_resource path="res://samagri/background/Clouds/Cloud 2.png" type="Texture" id=4] +[ext_resource path="res://samagri/background/Clouds/Cloud 1.png" type="Texture" id=5] +[ext_resource path="res://samagri/background/Clouds/Cloud 3.png" type="Texture" id=6] +[ext_resource path="res://samagri/background/Clouds/Cloud 8.png" type="Texture" id=7] +[ext_resource path="res://samagri/background/Clouds/Cloud 6.png" type="Texture" id=8] +[ext_resource path="res://samagri/background/Clouds/Cloud 10.png" type="Texture" id=9] +[ext_resource path="res://samagri/background/Clouds/Cloud 9.png" type="Texture" id=10] +[ext_resource path="res://samagri/background/Clouds/Cloud 7.png" type="Texture" id=11] +[ext_resource path="res://samagri/background/Clouds/Cloud 15.png" type="Texture" id=12] +[ext_resource path="res://samagri/background/Clouds/Cloud 13.png" type="Texture" id=13] +[ext_resource path="res://samagri/background/Clouds/Cloud 14.png" type="Texture" id=14] +[ext_resource path="res://samagri/background/Clouds/Cloud 11.png" type="Texture" id=15] +[ext_resource path="res://samagri/background/Clouds/Cloud 12.png" type="Texture" id=16] +[ext_resource path="res://samagri/background/Clouds/Cloud 19.png" type="Texture" id=17] +[ext_resource path="res://samagri/background/Clouds/Cloud 17.png" type="Texture" id=18] +[ext_resource path="res://samagri/background/Clouds/Cloud 20.png" type="Texture" id=19] +[ext_resource path="res://samagri/background/Clouds/Cloud 18.png" type="Texture" id=20] +[ext_resource path="res://samagri/background/Clouds/Cloud 16.png" type="Texture" id=21] +[ext_resource path="res://samagri/background/hills/hill3.png" type="Texture" id=22] +[ext_resource path="res://samagri/background/hills/hill4.png" type="Texture" id=23] +[ext_resource path="res://samagri/background/hills/hill2.png" type="Texture" id=24] +[ext_resource path="res://samagri/background/hills/hill1.png" type="Texture" id=25] +[ext_resource path="res://samagri/background/hills/hill5.png" type="Texture" id=26] + +[node name="Background" type="ParallaxBackground"] +__meta__ = { +"_edit_horizontal_guides_": [ ] +} + +[node name="Sky" type="ParallaxLayer" parent="."] +motion_mirroring = Vector2( 1024, 0 ) + +[node name="back" type="Sprite" parent="Sky"] +position = Vector2( 0, -79 ) +scale = Vector2( 1, 0.630556 ) +texture = ExtResource( 1 ) +centered = false + +[node name="Cloud1" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.25, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="Cloud 1" type="Sprite" parent="Cloud1"] +position = Vector2( 102, 306 ) +texture = ExtResource( 5 ) + +[node name="Cloud 2" type="Sprite" parent="Cloud1"] +position = Vector2( 502, 430 ) +texture = ExtResource( 4 ) + +[node name="Cloud 3" type="Sprite" parent="Cloud1"] +position = Vector2( 709, 388 ) +texture = ExtResource( 6 ) + +[node name="Cloud 4" type="Sprite" parent="Cloud1"] +position = Vector2( 944, 188 ) +texture = ExtResource( 2 ) + +[node name="Cloud 5" type="Sprite" parent="Cloud1"] +position = Vector2( 525, 282 ) +texture = ExtResource( 3 ) + +[node name="Cloud2" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.2, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="Cloud 6" type="Sprite" parent="Cloud2"] +position = Vector2( 936, 338 ) +texture = ExtResource( 8 ) + +[node name="Cloud 7" type="Sprite" parent="Cloud2"] +position = Vector2( 231, 82 ) +texture = ExtResource( 11 ) + +[node name="Cloud 8" type="Sprite" parent="Cloud2"] +position = Vector2( 944, 70 ) +texture = ExtResource( 7 ) + +[node name="Cloud 9" type="Sprite" parent="Cloud2"] +position = Vector2( 115, 160 ) +texture = ExtResource( 10 ) + +[node name="Cloud 10" type="Sprite" parent="Cloud2"] +position = Vector2( 565, 68 ) +texture = ExtResource( 9 ) + +[node name="Cloud3" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.15, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="Cloud 11" type="Sprite" parent="Cloud3"] +position = Vector2( 571, 171 ) +texture = ExtResource( 15 ) + +[node name="Cloud 12" type="Sprite" parent="Cloud3"] +position = Vector2( 728, 111 ) +texture = ExtResource( 16 ) + +[node name="Cloud 13" type="Sprite" parent="Cloud3"] +position = Vector2( 411, 79 ) +texture = ExtResource( 13 ) + +[node name="Cloud 14" type="Sprite" parent="Cloud3"] +position = Vector2( 483, 204 ) +texture = ExtResource( 14 ) + +[node name="Cloud 15" type="Sprite" parent="Cloud3"] +position = Vector2( 844, 451 ) +texture = ExtResource( 12 ) + +[node name="Cloud4" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.1, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="Cloud 16" type="Sprite" parent="Cloud4"] +position = Vector2( 717, 224 ) +texture = ExtResource( 21 ) + +[node name="Cloud 17" type="Sprite" parent="Cloud4"] +position = Vector2( 208, 402 ) +texture = ExtResource( 18 ) + +[node name="Cloud 18" type="Sprite" parent="Cloud4"] +position = Vector2( 328, 297 ) +texture = ExtResource( 20 ) + +[node name="Cloud 19" type="Sprite" parent="Cloud4"] +position = Vector2( 300, 189 ) +texture = ExtResource( 17 ) + +[node name="Cloud 20" type="Sprite" parent="Cloud4"] +position = Vector2( 769, 287 ) +texture = ExtResource( 19 ) + +[node name="Hills2" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.3, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="hill5" type="Sprite" parent="Hills2"] +position = Vector2( 974, 502 ) +texture = ExtResource( 26 ) + +[node name="hill3" type="Sprite" parent="Hills2"] +position = Vector2( 571, 499 ) +texture = ExtResource( 22 ) + +[node name="hill1" type="Sprite" parent="Hills2"] +position = Vector2( 674, 500 ) +texture = ExtResource( 25 ) + +[node name="hill4" type="Sprite" parent="Hills2"] +position = Vector2( 328, 501 ) +texture = ExtResource( 23 ) + +[node name="Hills1" type="ParallaxLayer" parent="."] +motion_scale = Vector2( 0.2, 1 ) +motion_mirroring = Vector2( 1024, 0 ) + +[node name="hill1" type="Sprite" parent="Hills1"] +position = Vector2( 151, 501 ) +texture = ExtResource( 25 ) + +[node name="hill4" type="Sprite" parent="Hills1"] +position = Vector2( 824, 501 ) +texture = ExtResource( 23 ) + +[node name="hill2" type="Sprite" parent="Hills1"] +position = Vector2( 478, 501 ) +texture = ExtResource( 24 ) diff --git a/src/layers/HelpInfo.tscn b/src/layers/HelpInfo.tscn new file mode 100644 index 0000000..a438625 --- /dev/null +++ b/src/layers/HelpInfo.tscn @@ -0,0 +1,28 @@ +[gd_scene load_steps=2 format=2] + +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=1] + +[node name="Node2D" type="Node2D"] + +[node name="ColorRect" type="ColorRect" parent="."] +margin_right = 480.0 +margin_bottom = 169.0 +color = Color( 0.215686, 0.223529, 0.243137, 0.509804 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="."] +margin_left = 9.0 +margin_top = 2.0 +margin_right = 523.0 +margin_bottom = 126.0 +theme = ExtResource( 1 ) +text = "Hot Keys: +A,W,D or Left,Up,Right to move +K or Ctrl to fire +P to pause" +autowrap = true +__meta__ = { +"_edit_use_anchors_": false +} diff --git a/src/layers/Hud.gd b/src/layers/Hud.gd new file mode 100644 index 0000000..364113d --- /dev/null +++ b/src/layers/Hud.gd @@ -0,0 +1,26 @@ +extends CanvasLayer +class_name Hud + +onready var score = $Control/ColorRect/Score +onready var coins = $Control/ColorRect2/Coins +onready var timer = $Control/ColorRect3/Timer + +onready var countdown = $CountDown + + +func _ready() -> void: + update_values() + +func _process(_delta: float) -> void: + update_values() + +func update_values(): + score.text = str(Global.score) + coins.text = str(Global.coins) + timer.text = str(ceil(countdown.time_left)) + + +func _on_CountDown_timeout() -> void: + if get_tree().change_scene("res://src/scenes/GameOver.tscn") != 0: + print('Failed to change scene') + get_tree().quit() diff --git a/src/layers/Hud.tscn b/src/layers/Hud.tscn new file mode 100644 index 0000000..2ef7fab --- /dev/null +++ b/src/layers/Hud.tscn @@ -0,0 +1,102 @@ +[gd_scene load_steps=7 format=2] + +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=1] +[ext_resource path="res://src/layers/Hud.gd" type="Script" id=2] +[ext_resource path="res://samagri/coin.png" type="Texture" id=3] +[ext_resource path="res://samagri/star.png" type="Texture" id=4] +[ext_resource path="res://samagri/clock.png" type="Texture" id=5] +[ext_resource path="res://samagri/pause.png" type="Texture" id=6] + +[node name="Hud" type="CanvasLayer"] +script = ExtResource( 2 ) + +[node name="Control" type="Control" parent="."] +theme = ExtResource( 1 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="Control"] +margin_left = 50.0 +margin_top = 41.0 +margin_right = 194.0 +margin_bottom = 81.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Score" type="Label" parent="Control/ColorRect"] +margin_left = 40.0 +margin_top = 1.0 +margin_right = 69.0 +margin_bottom = 39.0 +text = "0" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="Control/ColorRect"] +position = Vector2( 19, 20 ) +texture = ExtResource( 4 ) + +[node name="ColorRect2" type="ColorRect" parent="Control"] +margin_left = 224.0 +margin_top = 41.0 +margin_right = 368.0 +margin_bottom = 81.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Coins" type="Label" parent="Control/ColorRect2"] +margin_left = 40.0 +margin_top = 1.0 +margin_right = 69.0 +margin_bottom = 39.0 +text = "0" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="Control/ColorRect2"] +position = Vector2( 19, 20 ) +texture = ExtResource( 3 ) + +[node name="ColorRect3" type="ColorRect" parent="Control"] +margin_left = 403.0 +margin_top = 42.0 +margin_right = 547.0 +margin_bottom = 82.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Timer" type="Label" parent="Control/ColorRect3"] +margin_left = 40.0 +margin_top = 1.0 +margin_right = 69.0 +margin_bottom = 39.0 +text = "0" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="Control/ColorRect3"] +position = Vector2( 19, 20 ) +texture = ExtResource( 5 ) + +[node name="CountDown" type="Timer" parent="."] +wait_time = 300.0 +one_shot = true +autostart = true + +[node name="TouchScreenButton" type="TouchScreenButton" parent="."] +position = Vector2( 931, 29 ) +normal = ExtResource( 6 ) +action = "pause" +visibility_mode = 1 + +[connection signal="timeout" from="CountDown" to="." method="_on_CountDown_timeout"] diff --git a/src/layers/PauseMenu.gd b/src/layers/PauseMenu.gd new file mode 100644 index 0000000..bdcd438 --- /dev/null +++ b/src/layers/PauseMenu.gd @@ -0,0 +1,23 @@ +extends Control + +func _ready() -> void: + hide() + +func _input(event): + if Input.is_action_just_pressed('pause'): + open() + +func open(): + show() + get_tree().paused = true + +func close(): + hide() + get_tree().paused = false + +func _on_ResumeButton_pressed() -> void: + close() + +func _on_ExitButton_pressed() -> void: + close() + get_tree().change_scene("res://src/scenes/MainMenu.tscn") diff --git a/src/layers/PauseMenu.tscn b/src/layers/PauseMenu.tscn new file mode 100644 index 0000000..95f9347 --- /dev/null +++ b/src/layers/PauseMenu.tscn @@ -0,0 +1,63 @@ +[gd_scene load_steps=3 format=2] + +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=1] +[ext_resource path="res://src/layers/PauseMenu.gd" type="Script" id=2] + +[node name="PauseMenu" type="CanvasLayer"] + +[node name="Control" type="Control" parent="."] +pause_mode = 2 +anchor_left = 0.5 +anchor_top = 0.5 +anchor_right = 0.5 +anchor_bottom = 0.5 +margin_left = -512.0 +margin_top = -300.0 +margin_right = 512.0 +margin_bottom = 300.0 +theme = ExtResource( 1 ) +script = ExtResource( 2 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect" type="ColorRect" parent="Control"] +margin_right = 1024.0 +margin_bottom = 600.0 +color = Color( 0.133333, 0.141176, 0.172549, 0.901961 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ResumeButton" type="Button" parent="Control"] +anchor_left = 0.5 +anchor_top = 0.5 +anchor_right = 0.5 +anchor_bottom = 0.5 +margin_left = -126.5 +margin_top = -60.5 +margin_right = 126.5 +margin_bottom = -3.5 +text = "Resume" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ExitButton" type="Button" parent="Control"] +anchor_left = 0.5 +anchor_top = 0.5 +anchor_right = 0.5 +anchor_bottom = 0.5 +margin_left = -126.0 +margin_top = 26.0 +margin_right = 127.0 +margin_bottom = 83.0 +text = "Exit" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Tween" type="Tween" parent="."] + +[connection signal="pressed" from="Control/ResumeButton" to="Control" method="_on_ResumeButton_pressed"] +[connection signal="pressed" from="Control/ExitButton" to="Control" method="_on_ExitButton_pressed"] diff --git a/src/levels/Level1.gd b/src/levels/Level1.gd new file mode 100644 index 0000000..d4b9f1e --- /dev/null +++ b/src/levels/Level1.gd @@ -0,0 +1,6 @@ +extends Node2D + +func _on_Area2D_body_entered(_body: Node) -> void: + if get_tree().change_scene("res://src/scenes/GameWon.tscn") != 0: + print('Failed to change scene') + get_tree().quit() diff --git a/src/levels/Level1.tscn b/src/levels/Level1.tscn new file mode 100644 index 0000000..51dbbd1 --- /dev/null +++ b/src/levels/Level1.tscn @@ -0,0 +1,1854 @@ +[gd_scene load_steps=58 format=2] + +[ext_resource path="res://samagri/tile.png" type="Texture" id=1] +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=2] +[ext_resource path="res://src/objects/MagicBox.gd" type="Script" id=3] +[ext_resource path="res://src/actors/Enemy.tscn" type="PackedScene" id=4] +[ext_resource path="res://src/levels/Level1.gd" type="Script" id=5] +[ext_resource path="res://src/objects/Brick.gd" type="Script" id=6] + +[sub_resource type="ConvexPolygonShape2D" id=1] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=2] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=3] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=4] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=5] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=6] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=7] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=8] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=9] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=10] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=11] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=12] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=13] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=14] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=15] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=16] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=17] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=18] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=19] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=20] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=21] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=22] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=23] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=24] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=25] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=26] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=27] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=28] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=29] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=30] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=31] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=32] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=33] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=34] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=35] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=36] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=37] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=38] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=39] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=40] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=41] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=42] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=43] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=44] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=45] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=46] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=47] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="ConvexPolygonShape2D" id=48] +points = PoolVector2Array( 0, 0, 32, 0, 32, 32, 0, 32 ) + +[sub_resource type="TileSet" id=49] +0/name = "tile.png 0" +0/texture = ExtResource( 1 ) +0/tex_offset = Vector2( 0, 0 ) +0/modulate = Color( 1, 1, 1, 1 ) +0/region = Rect2( 32, 32, 32, 32 ) +0/tile_mode = 0 +0/occluder_offset = Vector2( 0, 0 ) +0/navigation_offset = Vector2( 0, 0 ) +0/shape_offset = Vector2( 0, 0 ) +0/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +0/shape = SubResource( 1 ) +0/shape_one_way = false +0/shape_one_way_margin = 1.0 +0/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 1 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +0/z_index = 0 +1/name = "tile.png 1" +1/texture = ExtResource( 1 ) +1/tex_offset = Vector2( 0, 0 ) +1/modulate = Color( 1, 1, 1, 1 ) +1/region = Rect2( 64, 32, 32, 32 ) +1/tile_mode = 0 +1/occluder_offset = Vector2( 0, 0 ) +1/navigation_offset = Vector2( 0, 0 ) +1/shape_offset = Vector2( 0, 0 ) +1/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +1/shape = SubResource( 2 ) +1/shape_one_way = false +1/shape_one_way_margin = 1.0 +1/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 2 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +1/z_index = 0 +2/name = "tile.png 2" +2/texture = ExtResource( 1 ) +2/tex_offset = Vector2( 0, 0 ) +2/modulate = Color( 1, 1, 1, 1 ) +2/region = Rect2( 96, 32, 32, 32 ) +2/tile_mode = 0 +2/occluder_offset = Vector2( 0, 0 ) +2/navigation_offset = Vector2( 0, 0 ) +2/shape_offset = Vector2( 0, 0 ) +2/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +2/shape = SubResource( 13 ) +2/shape_one_way = false +2/shape_one_way_margin = 1.0 +2/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 13 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +2/z_index = 0 +3/name = "tile.png 3" +3/texture = ExtResource( 1 ) +3/tex_offset = Vector2( 0, 0 ) +3/modulate = Color( 1, 1, 1, 1 ) +3/region = Rect2( 160, 32, 32, 32 ) +3/tile_mode = 0 +3/occluder_offset = Vector2( 0, 0 ) +3/navigation_offset = Vector2( 0, 0 ) +3/shape_offset = Vector2( 0, 0 ) +3/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +3/shape = SubResource( 24 ) +3/shape_one_way = false +3/shape_one_way_margin = 1.0 +3/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 24 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +3/z_index = 0 +4/name = "tile.png 4" +4/texture = ExtResource( 1 ) +4/tex_offset = Vector2( 0, 0 ) +4/modulate = Color( 1, 1, 1, 1 ) +4/region = Rect2( 192, 32, 32, 32 ) +4/tile_mode = 0 +4/occluder_offset = Vector2( 0, 0 ) +4/navigation_offset = Vector2( 0, 0 ) +4/shape_offset = Vector2( 0, 0 ) +4/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +4/shape = SubResource( 35 ) +4/shape_one_way = false +4/shape_one_way_margin = 1.0 +4/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 35 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +4/z_index = 0 +5/name = "tile.png 5" +5/texture = ExtResource( 1 ) +5/tex_offset = Vector2( 0, 0 ) +5/modulate = Color( 1, 1, 1, 1 ) +5/region = Rect2( 224, 32, 32, 32 ) +5/tile_mode = 0 +5/occluder_offset = Vector2( 0, 0 ) +5/navigation_offset = Vector2( 0, 0 ) +5/shape_offset = Vector2( 0, 0 ) +5/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +5/shape = SubResource( 44 ) +5/shape_one_way = false +5/shape_one_way_margin = 1.0 +5/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 44 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +5/z_index = 0 +6/name = "tile.png 6" +6/texture = ExtResource( 1 ) +6/tex_offset = Vector2( 0, 0 ) +6/modulate = Color( 1, 1, 1, 1 ) +6/region = Rect2( 288, 32, 32, 32 ) +6/tile_mode = 0 +6/occluder_offset = Vector2( 0, 0 ) +6/navigation_offset = Vector2( 0, 0 ) +6/shape_offset = Vector2( 0, 0 ) +6/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +6/shape = SubResource( 45 ) +6/shape_one_way = false +6/shape_one_way_margin = 1.0 +6/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 45 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +6/z_index = 0 +7/name = "tile.png 7" +7/texture = ExtResource( 1 ) +7/tex_offset = Vector2( 0, 0 ) +7/modulate = Color( 1, 1, 1, 1 ) +7/region = Rect2( 320, 32, 32, 32 ) +7/tile_mode = 0 +7/occluder_offset = Vector2( 0, 0 ) +7/navigation_offset = Vector2( 0, 0 ) +7/shape_offset = Vector2( 0, 0 ) +7/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +7/shape = SubResource( 46 ) +7/shape_one_way = false +7/shape_one_way_margin = 1.0 +7/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 46 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +7/z_index = 0 +8/name = "tile.png 8" +8/texture = ExtResource( 1 ) +8/tex_offset = Vector2( 0, 0 ) +8/modulate = Color( 1, 1, 1, 1 ) +8/region = Rect2( 352, 32, 32, 32 ) +8/tile_mode = 0 +8/occluder_offset = Vector2( 0, 0 ) +8/navigation_offset = Vector2( 0, 0 ) +8/shape_offset = Vector2( 0, 0 ) +8/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +8/shape = SubResource( 47 ) +8/shape_one_way = false +8/shape_one_way_margin = 1.0 +8/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 47 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +8/z_index = 0 +9/name = "tile.png 9" +9/texture = ExtResource( 1 ) +9/tex_offset = Vector2( 0, 0 ) +9/modulate = Color( 1, 1, 1, 1 ) +9/region = Rect2( 416, 32, 32, 32 ) +9/tile_mode = 0 +9/occluder_offset = Vector2( 0, 0 ) +9/navigation_offset = Vector2( 0, 0 ) +9/shape_offset = Vector2( 0, 0 ) +9/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +9/shape = SubResource( 48 ) +9/shape_one_way = false +9/shape_one_way_margin = 1.0 +9/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 48 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +9/z_index = 0 +10/name = "tile.png 10" +10/texture = ExtResource( 1 ) +10/tex_offset = Vector2( 0, 0 ) +10/modulate = Color( 1, 1, 1, 1 ) +10/region = Rect2( 448, 32, 32, 32 ) +10/tile_mode = 0 +10/occluder_offset = Vector2( 0, 0 ) +10/navigation_offset = Vector2( 0, 0 ) +10/shape_offset = Vector2( 0, 0 ) +10/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +10/shape = SubResource( 3 ) +10/shape_one_way = false +10/shape_one_way_margin = 1.0 +10/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 3 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +10/z_index = 0 +11/name = "tile.png 11" +11/texture = ExtResource( 1 ) +11/tex_offset = Vector2( 0, 0 ) +11/modulate = Color( 1, 1, 1, 1 ) +11/region = Rect2( 416, 64, 32, 32 ) +11/tile_mode = 0 +11/occluder_offset = Vector2( 0, 0 ) +11/navigation_offset = Vector2( 0, 0 ) +11/shape_offset = Vector2( 0, 0 ) +11/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +11/shape = SubResource( 4 ) +11/shape_one_way = false +11/shape_one_way_margin = 1.0 +11/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 4 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +11/z_index = 0 +12/name = "tile.png 12" +12/texture = ExtResource( 1 ) +12/tex_offset = Vector2( 0, 0 ) +12/modulate = Color( 1, 1, 1, 1 ) +12/region = Rect2( 448, 64, 32, 32 ) +12/tile_mode = 0 +12/occluder_offset = Vector2( 0, 0 ) +12/navigation_offset = Vector2( 0, 0 ) +12/shape_offset = Vector2( 0, 0 ) +12/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +12/shape = SubResource( 5 ) +12/shape_one_way = false +12/shape_one_way_margin = 1.0 +12/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 5 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +12/z_index = 0 +13/name = "tile.png 13" +13/texture = ExtResource( 1 ) +13/tex_offset = Vector2( 0, 0 ) +13/modulate = Color( 1, 1, 1, 1 ) +13/region = Rect2( 224, 96, 32, 32 ) +13/tile_mode = 0 +13/occluder_offset = Vector2( 0, 0 ) +13/navigation_offset = Vector2( 0, 0 ) +13/shape_offset = Vector2( 0, 0 ) +13/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +13/shape = SubResource( 6 ) +13/shape_one_way = false +13/shape_one_way_margin = 1.0 +13/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 6 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +13/z_index = 0 +14/name = "tile.png 14" +14/texture = ExtResource( 1 ) +14/tex_offset = Vector2( 0, 0 ) +14/modulate = Color( 1, 1, 1, 1 ) +14/region = Rect2( 224, 128, 32, 32 ) +14/tile_mode = 0 +14/occluder_offset = Vector2( 0, 0 ) +14/navigation_offset = Vector2( 0, 0 ) +14/shape_offset = Vector2( 0, 0 ) +14/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +14/shape = SubResource( 7 ) +14/shape_one_way = false +14/shape_one_way_margin = 1.0 +14/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 7 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +14/z_index = 0 +15/name = "tile.png 15" +15/texture = ExtResource( 1 ) +15/tex_offset = Vector2( 0, 0 ) +15/modulate = Color( 1, 1, 1, 1 ) +15/region = Rect2( 224, 160, 32, 32 ) +15/tile_mode = 0 +15/occluder_offset = Vector2( 0, 0 ) +15/navigation_offset = Vector2( 0, 0 ) +15/shape_offset = Vector2( 0, 0 ) +15/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +15/shape = SubResource( 8 ) +15/shape_one_way = false +15/shape_one_way_margin = 1.0 +15/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 8 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +15/z_index = 0 +16/name = "tile.png 16" +16/texture = ExtResource( 1 ) +16/tex_offset = Vector2( 0, 0 ) +16/modulate = Color( 1, 1, 1, 1 ) +16/region = Rect2( 224, 224, 32, 32 ) +16/tile_mode = 0 +16/occluder_offset = Vector2( 0, 0 ) +16/navigation_offset = Vector2( 0, 0 ) +16/shape_offset = Vector2( 0, 0 ) +16/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +16/shape = SubResource( 9 ) +16/shape_one_way = false +16/shape_one_way_margin = 1.0 +16/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 9 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +16/z_index = 0 +17/name = "tile.png 17" +17/texture = ExtResource( 1 ) +17/tex_offset = Vector2( 0, 0 ) +17/modulate = Color( 1, 1, 1, 1 ) +17/region = Rect2( 288, 96, 32, 32 ) +17/tile_mode = 0 +17/occluder_offset = Vector2( 0, 0 ) +17/navigation_offset = Vector2( 0, 0 ) +17/shape_offset = Vector2( 0, 0 ) +17/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +17/shape = SubResource( 10 ) +17/shape_one_way = false +17/shape_one_way_margin = 1.0 +17/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 10 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +17/z_index = 0 +18/name = "tile.png 18" +18/texture = ExtResource( 1 ) +18/tex_offset = Vector2( 0, 0 ) +18/modulate = Color( 1, 1, 1, 1 ) +18/region = Rect2( 320, 96, 32, 32 ) +18/tile_mode = 0 +18/occluder_offset = Vector2( 0, 0 ) +18/navigation_offset = Vector2( 0, 0 ) +18/shape_offset = Vector2( 0, 0 ) +18/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +18/shape = SubResource( 11 ) +18/shape_one_way = false +18/shape_one_way_margin = 1.0 +18/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 11 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +18/z_index = 0 +19/name = "tile.png 19" +19/texture = ExtResource( 1 ) +19/tex_offset = Vector2( 0, 0 ) +19/modulate = Color( 1, 1, 1, 1 ) +19/region = Rect2( 352, 96, 32, 32 ) +19/tile_mode = 0 +19/occluder_offset = Vector2( 0, 0 ) +19/navigation_offset = Vector2( 0, 0 ) +19/shape_offset = Vector2( 0, 0 ) +19/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +19/shape = SubResource( 12 ) +19/shape_one_way = false +19/shape_one_way_margin = 1.0 +19/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 12 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +19/z_index = 0 +20/name = "tile.png 20" +20/texture = ExtResource( 1 ) +20/tex_offset = Vector2( 0, 0 ) +20/modulate = Color( 1, 1, 1, 1 ) +20/region = Rect2( 288, 128, 32, 32 ) +20/tile_mode = 0 +20/occluder_offset = Vector2( 0, 0 ) +20/navigation_offset = Vector2( 0, 0 ) +20/shape_offset = Vector2( 0, 0 ) +20/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +20/shape = SubResource( 14 ) +20/shape_one_way = false +20/shape_one_way_margin = 1.0 +20/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 14 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +20/z_index = 0 +21/name = "tile.png 21" +21/texture = ExtResource( 1 ) +21/tex_offset = Vector2( 0, 0 ) +21/modulate = Color( 1, 1, 1, 1 ) +21/region = Rect2( 320, 128, 32, 32 ) +21/tile_mode = 0 +21/occluder_offset = Vector2( 0, 0 ) +21/navigation_offset = Vector2( 0, 0 ) +21/shape_offset = Vector2( 0, 0 ) +21/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +21/shape = SubResource( 15 ) +21/shape_one_way = false +21/shape_one_way_margin = 1.0 +21/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 15 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +21/z_index = 0 +22/name = "tile.png 22" +22/texture = ExtResource( 1 ) +22/tex_offset = Vector2( 0, 0 ) +22/modulate = Color( 1, 1, 1, 1 ) +22/region = Rect2( 352, 128, 32, 32 ) +22/tile_mode = 0 +22/occluder_offset = Vector2( 0, 0 ) +22/navigation_offset = Vector2( 0, 0 ) +22/shape_offset = Vector2( 0, 0 ) +22/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +22/shape = SubResource( 16 ) +22/shape_one_way = false +22/shape_one_way_margin = 1.0 +22/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 16 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +22/z_index = 0 +23/name = "tile.png 23" +23/texture = ExtResource( 1 ) +23/tex_offset = Vector2( 0, 0 ) +23/modulate = Color( 1, 1, 1, 1 ) +23/region = Rect2( 288, 160, 32, 32 ) +23/tile_mode = 0 +23/occluder_offset = Vector2( 0, 0 ) +23/navigation_offset = Vector2( 0, 0 ) +23/shape_offset = Vector2( 0, 0 ) +23/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +23/shape = SubResource( 17 ) +23/shape_one_way = false +23/shape_one_way_margin = 1.0 +23/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 17 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +23/z_index = 0 +24/name = "tile.png 24" +24/texture = ExtResource( 1 ) +24/tex_offset = Vector2( 0, 0 ) +24/modulate = Color( 1, 1, 1, 1 ) +24/region = Rect2( 320, 160, 32, 32 ) +24/tile_mode = 0 +24/occluder_offset = Vector2( 0, 0 ) +24/navigation_offset = Vector2( 0, 0 ) +24/shape_offset = Vector2( 0, 0 ) +24/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +24/shape = SubResource( 18 ) +24/shape_one_way = false +24/shape_one_way_margin = 1.0 +24/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 18 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +24/z_index = 0 +25/name = "tile.png 25" +25/texture = ExtResource( 1 ) +25/tex_offset = Vector2( 0, 0 ) +25/modulate = Color( 1, 1, 1, 1 ) +25/region = Rect2( 352, 160, 32, 32 ) +25/tile_mode = 0 +25/occluder_offset = Vector2( 0, 0 ) +25/navigation_offset = Vector2( 0, 0 ) +25/shape_offset = Vector2( 0, 0 ) +25/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +25/shape = SubResource( 19 ) +25/shape_one_way = false +25/shape_one_way_margin = 1.0 +25/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 19 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +25/z_index = 0 +26/name = "tile.png 26" +26/texture = ExtResource( 1 ) +26/tex_offset = Vector2( 0, 0 ) +26/modulate = Color( 1, 1, 1, 1 ) +26/region = Rect2( 288, 224, 32, 32 ) +26/tile_mode = 0 +26/occluder_offset = Vector2( 0, 0 ) +26/navigation_offset = Vector2( 0, 0 ) +26/shape_offset = Vector2( 0, 0 ) +26/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +26/shape = SubResource( 20 ) +26/shape_one_way = false +26/shape_one_way_margin = 1.0 +26/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 20 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +26/z_index = 0 +27/name = "tile.png 27" +27/texture = ExtResource( 1 ) +27/tex_offset = Vector2( 0, 0 ) +27/modulate = Color( 1, 1, 1, 1 ) +27/region = Rect2( 320, 224, 32, 32 ) +27/tile_mode = 0 +27/occluder_offset = Vector2( 0, 0 ) +27/navigation_offset = Vector2( 0, 0 ) +27/shape_offset = Vector2( 0, 0 ) +27/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +27/shape = SubResource( 21 ) +27/shape_one_way = false +27/shape_one_way_margin = 1.0 +27/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 21 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +27/z_index = 0 +28/name = "tile.png 28" +28/texture = ExtResource( 1 ) +28/tex_offset = Vector2( 0, 0 ) +28/modulate = Color( 1, 1, 1, 1 ) +28/region = Rect2( 352, 224, 32, 32 ) +28/tile_mode = 0 +28/occluder_offset = Vector2( 0, 0 ) +28/navigation_offset = Vector2( 0, 0 ) +28/shape_offset = Vector2( 0, 0 ) +28/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +28/shape = SubResource( 22 ) +28/shape_one_way = false +28/shape_one_way_margin = 1.0 +28/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 22 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +28/z_index = 0 +29/name = "tile.png 29" +29/texture = ExtResource( 1 ) +29/tex_offset = Vector2( 0, 0 ) +29/modulate = Color( 1, 1, 1, 1 ) +29/region = Rect2( 32, 96, 32, 32 ) +29/tile_mode = 0 +29/occluder_offset = Vector2( 0, 0 ) +29/navigation_offset = Vector2( 0, 0 ) +29/shape_offset = Vector2( 0, 0 ) +29/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +29/shape = SubResource( 23 ) +29/shape_one_way = false +29/shape_one_way_margin = 1.0 +29/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 23 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +29/z_index = 0 +30/name = "tile.png 30" +30/texture = ExtResource( 1 ) +30/tex_offset = Vector2( 0, 0 ) +30/modulate = Color( 1, 1, 1, 1 ) +30/region = Rect2( 32, 128, 32, 32 ) +30/tile_mode = 0 +30/occluder_offset = Vector2( 0, 0 ) +30/navigation_offset = Vector2( 0, 0 ) +30/shape_offset = Vector2( 0, 0 ) +30/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +30/shape = SubResource( 25 ) +30/shape_one_way = false +30/shape_one_way_margin = 1.0 +30/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 25 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +30/z_index = 0 +31/name = "tile.png 31" +31/texture = ExtResource( 1 ) +31/tex_offset = Vector2( 0, 0 ) +31/modulate = Color( 1, 1, 1, 1 ) +31/region = Rect2( 32, 160, 32, 32 ) +31/tile_mode = 0 +31/occluder_offset = Vector2( 0, 0 ) +31/navigation_offset = Vector2( 0, 0 ) +31/shape_offset = Vector2( 0, 0 ) +31/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +31/shape = SubResource( 26 ) +31/shape_one_way = false +31/shape_one_way_margin = 1.0 +31/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 26 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +31/z_index = 0 +32/name = "tile.png 32" +32/texture = ExtResource( 1 ) +32/tex_offset = Vector2( 0, 0 ) +32/modulate = Color( 1, 1, 1, 1 ) +32/region = Rect2( 32, 224, 32, 32 ) +32/tile_mode = 0 +32/occluder_offset = Vector2( 0, 0 ) +32/navigation_offset = Vector2( 0, 0 ) +32/shape_offset = Vector2( 0, 0 ) +32/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +32/shape = SubResource( 27 ) +32/shape_one_way = false +32/shape_one_way_margin = 1.0 +32/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 27 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +32/z_index = 0 +33/name = "tile.png 33" +33/texture = ExtResource( 1 ) +33/tex_offset = Vector2( 0, 0 ) +33/modulate = Color( 1, 1, 1, 1 ) +33/region = Rect2( 96, 96, 32, 32 ) +33/tile_mode = 0 +33/occluder_offset = Vector2( 0, 0 ) +33/navigation_offset = Vector2( 0, 0 ) +33/shape_offset = Vector2( 0, 0 ) +33/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +33/shape = SubResource( 28 ) +33/shape_one_way = false +33/shape_one_way_margin = 1.0 +33/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 28 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +33/z_index = 0 +34/name = "tile.png 34" +34/texture = ExtResource( 1 ) +34/tex_offset = Vector2( 0, 0 ) +34/modulate = Color( 1, 1, 1, 1 ) +34/region = Rect2( 96, 128, 32, 32 ) +34/tile_mode = 0 +34/occluder_offset = Vector2( 0, 0 ) +34/navigation_offset = Vector2( 0, 0 ) +34/shape_offset = Vector2( 0, 0 ) +34/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +34/shape = SubResource( 29 ) +34/shape_one_way = false +34/shape_one_way_margin = 1.0 +34/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 29 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +34/z_index = 0 +35/name = "tile.png 35" +35/texture = ExtResource( 1 ) +35/tex_offset = Vector2( 0, 0 ) +35/modulate = Color( 1, 1, 1, 1 ) +35/region = Rect2( 96, 160, 32, 32 ) +35/tile_mode = 0 +35/occluder_offset = Vector2( 0, 0 ) +35/navigation_offset = Vector2( 0, 0 ) +35/shape_offset = Vector2( 0, 0 ) +35/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +35/shape = SubResource( 30 ) +35/shape_one_way = false +35/shape_one_way_margin = 1.0 +35/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 30 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +35/z_index = 0 +36/name = "tile.png 36" +36/texture = ExtResource( 1 ) +36/tex_offset = Vector2( 0, 0 ) +36/modulate = Color( 1, 1, 1, 1 ) +36/region = Rect2( 128, 96, 32, 32 ) +36/tile_mode = 0 +36/occluder_offset = Vector2( 0, 0 ) +36/navigation_offset = Vector2( 0, 0 ) +36/shape_offset = Vector2( 0, 0 ) +36/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +36/shape = SubResource( 31 ) +36/shape_one_way = false +36/shape_one_way_margin = 1.0 +36/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 31 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +36/z_index = 0 +37/name = "tile.png 37" +37/texture = ExtResource( 1 ) +37/tex_offset = Vector2( 0, 0 ) +37/modulate = Color( 1, 1, 1, 1 ) +37/region = Rect2( 128, 128, 32, 32 ) +37/tile_mode = 0 +37/occluder_offset = Vector2( 0, 0 ) +37/navigation_offset = Vector2( 0, 0 ) +37/shape_offset = Vector2( 0, 0 ) +37/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +37/shape = SubResource( 32 ) +37/shape_one_way = false +37/shape_one_way_margin = 1.0 +37/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 32 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +37/z_index = 0 +38/name = "tile.png 38" +38/texture = ExtResource( 1 ) +38/tex_offset = Vector2( 0, 0 ) +38/modulate = Color( 1, 1, 1, 1 ) +38/region = Rect2( 128, 160, 32, 32 ) +38/tile_mode = 0 +38/occluder_offset = Vector2( 0, 0 ) +38/navigation_offset = Vector2( 0, 0 ) +38/shape_offset = Vector2( 0, 0 ) +38/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +38/shape = SubResource( 33 ) +38/shape_one_way = false +38/shape_one_way_margin = 1.0 +38/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 33 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +38/z_index = 0 +39/name = "tile.png 39" +39/texture = ExtResource( 1 ) +39/tex_offset = Vector2( 0, 0 ) +39/modulate = Color( 1, 1, 1, 1 ) +39/region = Rect2( 160, 96, 32, 32 ) +39/tile_mode = 0 +39/occluder_offset = Vector2( 0, 0 ) +39/navigation_offset = Vector2( 0, 0 ) +39/shape_offset = Vector2( 0, 0 ) +39/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +39/shape = SubResource( 34 ) +39/shape_one_way = false +39/shape_one_way_margin = 1.0 +39/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 34 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +39/z_index = 0 +40/name = "tile.png 40" +40/texture = ExtResource( 1 ) +40/tex_offset = Vector2( 0, 0 ) +40/modulate = Color( 1, 1, 1, 1 ) +40/region = Rect2( 160, 128, 32, 32 ) +40/tile_mode = 0 +40/occluder_offset = Vector2( 0, 0 ) +40/navigation_offset = Vector2( 0, 0 ) +40/shape_offset = Vector2( 0, 0 ) +40/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +40/shape = SubResource( 36 ) +40/shape_one_way = false +40/shape_one_way_margin = 1.0 +40/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 36 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +40/z_index = 0 +41/name = "tile.png 41" +41/texture = ExtResource( 1 ) +41/tex_offset = Vector2( 0, 0 ) +41/modulate = Color( 1, 1, 1, 1 ) +41/region = Rect2( 160, 160, 32, 32 ) +41/tile_mode = 0 +41/occluder_offset = Vector2( 0, 0 ) +41/navigation_offset = Vector2( 0, 0 ) +41/shape_offset = Vector2( 0, 0 ) +41/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +41/shape = SubResource( 37 ) +41/shape_one_way = false +41/shape_one_way_margin = 1.0 +41/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 37 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +41/z_index = 0 +42/name = "tile.png 42" +42/texture = ExtResource( 1 ) +42/tex_offset = Vector2( 0, 0 ) +42/modulate = Color( 1, 1, 1, 1 ) +42/region = Rect2( 96, 224, 32, 32 ) +42/tile_mode = 0 +42/occluder_offset = Vector2( 0, 0 ) +42/navigation_offset = Vector2( 0, 0 ) +42/shape_offset = Vector2( 0, 0 ) +42/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +42/shape = SubResource( 38 ) +42/shape_one_way = false +42/shape_one_way_margin = 1.0 +42/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 38 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +42/z_index = 0 +43/name = "tile.png 43" +43/texture = ExtResource( 1 ) +43/tex_offset = Vector2( 0, 0 ) +43/modulate = Color( 1, 1, 1, 1 ) +43/region = Rect2( 128, 224, 32, 32 ) +43/tile_mode = 0 +43/occluder_offset = Vector2( 0, 0 ) +43/navigation_offset = Vector2( 0, 0 ) +43/shape_offset = Vector2( 0, 0 ) +43/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +43/shape = SubResource( 39 ) +43/shape_one_way = false +43/shape_one_way_margin = 1.0 +43/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 39 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +43/z_index = 0 +44/name = "tile.png 44" +44/texture = ExtResource( 1 ) +44/tex_offset = Vector2( 0, 0 ) +44/modulate = Color( 1, 1, 1, 1 ) +44/region = Rect2( 160, 224, 32, 32 ) +44/tile_mode = 0 +44/occluder_offset = Vector2( 0, 0 ) +44/navigation_offset = Vector2( 0, 0 ) +44/shape_offset = Vector2( 0, 0 ) +44/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +44/shape = SubResource( 40 ) +44/shape_one_way = false +44/shape_one_way_margin = 1.0 +44/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 40 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +44/z_index = 0 +45/name = "tile.png 45" +45/texture = ExtResource( 1 ) +45/tex_offset = Vector2( 0, 0 ) +45/modulate = Color( 1, 1, 1, 1 ) +45/region = Rect2( 512, 32, 32, 32 ) +45/tile_mode = 0 +45/occluder_offset = Vector2( 0, 0 ) +45/navigation_offset = Vector2( 0, 0 ) +45/shape_offset = Vector2( 0, 0 ) +45/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +45/shape = SubResource( 41 ) +45/shape_one_way = false +45/shape_one_way_margin = 1.0 +45/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 41 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +45/z_index = 0 +46/name = "tile.png 46" +46/texture = ExtResource( 1 ) +46/tex_offset = Vector2( 0, 0 ) +46/modulate = Color( 1, 1, 1, 1 ) +46/region = Rect2( 544, 32, 32, 32 ) +46/tile_mode = 0 +46/occluder_offset = Vector2( 0, 0 ) +46/navigation_offset = Vector2( 0, 0 ) +46/shape_offset = Vector2( 0, 0 ) +46/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +46/shape = SubResource( 42 ) +46/shape_one_way = false +46/shape_one_way_margin = 1.0 +46/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 42 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +46/z_index = 0 +47/name = "tile.png 47" +47/texture = ExtResource( 1 ) +47/tex_offset = Vector2( 0, 0 ) +47/modulate = Color( 1, 1, 1, 1 ) +47/region = Rect2( 576, 32, 32, 32 ) +47/tile_mode = 0 +47/occluder_offset = Vector2( 0, 0 ) +47/navigation_offset = Vector2( 0, 0 ) +47/shape_offset = Vector2( 0, 0 ) +47/shape_transform = Transform2D( 1, 0, 0, 1, 0, 0 ) +47/shape = SubResource( 43 ) +47/shape_one_way = false +47/shape_one_way_margin = 1.0 +47/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 43 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 0, 0 ) +} ] +47/z_index = 0 + +[sub_resource type="RectangleShape2D" id=50] +extents = Vector2( 16, 2 ) + +[sub_resource type="RectangleShape2D" id=51] +extents = Vector2( 29, 6 ) + +[node name="Level1" type="Node2D"] +script = ExtResource( 5 ) + +[node name="TileMap" type="TileMap" parent="."] +position = Vector2( 49, 550 ) +tile_set = SubResource( 49 ) +cell_size = Vector2( 32, 32 ) +cell_quadrant_size = 32 +cell_custom_transform = Transform2D( 32, 0, 0, 32, 0, 0 ) +collision_bounce = 0.3 +collision_layer = 28 +format = 1 +tile_data = PoolIntArray( -1179482, 29, 0, -1113946, 30, 0, -1048410, 30, 0, -917511, 17, 0, -917510, 18, 0, -917509, 18, 0, -917508, 18, 0, -917507, 18, 0, -917506, 18, 0, -917505, 19, 0, -982931, 6, 0, -982930, 8, 0, -982874, 30, 0, -851975, 20, 0, -851974, 21, 0, -851973, 21, 0, -851972, 21, 0, -851971, 21, 0, -851970, 21, 0, -851969, 22, 0, -917338, 30, 0, -786439, 20, 0, -786438, 21, 0, -786437, 21, 0, -786436, 21, 0, -786435, 21, 0, -786434, 21, 0, -786433, 22, 0, -851843, 6, 0, -851842, 8, 0, -851802, 30, 0, -720903, 20, 0, -720902, 21, 0, -720901, 21, 0, -720900, 21, 0, -720899, 21, 0, -720898, 21, 0, -720897, 22, 0, -786273, 29, 0, -786266, 30, 0, -786235, 6, 0, -786234, 7, 0, -786233, 7, 0, -786232, 7, 0, -786231, 7, 0, -786230, 7, 0, -786229, 7, 0, -786228, 7, 0, -786227, 8, 0, -655367, 20, 0, -655366, 21, 0, -655365, 21, 0, -655364, 21, 0, -655363, 21, 0, -655362, 21, 0, -655361, 22, 0, -720737, 30, 0, -720730, 30, 0, -589831, 20, 0, -589830, 21, 0, -589829, 21, 0, -589828, 21, 0, -589827, 21, 0, -589826, 21, 0, -589825, 22, 0, -655251, 17, 0, -655250, 19, 0, -655201, 30, 0, -655194, 30, 0, -524295, 20, 0, -524294, 21, 0, -524293, 21, 0, -524292, 21, 0, -524291, 21, 0, -524290, 21, 0, -524289, 22, 0, -589726, 6, 0, -589725, 4, 0, -589724, 7, 0, -589723, 4, 0, -589722, 8, 0, -589715, 20, 0, -589714, 22, 0, -589700, 3, 0, -589699, 4, 0, -589698, 4, 0, -589697, 5, 0, -589665, 30, 0, -589658, 30, 0, -458759, 20, 0, -458758, 21, 0, -458757, 21, 0, -458756, 21, 0, -458755, 21, 0, -458754, 21, 0, -458753, 22, 0, -524191, 7, 0, -524185, 7, 0, -524179, 20, 0, -524178, 22, 0, -524149, 6, 0, -524148, 7, 0, -524147, 7, 0, -524146, 7, 0, -524145, 8, 0, -524132, 3, 0, -524131, 5, 0, -524129, 30, 0, -524128, 26, 0, -524127, 27, 0, -524126, 27, 0, -524125, 28, 0, -524122, 30, 0, -524104, 9, 0, -524103, 10, 0, -524091, 6, 0, -524090, 7, 0, -524089, 7, 0, -524088, 7, 0, -524087, 7, 0, -524086, 7, 0, -524085, 7, 0, -524084, 7, 0, -524083, 8, 0, -393223, 20, 0, -393222, 21, 0, -393221, 21, 0, -393220, 21, 0, -393219, 21, 0, -393218, 21, 0, -393217, 22, 0, -458705, 3, 0, -458704, 7, 0, -458703, 8, 0, -458655, 4, 0, -458649, 4, 0, -458643, 20, 0, -458642, 22, 0, -458593, 30, 0, -458586, 30, 0, -458568, 11, 0, -458567, 12, 0, -458547, 3, 0, -458546, 5, 0, -327687, 20, 0, -327686, 21, 0, -327685, 21, 0, -327684, 21, 0, -327683, 21, 0, -327682, 21, 0, -327681, 22, 0, -393151, 0, 0, -393150, 1, 0, -393149, 1, 0, -393148, 2, 0, -393129, 6, 0, -393128, 8, 0, -393119, 4, 0, -393113, 4, 0, -393107, 20, 0, -393106, 22, 0, -393085, 33, 0, -393084, 39, 0, -393057, 30, 0, -393050, 30, 0, -393032, 1, 0, -393031, 1, 0, -262151, 20, 0, -262150, 21, 0, -262149, 21, 0, -262148, 21, 0, -262147, 21, 0, -262146, 21, 0, -262145, 22, 0, -327628, 32, 0, -327583, 3, 0, -327582, 4, 0, -327581, 4, 0, -327580, 4, 0, -327579, 7, 0, -327578, 7, 0, -327577, 5, 0, -327571, 20, 0, -327570, 22, 0, -327549, 35, 0, -327548, 41, 0, -327521, 30, 0, -327520, 26, 0, -327519, 27, 0, -327518, 28, 0, -327514, 31, 0, -327506, 26, 0, -327505, 27, 0, -327504, 27, 0, -327503, 27, 0, -327502, 27, 0, -327501, 27, 0, -327500, 28, 0, -327496, 1, 0, -327495, 1, 0, -327490, 1, 0, -196615, 20, 0, -196614, 21, 0, -196613, 21, 0, -196612, 21, 0, -196611, 21, 0, -196610, 21, 0, -196609, 22, 0, -262121, 3, 0, -262120, 1, 0, -262119, 7, 0, -262118, 4, 0, -262117, 4, 0, -262116, 5, 0, -262091, 32, 0, -262050, 16, 0, -262038, 16, 0, -262035, 23, 0, -262034, 25, 0, -262022, 42, 0, -262021, 43, 0, -262020, 43, 0, -262019, 43, 0, -262018, 43, 0, -262017, 43, 0, -262016, 43, 0, -262015, 44, 0, -262006, 32, 0, -262004, 32, 0, -262002, 32, 0, -262000, 32, 0, -261988, 9, 0, -261987, 10, 0, -261985, 30, 0, -261978, 7, 0, -261960, 1, 0, -261959, 1, 0, -131079, 20, 0, -131078, 21, 0, -131077, 21, 0, -131076, 21, 0, -131075, 21, 0, -131074, 21, 0, -131073, 22, 0, -196564, 16, 0, -196562, 26, 0, -196561, 27, 0, -196560, 27, 0, -196559, 27, 0, -196558, 28, 0, -196554, 32, 0, -196514, 1, 0, -196502, 1, 0, -196488, 32, 0, -196452, 11, 0, -196451, 12, 0, -196449, 30, 0, -196436, 32, 0, -196424, 1, 0, -196423, 1, 0, -196412, 17, 0, -196411, 18, 0, -196410, 18, 0, -196409, 18, 0, -196408, 18, 0, -196407, 18, 0, -196406, 18, 0, -196405, 18, 0, -196404, 18, 0, -196403, 18, 0, -196402, 18, 0, -196401, 19, 0, -196394, 9, 0, -196393, 10, 0, -65543, 20, 0, -65542, 21, 0, -65541, 21, 0, -65540, 21, 0, -65539, 21, 0, -65538, 21, 0, -65537, 22, 0, -131041, 9, 0, -131040, 10, 0, -131030, 16, 0, -131017, 32, 0, -131009, 26, 0, -131008, 27, 0, -131007, 27, 0, -131006, 27, 0, -131005, 27, 0, -131004, 28, 0, -130995, 29, 0, -130986, 0, 0, -130985, 1, 0, -130984, 27, 0, -130983, 27, 0, -130982, 28, 0, -130978, 1, 0, -130966, 1, 0, -130954, 32, 0, -130921, 42, 0, -130920, 43, 0, -130919, 43, 0, -130918, 43, 0, -130917, 43, 0, -130916, 43, 0, -130915, 43, 0, -130914, 44, 0, -130913, 30, 0, -130910, 26, 0, -130909, 28, 0, -130902, 16, 0, -130888, 1, 0, -130887, 1, 0, -130876, 20, 0, -130875, 21, 0, -130874, 21, 0, -130873, 21, 0, -130872, 21, 0, -130871, 21, 0, -130870, 21, 0, -130869, 21, 0, -130868, 21, 0, -130867, 21, 0, -130866, 21, 0, -130865, 22, 0, -130858, 11, 0, -130857, 12, 0, -7, 20, 0, -6, 21, 0, -5, 21, 0, -4, 21, 0, -3, 21, 0, -2, 21, 0, -1, 22, 0, -65505, 11, 0, -65504, 12, 0, -65464, 13, 0, -65459, 30, 0, -65457, 32, 0, -65441, 17, 0, -65440, 18, 0, -65439, 18, 0, -65438, 18, 0, -65437, 18, 0, -65436, 18, 0, -65435, 18, 0, -65434, 18, 0, -65433, 18, 0, -65432, 18, 0, -65431, 19, 0, -65427, 9, 0, -65426, 10, 0, -65425, 0, 0, -65424, 1, 0, -65423, 1, 0, -65422, 1, 0, -65421, 1, 0, -65420, 2, 0, -65377, 30, 0, -65370, 26, 0, -65369, 27, 0, -65368, 28, 0, -65352, 1, 0, -65351, 1, 0, -65340, 20, 0, -65339, 21, 0, -65338, 21, 0, -65337, 21, 0, -65336, 21, 0, -65335, 21, 0, -65334, 21, 0, -65333, 21, 0, -65332, 21, 0, -65331, 21, 0, -65330, 21, 0, -65329, 22, 0, -65322, 1, 0, -65321, 1, 0, 65529, 21, 0, 65530, 21, 0, 65531, 21, 0, 65532, 21, 0, 65533, 21, 0, 65534, 21, 0, 65535, 21, 0, 0, 18, 0, 1, 18, 0, 2, 18, 0, 3, 18, 0, 4, 18, 0, 5, 18, 0, 6, 18, 0, 7, 18, 0, 8, 18, 0, 9, 18, 0, 10, 18, 0, 11, 18, 0, 12, 19, 0, 17, 17, 0, 18, 18, 0, 19, 18, 0, 20, 18, 0, 21, 18, 0, 22, 18, 0, 23, 18, 0, 24, 18, 0, 25, 18, 0, 26, 18, 0, 27, 18, 0, 28, 18, 0, 29, 18, 0, 30, 18, 0, 31, 18, 0, 32, 18, 0, 33, 18, 0, 34, 19, 0, 36, 13, 0, 38, 13, 0, 40, 13, 0, 58, 33, 0, 59, 36, 0, 60, 36, 0, 61, 39, 0, 72, 14, 0, 77, 30, 0, 95, 20, 0, 96, 21, 0, 97, 21, 0, 98, 21, 0, 99, 21, 0, 100, 21, 0, 101, 21, 0, 102, 21, 0, 103, 21, 0, 104, 21, 0, 105, 22, 0, 109, 11, 0, 110, 12, 0, 111, 6, 0, 112, 7, 0, 113, 7, 0, 114, 7, 0, 115, 8, 0, 159, 30, 0, 184, 1, 0, 185, 1, 0, 196, 20, 0, 197, 21, 0, 198, 21, 0, 199, 21, 0, 200, 21, 0, 201, 21, 0, 202, 21, 0, 203, 21, 0, 204, 21, 0, 205, 21, 0, 206, 21, 0, 207, 22, 0, 214, 1, 0, 215, 1, 0, 131065, 21, 0, 131066, 21, 0, 131067, 21, 0, 131068, 21, 0, 131069, 21, 0, 131070, 21, 0, 131071, 21, 0, 65536, 21, 0, 65537, 21, 0, 65538, 21, 0, 65539, 21, 0, 65540, 21, 0, 65541, 21, 0, 65542, 21, 0, 65543, 21, 0, 65544, 21, 0, 65545, 21, 0, 65546, 21, 0, 65547, 21, 0, 65548, 22, 0, 65553, 20, 0, 65554, 21, 0, 65555, 21, 0, 65556, 21, 0, 65557, 21, 0, 65558, 21, 0, 65559, 21, 0, 65560, 21, 0, 65561, 21, 0, 65562, 21, 0, 65563, 21, 0, 65564, 21, 0, 65565, 21, 0, 65566, 21, 0, 65567, 21, 0, 65568, 21, 0, 65569, 21, 0, 65570, 22, 0, 65572, 14, 0, 65574, 14, 0, 65576, 14, 0, 65594, 34, 0, 65595, 37, 0, 65596, 37, 0, 65597, 40, 0, 65608, 14, 0, 65613, 30, 0, 65631, 20, 0, 65632, 21, 0, 65633, 21, 0, 65634, 21, 0, 65635, 21, 0, 65636, 21, 0, 65637, 21, 0, 65638, 21, 0, 65639, 21, 0, 65640, 21, 0, 65641, 22, 0, 65645, 1, 0, 65655, 0, 0, 65656, 2, 0, 65695, 30, 0, 65720, 1, 0, 65721, 1, 0, 65732, 20, 0, 65733, 21, 0, 65734, 21, 0, 65735, 21, 0, 65736, 21, 0, 65737, 21, 0, 65738, 21, 0, 65739, 21, 0, 65740, 21, 0, 65741, 21, 0, 65742, 21, 0, 65743, 22, 0, 65750, 1, 0, 65751, 1, 0, 196601, 21, 0, 196602, 21, 0, 196603, 21, 0, 196604, 21, 0, 196605, 21, 0, 196606, 21, 0, 196607, 21, 0, 131072, 21, 0, 131073, 21, 0, 131074, 21, 0, 131075, 21, 0, 131076, 21, 0, 131077, 21, 0, 131078, 21, 0, 131079, 21, 0, 131080, 21, 0, 131081, 21, 0, 131082, 21, 0, 131083, 21, 0, 131084, 22, 0, 131089, 20, 0, 131090, 21, 0, 131091, 21, 0, 131092, 21, 0, 131093, 21, 0, 131094, 21, 0, 131095, 21, 0, 131096, 21, 0, 131097, 21, 0, 131098, 21, 0, 131099, 21, 0, 131100, 21, 0, 131101, 21, 0, 131102, 21, 0, 131103, 21, 0, 131104, 21, 0, 131105, 21, 0, 131106, 22, 0, 131108, 14, 0, 131110, 14, 0, 131112, 14, 0, 131130, 34, 0, 131131, 37, 0, 131132, 37, 0, 131133, 40, 0, 131144, 14, 0, 131149, 30, 0, 131167, 20, 0, 131168, 21, 0, 131169, 21, 0, 131170, 21, 0, 131171, 21, 0, 131172, 21, 0, 131173, 21, 0, 131174, 21, 0, 131175, 21, 0, 131176, 21, 0, 131177, 22, 0, 131181, 1, 0, 131231, 30, 0, 131256, 1, 0, 131257, 1, 0, 131268, 20, 0, 131269, 21, 0, 131270, 21, 0, 131271, 21, 0, 131272, 21, 0, 131273, 21, 0, 131274, 21, 0, 131275, 21, 0, 131276, 21, 0, 131277, 21, 0, 131278, 21, 0, 131279, 22, 0, 131286, 1, 0, 131287, 1, 0, 262137, 21, 0, 262138, 21, 0, 262139, 21, 0, 262140, 21, 0, 262141, 21, 0, 262142, 21, 0, 262143, 21, 0, 196608, 21, 0, 196609, 21, 0, 196610, 21, 0, 196611, 21, 0, 196612, 21, 0, 196613, 21, 0, 196614, 21, 0, 196615, 21, 0, 196616, 21, 0, 196617, 21, 0, 196618, 21, 0, 196619, 21, 0, 196620, 22, 0, 196625, 20, 0, 196626, 21, 0, 196627, 21, 0, 196628, 21, 0, 196629, 21, 0, 196630, 21, 0, 196631, 21, 0, 196632, 21, 0, 196633, 21, 0, 196634, 21, 0, 196635, 21, 0, 196636, 21, 0, 196637, 21, 0, 196638, 21, 0, 196639, 21, 0, 196640, 21, 0, 196641, 21, 0, 196642, 22, 0, 196644, 15, 0, 196646, 15, 0, 196648, 15, 0, 196666, 34, 0, 196667, 37, 0, 196668, 37, 0, 196669, 40, 0, 196680, 14, 0, 196685, 30, 0, 196703, 20, 0, 196704, 21, 0, 196705, 21, 0, 196706, 21, 0, 196707, 21, 0, 196708, 21, 0, 196709, 21, 0, 196710, 21, 0, 196711, 21, 0, 196712, 21, 0, 196713, 22, 0, 196717, 17, 0, 196718, 18, 0, 196719, 18, 0, 196720, 18, 0, 196721, 18, 0, 196722, 18, 0, 196723, 18, 0, 196724, 19, 0, 196767, 30, 0, 196792, 1, 0, 196793, 1, 0, 196804, 20, 0, 196805, 21, 0, 196806, 21, 0, 196807, 21, 0, 196808, 21, 0, 196809, 21, 0, 196810, 21, 0, 196811, 21, 0, 196812, 21, 0, 196813, 21, 0, 196814, 21, 0, 196815, 22, 0, 196822, 1, 0, 196823, 1, 0 ) + +[node name="MagicBoxs" type="Node2D" parent="TileMap"] + +[node name="MagicBox" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox"] +position = Vector2( 816, -97 ) +shape = SubResource( 50 ) + +[node name="MagicBox2" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox2"] +position = Vector2( 1584, -193 ) +shape = SubResource( 50 ) + +[node name="MagicBox3" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox3"] +position = Vector2( 1552, -193 ) +shape = SubResource( 50 ) + +[node name="MagicBox4" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox4"] +position = Vector2( 2800, -161 ) +shape = SubResource( 50 ) + +[node name="MagicBox5" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox5"] +position = Vector2( 2832, -161 ) +shape = SubResource( 50 ) + +[node name="MagicBox6" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox6"] +position = Vector2( 3568, 31 ) +shape = SubResource( 50 ) + +[node name="MagicBox19" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox19"] +position = Vector2( 3696, 31 ) +shape = SubResource( 50 ) + +[node name="MagicBox20" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox20"] +position = Vector2( 4016, -385 ) +shape = SubResource( 50 ) + +[node name="MagicBox21" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox21"] +position = Vector2( 4048, -385 ) +shape = SubResource( 50 ) + +[node name="MagicBox22" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox22"] +position = Vector2( 4464, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox23" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox23"] +position = Vector2( 4592, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox27" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox27"] +position = Vector2( 5328, -97 ) +shape = SubResource( 50 ) + +[node name="MagicBox28" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox28"] +position = Vector2( 6320, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox29" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox29"] +position = Vector2( 6576, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox30" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox30"] +position = Vector2( 6544, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox31" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox31"] +position = Vector2( 6512, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox32" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox32"] +position = Vector2( 6480, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox33" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox33"] +position = Vector2( 6448, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox34" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox34"] +position = Vector2( 6416, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox35" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox35"] +position = Vector2( 6384, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox36" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox36"] +position = Vector2( 6352, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox37" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox37"] +position = Vector2( 6320, -353 ) +shape = SubResource( 50 ) + +[node name="MagicBox38" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox38"] +position = Vector2( 6576, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox39" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox39"] +position = Vector2( 6544, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox40" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox40"] +position = Vector2( 6512, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox41" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox41"] +position = Vector2( 6480, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox42" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox42"] +position = Vector2( 6448, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox43" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox43"] +position = Vector2( 6416, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox44" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox44"] +position = Vector2( 6384, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox45" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox45"] +position = Vector2( 6352, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox24" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox24"] +position = Vector2( 4560, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox25" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox25"] +position = Vector2( 4528, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox26" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox26"] +position = Vector2( 4496, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox16" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox16"] +position = Vector2( 3664, 31 ) +shape = SubResource( 50 ) + +[node name="MagicBox17" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox17"] +position = Vector2( 3632, 31 ) +shape = SubResource( 50 ) + +[node name="MagicBox18" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox18"] +position = Vector2( 3600, 31 ) +shape = SubResource( 50 ) + +[node name="MagicBox7" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox7"] +position = Vector2( 3152, -257 ) +shape = SubResource( 50 ) + +[node name="MagicBox8" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox8"] +position = Vector2( 3536, -449 ) +shape = SubResource( 50 ) + +[node name="MagicBox9" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox9"] +position = Vector2( 3120, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox10" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox10"] +position = Vector2( 3504, -449 ) +shape = SubResource( 50 ) + +[node name="MagicBox11" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox11"] +position = Vector2( 3312, -225 ) +shape = SubResource( 50 ) + +[node name="MagicBox12" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox12"] +position = Vector2( 3280, -129 ) +shape = SubResource( 50 ) + +[node name="MagicBox13" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox13"] +position = Vector2( 3248, -129 ) +shape = SubResource( 50 ) + +[node name="MagicBox14" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 47 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox14"] +position = Vector2( 3280, -257 ) +shape = SubResource( 50 ) + +[node name="MagicBox15" type="Area2D" parent="TileMap/MagicBoxs"] +collision_layer = 8 +script = ExtResource( 3 ) +type = 46 + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/MagicBoxs/MagicBox15"] +position = Vector2( 3216, -257 ) +shape = SubResource( 50 ) + +[node name="Bricks" type="Node2D" parent="TileMap"] + +[node name="Brick" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick"] +position = Vector2( 752, -97 ) +shape = SubResource( 50 ) + +[node name="Brick2" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick2"] +position = Vector2( 848, -97 ) +shape = SubResource( 50 ) + +[node name="Brick3" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick3"] +position = Vector2( 880, -97 ) +shape = SubResource( 50 ) + +[node name="Brick4" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick4"] +position = Vector2( 912, -97 ) +shape = SubResource( 50 ) + +[node name="Brick5" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick5"] +position = Vector2( 1520, -193 ) +shape = SubResource( 50 ) + +[node name="Brick6" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick6"] +position = Vector2( 3120, -129 ) +shape = SubResource( 50 ) + +[node name="Brick7" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick7"] +position = Vector2( 3184, -257 ) +shape = SubResource( 50 ) + +[node name="Brick8" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick8"] +position = Vector2( 3248, -257 ) +shape = SubResource( 50 ) + +[node name="Brick9" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick9"] +position = Vector2( 3312, -161 ) +shape = SubResource( 50 ) + +[node name="Brick10" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick10"] +position = Vector2( 3312, -193 ) +shape = SubResource( 50 ) + +[node name="Brick11" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick11"] +position = Vector2( 3120, -193 ) +shape = SubResource( 50 ) + +[node name="Brick12" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick12"] +position = Vector2( 3120, -161 ) +shape = SubResource( 50 ) + +[node name="Brick13" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick13"] +position = Vector2( 3312, -129 ) +shape = SubResource( 50 ) + +[node name="Brick14" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick14"] +position = Vector2( 3216, -129 ) +shape = SubResource( 50 ) + +[node name="Brick15" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick15"] +position = Vector2( 3184, -129 ) +shape = SubResource( 50 ) + +[node name="Brick16" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick16"] +position = Vector2( 3152, -129 ) +shape = SubResource( 50 ) + +[node name="Brick17" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick17"] +position = Vector2( 3984, -257 ) +shape = SubResource( 50 ) + +[node name="Brick18" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick18"] +position = Vector2( 4080, -257 ) +shape = SubResource( 50 ) + +[node name="Brick21" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick21"] +position = Vector2( 5008, -225 ) +shape = SubResource( 50 ) + +[node name="Brick22" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick22"] +position = Vector2( 5040, -225 ) +shape = SubResource( 50 ) + +[node name="Brick23" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick23"] +position = Vector2( 6576, -193 ) +shape = SubResource( 50 ) + +[node name="Brick24" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick24"] +position = Vector2( 6608, -193 ) +shape = SubResource( 50 ) + +[node name="Brick19" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick19"] +position = Vector2( 4048, -257 ) +shape = SubResource( 50 ) + +[node name="Brick20" type="Area2D" parent="TileMap/Bricks"] +collision_layer = 4 +script = ExtResource( 6 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="TileMap/Bricks/Brick20"] +position = Vector2( 4016, -257 ) +shape = SubResource( 50 ) + +[node name="Label" type="Label" parent="."] +margin_left = 6888.0 +margin_top = 385.0 +margin_right = 6980.0 +margin_bottom = 423.0 +theme = ExtResource( 2 ) +text = "FINISH" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Area2D" type="Area2D" parent="."] +collision_layer = 16 + +[node name="Finish" type="CollisionShape2D" parent="Area2D"] +position = Vector2( 6929, 448 ) +shape = SubResource( 51 ) + +[node name="Enemies" type="Node2D" parent="."] + +[node name="Enemy" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 950, 519 ) +turn_back_on_fall = true + +[node name="Enemy11" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 6671, 437 ) +turn_back_on_fall = true + +[node name="Enemy14" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 6373, 440 ) +turn_back_on_fall = true + +[node name="Enemy12" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 6585, 280 ) +turn_back_on_fall = true + +[node name="Enemy13" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 6592, 152 ) +turn_back_on_fall = true + +[node name="Enemy9" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 5400, 510 ) +turn_back_on_fall = true + +[node name="Enemy10" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 4669, 400 ) +turn_back_on_fall = true + +[node name="Enemy8" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 3573, 223 ) +speed = Vector2( 100, 500 ) +turn_back_on_fall = true + +[node name="Enemy7" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 3399, 484 ) +turn_back_on_fall = true + +[node name="Enemy2" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 3320, 378 ) +speed = Vector2( 200, 500 ) + +[node name="Enemy3" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 2842, 464 ) +turn_back_on_fall = true + +[node name="Enemy4" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 2910, 466 ) +turn_back_on_fall = true + +[node name="Enemy5" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 2192, 341 ) +turn_back_on_fall = true + +[node name="Enemy6" parent="Enemies" instance=ExtResource( 4 )] +position = Vector2( 1971, 529 ) +turn_back_on_fall = true + +[connection signal="body_entered" from="Area2D" to="." method="_on_Area2D_body_entered"] diff --git a/src/objects/Brick.gd b/src/objects/Brick.gd new file mode 100644 index 0000000..99f8da0 --- /dev/null +++ b/src/objects/Brick.gd @@ -0,0 +1,18 @@ +extends Area2D +class_name Brick + +onready var grid: TileMap = get_parent().get_parent() +onready var collision = $CollisionShape2D + +var brokenbrick = preload('res://src/objects/BrokenBrick.tscn') + +func _physics_process(_delta: float) -> void: + for bd in get_overlapping_bodies(): + if bd is Player: + grid.set_cellv(grid.world_to_map(get_child(0).get_position()), -1) + collision.set_disabled(true) + + var broken = brokenbrick.instance() + broken.global_position = get_child(0).global_position + broken.set_as_toplevel(true) + add_child(broken) diff --git a/src/objects/BrokenBrick.gd b/src/objects/BrokenBrick.gd new file mode 100644 index 0000000..cdfea3f --- /dev/null +++ b/src/objects/BrokenBrick.gd @@ -0,0 +1,11 @@ +extends Node2D + +onready var animation = $AnimationPlayer +onready var audio = $AudioStreamPlayer2D + +func _ready() -> void: + animation.play('fall') + audio.play() + +func _on_Timer_timeout() -> void: + queue_free() diff --git a/src/objects/BrokenBrick.tscn b/src/objects/BrokenBrick.tscn new file mode 100644 index 0000000..79affca --- /dev/null +++ b/src/objects/BrokenBrick.tscn @@ -0,0 +1,145 @@ +[gd_scene load_steps=8 format=2] + +[ext_resource path="res://samagri/broke_brick/p4.png" type="Texture" id=1] +[ext_resource path="res://samagri/broke_brick/p2.png" type="Texture" id=2] +[ext_resource path="res://samagri/broke_brick/p1.png" type="Texture" id=3] +[ext_resource path="res://samagri/broke_brick/p3.png" type="Texture" id=4] +[ext_resource path="res://src/objects/BrokenBrick.gd" type="Script" id=5] +[ext_resource path="res://samagri/sfx/explode.wav" type="AudioStream" id=6] + +[sub_resource type="Animation" id=1] +resource_name = "fall" +length = 1.5 +tracks/0/type = "value" +tracks/0/path = NodePath("p1:position") +tracks/0/interp = 1 +tracks/0/loop_wrap = true +tracks/0/imported = false +tracks/0/enabled = true +tracks/0/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( -8, -8 ), Vector2( -26, -37 ), Vector2( -51, -55 ), Vector2( -72, -16 ), Vector2( -217, 628 ) ] +} +tracks/1/type = "value" +tracks/1/path = NodePath("p1:rotation_degrees") +tracks/1/interp = 1 +tracks/1/loop_wrap = true +tracks/1/imported = false +tracks/1/enabled = true +tracks/1/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ 0.0, -15.0, -30.0, -74.9999, -120.0 ] +} +tracks/2/type = "value" +tracks/2/path = NodePath("p2:position") +tracks/2/interp = 1 +tracks/2/loop_wrap = true +tracks/2/imported = false +tracks/2/enabled = true +tracks/2/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( 8, -8 ), Vector2( 29, -37 ), Vector2( 47, -58 ), Vector2( 76, -20 ), Vector2( 245, 632 ) ] +} +tracks/3/type = "value" +tracks/3/path = NodePath("p2:rotation_degrees") +tracks/3/interp = 1 +tracks/3/loop_wrap = true +tracks/3/imported = false +tracks/3/enabled = true +tracks/3/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ 0.0, 15.0, 30.0, 59.9999, 105.0 ] +} +tracks/4/type = "value" +tracks/4/path = NodePath("p3:position") +tracks/4/interp = 1 +tracks/4/loop_wrap = true +tracks/4/imported = false +tracks/4/enabled = true +tracks/4/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( -8, 8 ), Vector2( -14, -26 ), Vector2( -29, -52 ), Vector2( -50, -12 ), Vector2( -164, 632 ) ] +} +tracks/5/type = "value" +tracks/5/path = NodePath("p3:rotation_degrees") +tracks/5/interp = 1 +tracks/5/loop_wrap = true +tracks/5/imported = false +tracks/5/enabled = true +tracks/5/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ 0.0, -13.0706, -20.6571, -5.02922, -128.673 ] +} +tracks/6/type = "value" +tracks/6/path = NodePath("p4:position") +tracks/6/interp = 1 +tracks/6/loop_wrap = true +tracks/6/imported = false +tracks/6/enabled = true +tracks/6/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( 8, 8 ), Vector2( 16, -28 ), Vector2( 23, -53 ), Vector2( 48, -13 ), Vector2( 186, 633 ) ] +} +tracks/7/type = "value" +tracks/7/path = NodePath("p4:rotation_degrees") +tracks/7/interp = 1 +tracks/7/loop_wrap = true +tracks/7/imported = false +tracks/7/enabled = true +tracks/7/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3, 1.5 ), +"transitions": PoolRealArray( 1, 1, 1, 1, 1 ), +"update": 0, +"values": [ 0.0, 15.0, 30.0, 44.9999, 89.9999 ] +} + +[node name="BrokenBrick" type="Node2D"] +script = ExtResource( 5 ) + +[node name="p1" type="Sprite" parent="."] +position = Vector2( -217, 628 ) +rotation = -2.0944 +texture = ExtResource( 3 ) + +[node name="p2" type="Sprite" parent="."] +position = Vector2( 245, 632 ) +rotation = 1.8326 +texture = ExtResource( 2 ) + +[node name="p3" type="Sprite" parent="."] +position = Vector2( -164, 632 ) +rotation = -2.24577 +texture = ExtResource( 4 ) + +[node name="p4" type="Sprite" parent="."] +position = Vector2( 186, 633 ) +rotation = 1.57079 +texture = ExtResource( 1 ) + +[node name="AnimationPlayer" type="AnimationPlayer" parent="."] +anims/fall = SubResource( 1 ) + +[node name="Timer" type="Timer" parent="."] +wait_time = 1.5 +one_shot = true +autostart = true + +[node name="AudioStreamPlayer2D" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 6 ) +volume_db = -10.0 + +[connection signal="timeout" from="Timer" to="." method="_on_Timer_timeout"] diff --git a/src/objects/Bullet.gd b/src/objects/Bullet.gd new file mode 100644 index 0000000..84cc4d0 --- /dev/null +++ b/src/objects/Bullet.gd @@ -0,0 +1,11 @@ +extends RigidBody2D +class_name Bullet + +func _on_Timer_timeout() -> void: + queue_free() + pass + +func _on_body_entered(body): + if body is Enemy: + body.kill_me() + pass diff --git a/src/objects/Bullet.tscn b/src/objects/Bullet.tscn new file mode 100644 index 0000000..e898b7a --- /dev/null +++ b/src/objects/Bullet.tscn @@ -0,0 +1,28 @@ +[gd_scene load_steps=4 format=2] + +[ext_resource path="res://samagri/bullet.png" type="Texture" id=1] +[ext_resource path="res://src/objects/Bullet.gd" type="Script" id=3] + +[sub_resource type="CircleShape2D" id=1] +radius = 6.0 + +[node name="Bullet" type="RigidBody2D"] +collision_layer = 64 +collision_mask = 30 +contacts_reported = 1 +contact_monitor = true +script = ExtResource( 3 ) + +[node name="Sprite" type="Sprite" parent="."] +scale = Vector2( 0.8, 0.8 ) +texture = ExtResource( 1 ) + +[node name="CollisionShape2D" type="CollisionShape2D" parent="."] +shape = SubResource( 1 ) + +[node name="Timer" type="Timer" parent="."] +one_shot = true +autostart = true + +[connection signal="body_entered" from="." to="." method="_on_body_entered"] +[connection signal="timeout" from="Timer" to="." method="_on_Timer_timeout"] diff --git a/src/objects/CoinFlip.gd b/src/objects/CoinFlip.gd new file mode 100644 index 0000000..9ce6124 --- /dev/null +++ b/src/objects/CoinFlip.gd @@ -0,0 +1,11 @@ +extends Node2D + +onready var animation = $AnimationPlayer +onready var audio = $AudioStreamPlayer2D + +func _ready() -> void: + animation.play('flip') + audio.play() + +func _on_Timer_timeout() -> void: + queue_free() diff --git a/src/objects/CoinFlip.tscn b/src/objects/CoinFlip.tscn new file mode 100644 index 0000000..53badfa --- /dev/null +++ b/src/objects/CoinFlip.tscn @@ -0,0 +1,79 @@ +[gd_scene load_steps=5 format=2] + +[ext_resource path="res://samagri/coin.png" type="Texture" id=1] +[ext_resource path="res://src/objects/CoinFlip.gd" type="Script" id=2] +[ext_resource path="res://samagri/sfx/coin_pickup.wav" type="AudioStream" id=3] + +[sub_resource type="Animation" id=1] +resource_name = "flip" +length = 0.3 +tracks/0/type = "value" +tracks/0/path = NodePath("coin:position") +tracks/0/interp = 1 +tracks/0/loop_wrap = true +tracks/0/imported = false +tracks/0/enabled = true +tracks/0/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3 ), +"transitions": PoolRealArray( 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( 0, 0 ), Vector2( 0, -42 ), Vector2( 0, -56 ), Vector2( 0, -84 ) ] +} +tracks/1/type = "value" +tracks/1/path = NodePath("coin:rotation_degrees") +tracks/1/interp = 1 +tracks/1/loop_wrap = true +tracks/1/imported = false +tracks/1/enabled = true +tracks/1/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3 ), +"transitions": PoolRealArray( 1, 1, 1, 1 ), +"update": 0, +"values": [ 0.0, -180.0, -220.779, -33.9 ] +} +tracks/2/type = "value" +tracks/2/path = NodePath("coin:scale") +tracks/2/interp = 1 +tracks/2/loop_wrap = true +tracks/2/imported = false +tracks/2/enabled = true +tracks/2/keys = { +"times": PoolRealArray( 0, 0.1, 0.2, 0.3 ), +"transitions": PoolRealArray( 1, 1, 1, 1 ), +"update": 0, +"values": [ Vector2( 1, 1 ), Vector2( 0.1, 1 ), Vector2( 1, 1 ), Vector2( 1, 1 ) ] +} +tracks/3/type = "value" +tracks/3/path = NodePath("coin:self_modulate") +tracks/3/interp = 1 +tracks/3/loop_wrap = true +tracks/3/imported = false +tracks/3/enabled = true +tracks/3/keys = { +"times": PoolRealArray( 0, 0.3 ), +"transitions": PoolRealArray( 1, 1 ), +"update": 0, +"values": [ Color( 1, 1, 1, 1 ), Color( 1, 1, 1, 0 ) ] +} + +[node name="CoinFlip" type="Node2D"] +script = ExtResource( 2 ) + +[node name="coin" type="Sprite" parent="."] +self_modulate = Color( 1, 1, 1, 0 ) +position = Vector2( 0, -84 ) +rotation = -0.591667 +texture = ExtResource( 1 ) + +[node name="AnimationPlayer" type="AnimationPlayer" parent="."] +anims/flip = SubResource( 1 ) + +[node name="Timer" type="Timer" parent="."] +one_shot = true +autostart = true + +[node name="AudioStreamPlayer2D" type="AudioStreamPlayer2D" parent="."] +stream = ExtResource( 3 ) +volume_db = -10.0 + +[connection signal="timeout" from="Timer" to="." method="_on_Timer_timeout"] diff --git a/src/objects/Gun.gd b/src/objects/Gun.gd new file mode 100644 index 0000000..15c3a1d --- /dev/null +++ b/src/objects/Gun.gd @@ -0,0 +1,12 @@ +extends Position2D +class_name Gun + +const bullet_velocity = 800 +const Bullet = preload('res://src/objects/Bullet.tscn') + +func shoot(direction: int): + var bullet = Bullet.instance() + bullet.set_position(global_position) + bullet.linear_velocity = Vector2(direction * bullet_velocity, 0) + bullet.set_as_toplevel(true) + add_child(bullet) diff --git a/src/objects/MagicBox.gd b/src/objects/MagicBox.gd new file mode 100644 index 0000000..f2bb962 --- /dev/null +++ b/src/objects/MagicBox.gd @@ -0,0 +1,24 @@ +extends Area2D +class_name MagicBox + +onready var grid: TileMap = get_parent().get_parent() +onready var collision = $CollisionShape2D + +var coinflip = preload('res://src/objects/CoinFlip.tscn') + +enum Type {LEFT_BLOCK = 45, MID_BLOCK = 46, RIGHT_BLOCK = 47} + +export(Type) var type = Type.LEFT_BLOCK + +func _physics_process(_delta: float) -> void: + for bd in get_overlapping_bodies(): + if bd is Player: + grid.set_cellv(grid.world_to_map(get_child(0).get_position()), type) + Global.score += Global.SCORE_COIN + Global.coins += 1 + collision.set_disabled(true) + + var coin = coinflip.instance() + coin.global_position = get_child(0).global_position + coin.set_as_toplevel(true) + add_child(coin) diff --git a/src/scenes/Game.gd b/src/scenes/Game.gd new file mode 100644 index 0000000..612504f --- /dev/null +++ b/src/scenes/Game.gd @@ -0,0 +1,11 @@ +extends Node2D +class_name Game + +func _ready() -> void: + Global.score = 0 + Global.coins = 0 + + if !OS.has_touchscreen_ui_hint(): + var info = load('res://src/layers/HelpInfo.tscn').instance() + info.global_position = $HelpHere.global_position + add_child(info) diff --git a/src/scenes/Game.tscn b/src/scenes/Game.tscn new file mode 100644 index 0000000..8b473c3 --- /dev/null +++ b/src/scenes/Game.tscn @@ -0,0 +1,28 @@ +[gd_scene load_steps=8 format=2] + +[ext_resource path="res://src/actors/Player.tscn" type="PackedScene" id=1] +[ext_resource path="res://src/layers/Hud.tscn" type="PackedScene" id=2] +[ext_resource path="res://src/levels/Level1.tscn" type="PackedScene" id=3] +[ext_resource path="res://src/scenes/Game.gd" type="Script" id=4] +[ext_resource path="res://src/layers/Background.tscn" type="PackedScene" id=5] +[ext_resource path="res://src/controller/ControlTouch.tscn" type="PackedScene" id=6] +[ext_resource path="res://src/layers/PauseMenu.tscn" type="PackedScene" id=7] + +[node name="Game" type="Node2D"] +script = ExtResource( 4 ) + +[node name="Level1" parent="." instance=ExtResource( 3 )] + +[node name="Player" parent="Level1" instance=ExtResource( 1 )] +position = Vector2( 156, 439 ) + +[node name="Hud" parent="." instance=ExtResource( 2 )] + +[node name="Background" parent="." instance=ExtResource( 5 )] + +[node name="ControlTouch" parent="." instance=ExtResource( 6 )] + +[node name="HelpHere" type="Position2D" parent="."] +position = Vector2( 90, 216 ) + +[node name="PauseMenu" parent="." instance=ExtResource( 7 )] diff --git a/src/scenes/GameOver.tscn b/src/scenes/GameOver.tscn new file mode 100644 index 0000000..940f859 --- /dev/null +++ b/src/scenes/GameOver.tscn @@ -0,0 +1,241 @@ +[gd_scene load_steps=19 format=2] + +[ext_resource path="res://src/layers/Background.tscn" type="PackedScene" id=1] +[ext_resource path="res://src/scenes/GameOver_Won.gd" type="Script" id=2] +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=3] +[ext_resource path="res://samagri/Player_MainMenu.png" type="Texture" id=4] +[ext_resource path="res://samagri/coin.png" type="Texture" id=5] +[ext_resource path="res://samagri/star.png" type="Texture" id=6] + +[sub_resource type="AtlasTexture" id=1] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 0, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=2] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 320, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=3] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 640, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=4] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 960, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=5] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1280, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=6] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1600, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=7] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1920, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=8] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2240, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=9] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2560, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=10] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2880, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=11] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 3200, 0, 320, 320 ) + +[sub_resource type="SpriteFrames" id=12] +animations = [ { +"frames": [ ], +"loop": true, +"name": "default", +"speed": 5.0 +}, { +"frames": [ SubResource( 1 ), SubResource( 2 ), SubResource( 3 ), SubResource( 4 ), SubResource( 5 ), SubResource( 6 ), SubResource( 7 ), SubResource( 8 ), SubResource( 9 ), SubResource( 10 ), SubResource( 11 ) ], +"loop": true, +"name": "New Anim", +"speed": 10.0 +} ] + +[node name="MainMenu" type="Control"] +anchor_right = 1.0 +anchor_bottom = 1.0 +theme = ExtResource( 3 ) +script = ExtResource( 2 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Background" parent="." instance=ExtResource( 1 )] + +[node name="Camera2D" type="Camera2D" parent="."] +position = Vector2( 412, 300 ) +offset = Vector2( 100, 0 ) +current = true + +[node name="CanvasLayer" type="CanvasLayer" parent="."] + +[node name="Control" type="Control" parent="CanvasLayer"] +margin_right = 40.0 +margin_bottom = 40.0 +theme = ExtResource( 3 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="PlayButton" type="Button" parent="CanvasLayer/Control"] +anchor_left = 0.5 +anchor_top = 1.0 +anchor_right = 0.5 +anchor_bottom = 1.0 +margin_left = 458.0 +margin_top = 381.0 +margin_right = 674.0 +margin_bottom = 436.0 +text = "Re-Play" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ExitButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 710.0 +margin_top = 421.0 +margin_right = 926.0 +margin_bottom = 476.0 +text = "Exit" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="MainMenuButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 478.0 +margin_top = 491.0 +margin_right = 926.0 +margin_bottom = 546.0 +text = "Main Menu" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="AnimatedSprite" type="AnimatedSprite" parent="CanvasLayer/Control"] +position = Vector2( 243, 313 ) +frames = SubResource( 12 ) +animation = "New Anim" +frame = 2 +playing = true + +[node name="ColorRect" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 138.0 +margin_top = 140.0 +margin_right = 338.0 +margin_bottom = 189.0 +color = Color( 0.262745, 0.290196, 0.372549, 0.819608 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="CanvasLayer/Control/ColorRect"] +anchor_left = -1.287 +anchor_top = -4.437 +anchor_right = -1.287 +anchor_bottom = -4.437 +margin_left = 245.4 +margin_top = 208.413 +margin_right = 380.4 +margin_bottom = 246.413 +rect_scale = Vector2( 1.72402, 1.67047 ) +text = "Runner" +align = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect4" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 549.0 +margin_top = 160.0 +margin_right = 847.0 +margin_bottom = 210.0 +color = Color( 0.619608, 0.298039, 0.2, 0.819608 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="CanvasLayer/Control/ColorRect4"] +margin_left = 7.0 +margin_top = -10.0 +margin_right = 174.0 +margin_bottom = 28.0 +rect_scale = Vector2( 1.72402, 1.67047 ) +text = "Game OVER" +align = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect2" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 628.0 +margin_top = 240.0 +margin_right = 788.0 +margin_bottom = 280.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Score" type="Label" parent="CanvasLayer/Control/ColorRect2"] +margin_left = 39.0 +margin_top = 0.999969 +margin_right = 67.0 +margin_bottom = 39.0 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="CanvasLayer/Control/ColorRect2"] +position = Vector2( 19, 20 ) +texture = ExtResource( 6 ) + +[node name="ColorRect3" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 628.0 +margin_top = 302.0 +margin_right = 788.0 +margin_bottom = 342.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Coins" type="Label" parent="CanvasLayer/Control/ColorRect3"] +margin_left = 39.0 +margin_top = 0.999969 +margin_right = 96.0 +margin_bottom = 39.0 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="CanvasLayer/Control/ColorRect3"] +position = Vector2( 19, 20 ) +texture = ExtResource( 5 ) + +[connection signal="pressed" from="CanvasLayer/Control/PlayButton" to="." method="_on_PlayButton_pressed"] +[connection signal="pressed" from="CanvasLayer/Control/ExitButton" to="." method="_on_ExitButton_pressed"] +[connection signal="pressed" from="CanvasLayer/Control/MainMenuButton" to="." method="_on_MainMenuButton_pressed"] diff --git a/src/scenes/GameOver_Won.gd b/src/scenes/GameOver_Won.gd new file mode 100644 index 0000000..8ea13e9 --- /dev/null +++ b/src/scenes/GameOver_Won.gd @@ -0,0 +1,28 @@ +extends Control +class_name GameOverOrWon + +onready var camera = $Camera2D +onready var score = $CanvasLayer/Control/ColorRect2/Score +onready var coins = $CanvasLayer/Control/ColorRect3/Coins + +func _ready() -> void: + score.text = str(Global.score) + coins.text = str(Global.coins) + +func _physics_process(delta: float) -> void: + $Camera2D.offset_h += 2 * delta + + +func _on_PlayButton_pressed() -> void: + if get_tree().change_scene("res://src/scenes/Game.tscn") != 0: + print('Failed to change scene') + get_tree().quit() + + +func _on_ExitButton_pressed() -> void: + get_tree().quit(0) + +func _on_MainMenuButton_pressed() -> void: + if get_tree().change_scene("res://src/scenes/MainMenu.tscn") != 0: + print('Failed to change scene') + get_tree().quit() diff --git a/src/scenes/GameWon.tscn b/src/scenes/GameWon.tscn new file mode 100644 index 0000000..5a6cb47 --- /dev/null +++ b/src/scenes/GameWon.tscn @@ -0,0 +1,241 @@ +[gd_scene load_steps=19 format=2] + +[ext_resource path="res://src/layers/Background.tscn" type="PackedScene" id=1] +[ext_resource path="res://src/scenes/GameOver_Won.gd" type="Script" id=2] +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=3] +[ext_resource path="res://samagri/Player_MainMenu.png" type="Texture" id=4] +[ext_resource path="res://samagri/coin.png" type="Texture" id=5] +[ext_resource path="res://samagri/star.png" type="Texture" id=6] + +[sub_resource type="AtlasTexture" id=1] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 0, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=2] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 320, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=3] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 640, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=4] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 960, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=5] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1280, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=6] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1600, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=7] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1920, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=8] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2240, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=9] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2560, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=10] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2880, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=11] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 3200, 0, 320, 320 ) + +[sub_resource type="SpriteFrames" id=12] +animations = [ { +"frames": [ ], +"loop": true, +"name": "default", +"speed": 5.0 +}, { +"frames": [ SubResource( 1 ), SubResource( 2 ), SubResource( 3 ), SubResource( 4 ), SubResource( 5 ), SubResource( 6 ), SubResource( 7 ), SubResource( 8 ), SubResource( 9 ), SubResource( 10 ), SubResource( 11 ) ], +"loop": true, +"name": "New Anim", +"speed": 10.0 +} ] + +[node name="MainMenu" type="Control"] +anchor_right = 1.0 +anchor_bottom = 1.0 +theme = ExtResource( 3 ) +script = ExtResource( 2 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Background" parent="." instance=ExtResource( 1 )] + +[node name="Camera2D" type="Camera2D" parent="."] +position = Vector2( 412, 300 ) +offset = Vector2( 100, 0 ) +current = true + +[node name="CanvasLayer" type="CanvasLayer" parent="."] + +[node name="Control" type="Control" parent="CanvasLayer"] +margin_right = 40.0 +margin_bottom = 40.0 +theme = ExtResource( 3 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="PlayButton" type="Button" parent="CanvasLayer/Control"] +anchor_left = 0.5 +anchor_top = 1.0 +anchor_right = 0.5 +anchor_bottom = 1.0 +margin_left = 458.0 +margin_top = 381.0 +margin_right = 674.0 +margin_bottom = 436.0 +text = "Re-Play" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ExitButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 710.0 +margin_top = 421.0 +margin_right = 926.0 +margin_bottom = 476.0 +text = "Exit" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="MainMenuButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 478.0 +margin_top = 491.0 +margin_right = 926.0 +margin_bottom = 546.0 +text = "Main Menu" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="AnimatedSprite" type="AnimatedSprite" parent="CanvasLayer/Control"] +position = Vector2( 243, 307 ) +frames = SubResource( 12 ) +animation = "New Anim" +frame = 8 +playing = true + +[node name="ColorRect" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 139.0 +margin_top = 140.0 +margin_right = 339.0 +margin_bottom = 189.0 +color = Color( 0.262745, 0.290196, 0.372549, 0.819608 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="CanvasLayer/Control/ColorRect"] +anchor_left = -1.287 +anchor_top = -4.437 +anchor_right = -1.287 +anchor_bottom = -4.437 +margin_left = 245.4 +margin_top = 208.413 +margin_right = 380.4 +margin_bottom = 246.413 +rect_scale = Vector2( 1.72402, 1.67047 ) +text = "Runner" +align = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect4" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 560.0 +margin_top = 160.0 +margin_right = 858.0 +margin_bottom = 210.0 +color = Color( 0.113725, 0.513726, 0.337255, 0.819608 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="CanvasLayer/Control/ColorRect4"] +margin_left = 7.0 +margin_top = -10.0 +margin_right = 174.0 +margin_bottom = 28.0 +rect_scale = Vector2( 1.72402, 1.67047 ) +text = "You Won" +align = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ColorRect2" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 628.0 +margin_top = 241.0 +margin_right = 788.0 +margin_bottom = 281.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Score" type="Label" parent="CanvasLayer/Control/ColorRect2"] +margin_left = 39.0 +margin_top = 0.999969 +margin_right = 67.0 +margin_bottom = 39.0 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="CanvasLayer/Control/ColorRect2"] +position = Vector2( 19, 20 ) +texture = ExtResource( 6 ) + +[node name="ColorRect3" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 628.0 +margin_top = 303.0 +margin_right = 788.0 +margin_bottom = 343.0 +color = Color( 0.152941, 0.172549, 0.188235, 0.862745 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Coins" type="Label" parent="CanvasLayer/Control/ColorRect3"] +margin_left = 39.0 +margin_top = 0.999969 +margin_right = 96.0 +margin_bottom = 39.0 +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Sprite" type="Sprite" parent="CanvasLayer/Control/ColorRect3"] +position = Vector2( 19, 20 ) +texture = ExtResource( 5 ) + +[connection signal="pressed" from="CanvasLayer/Control/PlayButton" to="." method="_on_PlayButton_pressed"] +[connection signal="pressed" from="CanvasLayer/Control/ExitButton" to="." method="_on_ExitButton_pressed"] +[connection signal="pressed" from="CanvasLayer/Control/MainMenuButton" to="." method="_on_MainMenuButton_pressed"] diff --git a/src/scenes/MainMenu.gd b/src/scenes/MainMenu.gd new file mode 100644 index 0000000..054ade3 --- /dev/null +++ b/src/scenes/MainMenu.gd @@ -0,0 +1,15 @@ +extends Control +class_name MainMenu + +onready var camera = $Camera2D + +func _physics_process(delta: float) -> void: + camera.offset_h += 1.5 * delta + +func _on_PlayButton_pressed() -> void: + if get_tree().change_scene("res://src/scenes/Game.tscn") != 0: + print('Failed to change scene') + get_tree().quit() + +func _on_ExitButton_pressed() -> void: + get_tree().quit(0) diff --git a/src/scenes/MainMenu.tscn b/src/scenes/MainMenu.tscn new file mode 100644 index 0000000..46a8ac1 --- /dev/null +++ b/src/scenes/MainMenu.tscn @@ -0,0 +1,152 @@ +[gd_scene load_steps=17 format=2] + +[ext_resource path="res://src/layers/Background.tscn" type="PackedScene" id=1] +[ext_resource path="res://src/scenes/MainMenu.gd" type="Script" id=2] +[ext_resource path="res://samagri/theme/user_interface.tres" type="Theme" id=3] +[ext_resource path="res://samagri/Player_MainMenu.png" type="Texture" id=4] + +[sub_resource type="AtlasTexture" id=1] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 0, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=2] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 320, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=3] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 640, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=4] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 960, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=5] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1280, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=6] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1600, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=7] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 1920, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=8] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2240, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=9] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2560, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=10] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 2880, 0, 320, 320 ) + +[sub_resource type="AtlasTexture" id=11] +flags = 4 +atlas = ExtResource( 4 ) +region = Rect2( 3200, 0, 320, 320 ) + +[sub_resource type="SpriteFrames" id=12] +animations = [ { +"frames": [ ], +"loop": true, +"name": "default", +"speed": 5.0 +}, { +"frames": [ SubResource( 1 ), SubResource( 2 ), SubResource( 3 ), SubResource( 4 ), SubResource( 5 ), SubResource( 6 ), SubResource( 7 ), SubResource( 8 ), SubResource( 9 ), SubResource( 10 ), SubResource( 11 ) ], +"loop": true, +"name": "New Anim", +"speed": 10.0 +} ] + +[node name="MainMenu" type="Control"] +anchor_right = 1.0 +anchor_bottom = 1.0 +theme = ExtResource( 3 ) +script = ExtResource( 2 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Background" parent="." instance=ExtResource( 1 )] + +[node name="Camera2D" type="Camera2D" parent="."] +position = Vector2( 414, 301 ) +offset = Vector2( 100, 0 ) +current = true + +[node name="CanvasLayer" type="CanvasLayer" parent="."] + +[node name="Control" type="Control" parent="CanvasLayer"] +margin_right = 1024.0 +margin_bottom = 601.0 +theme = ExtResource( 3 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="PlayButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 403.0 +margin_top = 401.0 +margin_right = 632.0 +margin_bottom = 455.0 +text = "Play" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="ExitButton" type="Button" parent="CanvasLayer/Control"] +margin_left = 403.0 +margin_top = 479.0 +margin_right = 632.0 +margin_bottom = 534.0 +text = "Exit" +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="AnimatedSprite" type="AnimatedSprite" parent="CanvasLayer/Control"] +position = Vector2( 521, 219 ) +frames = SubResource( 12 ) +animation = "New Anim" +frame = 6 +playing = true + +[node name="ColorRect" type="ColorRect" parent="CanvasLayer/Control"] +margin_left = 421.0 +margin_top = 59.0 +margin_right = 621.0 +margin_bottom = 108.0 +color = Color( 0.262745, 0.290196, 0.372549, 0.819608 ) +__meta__ = { +"_edit_use_anchors_": false +} + +[node name="Label" type="Label" parent="CanvasLayer/Control/ColorRect"] +margin_left = -11.0 +margin_top = -10.0 +margin_right = 124.0 +margin_bottom = 28.0 +rect_scale = Vector2( 1.72402, 1.67047 ) +text = "Runner" +align = 1 +__meta__ = { +"_edit_use_anchors_": false +} + +[connection signal="pressed" from="CanvasLayer/Control/PlayButton" to="." method="_on_PlayButton_pressed"] +[connection signal="pressed" from="CanvasLayer/Control/ExitButton" to="." method="_on_ExitButton_pressed"] diff --git a/tile.tres b/tile.tres new file mode 100644 index 0000000..1184372 --- /dev/null +++ b/tile.tres @@ -0,0 +1,29 @@ +[gd_resource type="TileSet" load_steps=3 format=2] + +[ext_resource path="res://samagri/coin.png" type="Texture" id=1] + +[sub_resource type="RectangleShape2D" id=1] +extents = Vector2( 16, 16 ) + +[resource] +0/name = "Sprite" +0/texture = ExtResource( 1 ) +0/tex_offset = Vector2( 0, 0 ) +0/modulate = Color( 1, 1, 1, 1 ) +0/region = Rect2( 0, 0, 32, 32 ) +0/tile_mode = 0 +0/occluder_offset = Vector2( 16, 16 ) +0/navigation_offset = Vector2( 16, 16 ) +0/shape_offset = Vector2( 16, 16 ) +0/shape_transform = Transform2D( 1, 0, 0, 1, 16, 16 ) +0/shape = SubResource( 1 ) +0/shape_one_way = false +0/shape_one_way_margin = 1.0 +0/shapes = [ { +"autotile_coord": Vector2( 0, 0 ), +"one_way": false, +"one_way_margin": 1.0, +"shape": SubResource( 1 ), +"shape_transform": Transform2D( 1, 0, 0, 1, 16, 16 ) +} ] +0/z_index = 0