Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Godot File Handler #268

Merged
merged 10 commits into from
May 18, 2024
16 changes: 16 additions & 0 deletions FileHandler.gd
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
static func call_xml_converter(args: PoolStringArray):
var output: Array = []
print(args)
var result: int = OS.execute("./xml_converter/build/xml_converter", args, true, output, true)
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This can probably be a constant variable in FileHandler instead of a magic string here.

Also: does this work with the exported files? I think it is fine if not right now but we will need to test it to be sure.

print(output)
if result != OK:
print("Failed to execute the converter. Error code:", result)
else:
print("Command executed successfully.")

static func create_directory_if_missing(path: String):
var dir = Directory.new()
if not dir.dir_exists(path):
var success = dir.make_dir(path)
if success != OK:
print("Error: Could not create data folder:", path)
25 changes: 25 additions & 0 deletions ImportPackDialog.gd
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
extends FileDialog

const FileHandler = preload("res://FileHandler.gd")
AsherGlick marked this conversation as resolved.
Show resolved Hide resolved
var downloaded_markers_dir: String
var unsaved_markers_dir: String
var user_data_dir: String

func _ready():
#TODO: Move these to global file Settings so they can be customized
self.user_data_dir = str(OS.get_user_data_dir())
self.downloaded_markers_dir = self.user_data_dir.plus_file("packs")
self.unsaved_markers_dir = self.user_data_dir.plus_file("protobins")
FileHandler.create_directory_if_missing(self.downloaded_markers_dir)
FileHandler.create_directory_if_missing(self.unsaved_markers_dir)

func _on_FileDialog_dir_selected(dir_path: String):
print("Selected folder:", dir_path)
var new_path: String = self.downloaded_markers_dir.plus_file(dir_path.get_file())
FileHandler.create_directory_if_missing(new_path)
var args: PoolStringArray = [
"--input-taco-path", dir_path,
"--output-waypoint-path", new_path,
"--output-split-waypoint-path", self.unsaved_markers_dir
]
FileHandler.call_xml_converter(args)
44 changes: 0 additions & 44 deletions PackDialog.gd

This file was deleted.

19 changes: 2 additions & 17 deletions Spatial.gd
Original file line number Diff line number Diff line change
Expand Up @@ -51,9 +51,10 @@ const category3d_scene = preload("res://Category3D.tscn")
const category2d_scene = preload("res://Category2D.tscn")
const path2d_scene = preload("res://Route2D.tscn")
const gizmo_scene = preload("res://Gizmo/PointEdit.tscn")

# Scripts containing code used by this scene
const CategoryData = preload("res://CategoryData.gd")
const Waypoint = preload("res://waypoint.gd")
const PackDialog = preload("res://PackDialog.gd")

##########Node Connections###########
onready var markers_ui := $Control/Dialogs/CategoriesDialog/MarkersUI as Tree
Expand Down Expand Up @@ -817,22 +818,6 @@ func _on_NewPathPoint_pressed():
self.currently_active_path.add_point(z_accurate_player_position)
self.currently_active_path_2d.add_point(Vector2(self.player_position.x, -self.player_position.z))


################################################################################
#
################################################################################
func _on_SavePath_pressed():
$Control/Dialogs/SaveDialog.show()

################################################################################
# TODO: This function will be used when exporting packs
################################################################################
func _on_SaveDialog_file_selected(path):
self.markerdata[str(self.map_id)] = data_from_renderview()
var save_game = File.new()
save_game.open(path, File.WRITE)
save_game.store_string(JSON.print(self.markerdata))

func _on_NodeEditorDialog_hide():
self.currently_selected_node = null
clear_adjustment_nodes()
Expand Down
2 changes: 1 addition & 1 deletion Spatial.tscn
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
[ext_resource path="res://icon_new_point.png" type="Texture" id=11]
[ext_resource path="res://SettingsDialog.gd" type="Script" id=12]
[ext_resource path="res://Category3D.gd" type="Script" id=13]
[ext_resource path="res://PackDialog.gd" type="Script" id=14]
[ext_resource path="res://ImportPackDialog.gd" type="Script" id=14]
[ext_resource path="res://Category2D.gd" type="Script" id=15]

[sub_resource type="Shader" id=1]
Expand Down
Loading