mirror of
https://github.com/curioustorvald/Terrarum.git
synced 2026-06-09 18:14:06 +09:00
writeworld wip
This commit is contained in:
@@ -3,14 +3,13 @@ package net.torvald.terrarum.serialise
|
|||||||
import com.badlogic.gdx.utils.Json
|
import com.badlogic.gdx.utils.Json
|
||||||
import com.badlogic.gdx.utils.JsonWriter
|
import com.badlogic.gdx.utils.JsonWriter
|
||||||
import net.torvald.terrarum.ModMgr
|
import net.torvald.terrarum.ModMgr
|
||||||
import net.torvald.terrarum.blockproperties.BlockCodex
|
|
||||||
import net.torvald.terrarum.blockproperties.WireCodex
|
|
||||||
import net.torvald.terrarum.itemproperties.ItemCodex
|
|
||||||
import net.torvald.terrarum.itemproperties.MaterialCodex
|
|
||||||
import net.torvald.terrarum.modulebasegame.TerrarumIngame
|
import net.torvald.terrarum.modulebasegame.TerrarumIngame
|
||||||
import net.torvald.terrarum.modulebasegame.worldgenerator.RoguelikeRandomiser
|
import net.torvald.terrarum.modulebasegame.worldgenerator.RoguelikeRandomiser
|
||||||
import net.torvald.terrarum.weather.WeatherMixer
|
import net.torvald.terrarum.weather.WeatherMixer
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by minjaesong on 2021-08-23.
|
||||||
|
*/
|
||||||
open class WriteMeta(val ingame: TerrarumIngame) {
|
open class WriteMeta(val ingame: TerrarumIngame) {
|
||||||
|
|
||||||
open fun invoke(): String {
|
open fun invoke(): String {
|
||||||
|
|||||||
48
src/net/torvald/terrarum/serialise/WriteWorld.kt
Normal file
48
src/net/torvald/terrarum/serialise/WriteWorld.kt
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
package net.torvald.terrarum.serialise
|
||||||
|
|
||||||
|
import net.torvald.terrarum.gameworld.BlockLayer
|
||||||
|
import net.torvald.terrarum.modulecomputers.virtualcomputer.tvd.ByteArray64GrowableOutputStream
|
||||||
|
import java.util.zip.GZIPOutputStream
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by minjaesong on 2021-08-23.
|
||||||
|
*/
|
||||||
|
class WriteWorld {
|
||||||
|
|
||||||
|
open fun invoke(): String {
|
||||||
|
|
||||||
|
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param b a BlockLayer
|
||||||
|
* @return Bytes in BlockLayer, GZip'd then Ascii85-encoded
|
||||||
|
*/
|
||||||
|
private fun blockLayerToStr(b: BlockLayer): String {
|
||||||
|
val sb = StringBuilder()
|
||||||
|
val bo = ByteArray64GrowableOutputStream()
|
||||||
|
val zo = GZIPOutputStream(bo)
|
||||||
|
|
||||||
|
b.bytesIterator().forEachRemaining {
|
||||||
|
zo.write(it.toInt())
|
||||||
|
}
|
||||||
|
zo.flush(); zo.close()
|
||||||
|
|
||||||
|
val ba = bo.toByteArray64()
|
||||||
|
var bai = 0
|
||||||
|
val buf = IntArray(4) { Ascii85.PAD_BYTE }
|
||||||
|
ba.forEach {
|
||||||
|
if (bai > 0 && bai % 4 == 0) {
|
||||||
|
sb.append(Ascii85.encode(buf[0], buf[1], buf[2], buf[3]))
|
||||||
|
}
|
||||||
|
|
||||||
|
buf[bai % 4] = it.toInt() and 255
|
||||||
|
|
||||||
|
bai += 1
|
||||||
|
}; sb.append(Ascii85.encode(buf[0], buf[1], buf[2], buf[3]))
|
||||||
|
|
||||||
|
return sb.toString()
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user