2018-09-26 17:04:46 +00:00
|
|
|
package doodads
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
2018-10-20 22:42:49 +00:00
|
|
|
"path/filepath"
|
2019-07-07 06:28:11 +00:00
|
|
|
|
2021-07-14 02:23:09 +00:00
|
|
|
"git.kirsle.net/apps/doodle/pkg/balance"
|
2021-06-20 05:14:41 +00:00
|
|
|
"git.kirsle.net/apps/doodle/pkg/usercfg"
|
2018-09-26 17:04:46 +00:00
|
|
|
)
|
|
|
|
|
2021-07-14 02:23:09 +00:00
|
|
|
// ToJSON serializes the doodad as JSON (gzip supported).
|
|
|
|
//
|
|
|
|
// If balance.CompressLevels=true the doodad will be gzip compressed
|
|
|
|
// and the return value is gz bytes and not the raw JSON.
|
2018-09-26 17:04:46 +00:00
|
|
|
func (d *Doodad) ToJSON() ([]byte, error) {
|
2021-07-14 02:23:09 +00:00
|
|
|
// Gzip compressing?
|
|
|
|
if balance.CompressDrawings {
|
|
|
|
return d.ToGzip()
|
|
|
|
}
|
|
|
|
|
2018-09-26 17:04:46 +00:00
|
|
|
out := bytes.NewBuffer([]byte{})
|
|
|
|
encoder := json.NewEncoder(out)
|
2021-06-20 05:14:41 +00:00
|
|
|
if usercfg.Current.JSONIndent {
|
2019-07-07 06:28:11 +00:00
|
|
|
encoder.SetIndent("", "\t")
|
|
|
|
}
|
2018-09-26 17:04:46 +00:00
|
|
|
err := encoder.Encode(d)
|
|
|
|
return out.Bytes(), err
|
|
|
|
}
|
|
|
|
|
2021-07-14 02:23:09 +00:00
|
|
|
// FromJSON loads a doodad from JSON string (gzip supported).
|
2019-06-27 22:07:34 +00:00
|
|
|
func FromJSON(filename string, data []byte) (*Doodad, error) {
|
|
|
|
var doodad = &Doodad{}
|
2021-07-14 02:23:09 +00:00
|
|
|
|
|
|
|
// Inspect the headers of the file to see how it was encoded.
|
|
|
|
if len(data) > 0 && data[0] == '{' {
|
|
|
|
// Looks standard JSON.
|
|
|
|
err := json.Unmarshal(data, doodad)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
} else if len(data) > 1 && data[0] == 0x1f && data[1] == 0x8b {
|
|
|
|
// Gzip compressed. `1F8B` is gzip magic number.
|
|
|
|
if gzd, err := FromGzip(data); err != nil {
|
|
|
|
return nil, err
|
|
|
|
} else {
|
|
|
|
doodad = gzd
|
|
|
|
}
|
|
|
|
}
|
2019-06-27 22:07:34 +00:00
|
|
|
|
|
|
|
// Inflate the chunk metadata to map the pixels to their palette indexes.
|
|
|
|
doodad.Filename = filepath.Base(filename)
|
|
|
|
doodad.Inflate()
|
|
|
|
|
2021-07-14 02:23:09 +00:00
|
|
|
return doodad, nil
|
2019-06-27 22:07:34 +00:00
|
|
|
}
|
|
|
|
|
2018-09-26 17:04:46 +00:00
|
|
|
// WriteJSON writes a Doodad to JSON on disk.
|
|
|
|
func (d *Doodad) WriteJSON(filename string) error {
|
|
|
|
json, err := d.ToJSON()
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Doodad.WriteJSON: JSON encode error: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = ioutil.WriteFile(filename, json, 0755)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Doodad.WriteJSON: WriteFile error: %s", err)
|
|
|
|
}
|
|
|
|
|
2018-10-20 22:42:49 +00:00
|
|
|
d.Filename = filepath.Base(filename)
|
2018-09-26 17:04:46 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// LoadJSON loads a map from JSON file.
|
|
|
|
func LoadJSON(filename string) (*Doodad, error) {
|
2021-07-14 02:23:09 +00:00
|
|
|
data, err := ioutil.ReadFile(filename)
|
2018-09-26 17:04:46 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2021-07-14 02:23:09 +00:00
|
|
|
return FromJSON(filename, data)
|
2018-09-26 17:04:46 +00:00
|
|
|
}
|