1
0
Fork 0
mirror of https://github.com/Orama-Interactive/Pixelorama.git synced 2025-01-18 17:19:50 +00:00

[CLI] Make arguments case sensitive, add support for OS.get_cmdline_user_args(), add short form flags as alternatives for the long form arguments

This commit is contained in:
Emmanouil Papadeas 2024-04-03 16:25:34 +03:00
parent af01234470
commit 1c8d81d1b7

View file

@ -191,6 +191,7 @@ func _handle_backup() -> void:
func _handle_cmdline_arguments() -> void: func _handle_cmdline_arguments() -> void:
var args := OS.get_cmdline_args() var args := OS.get_cmdline_args()
args.append_array(OS.get_cmdline_user_args())
if args.is_empty(): if args.is_empty():
return return
# Load the files first # Load the files first
@ -206,33 +207,32 @@ func _handle_cmdline_arguments() -> void:
var should_export := false var should_export := false
for i in args.size(): # Handle the rest of the CLI arguments for i in args.size(): # Handle the rest of the CLI arguments
var arg := args[i] var arg := args[i]
var arg_lower := arg.to_lower() var next_argument := ""
if i + 1 < args.size():
next_argument = args[i + 1]
if arg.begins_with("-") or arg.begins_with("--"): if arg.begins_with("-") or arg.begins_with("--"):
if arg_lower == "--pixelorama-version": if arg in ["--version", "--pixelorama-version"]:
print(Global.current_version) print(Global.current_version)
elif arg_lower == "--size": elif arg == "--size":
print(project.size) print(project.size)
elif arg_lower == "--framecount": elif arg == "--framecount":
print(project.frames.size()) print(project.frames.size())
elif arg_lower == "--export": elif arg in ["--export", "-e"]:
should_export = true should_export = true
elif arg_lower == "--spritesheet": elif arg in ["--spritesheet", "-s"]:
Export.current_tab = Export.ExportTab.SPRITESHEET Export.current_tab = Export.ExportTab.SPRITESHEET
should_export = true should_export = true
elif arg_lower == "--output" or arg_lower == "-o": elif arg in ["--output", "-o"]:
if i + 1 < args.size(): if not next_argument.is_empty():
var next_argument := args[i + 1]
project.file_name = next_argument.get_basename() project.file_name = next_argument.get_basename()
var extension := next_argument.get_extension() var extension := next_argument.get_extension()
project.file_format = Export.get_file_format_from_extension(extension) project.file_format = Export.get_file_format_from_extension(extension)
elif arg_lower == "--scale": elif arg == "--scale":
if i + 1 < args.size(): if not next_argument.is_empty():
var next_argument := args[i + 1]
if next_argument.is_valid_float(): if next_argument.is_valid_float():
Export.resize = next_argument.to_float() * 100 Export.resize = next_argument.to_float() * 100
elif arg_lower == "--frames": elif arg in ["--frames", "-f"]:
if i + 1 < args.size(): if not next_argument.is_empty():
var next_argument := args[i + 1]
if next_argument.contains("-"): if next_argument.contains("-"):
var frame_numbers := next_argument.split("-") var frame_numbers := next_argument.split("-")
if frame_numbers.size() > 1: if frame_numbers.size() > 1:
@ -255,9 +255,9 @@ func _handle_cmdline_arguments() -> void:
project.selected_cels = [[frame_number, project.current_layer]] project.selected_cels = [[frame_number, project.current_layer]]
project.change_cel(frame_number) project.change_cel(frame_number)
Export.frame_current_tag = Export.ExportFrames.SELECTED_FRAMES Export.frame_current_tag = Export.ExportFrames.SELECTED_FRAMES
elif arg_lower == "--direction": elif arg in ["--direction", "-d"]:
if i + 1 < args.size(): if not next_argument.is_empty():
var next_argument := args[i + 1].to_lower() next_argument = next_argument.to_lower()
if next_argument == "0" or next_argument.contains("forward"): if next_argument == "0" or next_argument.contains("forward"):
Export.direction = Export.AnimationDirection.FORWARD Export.direction = Export.AnimationDirection.FORWARD
elif next_argument == "1" or next_argument.contains("backward"): elif next_argument == "1" or next_argument.contains("backward"):
@ -268,7 +268,7 @@ func _handle_cmdline_arguments() -> void:
print(Export.AnimationDirection.keys()[Export.direction]) print(Export.AnimationDirection.keys()[Export.direction])
else: else:
print(Export.AnimationDirection.keys()[Export.direction]) print(Export.AnimationDirection.keys()[Export.direction])
elif arg_lower == "--split-layers": elif arg == "--split-layers":
Export.split_layers = true Export.split_layers = true
if should_export: if should_export:
Export.external_export(project) Export.external_export(project)