diff --git a/src/Autoload/OpenSave.gd b/src/Autoload/OpenSave.gd index 1682b3ad0225..9fabf9730e1c 100644 --- a/src/Autoload/OpenSave.gd +++ b/src/Autoload/OpenSave.gd @@ -23,7 +23,7 @@ func handle_loading_files(files : PoolStringArray) -> void: var file_ext : String = file.get_extension().to_lower() if file_ext == "pxo": # Pixelorama project file open_pxo_file(file) - elif file_ext == "tres" or file_ext == "gpl" or file_ext == "pal": # Palettes + elif file_ext == "tres" or file_ext == "gpl" or file_ext == "pal" or file_ext == "json": # Palettes Palettes.import_palette(file) else: # Image files var image := Image.new() diff --git a/src/Autoload/Palettes.gd b/src/Autoload/Palettes.gd index cc67b80dbc55..420cb568bddf 100644 --- a/src/Autoload/Palettes.gd +++ b/src/Autoload/Palettes.gd @@ -407,6 +407,13 @@ func import_palette(path: String) -> void: var err := image.load(path) if !err: palette = import_image_palette(path, image) + "json": + var file = File.new() + if file.file_exists(path): + file.open(path, File.READ) + var text = file.get_as_text() + file.close() + palette = import_json_palette(text) if palette: var palette_path := save_palette(palette) @@ -416,7 +423,7 @@ func import_palette(path: String) -> void: Global.palette_panel.select_palette(palette_path) -func import_gpl(path : String, text : String) -> Palette: +func import_gpl(path: String, text: String) -> Palette: # Refer to app/core/gimppalette-load.c of the GIMP for the "living spec" var result : Palette = null var lines = text.split('\n') @@ -466,7 +473,7 @@ func import_gpl(path : String, text : String) -> Palette: return result -func import_pal_palette(path : String, text : String) -> Palette: +func import_pal_palette(path: String, text: String) -> Palette: var result: Palette = null var lines = text.split('\n') @@ -490,7 +497,7 @@ func import_pal_palette(path : String, text : String) -> Palette: return result -func import_image_palette(path: String, image : Image) -> Palette: +func import_image_palette(path: String, image: Image) -> Palette: var result: Palette = Palette.new(path.get_basename().get_file()) var height: int = image.get_height() @@ -506,3 +513,28 @@ func import_image_palette(path: String, image : Image) -> Palette: image.unlock() return result + + +# Import of deprecated older json palette format +func import_json_palette(text: String): + var result: Palette = Palette.new() + var result_json = JSON.parse(text) + + if result_json.error != OK: # If parse has errors + printerr("JSON palette import error") + printerr("Error: ", result_json.error) + printerr("Error Line: ", result_json.error_line) + printerr("Error String: ", result_json.error_string) + result = null + else: # If parse OK + var data = result_json.result + if data.has("name"): # If data is 'valid' palette file + result.name = data.name + if data.has("comments"): + result.comment = data.comments + if data.has("colors"): + for color_data in data.colors: + var color: Color = Color(color_data.data) + result.add_color(color) + + return result