mirror of
https://port.numenaute.org/aleajactaest/bazar_alea.git
synced 2024-11-21 14:46:14 +00:00
adding client
This commit is contained in:
parent
3816f3ca6e
commit
56c84e1ee7
16 changed files with 856 additions and 0 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -1,2 +1,4 @@
|
||||||
.rust/
|
.rust/
|
||||||
server/target/
|
server/target/
|
||||||
|
Godot_*
|
||||||
|
.current_version
|
||||||
|
|
4
client/.gitignore
vendored
Normal file
4
client/.gitignore
vendored
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
# Godot 4+ specific ignores
|
||||||
|
.godot/
|
||||||
|
assets/*.import
|
||||||
|
*.import
|
BIN
client/assets/ground.jpg
Normal file
BIN
client/assets/ground.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 12 KiB |
BIN
client/assets/player.glb
Normal file
BIN
client/assets/player.glb
Normal file
Binary file not shown.
BIN
client/assets/root.glb
Normal file
BIN
client/assets/root.glb
Normal file
Binary file not shown.
13
client/assets/root.tscn
Normal file
13
client/assets/root.tscn
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
[gd_scene load_steps=3 format=3 uid="uid://c688gu5xrshpg"]
|
||||||
|
|
||||||
|
[ext_resource type="PackedScene" uid="uid://b5ej7nfagdlmf" path="res://assets/root.glb" id="1_s8vvr"]
|
||||||
|
|
||||||
|
[sub_resource type="ConcavePolygonShape3D" id="ConcavePolygonShape3D_rf26g"]
|
||||||
|
data = PackedVector3Array(20, -1, -20, -21, -1, 20, -21, -1, -20, 20, -1, -20, 20, -1, 20, -21, -1, 20, 20, -3, 20, -21, -1, 20, 20, -1, 20, 20, -3, 20, -21, -3, 20, -21, -1, 20, -21, -3, 20, -21, -1, -20, -21, -1, 20, -21, -3, 20, -21, -3, -20, -21, -1, -20, -21, -3, -20, 20, -3, 20, 20, -3, -20, -21, -3, -20, -21, -3, 20, 20, -3, 20, 20, -3, -20, 20, -1, 20, 20, -1, -20, 20, -3, -20, 20, -3, 20, 20, -1, 20, -21, -3, -20, 20, -1, -20, -21, -1, -20, -21, -3, -20, 20, -3, -20, 20, -1, -20)
|
||||||
|
|
||||||
|
[node name="root" instance=ExtResource("1_s8vvr")]
|
||||||
|
|
||||||
|
[node name="StaticBody3D" type="StaticBody3D" parent="Cube" index="0"]
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="Cube/StaticBody3D" index="0"]
|
||||||
|
shape = SubResource("ConcavePolygonShape3D_rf26g")
|
1
client/icon.svg
Normal file
1
client/icon.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg height="128" width="128" xmlns="http://www.w3.org/2000/svg"><rect x="2" y="2" width="124" height="124" rx="14" fill="#363d52" stroke="#212532" stroke-width="4"/><g transform="scale(.101) translate(122 122)"><g fill="#fff"><path d="M105 673v33q407 354 814 0v-33z"/><path fill="#478cbf" d="m105 673 152 14q12 1 15 14l4 67 132 10 8-61q2-11 15-15h162q13 4 15 15l8 61 132-10 4-67q3-13 15-14l152-14V427q30-39 56-81-35-59-83-108-43 20-82 47-40-37-88-64 7-51 8-102-59-28-123-42-26 43-46 89-49-7-98 0-20-46-46-89-64 14-123 42 1 51 8 102-48 27-88 64-39-27-82-47-48 49-83 108 26 42 56 81zm0 33v39c0 276 813 276 813 0v-39l-134 12-5 69q-2 10-14 13l-162 11q-12 0-16-11l-10-65H447l-10 65q-4 11-16 11l-162-11q-12-3-14-13l-5-69z"/><path d="M483 600c3 34 55 34 58 0v-86c-3-34-55-34-58 0z"/><circle cx="725" cy="526" r="90"/><circle cx="299" cy="526" r="90"/></g><g fill="#414042"><circle cx="307" cy="532" r="60"/><circle cx="717" cy="532" r="60"/></g></g></svg>
|
After Width: | Height: | Size: 950 B |
60
client/project.godot
Normal file
60
client/project.godot
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
; Engine configuration file.
|
||||||
|
; It's best edited using the editor UI and not directly,
|
||||||
|
; since the parameters that go here are not all obvious.
|
||||||
|
;
|
||||||
|
; Format:
|
||||||
|
; [section] ; section goes between []
|
||||||
|
; param=value ; assign values to parameters
|
||||||
|
|
||||||
|
config_version=5
|
||||||
|
|
||||||
|
[application]
|
||||||
|
|
||||||
|
config/name="Khaganat Short Client Server"
|
||||||
|
run/main_scene="res://scenes/main.tscn"
|
||||||
|
config/features=PackedStringArray("4.1", "Forward Plus")
|
||||||
|
config/icon="res://icon.svg"
|
||||||
|
|
||||||
|
[input]
|
||||||
|
|
||||||
|
ui_left={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":4194319,"physical_keycode":0,"key_label":0,"unicode":0,"echo":false,"script":null)
|
||||||
|
, Object(InputEventJoypadButton,"resource_local_to_scene":false,"resource_name":"","device":0,"button_index":13,"pressure":0.0,"pressed":false,"script":null)
|
||||||
|
, Object(InputEventJoypadMotion,"resource_local_to_scene":false,"resource_name":"","device":0,"axis":0,"axis_value":-1.0,"script":null)
|
||||||
|
, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":65,"key_label":0,"unicode":113,"echo":false,"script":null)
|
||||||
|
, null]
|
||||||
|
}
|
||||||
|
ui_right={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":4194321,"physical_keycode":0,"key_label":0,"unicode":0,"echo":false,"script":null)
|
||||||
|
, Object(InputEventJoypadButton,"resource_local_to_scene":false,"resource_name":"","device":0,"button_index":14,"pressure":0.0,"pressed":false,"script":null)
|
||||||
|
, Object(InputEventJoypadMotion,"resource_local_to_scene":false,"resource_name":"","device":0,"axis":0,"axis_value":1.0,"script":null)
|
||||||
|
, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":68,"key_label":0,"unicode":100,"echo":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
ui_up={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":4194320,"physical_keycode":0,"key_label":0,"unicode":0,"echo":false,"script":null)
|
||||||
|
, Object(InputEventJoypadButton,"resource_local_to_scene":false,"resource_name":"","device":0,"button_index":11,"pressure":0.0,"pressed":false,"script":null)
|
||||||
|
, Object(InputEventJoypadMotion,"resource_local_to_scene":false,"resource_name":"","device":0,"axis":1,"axis_value":-1.0,"script":null)
|
||||||
|
, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":87,"key_label":0,"unicode":122,"echo":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
ui_down={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":4194322,"physical_keycode":0,"key_label":0,"unicode":0,"echo":false,"script":null)
|
||||||
|
, Object(InputEventJoypadButton,"resource_local_to_scene":false,"resource_name":"","device":0,"button_index":12,"pressure":0.0,"pressed":false,"script":null)
|
||||||
|
, Object(InputEventJoypadMotion,"resource_local_to_scene":false,"resource_name":"","device":0,"axis":1,"axis_value":1.0,"script":null)
|
||||||
|
, Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":83,"key_label":0,"unicode":115,"echo":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
ui_rotate_player={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventMouseButton,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"button_mask":0,"position":Vector2(0, 0),"global_position":Vector2(0, 0),"factor":1.0,"button_index":1,"canceled":false,"pressed":false,"double_click":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
[rendering]
|
||||||
|
|
||||||
|
environment/defaults/default_clear_color=Color(0.682353, 0.678431, 0.631373, 1)
|
58
client/scenes/Window.gd
Normal file
58
client/scenes/Window.gd
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
extends Window
|
||||||
|
|
||||||
|
var focus_ok:bool = false
|
||||||
|
var last_event = null
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
pass # Replace with function body.
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(_delta):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
func _on_button_pressed():
|
||||||
|
if $VBoxContainer/TextEdit.get_text() != "":
|
||||||
|
self.hide()
|
||||||
|
#get_parent().get_node("CharacterBody3D").set_enable_event(true)
|
||||||
|
get_parent().connect_enet($VBoxContainer/TextEdit.get_text())
|
||||||
|
|
||||||
|
|
||||||
|
func _on_text_edit_text_changed(value:String):
|
||||||
|
if len(value) > 0:
|
||||||
|
$VBoxContainer/Button.disabled = false
|
||||||
|
else:
|
||||||
|
$VBoxContainer/Button.disabled = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_focus_entered():
|
||||||
|
focus_ok = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_focus_exited():
|
||||||
|
focus_ok = false
|
||||||
|
|
||||||
|
|
||||||
|
func _on_mouse_entered():
|
||||||
|
focus_ok = true
|
||||||
|
self.get_parent().CharacterBody3D.disabled = true
|
||||||
|
|
||||||
|
|
||||||
|
func _on_mouse_exited():
|
||||||
|
focus_ok = false
|
||||||
|
self.get_parent().CharacterBody3D.disabled = false
|
||||||
|
|
||||||
|
func open_windows():
|
||||||
|
focus_ok = false
|
||||||
|
get_parent().get_node("CharacterBody3D").set_enable_event(false)
|
||||||
|
self.show()
|
||||||
|
|
||||||
|
#func _on_window_input(event):
|
||||||
|
# if event.is_pressed() == false:
|
||||||
|
# return
|
||||||
|
# if focus_ok:
|
||||||
|
# return
|
||||||
|
# if (event is InputEventKey) && (self.type_event == 1):
|
||||||
|
# last_event = event
|
299
client/scenes/main.gd
Normal file
299
client/scenes/main.gd
Normal file
|
@ -0,0 +1,299 @@
|
||||||
|
extends Node3D
|
||||||
|
|
||||||
|
# The player name.
|
||||||
|
var player_name: String
|
||||||
|
var connected:bool = false
|
||||||
|
var enet:ENetConnection
|
||||||
|
var dataEnet:ENetPacketPeer
|
||||||
|
var errorEnet:Error
|
||||||
|
var id = 0
|
||||||
|
var maxplayer = 0
|
||||||
|
|
||||||
|
# Server confirm our account
|
||||||
|
var account_confirmed:bool = false
|
||||||
|
|
||||||
|
const PLAYER = preload("res://scenes/player.tscn")
|
||||||
|
|
||||||
|
const PORT = 33333
|
||||||
|
const ADDR = "127.0.0.1"
|
||||||
|
|
||||||
|
var dtls := PacketPeerDTLS.new()
|
||||||
|
var udp := PacketPeerUDP.new()
|
||||||
|
|
||||||
|
|
||||||
|
func test_cert(filename):
|
||||||
|
print("------", filename)
|
||||||
|
enet = ENetConnection.new()
|
||||||
|
print(enet)
|
||||||
|
#var cert: X509Certificate = X509Certificate.new()
|
||||||
|
#errorEnet = cert.load(filename)
|
||||||
|
#print("load cert:", errorEnet)
|
||||||
|
#print(cert)
|
||||||
|
#var client_tls_options = TLSOptions.client_unsafe(cert)
|
||||||
|
#print(client_tls_options)
|
||||||
|
errorEnet = enet.create_host(10)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET.create_host: ", errorEnet)
|
||||||
|
return
|
||||||
|
#enet.connect_to_host(ADDR, PORT)
|
||||||
|
#errorEnet = enet.dtls_client_setup(ADDR, client_tls_options)
|
||||||
|
#print("dtls_client_setup:", errorEnet)
|
||||||
|
#if errorEnet != OK:
|
||||||
|
# print("ERROR ENET: ", errorEnet)
|
||||||
|
# return
|
||||||
|
dataEnet = enet.connect_to_host(ADDR, PORT, 10)
|
||||||
|
print(dataEnet)
|
||||||
|
if not dataEnet.is_active():
|
||||||
|
print("ERROR enet.connect_to_host: ", dataEnet.is_active())
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
func create_server_enet():
|
||||||
|
print("------ create_server_enet")
|
||||||
|
test_cert("res://cert.crt")
|
||||||
|
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
func _ready():
|
||||||
|
#test_cert("res://cert.crt")
|
||||||
|
create_server_enet()
|
||||||
|
pass # Replace with function body.
|
||||||
|
|
||||||
|
|
||||||
|
func decode_msg(data:PackedByteArray):
|
||||||
|
print("==========================")
|
||||||
|
var cmd = data.decode_u8(0)
|
||||||
|
print("cmd:", cmd)
|
||||||
|
var taille = data.decode_u8(1)
|
||||||
|
print("taille:", taille)
|
||||||
|
var str:String = ""
|
||||||
|
var tmp = data.slice(2,taille+2)
|
||||||
|
print("tmp:", tmp)
|
||||||
|
|
||||||
|
str = tmp.get_string_from_utf8()
|
||||||
|
|
||||||
|
print("str:", str)
|
||||||
|
print("len str:", len(str))
|
||||||
|
|
||||||
|
print("==========================")
|
||||||
|
|
||||||
|
func send_account():
|
||||||
|
var data:PackedByteArray = PackedByteArray()
|
||||||
|
|
||||||
|
#data.encode_u8(1,0)
|
||||||
|
data.append(1)
|
||||||
|
data.append(len(player_name))
|
||||||
|
var packed_array = player_name.to_ascii_buffer()
|
||||||
|
# var str:PackedStringArray = PackedStringArray()
|
||||||
|
# str.push_back(player_name)
|
||||||
|
data += packed_array
|
||||||
|
#data.append_array(str.to_byte_array())
|
||||||
|
|
||||||
|
# print("-------------------------")
|
||||||
|
# print(len(packed_array))
|
||||||
|
# print("player_name: ", player_name)
|
||||||
|
# print("packed_array: ", packed_array)
|
||||||
|
# print("str: ", str)
|
||||||
|
# print("str -> bytes: ", str.to_byte_array())
|
||||||
|
# print("data: ", data)
|
||||||
|
# print("-------------------------")
|
||||||
|
|
||||||
|
print(player_name, " -> size:", data.size(), " / " , len(player_name) )
|
||||||
|
errorEnet = dataEnet.send(1, data, 1)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET: ", errorEnet)
|
||||||
|
return
|
||||||
|
#decode_msg(data)
|
||||||
|
|
||||||
|
|
||||||
|
func set_player_position(pos: Vector3):
|
||||||
|
self.get_node("CharacterBody3D").set_global_position(pos)
|
||||||
|
|
||||||
|
|
||||||
|
func get_player_position():
|
||||||
|
if not account_confirmed:
|
||||||
|
return
|
||||||
|
print("perso: ", id, " ", self.get_node("CharacterBody3D").get_position())
|
||||||
|
var pos:PackedFloat64Array = PackedFloat64Array()
|
||||||
|
var posRaw:Vector3 = self.get_node("CharacterBody3D").get_position()
|
||||||
|
#posRaw.x = 123456789182729270e15
|
||||||
|
#posRaw.y = 2.0
|
||||||
|
#posRaw.z = 3.0
|
||||||
|
pos.append(posRaw.x)
|
||||||
|
#print("x:", pos.to_byte_array())
|
||||||
|
pos.append(posRaw.y)
|
||||||
|
#print("x+y:", pos.to_byte_array())
|
||||||
|
pos.append(posRaw.z)
|
||||||
|
#print("x+y+z:", pos.to_byte_array())
|
||||||
|
var data:PackedByteArray = PackedByteArray()
|
||||||
|
data += pos.to_byte_array()
|
||||||
|
#data.append(len(player_name))
|
||||||
|
#var packed_array = player_name.to_ascii_buffer()
|
||||||
|
#data += packed_array
|
||||||
|
#print(player_name, " -> size:", data.size(), " / " , len(player_name) )
|
||||||
|
errorEnet = dataEnet.send(2, data, 1)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET: ", errorEnet)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
func bad_acocunt():
|
||||||
|
player_name = ""
|
||||||
|
self.get_node("Window").open_windows()
|
||||||
|
|
||||||
|
|
||||||
|
func get_event_received():
|
||||||
|
var data = dataEnet.get_packet()
|
||||||
|
print("get: ", data)
|
||||||
|
if data[0] == 1: # Return connexion
|
||||||
|
if data[1] == 0: # OK
|
||||||
|
id = data.decode_u64(2)
|
||||||
|
var x = data.decode_double(2+8)
|
||||||
|
var y = data.decode_double(2+16)
|
||||||
|
var z = data.decode_double(2+24)
|
||||||
|
print("id:", id, " x:", x, " y:", y, " z:", z)
|
||||||
|
self.set_player_position(Vector3(x, y, z))
|
||||||
|
account_confirmed = true
|
||||||
|
self.get_node("CharacterBody3D").set_enable_event(true)
|
||||||
|
else: # KO
|
||||||
|
bad_acocunt()
|
||||||
|
elif data[0] == 3: # Get position
|
||||||
|
if id == 0:
|
||||||
|
return
|
||||||
|
var nb = data[1]
|
||||||
|
var pos = 2
|
||||||
|
for i in nb:
|
||||||
|
var mid = data.decode_u64(pos)
|
||||||
|
var mx = data.decode_double(pos+8)
|
||||||
|
var my = data.decode_double(pos+16)
|
||||||
|
var mz = data.decode_double(pos+24)
|
||||||
|
pos += 32
|
||||||
|
if mid == id:
|
||||||
|
print("Me id:", mid, " x:", mx, " y:", my, " z:", mz)
|
||||||
|
continue
|
||||||
|
print("-- id:", mid, " x:", mx, " y:", my, " z:", mz)
|
||||||
|
var child = $Players.find_child(str(mid), false, false)
|
||||||
|
if child == null:
|
||||||
|
print("Not found")
|
||||||
|
if maxplayer > 3:
|
||||||
|
continue
|
||||||
|
var scene = preload("res://scenes/player.tscn")
|
||||||
|
var instance = scene.instantiate()
|
||||||
|
#var current_scene = scene.instance()
|
||||||
|
#var GrabbedInstance = PLAYER.instance()
|
||||||
|
instance.set_name(str(mid))
|
||||||
|
$Players.add_child(instance)
|
||||||
|
#$Players.add_child(scene)
|
||||||
|
maxplayer += 1
|
||||||
|
for child3 in $Players.get_children():
|
||||||
|
print(" -> ", child3.get_name())
|
||||||
|
var child2 = $Players.find_child(str(mid), false, false)
|
||||||
|
child2.set_global_position(Vector3(mx, my, mz))
|
||||||
|
|
||||||
|
else:
|
||||||
|
child.set_global_position(Vector3(mx, my, mz))
|
||||||
|
print("Found:", $Players.get_child_count())
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(_delta):
|
||||||
|
#print("state:", dataEnet.get_state())
|
||||||
|
get_player_position()
|
||||||
|
if dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTED:
|
||||||
|
var event = enet.service()
|
||||||
|
if event[0] == ENetConnection.EVENT_RECEIVE:
|
||||||
|
#print("get: ", dataEnet.get_packet())
|
||||||
|
get_event_received()
|
||||||
|
if player_name != "" and not account_confirmed:
|
||||||
|
send_account()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTING:
|
||||||
|
var event = enet.service()
|
||||||
|
if event[0] == ENetConnection.EVENT_RECEIVE:
|
||||||
|
pass
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_DISCONNECTED:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_ACKNOWLEDGING_CONNECT:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTION_PENDING:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTION_SUCCEEDED:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_DISCONNECT_LATER:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_DISCONNECTING:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_ACKNOWLEDGING_DISCONNECT:
|
||||||
|
var _event = enet.service()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_ZOMBIE:
|
||||||
|
var _event = enet.service()
|
||||||
|
else:
|
||||||
|
var _event = enet.service()
|
||||||
|
|
||||||
|
|
||||||
|
func _process_ter(_delta):
|
||||||
|
var res = enet.service(1)
|
||||||
|
#print(res)
|
||||||
|
if res[0] == ENetConnection.EVENT_RECEIVE:
|
||||||
|
#print("EVENT_RECEIVE")
|
||||||
|
print(dataEnet.get_packet())
|
||||||
|
#if res[1]
|
||||||
|
var data:PackedByteArray = PackedByteArray()
|
||||||
|
data.append(len(player_name))
|
||||||
|
data.append(123)
|
||||||
|
errorEnet = dataEnet.send(1, data, 1)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET: ", errorEnet)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
func _process_bis(_delta):
|
||||||
|
if not dataEnet.is_active():
|
||||||
|
create_server_enet()
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTING:
|
||||||
|
var res = enet.service(1)
|
||||||
|
print(res)
|
||||||
|
elif dataEnet.get_state() == ENetPacketPeer.STATE_CONNECTED:
|
||||||
|
var res = enet.service(1)
|
||||||
|
print(res)
|
||||||
|
var data:PackedByteArray = PackedByteArray()
|
||||||
|
data.append(len(player_name))
|
||||||
|
data.append(123)
|
||||||
|
errorEnet = dataEnet.send(1, data, 1)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET: ", errorEnet)
|
||||||
|
return
|
||||||
|
#print("<> get_state: ", dataEnet.get_state())
|
||||||
|
else:
|
||||||
|
print("get_state: ", dataEnet.get_state())
|
||||||
|
return
|
||||||
|
|
||||||
|
if not connected:
|
||||||
|
if player_name != "":
|
||||||
|
create_server_enet()
|
||||||
|
return
|
||||||
|
var res = enet.service(1)
|
||||||
|
print(res)
|
||||||
|
return
|
||||||
|
if not connected:
|
||||||
|
if player_name != "":
|
||||||
|
create_server_enet()
|
||||||
|
else:
|
||||||
|
var data:PackedByteArray = PackedByteArray()
|
||||||
|
data.append(len(player_name))
|
||||||
|
data.append(123)
|
||||||
|
#print(len(data))
|
||||||
|
print("active:", dataEnet.is_active())
|
||||||
|
print("state:", dataEnet.get_state())
|
||||||
|
print("address:", dataEnet.get_remote_address())
|
||||||
|
print("port:", dataEnet.get_remote_port())
|
||||||
|
errorEnet = dataEnet.send(1, data, 1)
|
||||||
|
if errorEnet != OK:
|
||||||
|
print("ERROR ENET: ", errorEnet)
|
||||||
|
return
|
||||||
|
#enet.socket_send(ADDR, PORT, data)
|
||||||
|
|
||||||
|
|
||||||
|
func connect_enet(_name:String):
|
||||||
|
player_name = _name
|
||||||
|
print("My name:" + player_name)
|
||||||
|
|
21
client/scenes/main.gdshader
Normal file
21
client/scenes/main.gdshader
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
shader_type spatial;
|
||||||
|
|
||||||
|
void fragment() {
|
||||||
|
bool v = false;
|
||||||
|
bool w = false;
|
||||||
|
float b = 0.0;
|
||||||
|
float g = 0.2;
|
||||||
|
float r = 0.0;
|
||||||
|
if ( mod(UV.x,0.005) > 0.0025 ) {
|
||||||
|
v = true;
|
||||||
|
};
|
||||||
|
if ( mod(UV.y,0.005) > 0.0025 ) {
|
||||||
|
w = true;
|
||||||
|
};
|
||||||
|
if ( ( v && ! w ) || ( !v && w ) ) {
|
||||||
|
b = 0.0;
|
||||||
|
g = 0.0;
|
||||||
|
r = 0.2;
|
||||||
|
}
|
||||||
|
ALBEDO = vec3(r, g, b);
|
||||||
|
}
|
89
client/scenes/main.tscn
Normal file
89
client/scenes/main.tscn
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
[gd_scene load_steps=11 format=3 uid="uid://bemavktwweaog"]
|
||||||
|
|
||||||
|
[ext_resource type="Shader" path="res://scenes/main.gdshader" id="1_caff6"]
|
||||||
|
[ext_resource type="PackedScene" uid="uid://cg5uqqd4ibdem" path="res://scenes/player.tscn" id="1_nc7b3"]
|
||||||
|
[ext_resource type="Script" path="res://scenes/main.gd" id="1_ts8of"]
|
||||||
|
[ext_resource type="Script" path="res://scenes/Window.gd" id="3_uwnj8"]
|
||||||
|
|
||||||
|
[sub_resource type="BoxShape3D" id="BoxShape3D_5dcgs"]
|
||||||
|
size = Vector3(1000, 1, 1000)
|
||||||
|
|
||||||
|
[sub_resource type="ShaderMaterial" id="ShaderMaterial_gypq5"]
|
||||||
|
render_priority = 0
|
||||||
|
shader = ExtResource("1_caff6")
|
||||||
|
|
||||||
|
[sub_resource type="BoxMesh" id="BoxMesh_fm2j6"]
|
||||||
|
material = SubResource("ShaderMaterial_gypq5")
|
||||||
|
size = Vector3(1000, 1, 1000)
|
||||||
|
|
||||||
|
[sub_resource type="ProceduralSkyMaterial" id="ProceduralSkyMaterial_0qg6h"]
|
||||||
|
|
||||||
|
[sub_resource type="Sky" id="Sky_i4xvw"]
|
||||||
|
sky_material = SubResource("ProceduralSkyMaterial_0qg6h")
|
||||||
|
|
||||||
|
[sub_resource type="Environment" id="Environment_12j7q"]
|
||||||
|
background_mode = 2
|
||||||
|
background_color = Color(0.803922, 0.776471, 0.733333, 1)
|
||||||
|
sky = SubResource("Sky_i4xvw")
|
||||||
|
ambient_light_color = Color(0.968627, 0.933333, 0.596078, 1)
|
||||||
|
reflected_light_source = 2
|
||||||
|
|
||||||
|
[node name="main" type="Node3D"]
|
||||||
|
script = ExtResource("1_ts8of")
|
||||||
|
|
||||||
|
[node name="ground" type="StaticBody3D" parent="."]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, -1, 0)
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="ground"]
|
||||||
|
shape = SubResource("BoxShape3D_5dcgs")
|
||||||
|
|
||||||
|
[node name="MeshInstance3D" type="MeshInstance3D" parent="ground"]
|
||||||
|
mesh = SubResource("BoxMesh_fm2j6")
|
||||||
|
|
||||||
|
[node name="DirectionalLight3D" type="DirectionalLight3D" parent="."]
|
||||||
|
transform = Transform3D(-0.866025, 0, -0.5, -0.25, 0.866025, 0.433013, 0.433013, 0.5, -0.75, 0, 50, 0)
|
||||||
|
shadow_enabled = true
|
||||||
|
shadow_opacity = 0.5
|
||||||
|
|
||||||
|
[node name="CharacterBody3D" parent="." instance=ExtResource("1_nc7b3")]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 6, 0)
|
||||||
|
|
||||||
|
[node name="Players" type="Node3D" parent="."]
|
||||||
|
|
||||||
|
[node name="WorldEnvironment" type="WorldEnvironment" parent="."]
|
||||||
|
environment = SubResource("Environment_12j7q")
|
||||||
|
|
||||||
|
[node name="Window" type="Window" parent="."]
|
||||||
|
title = "Connexion"
|
||||||
|
initial_position = 1
|
||||||
|
size = Vector2i(300, 100)
|
||||||
|
script = ExtResource("3_uwnj8")
|
||||||
|
|
||||||
|
[node name="VBoxContainer" type="VBoxContainer" parent="Window"]
|
||||||
|
anchors_preset = 15
|
||||||
|
anchor_right = 1.0
|
||||||
|
anchor_bottom = 1.0
|
||||||
|
grow_horizontal = 2
|
||||||
|
grow_vertical = 2
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="Window/VBoxContainer"]
|
||||||
|
layout_mode = 2
|
||||||
|
text = "Login"
|
||||||
|
horizontal_alignment = 1
|
||||||
|
|
||||||
|
[node name="TextEdit" type="LineEdit" parent="Window/VBoxContainer"]
|
||||||
|
layout_mode = 2
|
||||||
|
size_flags_vertical = 3
|
||||||
|
placeholder_text = "Account"
|
||||||
|
|
||||||
|
[node name="Button" type="Button" parent="Window/VBoxContainer"]
|
||||||
|
layout_mode = 2
|
||||||
|
disabled = true
|
||||||
|
text = "OK"
|
||||||
|
|
||||||
|
[connection signal="focus_entered" from="Window" to="Window" method="_on_focus_entered"]
|
||||||
|
[connection signal="focus_exited" from="Window" to="Window" method="_on_focus_exited"]
|
||||||
|
[connection signal="mouse_entered" from="Window" to="Window" method="_on_mouse_entered"]
|
||||||
|
[connection signal="mouse_exited" from="Window" to="Window" method="_on_mouse_exited"]
|
||||||
|
[connection signal="text_changed" from="Window/VBoxContainer/TextEdit" to="Window" method="_on_text_edit_text_changed"]
|
||||||
|
[connection signal="pressed" from="Window/VBoxContainer/Button" to="Window" method="_on_button_pressed"]
|
67
client/scenes/player.gd
Normal file
67
client/scenes/player.gd
Normal file
|
@ -0,0 +1,67 @@
|
||||||
|
extends CharacterBody3D
|
||||||
|
|
||||||
|
|
||||||
|
const SPEED = 30.0
|
||||||
|
const JUMP_VELOCITY = 14.5
|
||||||
|
|
||||||
|
# Get the gravity from the project settings to be synced with RigidBody nodes.
|
||||||
|
var gravity = ProjectSettings.get_setting("physics/3d/default_gravity")
|
||||||
|
@export var event_disabled:bool = true
|
||||||
|
|
||||||
|
# How fast the player moves in meters per second.
|
||||||
|
@export var speed = 14
|
||||||
|
# The downward acceleration when in the air, in meters per second squared.
|
||||||
|
@export var fall_acceleration = 75
|
||||||
|
|
||||||
|
var target_velocity = Vector3.ZERO
|
||||||
|
|
||||||
|
var direction = Vector3.FORWARD
|
||||||
|
var h_sensitivity:float = 0.1
|
||||||
|
var v_sensitivity:float = 0.1
|
||||||
|
var camrot_h:float = 0.0
|
||||||
|
var camrot_v:float = 0.0
|
||||||
|
var h_acceleration:float = 10.0
|
||||||
|
var v_acceleration:float = 10.0
|
||||||
|
var input_view_camera_move_player_follow_mouse:bool = false
|
||||||
|
|
||||||
|
func _input(event):
|
||||||
|
if event_disabled:
|
||||||
|
return
|
||||||
|
if event is InputEventMouseButton:
|
||||||
|
if Input.is_action_pressed("ui_rotate_player"):
|
||||||
|
input_view_camera_move_player_follow_mouse = true
|
||||||
|
else:
|
||||||
|
input_view_camera_move_player_follow_mouse = false
|
||||||
|
|
||||||
|
if event is InputEventMouseMotion and input_view_camera_move_player_follow_mouse:
|
||||||
|
camrot_h += -event.relative.x * h_sensitivity
|
||||||
|
camrot_v += -event.relative.y * v_sensitivity
|
||||||
|
|
||||||
|
func _physics_process(delta:float):
|
||||||
|
if event_disabled:
|
||||||
|
return
|
||||||
|
var h_rot:float = $h.global_transform.basis.get_euler().y
|
||||||
|
# Add the gravity.
|
||||||
|
if not is_on_floor():
|
||||||
|
velocity.y -= gravity * delta
|
||||||
|
|
||||||
|
# Handle Jump.
|
||||||
|
if Input.is_action_just_pressed("ui_accept") and is_on_floor():
|
||||||
|
velocity.y = JUMP_VELOCITY
|
||||||
|
|
||||||
|
# Get the input direction and handle the movement/deceleration.
|
||||||
|
# As good practice, you should replace UI actions with custom gameplay actions.
|
||||||
|
var input_dir = Input.get_vector("ui_left", "ui_right", "ui_up", "ui_down").rotated(-h_rot)
|
||||||
|
direction = (transform.basis * Vector3(input_dir.x, 0, input_dir.y)).normalized()
|
||||||
|
if direction:
|
||||||
|
velocity.x = direction.x * SPEED
|
||||||
|
velocity.z = direction.z * SPEED
|
||||||
|
else:
|
||||||
|
velocity.x = move_toward(velocity.x, 0, SPEED)
|
||||||
|
velocity.z = move_toward(velocity.z, 0, SPEED)
|
||||||
|
$h.rotation_degrees.y = lerp($h.rotation_degrees.y, camrot_h, delta * h_acceleration)
|
||||||
|
$h/v.rotation_degrees.x = lerp($h/v.rotation_degrees.x, camrot_v, delta * v_acceleration)
|
||||||
|
move_and_slide()
|
||||||
|
|
||||||
|
func set_enable_event(state:bool):
|
||||||
|
event_disabled = ! state
|
24
client/scenes/player.tscn
Normal file
24
client/scenes/player.tscn
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
[gd_scene load_steps=4 format=3 uid="uid://cg5uqqd4ibdem"]
|
||||||
|
|
||||||
|
[ext_resource type="PackedScene" uid="uid://bng6cjt7kq1hv" path="res://assets/player.glb" id="1_bpxp1"]
|
||||||
|
[ext_resource type="Script" path="res://scenes/player.gd" id="1_br7n0"]
|
||||||
|
|
||||||
|
[sub_resource type="SphereShape3D" id="SphereShape3D_cjbav"]
|
||||||
|
|
||||||
|
[node name="CharacterBody3D" type="CharacterBody3D"]
|
||||||
|
script = ExtResource("1_br7n0")
|
||||||
|
|
||||||
|
[node name="Pivot" type="Node3D" parent="."]
|
||||||
|
|
||||||
|
[node name="player" parent="Pivot" instance=ExtResource("1_bpxp1")]
|
||||||
|
|
||||||
|
[node name="CollisionShape3D" type="CollisionShape3D" parent="."]
|
||||||
|
transform = Transform3D(2, 0, 0, 0, 2, 0, 0, 0, 2, 0, 1, 0)
|
||||||
|
shape = SubResource("SphereShape3D_cjbav")
|
||||||
|
|
||||||
|
[node name="h" type="Node3D" parent="."]
|
||||||
|
|
||||||
|
[node name="v" type="Node3D" parent="h"]
|
||||||
|
|
||||||
|
[node name="Camera3D" type="Camera3D" parent="h/v"]
|
||||||
|
transform = Transform3D(1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 2, 5)
|
37
precheck.gd
Normal file
37
precheck.gd
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
extends MainLoop
|
||||||
|
#extends Node
|
||||||
|
|
||||||
|
# print("Example")
|
||||||
|
|
||||||
|
|
||||||
|
# Called when the node enters the scene tree for the first time.
|
||||||
|
#func _ready():
|
||||||
|
# print("Example _ready")
|
||||||
|
# # print( get_user_data_dir() )
|
||||||
|
# # print(Performance.get_monitor(Performance.TIME_FPS))
|
||||||
|
# pass # Replace with function body.
|
||||||
|
|
||||||
|
|
||||||
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
#func _process(delta):
|
||||||
|
# print("Example _process")
|
||||||
|
# pass
|
||||||
|
func _process(delta):
|
||||||
|
return true
|
||||||
|
|
||||||
|
func _init():
|
||||||
|
var info:String = ""
|
||||||
|
#info = get_base_script()
|
||||||
|
var processName:String = OS.get_processor_name()
|
||||||
|
var modelName:String = OS.get_model_name()
|
||||||
|
var osName:String = OS.get_name()
|
||||||
|
var version:String = OS.get_version()
|
||||||
|
var detailCardGraphics: PackedStringArray = OS.get_video_adapter_driver_info()
|
||||||
|
var idHardware:String = OS.get_unique_id()
|
||||||
|
var idGodot:String = str(Engine.get_version_info())
|
||||||
|
#for i in range(OS.get_screen_cound()):
|
||||||
|
# print(i)
|
||||||
|
var data = " - ".join(detailCardGraphics)
|
||||||
|
print( processName + "!" + modelName + "!" + osName + "!" + version + "!" + data + "!" + idHardware + "!" + idGodot)
|
||||||
|
|
||||||
|
|
181
start-bazar-client.sh
Executable file
181
start-bazar-client.sh
Executable file
|
@ -0,0 +1,181 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
declare DEBUG=0
|
||||||
|
declare HELP=0
|
||||||
|
declare EDITOR=0
|
||||||
|
declare FORCE=0
|
||||||
|
declare IMPORT=0
|
||||||
|
declare ERASEIMPORT=0
|
||||||
|
declare WORKDIR="$(dirname $(readlink -f $0))"
|
||||||
|
declare GODOT_SRC="https://downloads.tuxfamily.org/godotengine/4.1.2/Godot_v4.1.2-stable_linux.x86_64.zip"
|
||||||
|
declare OUTZIP="$WORKDIR/$(basename $GODOT_SRC)"
|
||||||
|
declare CLIENTDIR="$WORKDIR/client"
|
||||||
|
declare OPTION=""
|
||||||
|
declare NEWPRG=0
|
||||||
|
declare DISABLEAUTODETECTCARD=0
|
||||||
|
|
||||||
|
function msg_debug()
|
||||||
|
{
|
||||||
|
if [ $DEBUG -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "### DEBUG : $*" >&2
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_info()
|
||||||
|
{
|
||||||
|
echo "--- INFO : $*" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
function msg_error()
|
||||||
|
{
|
||||||
|
echo "*** ERROR : $*" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
function download()
|
||||||
|
{
|
||||||
|
local package="$1"
|
||||||
|
local out="$2"
|
||||||
|
if [[ $FORCE -eq 0 && -f $2 ]]
|
||||||
|
then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
which curl 1>/dev/null 2>/dev/null
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
curl -o $out $package
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
msg_info "Package GODOT downloaded"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
which wget 1>/dev/null 2>/dev/null
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
wget $package -O $out
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
msg_info "Package GODOT downloaded"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
msg_error "Impossible to download"
|
||||||
|
exit 2
|
||||||
|
}
|
||||||
|
|
||||||
|
function extract()
|
||||||
|
{
|
||||||
|
local compressed_file="$1"
|
||||||
|
which unzip 1>/dev/null 2>/dev/null
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
fileout=$(unzip -Z1 $compressed_file)
|
||||||
|
if [[ $FORCE -eq 0 && -f $fileout ]]
|
||||||
|
then
|
||||||
|
echo $fileout
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
unzip -u $compressed_file -d $WORKDIR 1>&2
|
||||||
|
if [ $? -eq 0 ]
|
||||||
|
then
|
||||||
|
msg_info "Uncompressed GODOT"
|
||||||
|
echo $fileout
|
||||||
|
NEWPRG=1
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
msg_error "Impossible to extract"
|
||||||
|
exit 2
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
while getopts hdeo:s:fix flag
|
||||||
|
do
|
||||||
|
case "${flag}" in
|
||||||
|
h) HELP=1;;
|
||||||
|
d) DEBUG=1;;
|
||||||
|
e) EDITOR=1;;
|
||||||
|
o) OUTZIP=${OPTARG};;
|
||||||
|
s) GODOT_SRC=${OPTARG};;
|
||||||
|
f) FORCE=1;;
|
||||||
|
i) IMPORT=1;;
|
||||||
|
x) ERASEIMPORT=1;;
|
||||||
|
y) DISABLEAUTODETECTCARD=1;;
|
||||||
|
*) HELP=1;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [[ $HELP -ne 0 ]]
|
||||||
|
then
|
||||||
|
cat << EOF
|
||||||
|
$(basename $0) [Option] : Donwload Launch Godot
|
||||||
|
Option:
|
||||||
|
-h : Show help
|
||||||
|
-d : Show debug message
|
||||||
|
-e : Start Godot in editor mode
|
||||||
|
-f : force download & uncompress
|
||||||
|
-i : force import data
|
||||||
|
-x : erase import data
|
||||||
|
-y : Disable auto detect host (OS/CPU/GPU)
|
||||||
|
-o <File> : target godot file (downloaded)
|
||||||
|
-s <Url> : Url to download a specific godot version
|
||||||
|
EOF
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
msg_info "Start"
|
||||||
|
msg_debug "WORKDIR:$WORKDIR OUTZIP:$OUTZIP GODOT_SRC:$GODOT_SRC"
|
||||||
|
download "$GODOT_SRC" "$OUTZIP"
|
||||||
|
EXE=$(extract "$OUTZIP")
|
||||||
|
msg_info "Prg:$EXE"
|
||||||
|
|
||||||
|
if [ $NEWPRG -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "--- New program detected"
|
||||||
|
ERASEIMPORT=1
|
||||||
|
IMPORT=1
|
||||||
|
elif [ $DISABLEAUTODETECTCARD -eq 0 ]
|
||||||
|
then
|
||||||
|
echo "--- Check host"
|
||||||
|
$WORKDIR/$EXE --script precheck.gd > $WORKDIR/.current_version.tmp
|
||||||
|
if [ -f $WORKDIR/.current_version ]
|
||||||
|
then
|
||||||
|
diff $WORKDIR/.current_version.tmp $WORKDIR/.current_version >/dev/null
|
||||||
|
if [ $? -ne 0 ]
|
||||||
|
then
|
||||||
|
ERASEIMPORT=1
|
||||||
|
IMPORT=1
|
||||||
|
mv $WORKDIR/.current_version.tmp $WORKDIR/.current_version
|
||||||
|
else
|
||||||
|
rm $WORKDIR/.current_version.tmp
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
ERASEIMPORT=1
|
||||||
|
IMPORT=1
|
||||||
|
mv $WORKDIR/.current_version.tmp $WORKDIR/.current_version
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $ERASEIMPORT -ne 0 ]
|
||||||
|
then
|
||||||
|
echo "--- Erase imported data"
|
||||||
|
rm -f $WORKDIR/.godot/imported/*
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ($IMPORT -ne 0) || (! -d $WORKDIR/.godot) ]]
|
||||||
|
then
|
||||||
|
echo "--- Launch import (please wait)"
|
||||||
|
$WORKDIR/$EXE --editor --quit
|
||||||
|
echo "--- Import finished"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $EDITOR -ne 0 ]
|
||||||
|
then
|
||||||
|
OPTION="$OPTION -e"
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd $CLIENTDIR
|
||||||
|
$WORKDIR/$EXE $OPTION
|
||||||
|
|
||||||
|
msg_info "End"
|
Loading…
Reference in a new issue