0.5 update
This commit is contained in:
parent
7fdbf170f1
commit
cb418f547d
@ -24,3 +24,11 @@ initial release
|
|||||||
- bbcode enabled globally
|
- bbcode enabled globally
|
||||||
- intrusive bbcode separated
|
- intrusive bbcode separated
|
||||||
- custom name bbcode
|
- custom name bbcode
|
||||||
|
|
||||||
|
0.5
|
||||||
|
----
|
||||||
|
- update to webfishing 1.09
|
||||||
|
- bbcode stuff only to lucystools users
|
||||||
|
- intrusive bbcode now client toggle
|
||||||
|
- lots of stuff removed due to 1.09 having it already!
|
||||||
|
- panel stays closed if closed, open if open
|
||||||
|
@ -6,13 +6,11 @@ func setup():
|
|||||||
get_node("%lucy_bbcode").pressed = MANAGER.allow_bbcode
|
get_node("%lucy_bbcode").pressed = MANAGER.allow_bbcode
|
||||||
get_node("%lucy_punchback").pressed = MANAGER.do_punchback
|
get_node("%lucy_punchback").pressed = MANAGER.do_punchback
|
||||||
get_node("%lucy_servername").text = MANAGER.custom_server_name
|
get_node("%lucy_servername").text = MANAGER.custom_server_name
|
||||||
get_node("%lucy_servername_preview").bbcode_text = MANAGER.custom_server_name + "'s Lobby"
|
get_node("%lucy_servername_preview").bbcode_text = MANAGER.custom_server_name
|
||||||
get_node("%lucy_servermsg").text = MANAGER.server_join_message
|
get_node("%lucy_servermsg").text = MANAGER.server_join_message
|
||||||
get_node("%lucy_servermsg_preview").bbcode_text = MANAGER.server_join_message
|
get_node("%lucy_servermsg_preview").bbcode_text = MANAGER.server_join_message
|
||||||
get_node("%lucy_fpackets").value = MANAGER.frame_packets
|
var srv_m_bb = MANAGER.bbcode_process(MANAGER.server_join_message)
|
||||||
get_node("%lucy_bpackets").value = MANAGER.bulk_packets
|
get_node("%lucy_servermsg_preview2").bbcode_text = srv_m_bb.stripped
|
||||||
get_node("%lucy_binterval").value = MANAGER.bulk_interval
|
|
||||||
get_node("%lucy_finterval").value = MANAGER.full_interval
|
|
||||||
|
|
||||||
get_node("%lucy_intbbcode").pressed = MANAGER.allow_intrusive_bbcode
|
get_node("%lucy_intbbcode").pressed = MANAGER.allow_intrusive_bbcode
|
||||||
|
|
||||||
@ -25,7 +23,6 @@ func setup():
|
|||||||
|
|
||||||
|
|
||||||
func update():
|
func update():
|
||||||
get_node("%lucy_srv_allow_bbcode").text = "Yes" if MANAGER.srv_allow_bbcode else "No"
|
|
||||||
_on_lucy_name_text_changed(MANAGER.custom_name)
|
_on_lucy_name_text_changed(MANAGER.custom_name)
|
||||||
|
|
||||||
|
|
||||||
@ -41,13 +38,15 @@ func _on_lucy_name_text_changed(new_text):
|
|||||||
get_node("%lucy_namegood").bbcode_text = "[color=green]Good[/color]" if good else "[color=red]Bad[/color]"
|
get_node("%lucy_namegood").bbcode_text = "[color=green]Good[/color]" if good else "[color=red]Bad[/color]"
|
||||||
|
|
||||||
MANAGER.custom_name_enabled = good
|
MANAGER.custom_name_enabled = good
|
||||||
MANAGER.custom_name = result.fin
|
MANAGER.custom_name = new_text
|
||||||
|
|
||||||
func _ready():
|
func _ready():
|
||||||
print("[LUCY] Menu Ready")
|
print("[LUCY] Menu Ready")
|
||||||
|
|
||||||
MANAGER = $"/root/LucyLucysTools"
|
MANAGER = $"/root/LucyLucysTools"
|
||||||
|
|
||||||
|
visible = MANAGER.lucys_menu_visible
|
||||||
|
|
||||||
get_node("%lucy_bbcode").disabled = MANAGER.host_required and not Network.GAME_MASTER
|
get_node("%lucy_bbcode").disabled = MANAGER.host_required and not Network.GAME_MASTER
|
||||||
get_node("%lucy_raincloud").disabled = not Network.GAME_MASTER or not MANAGER.ingame
|
get_node("%lucy_raincloud").disabled = not Network.GAME_MASTER or not MANAGER.ingame
|
||||||
get_node("%lucy_meteor").disabled = not Network.GAME_MASTER or not MANAGER.ingame
|
get_node("%lucy_meteor").disabled = not Network.GAME_MASTER or not MANAGER.ingame
|
||||||
@ -59,13 +58,16 @@ func _input(event):
|
|||||||
if event is InputEventKey and event.scancode == KEY_F5 && event.pressed:
|
if event is InputEventKey and event.scancode == KEY_F5 && event.pressed:
|
||||||
visible = !visible
|
visible = !visible
|
||||||
print("[LUCY] Menu visble: ", visible)
|
print("[LUCY] Menu visble: ", visible)
|
||||||
|
MANAGER.lucys_menu_visible = visible
|
||||||
|
|
||||||
if event is InputEventKey and event.scancode == KEY_F6 && event.pressed:
|
if event is InputEventKey and event.scancode == KEY_F6 && event.pressed:
|
||||||
var name = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "name")
|
var name = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "name")
|
||||||
|
var lname = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "lobby_name")
|
||||||
var nm = Steam.getNumLobbyMembers(Network.STEAM_LOBBY_ID)
|
var nm = Steam.getNumLobbyMembers(Network.STEAM_LOBBY_ID)
|
||||||
var code = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "code")
|
var code = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "code")
|
||||||
var type = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "type")
|
var type = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "type")
|
||||||
var lobby_dat = {"name": name, "nm": nm, "code": code, "type": type}
|
var bbname = Steam.getLobbyData(Network.STEAM_LOBBY_ID, "bbcode_lobby_name")
|
||||||
|
var lobby_dat = {"name": name, "lobby_name":lname, "bbcode_lobby_name":bbname, "nm": nm, "code": code, "type": type}
|
||||||
print("[LUCY] LOBBY ", lobby_dat)
|
print("[LUCY] LOBBY ", lobby_dat)
|
||||||
|
|
||||||
func _on_lucy_bbcode_toggled(button_pressed):
|
func _on_lucy_bbcode_toggled(button_pressed):
|
||||||
@ -73,19 +75,13 @@ func _on_lucy_bbcode_toggled(button_pressed):
|
|||||||
func _on_lucy_punchback_toggled(button_pressed):
|
func _on_lucy_punchback_toggled(button_pressed):
|
||||||
MANAGER.do_punchback = button_pressed
|
MANAGER.do_punchback = button_pressed
|
||||||
func _on_lucy_servername_text_changed(new_text):
|
func _on_lucy_servername_text_changed(new_text):
|
||||||
get_node("%lucy_servername_preview").bbcode_text = new_text + "'s Lobby"
|
get_node("%lucy_servername_preview").bbcode_text = new_text
|
||||||
MANAGER.custom_server_name = new_text
|
MANAGER.custom_server_name = new_text
|
||||||
func _on_lucy_servermsg_text_changed(new_text):
|
func _on_lucy_servermsg_text_changed(new_text):
|
||||||
get_node("%lucy_servermsg_preview").bbcode_text = new_text
|
var result = MANAGER.bbcode_process(new_text)
|
||||||
|
get_node("%lucy_servermsg_preview").bbcode_text = result.fin
|
||||||
|
get_node("%lucy_servermsg_preview2").bbcode_text = result.stripped
|
||||||
MANAGER.server_join_message = new_text
|
MANAGER.server_join_message = new_text
|
||||||
func _on_lucy_fpackets_value_changed(value):
|
|
||||||
MANAGER.frame_packets = value
|
|
||||||
func _on_lucy_bpackets_value_changed(value):
|
|
||||||
MANAGER.bulk_packets = value
|
|
||||||
func _on_lucy_binterval_value_changed(value):
|
|
||||||
MANAGER.bulk_interval = value
|
|
||||||
func _on_lucy_finterval_value_changed(value):
|
|
||||||
MANAGER.full_interval = value
|
|
||||||
func _on_lucy_chatcolor_bool_toggled(button_pressed):
|
func _on_lucy_chatcolor_bool_toggled(button_pressed):
|
||||||
MANAGER.custom_color_enabled = button_pressed
|
MANAGER.custom_color_enabled = button_pressed
|
||||||
func _on_lucy_chatcolor_color_changed(color):
|
func _on_lucy_chatcolor_color_changed(color):
|
||||||
@ -132,8 +128,7 @@ func _on_lucy_clearrain_pressed():
|
|||||||
cloud._deinstantiate(true)
|
cloud._deinstantiate(true)
|
||||||
|
|
||||||
func _on_lucy_clearchat_pressed():
|
func _on_lucy_clearchat_pressed():
|
||||||
Network.GAMECHAT = ""
|
Network._wipe_chat()
|
||||||
Network.LOCAL_GAMECHAT = ""
|
|
||||||
Network.emit_signal("_chat_update")
|
Network.emit_signal("_chat_update")
|
||||||
|
|
||||||
func _on_lucy_clearmeteor_pressed():
|
func _on_lucy_clearmeteor_pressed():
|
||||||
|
@ -21,95 +21,82 @@ margin_bottom = 393.0
|
|||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 14.0
|
margin_bottom = 14.0
|
||||||
text = "Lucy's Options - F5 to Toggle Menu"
|
text = "Lucy's Options 0.5.0 - F5 to Toggle Menu"
|
||||||
|
|
||||||
[node name="HSeparator" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
[node name="HSeparator" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 18.0
|
margin_top = 18.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 22.0
|
margin_bottom = 22.0
|
||||||
|
|
||||||
[node name="HFlowContainer" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="Label4" type="Label" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 26.0
|
margin_top = 26.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 66.0
|
margin_bottom = 40.0
|
||||||
|
text = "BBCode is only visible to LucysTools-compatible users"
|
||||||
|
|
||||||
|
[node name="HFlowContainer" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
|
margin_top = 44.0
|
||||||
|
margin_right = 786.0
|
||||||
|
margin_bottom = 84.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
margin_top = 13.0
|
margin_top = 13.0
|
||||||
margin_right = 138.0
|
margin_right = 89.0
|
||||||
margin_bottom = 27.0
|
margin_bottom = 27.0
|
||||||
text = "Allow BBCode (Client)"
|
text = "Allow BBCode"
|
||||||
|
|
||||||
[node name="lucy_bbcode" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="lucy_bbcode" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 142.0
|
margin_left = 93.0
|
||||||
margin_right = 218.0
|
margin_right = 169.0
|
||||||
margin_bottom = 40.0
|
margin_bottom = 40.0
|
||||||
|
|
||||||
[node name="Label3" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="Label3" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
margin_left = 222.0
|
margin_left = 173.0
|
||||||
margin_top = 13.0
|
margin_top = 13.0
|
||||||
margin_right = 471.0
|
margin_right = 323.0
|
||||||
margin_bottom = 27.0
|
margin_bottom = 27.0
|
||||||
text = "Allow Intrusive BBCode (requires Host)"
|
text = "Allow Intrusive BBCode"
|
||||||
|
|
||||||
[node name="lucy_intbbcode" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="lucy_intbbcode" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 475.0
|
margin_left = 327.0
|
||||||
margin_right = 551.0
|
margin_right = 403.0
|
||||||
margin_bottom = 40.0
|
margin_bottom = 40.0
|
||||||
|
|
||||||
[node name="Label2" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="Label2" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
margin_left = 555.0
|
margin_left = 407.0
|
||||||
margin_top = 13.0
|
margin_top = 13.0
|
||||||
margin_right = 690.0
|
margin_right = 542.0
|
||||||
margin_bottom = 27.0
|
margin_bottom = 27.0
|
||||||
text = "Punch back on Punch"
|
text = "Punch back on Punch"
|
||||||
|
|
||||||
[node name="lucy_punchback" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
[node name="lucy_punchback" type="CheckButton" parent="PanelContainer/VBoxContainer/HFlowContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 694.0
|
margin_left = 546.0
|
||||||
margin_right = 770.0
|
margin_right = 622.0
|
||||||
margin_bottom = 40.0
|
margin_bottom = 40.0
|
||||||
|
|
||||||
[node name="HFlowContainer3" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
|
||||||
margin_top = 70.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 84.0
|
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer3"]
|
|
||||||
margin_right = 199.0
|
|
||||||
margin_bottom = 14.0
|
|
||||||
text = "Host Allows Intrusive BBCode: "
|
|
||||||
|
|
||||||
[node name="lucy_srv_allow_bbcode" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer3"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
margin_left = 203.0
|
|
||||||
margin_right = 221.0
|
|
||||||
margin_bottom = 14.0
|
|
||||||
text = "No"
|
|
||||||
|
|
||||||
[node name="HSeparator3" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
[node name="HSeparator3" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 88.0
|
margin_top = 88.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 92.0
|
margin_bottom = 92.0
|
||||||
|
|
||||||
[node name="HFlowContainer4" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="Label2" type="Label" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 96.0
|
margin_top = 96.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 120.0
|
margin_bottom = 110.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
text = "Custom Server Name - Only shown for LucysTools users (base game field for others)"
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer4"]
|
[node name="HFlowContainer4" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 5.0
|
margin_top = 114.0
|
||||||
margin_right = 135.0
|
margin_right = 786.0
|
||||||
margin_bottom = 19.0
|
margin_bottom = 138.0
|
||||||
text = "Custom Server Name"
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="lucy_servername" type="LineEdit" parent="PanelContainer/VBoxContainer/HFlowContainer4"]
|
[node name="lucy_servername" type="LineEdit" parent="PanelContainer/VBoxContainer/HFlowContainer4"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 139.0
|
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 24.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
@ -117,9 +104,9 @@ expand_to_text_length = true
|
|||||||
placeholder_text = "Name"
|
placeholder_text = "Name"
|
||||||
|
|
||||||
[node name="HFlowContainer6" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HFlowContainer6" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 124.0
|
margin_top = 142.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 138.0
|
margin_bottom = 156.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer6"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer6"]
|
||||||
@ -139,25 +126,24 @@ text = "'s Lobby"
|
|||||||
scroll_active = false
|
scroll_active = false
|
||||||
|
|
||||||
[node name="HSeparator4" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
[node name="HSeparator4" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 142.0
|
margin_top = 160.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 146.0
|
margin_bottom = 164.0
|
||||||
|
|
||||||
|
[node name="Label3" type="Label" parent="PanelContainer/VBoxContainer"]
|
||||||
|
margin_top = 168.0
|
||||||
|
margin_right = 786.0
|
||||||
|
margin_bottom = 182.0
|
||||||
|
text = "Server Join Message - Will be shown without BBCode for people without LucysTools"
|
||||||
|
|
||||||
[node name="HFlowContainer5" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HFlowContainer5" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 150.0
|
margin_top = 186.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 174.0
|
margin_bottom = 210.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer5"]
|
|
||||||
margin_top = 5.0
|
|
||||||
margin_right = 127.0
|
|
||||||
margin_bottom = 19.0
|
|
||||||
text = "Server Join Message"
|
|
||||||
|
|
||||||
[node name="lucy_servermsg" type="LineEdit" parent="PanelContainer/VBoxContainer/HFlowContainer5"]
|
[node name="lucy_servermsg" type="LineEdit" parent="PanelContainer/VBoxContainer/HFlowContainer5"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 131.0
|
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 24.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
@ -165,19 +151,39 @@ expand_to_text_length = true
|
|||||||
placeholder_text = "Message"
|
placeholder_text = "Message"
|
||||||
|
|
||||||
[node name="HFlowContainer7" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HFlowContainer7" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 178.0
|
margin_top = 214.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 192.0
|
margin_bottom = 228.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer7"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer7"]
|
||||||
margin_right = 145.0
|
margin_right = 109.0
|
||||||
margin_bottom = 14.0
|
margin_bottom = 14.0
|
||||||
text = "Join Message Preview: "
|
text = "Normal Preview: "
|
||||||
|
|
||||||
[node name="lucy_servermsg_preview" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer7"]
|
[node name="lucy_servermsg_preview" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer7"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 149.0
|
margin_left = 113.0
|
||||||
|
margin_right = 786.0
|
||||||
|
margin_bottom = 14.0
|
||||||
|
size_flags_horizontal = 3
|
||||||
|
bbcode_enabled = true
|
||||||
|
scroll_active = false
|
||||||
|
|
||||||
|
[node name="HFlowContainer10" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
|
margin_top = 232.0
|
||||||
|
margin_right = 786.0
|
||||||
|
margin_bottom = 246.0
|
||||||
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer10"]
|
||||||
|
margin_right = 97.0
|
||||||
|
margin_bottom = 14.0
|
||||||
|
text = "Lame Preview: "
|
||||||
|
|
||||||
|
[node name="lucy_servermsg_preview2" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer10"]
|
||||||
|
unique_name_in_owner = true
|
||||||
|
margin_left = 101.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 14.0
|
margin_bottom = 14.0
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
@ -185,82 +191,89 @@ bbcode_enabled = true
|
|||||||
scroll_active = false
|
scroll_active = false
|
||||||
|
|
||||||
[node name="HSeparator5" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
[node name="HSeparator5" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 196.0
|
margin_top = 250.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 200.0
|
margin_bottom = 254.0
|
||||||
|
|
||||||
[node name="HFlowContainer8" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HFlowContainer8" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 204.0
|
margin_top = 258.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 228.0
|
margin_bottom = 282.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
||||||
margin_top = 5.0
|
margin_top = 5.0
|
||||||
margin_right = 107.0
|
margin_right = 157.0
|
||||||
margin_bottom = 19.0
|
margin_bottom = 19.0
|
||||||
text = "Chat Name Color"
|
text = "Chat Name Color (global)"
|
||||||
|
|
||||||
[node name="lucy_chatcolor_bool" type="CheckBox" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
[node name="lucy_chatcolor_bool" type="CheckBox" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 111.0
|
margin_left = 161.0
|
||||||
margin_right = 181.0
|
margin_right = 231.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 24.0
|
||||||
text = "Enable"
|
text = "Enable"
|
||||||
|
|
||||||
[node name="lucy_chatcolor" type="ColorPickerButton" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
[node name="lucy_chatcolor" type="ColorPickerButton" parent="PanelContainer/VBoxContainer/HFlowContainer8"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 185.0
|
margin_left = 235.0
|
||||||
margin_right = 227.0
|
margin_right = 277.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 24.0
|
||||||
rect_min_size = Vector2( 42, 0 )
|
rect_min_size = Vector2( 42, 0 )
|
||||||
edit_alpha = false
|
edit_alpha = false
|
||||||
|
|
||||||
[node name="HFlowContainer9" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HFlowContainer9" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 232.0
|
margin_top = 286.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 256.0
|
margin_bottom = 300.0
|
||||||
rect_pivot_offset = Vector2( -141, -49 )
|
rect_pivot_offset = Vector2( -141, -49 )
|
||||||
hint_tooltip = "Must match Steam username"
|
hint_tooltip = "Must match Steam username"
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
||||||
margin_top = 5.0
|
margin_right = 379.0
|
||||||
margin_right = 91.0
|
margin_bottom = 14.0
|
||||||
margin_bottom = 19.0
|
text = "Custom Name - Must match Steam Name (LucysTools only)"
|
||||||
text = "Custom Name"
|
|
||||||
|
|
||||||
[node name="lucy_namegood" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
[node name="lucy_namegood" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 95.0
|
margin_left = 383.0
|
||||||
margin_right = 145.0
|
margin_right = 433.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 14.0
|
||||||
rect_min_size = Vector2( 50, 0 )
|
rect_min_size = Vector2( 50, 0 )
|
||||||
bbcode_enabled = true
|
bbcode_enabled = true
|
||||||
bbcode_text = "[color=green]Good[/color]"
|
bbcode_text = "[color=green]Good[/color]"
|
||||||
text = "Good"
|
text = "Good"
|
||||||
scroll_active = false
|
scroll_active = false
|
||||||
|
|
||||||
[node name="lucy_name" type="LineEdit" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
[node name="lucy_name" type="LineEdit" parent="PanelContainer/VBoxContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 149.0
|
margin_top = 304.0
|
||||||
margin_right = 207.0
|
margin_right = 786.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 328.0
|
||||||
expand_to_text_length = true
|
expand_to_text_length = true
|
||||||
placeholder_text = "Name"
|
placeholder_text = "Name"
|
||||||
|
|
||||||
[node name="lucy_name_preview" type="RichTextLabel" parent="PanelContainer/VBoxContainer/HFlowContainer9"]
|
[node name="lucy_name_preview" type="RichTextLabel" parent="PanelContainer/VBoxContainer"]
|
||||||
unique_name_in_owner = true
|
unique_name_in_owner = true
|
||||||
margin_left = 211.0
|
margin_top = 332.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 24.0
|
margin_bottom = 347.0
|
||||||
|
rect_min_size = Vector2( 0, 15 )
|
||||||
size_flags_horizontal = 3
|
size_flags_horizontal = 3
|
||||||
bbcode_enabled = true
|
bbcode_enabled = true
|
||||||
|
bbcode_text = "If you see this, modify your custom name"
|
||||||
|
text = "If you see this, modify your custom name"
|
||||||
scroll_active = false
|
scroll_active = false
|
||||||
|
|
||||||
[node name="HFlowContainer2" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
[node name="HSeparator6" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
||||||
margin_top = 260.0
|
margin_top = 351.0
|
||||||
margin_right = 786.0
|
margin_right = 786.0
|
||||||
margin_bottom = 280.0
|
margin_bottom = 355.0
|
||||||
|
|
||||||
|
[node name="HFlowContainer2" type="HFlowContainer" parent="PanelContainer/VBoxContainer"]
|
||||||
|
margin_top = 359.0
|
||||||
|
margin_right = 786.0
|
||||||
|
margin_bottom = 379.0
|
||||||
|
|
||||||
[node name="lucy_clearchat" type="Button" parent="PanelContainer/VBoxContainer/HFlowContainer2"]
|
[node name="lucy_clearchat" type="Button" parent="PanelContainer/VBoxContainer/HFlowContainer2"]
|
||||||
margin_right = 76.0
|
margin_right = 76.0
|
||||||
@ -303,105 +316,6 @@ margin_right = 571.0
|
|||||||
margin_bottom = 20.0
|
margin_bottom = 20.0
|
||||||
text = "Clear Meteor"
|
text = "Clear Meteor"
|
||||||
|
|
||||||
[node name="HSeparator2" type="HSeparator" parent="PanelContainer/VBoxContainer"]
|
|
||||||
margin_top = 284.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 288.0
|
|
||||||
|
|
||||||
[node name="HSplitContainer" type="HSplitContainer" parent="PanelContainer/VBoxContainer"]
|
|
||||||
margin_top = 292.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 316.0
|
|
||||||
split_offset = 100
|
|
||||||
|
|
||||||
[node name="HFlowContainer3" type="HFlowContainer" parent="PanelContainer/VBoxContainer/HSplitContainer"]
|
|
||||||
margin_right = 218.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer3"]
|
|
||||||
margin_top = 5.0
|
|
||||||
margin_right = 118.0
|
|
||||||
margin_bottom = 19.0
|
|
||||||
text = "Per Frame Packets"
|
|
||||||
|
|
||||||
[node name="lucy_fpackets" type="SpinBox" parent="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer3"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
margin_left = 122.0
|
|
||||||
margin_right = 196.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
max_value = 256.0
|
|
||||||
value = 32.0
|
|
||||||
rounded = true
|
|
||||||
allow_greater = true
|
|
||||||
|
|
||||||
[node name="HFlowContainer" type="HFlowContainer" parent="PanelContainer/VBoxContainer/HSplitContainer"]
|
|
||||||
margin_left = 230.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
|
|
||||||
[node name="Label2" type="Label" parent="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer"]
|
|
||||||
margin_top = 5.0
|
|
||||||
margin_right = 116.0
|
|
||||||
margin_bottom = 19.0
|
|
||||||
text = "Bulk Read Packets"
|
|
||||||
|
|
||||||
[node name="lucy_bpackets" type="SpinBox" parent="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
margin_left = 120.0
|
|
||||||
margin_right = 194.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
max_value = 4096.0
|
|
||||||
value = 128.0
|
|
||||||
rounded = true
|
|
||||||
allow_greater = true
|
|
||||||
|
|
||||||
[node name="HSplitContainer2" type="HSplitContainer" parent="PanelContainer/VBoxContainer"]
|
|
||||||
margin_top = 320.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 344.0
|
|
||||||
split_offset = 100
|
|
||||||
|
|
||||||
[node name="HFlowContainer3" type="HFlowContainer" parent="PanelContainer/VBoxContainer/HSplitContainer2"]
|
|
||||||
margin_right = 216.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
|
|
||||||
[node name="Label" type="Label" parent="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer3"]
|
|
||||||
margin_top = 5.0
|
|
||||||
margin_right = 116.0
|
|
||||||
margin_bottom = 19.0
|
|
||||||
text = "Bulk Read Interval"
|
|
||||||
|
|
||||||
[node name="lucy_binterval" type="SpinBox" parent="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer3"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
margin_left = 120.0
|
|
||||||
margin_right = 194.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
max_value = 120.0
|
|
||||||
step = 0.05
|
|
||||||
value = 0.8
|
|
||||||
allow_greater = true
|
|
||||||
|
|
||||||
[node name="HFlowContainer" type="HFlowContainer" parent="PanelContainer/VBoxContainer/HSplitContainer2"]
|
|
||||||
margin_left = 228.0
|
|
||||||
margin_right = 786.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
|
|
||||||
[node name="Label2" type="Label" parent="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer"]
|
|
||||||
margin_top = 5.0
|
|
||||||
margin_right = 111.0
|
|
||||||
margin_bottom = 19.0
|
|
||||||
text = "Full Read Interval"
|
|
||||||
|
|
||||||
[node name="lucy_finterval" type="SpinBox" parent="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer"]
|
|
||||||
unique_name_in_owner = true
|
|
||||||
margin_left = 115.0
|
|
||||||
margin_right = 189.0
|
|
||||||
margin_bottom = 24.0
|
|
||||||
max_value = 120.0
|
|
||||||
step = 0.05
|
|
||||||
value = 6.4
|
|
||||||
allow_greater = true
|
|
||||||
|
|
||||||
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_bbcode" to="." method="_on_lucy_bbcode_toggled"]
|
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_bbcode" to="." method="_on_lucy_bbcode_toggled"]
|
||||||
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_intbbcode" to="." method="_on_lucy_intbbcode_toggled"]
|
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_intbbcode" to="." method="_on_lucy_intbbcode_toggled"]
|
||||||
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_punchback" to="." method="_on_lucy_punchback_toggled"]
|
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer/lucy_punchback" to="." method="_on_lucy_punchback_toggled"]
|
||||||
@ -409,14 +323,10 @@ allow_greater = true
|
|||||||
[connection signal="text_changed" from="PanelContainer/VBoxContainer/HFlowContainer5/lucy_servermsg" to="." method="_on_lucy_servermsg_text_changed"]
|
[connection signal="text_changed" from="PanelContainer/VBoxContainer/HFlowContainer5/lucy_servermsg" to="." method="_on_lucy_servermsg_text_changed"]
|
||||||
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer8/lucy_chatcolor_bool" to="." method="_on_lucy_chatcolor_bool_toggled"]
|
[connection signal="toggled" from="PanelContainer/VBoxContainer/HFlowContainer8/lucy_chatcolor_bool" to="." method="_on_lucy_chatcolor_bool_toggled"]
|
||||||
[connection signal="color_changed" from="PanelContainer/VBoxContainer/HFlowContainer8/lucy_chatcolor" to="." method="_on_lucy_chatcolor_color_changed"]
|
[connection signal="color_changed" from="PanelContainer/VBoxContainer/HFlowContainer8/lucy_chatcolor" to="." method="_on_lucy_chatcolor_color_changed"]
|
||||||
[connection signal="text_changed" from="PanelContainer/VBoxContainer/HFlowContainer9/lucy_name" to="." method="_on_lucy_name_text_changed"]
|
[connection signal="text_changed" from="PanelContainer/VBoxContainer/lucy_name" to="." method="_on_lucy_name_text_changed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearchat" to="." method="_on_lucy_clearchat_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearchat" to="." method="_on_lucy_clearchat_pressed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_raincloud" to="." method="_on_lucy_raincloud_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_raincloud" to="." method="_on_lucy_raincloud_pressed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_meteor" to="." method="_on_lucy_meteor_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_meteor" to="." method="_on_lucy_meteor_pressed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_freezerain" to="." method="_on_lucy_freezerain_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_freezerain" to="." method="_on_lucy_freezerain_pressed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearrain" to="." method="_on_lucy_clearrain_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearrain" to="." method="_on_lucy_clearrain_pressed"]
|
||||||
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearmeteor" to="." method="_on_lucy_clearmeteor_pressed"]
|
[connection signal="pressed" from="PanelContainer/VBoxContainer/HFlowContainer2/lucy_clearmeteor" to="." method="_on_lucy_clearmeteor_pressed"]
|
||||||
[connection signal="value_changed" from="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer3/lucy_fpackets" to="." method="_on_lucy_fpackets_value_changed"]
|
|
||||||
[connection signal="value_changed" from="PanelContainer/VBoxContainer/HSplitContainer/HFlowContainer/lucy_bpackets" to="." method="_on_lucy_bpackets_value_changed"]
|
|
||||||
[connection signal="value_changed" from="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer3/lucy_binterval" to="." method="_on_lucy_binterval_value_changed"]
|
|
||||||
[connection signal="value_changed" from="PanelContainer/VBoxContainer/HSplitContainer2/HFlowContainer/lucy_finterval" to="." method="_on_lucy_finterval_value_changed"]
|
|
||||||
|
@ -5,31 +5,36 @@ const LUCYS_MENU_SCENE = preload("res://mods/Lucy.LucysTools/lucys_menu.tscn")
|
|||||||
var lucys_menu = null
|
var lucys_menu = null
|
||||||
onready var root = get_tree().root
|
onready var root = get_tree().root
|
||||||
|
|
||||||
|
var INCERCEPT_MSG = false
|
||||||
|
var INCERCEPT_SEND_MSG = false
|
||||||
|
|
||||||
var do_punchback = false
|
var do_punchback = false
|
||||||
var allow_bbcode = false
|
var allow_bbcode = false
|
||||||
var custom_server_name = "" setget set_server_name
|
var custom_server_name = "" setget set_server_name
|
||||||
var server_join_message = "[color=#5BCEFA]TRAN[/color][color=#F5A9B8]S RIG[/color][color=#ffffff]HTS![/color]" setget set_join_message
|
var server_join_message = "[color=#5BCEFA]TRAN[/color][color=#F5A9B8]S RIG[/color][color=#ffffff]HTS![/color]" setget set_join_message
|
||||||
var frame_packets = 50 setget set_frame_packets
|
|
||||||
var bulk_packets = 200 setget set_bulk_packets
|
|
||||||
var bulk_interval = 1 setget set_bulk_interval
|
|
||||||
var full_interval = 5 setget set_full_interval
|
|
||||||
|
|
||||||
var custom_color_enabled = false
|
var custom_color_enabled = false
|
||||||
var custom_color = Color("009cd0") setget set_custom_color
|
var custom_color = Color("009cd0") setget set_custom_color
|
||||||
|
|
||||||
var custom_name_enabled = false
|
var custom_name_enabled = false
|
||||||
var custom_name = ""
|
var real_custom_name = ""
|
||||||
|
var custom_name = "" setget set_custom_name
|
||||||
|
|
||||||
var allow_intrusive_bbcode = false setget set_allow_intrusive_bbcode
|
var allow_intrusive_bbcode = false setget set_allow_intrusive_bbcode
|
||||||
var srv_allow_bbcode = false setget set_srv_bbcode
|
|
||||||
|
|
||||||
var log_messages = false setget set_log_messages
|
var log_messages = false setget set_log_messages
|
||||||
|
|
||||||
|
var lucys_menu_visible = true
|
||||||
|
|
||||||
var allowed_tags = ["b", "i", "u", "s", "color"]
|
var allowed_tags = ["b", "i", "u", "s", "color"]
|
||||||
var escape_invalid = true
|
var escape_invalid = true
|
||||||
var bbcode_matcher = null
|
var bbcode_matcher = null
|
||||||
|
|
||||||
|
func set_custom_name(val):
|
||||||
|
custom_name = val
|
||||||
|
var bb = bbcode_process(val)
|
||||||
|
real_custom_name = bb.fin
|
||||||
|
|
||||||
# i know this sucks
|
# i know this sucks
|
||||||
# but i have things to do
|
# but i have things to do
|
||||||
func bbcode_recurse(text, data):
|
func bbcode_recurse(text, data):
|
||||||
@ -67,48 +72,152 @@ func bbcode_process(text):
|
|||||||
bbcode_recurse(text, data)
|
bbcode_recurse(text, data)
|
||||||
return data
|
return data
|
||||||
|
|
||||||
# Patched Network vars
|
|
||||||
# var LUCY_PACKETS_READ = 0
|
|
||||||
# var LUCY_BULK_FULL_TIMER = 0
|
|
||||||
# var LUCY_FRAME_PACKETS = 32
|
|
||||||
# var LUCY_BULK_PACKETS = 128
|
|
||||||
# var LUCY_BULK_INTERVAL = 0.8
|
|
||||||
# var LUCY_BULK_FULL_INTERVAL = 6.4
|
|
||||||
# var LUCY_SRV_NAME
|
|
||||||
# var LUCY_PUNCHED_ME
|
|
||||||
# var LUCY_INSTANCE_SENDER
|
|
||||||
# var LUCY_LOG_MESSAGES
|
|
||||||
|
|
||||||
var ingame = false
|
var ingame = false
|
||||||
|
|
||||||
func process_message(lit_text, final_text, prefix, suffix, endcap, username, final_color, spoken_text):
|
func get_user_color() -> Color:
|
||||||
|
var base_color = Color(Globals.cosmetic_data[PlayerData.cosmetics_equipped["primary_color"]]["file"].main_color) * Color(0.95, 0.9, 0.9)
|
||||||
|
var color = custom_color if custom_color_enabled else base_color
|
||||||
|
return color
|
||||||
|
|
||||||
|
func safe_message(user_id, color, boring_msg, local, lucy_user, lucy_msg):
|
||||||
|
var username = Network._get_username_from_id(user_id) if lucy_user == "" else lucy_user
|
||||||
|
var bb_user = bbcode_process(username)
|
||||||
|
username = bb_user.fin
|
||||||
|
|
||||||
|
var msg = lucy_msg if lucy_msg != "" else boring_msg
|
||||||
|
var bb_data = bbcode_process(msg)
|
||||||
|
var filter_message = bb_data.fin
|
||||||
|
|
||||||
|
if bb_user.stripped != Network._get_username_from_id(user_id):
|
||||||
|
filter_message = "(" + Network._get_username_from_id(user_id) + ") " + filter_message
|
||||||
|
|
||||||
|
if OptionsMenu.chat_filter:
|
||||||
|
filter_message = SwearFilter._filter_string(filter_message)
|
||||||
|
|
||||||
|
var final_message = filter_message.replace("%u", "[color=#" + str(color) + "]" + username + "[/color]")
|
||||||
|
var thing = {"username":username, "color":color, "filter_message":filter_message,
|
||||||
|
"final_message":final_message,"lucy_user":lucy_user,"lucy_msg":lucy_msg}
|
||||||
|
print("FUCK2 ", thing)
|
||||||
|
Network._update_chat(final_message, local)
|
||||||
|
|
||||||
|
# this is stinky
|
||||||
|
func process_message(lit_text, final, prefix, suffix, endcap, spoken_text, local, colon, playerhud):
|
||||||
var thing = {
|
var thing = {
|
||||||
"lit_text": lit_text, "final_text": final_text, "prefix": prefix, "suffix": suffix,
|
"lit_text": lit_text, "final": final, "prefix": prefix, "suffix": suffix,
|
||||||
"endcap": endcap, "username": username, "final_color": final_color,
|
"endcap": endcap,
|
||||||
"srv_allow_bbcode": srv_allow_bbcode, "custom_color_enabled": custom_color_enabled,
|
"custom_color_enabled": custom_color_enabled,
|
||||||
"custom_name_enabled": custom_name_enabled, "allow_bbcode": allow_bbcode,
|
"custom_name_enabled": custom_name_enabled, "allow_bbcode": allow_bbcode,
|
||||||
"allowed_tags": allowed_tags
|
"allowed_tags": allowed_tags
|
||||||
}
|
}
|
||||||
#print("FUCK ", thing)
|
print("FUCK ", thing)
|
||||||
if srv_allow_bbcode and lit_text.begins_with("%"):
|
if Network.GAME_MASTER and lit_text.begins_with("%"):
|
||||||
return [lit_text.trim_prefix('%'), spoken_text]
|
var bb_dat = bbcode_process(lit_text)
|
||||||
|
lucy_send_message(lit_text.trim_prefix('%'), bb_dat.stripped, false)
|
||||||
|
# we sent the message ourself
|
||||||
|
return [true]
|
||||||
|
|
||||||
var name = custom_name if custom_name_enabled else username
|
var msg = final
|
||||||
var color = custom_color if custom_color_enabled else final_color
|
var boring_msg = final
|
||||||
var msg = final_text
|
|
||||||
var speak = spoken_text
|
var speak = spoken_text
|
||||||
if allow_bbcode:
|
if allow_bbcode:
|
||||||
var p = bbcode_process(lit_text)
|
var p = bbcode_process(lit_text)
|
||||||
if not p.tags.empty():
|
if not p.tags.empty():
|
||||||
msg = p.fin
|
msg = prefix + "%u" + endcap + p.fin + suffix
|
||||||
|
boring_msg = prefix + "%u" + endcap + p.stripped + suffix
|
||||||
speak = p.stripped
|
speak = p.stripped
|
||||||
return [
|
print("FUCK3 ", {"msg":msg,"boring_msg":boring_msg,"p":p})
|
||||||
prefix + "[color=#" + str(color.to_html()) + "]" + name + endcap + msg + suffix,
|
if msg != "": lucy_send_message(msg, boring_msg, local)
|
||||||
speak
|
|
||||||
]
|
if spoken_text != "" and colon: playerhud.emit_signal("_message_sent", speak)
|
||||||
|
# we did it ourselves
|
||||||
|
return [true]
|
||||||
|
|
||||||
|
# return the custom color
|
||||||
|
return [false, get_user_color().to_html()]
|
||||||
|
|
||||||
|
var LUCYSTOOLS_USERS = []
|
||||||
|
|
||||||
|
func lucy_send_message(message, boring_msg, local = false):
|
||||||
|
if not Network._message_cap(Network.STEAM_ID):
|
||||||
|
Network._update_chat("Sending too many messages too quickly!", false)
|
||||||
|
Network._update_chat("Sending too many messages too quickly!", true)
|
||||||
|
return
|
||||||
|
|
||||||
|
var msg_pos = Network.MESSAGE_ORIGIN.round()
|
||||||
|
|
||||||
|
var lucy_user = real_custom_name if custom_name_enabled else ""
|
||||||
|
var color = get_user_color().to_html()
|
||||||
|
|
||||||
|
safe_message(Network.STEAM_ID, color, boring_msg, local, lucy_user, message)
|
||||||
|
Network._send_P2P_Packet(
|
||||||
|
{"type": "message", "message": boring_msg, "color": color, "local": local,
|
||||||
|
"position": Network.MESSAGE_ORIGIN, "zone": Network.MESSAGE_ZONE,
|
||||||
|
"zone_owner": PlayerData.player_saved_zone_owner,
|
||||||
|
"bb_user": lucy_user, "bb_msg": message},
|
||||||
|
"peers", 2, Network.CHANNELS.GAME_STATE)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
func process_read(DATA, PACKET_SENDER, from_host):
|
||||||
|
match DATA["type"]:
|
||||||
|
"lucy_packet":
|
||||||
|
print("[LUCY PACKET]")
|
||||||
|
if not PACKET_SENDER in LUCYSTOOLS_USERS: LUCYSTOOLS_USERS.append(PACKET_SENDER)
|
||||||
|
return true
|
||||||
|
|
||||||
|
"message":
|
||||||
|
if DATA.has("message"):
|
||||||
|
if typeof(DATA["message"]) == TYPE_STRING:
|
||||||
|
if not "%u" in DATA["message"] and not from_host:
|
||||||
|
DATA["message"] = "(%u)" + DATA["message"]
|
||||||
|
if DATA.has("bb_msg"):
|
||||||
|
if typeof(DATA["bb_msg"]) == TYPE_STRING:
|
||||||
|
if not "%u" in DATA["bb_msg"] and not from_host:
|
||||||
|
DATA["bb_msg"] = "(%u)" + DATA["bb_msg"]
|
||||||
|
|
||||||
|
if DATA.has("bb_msg") or DATA.has("bb_user"):
|
||||||
|
if not PACKET_SENDER in LUCYSTOOLS_USERS:
|
||||||
|
LUCYSTOOLS_USERS.append(PACKET_SENDER)
|
||||||
|
else:
|
||||||
|
return false
|
||||||
|
# yay! this is a lucy user :3
|
||||||
|
if PlayerData.players_muted.has(PACKET_SENDER) or PlayerData.players_hidden.has(PACKET_SENDER): return
|
||||||
|
|
||||||
|
if not Network._validate_packet_information(DATA,
|
||||||
|
["message", "color", "local", "position", "zone", "zone_owner", "bb_user", "bb_msg"],
|
||||||
|
[TYPE_STRING, TYPE_STRING, TYPE_BOOL, TYPE_VECTOR3, TYPE_STRING, TYPE_INT, TYPE_STRING, TYPE_STRING]):
|
||||||
|
return
|
||||||
|
|
||||||
|
if not Network._message_cap(PACKET_SENDER): return
|
||||||
|
|
||||||
|
var user_id: int = PACKET_SENDER
|
||||||
|
var user_color: String = DATA["color"]
|
||||||
|
var user_message: String = DATA["message"]
|
||||||
|
var lucy_user: String = DATA["bb_user"]
|
||||||
|
var lucy_msg: String = DATA["bb_msg"]
|
||||||
|
|
||||||
|
|
||||||
|
if not DATA["local"]:
|
||||||
|
safe_message(user_id, user_color, user_message, false, lucy_user, lucy_msg)
|
||||||
|
else :
|
||||||
|
var dist = DATA["position"].distance_to(Network.MESSAGE_ORIGIN)
|
||||||
|
if DATA["zone"] == Network.MESSAGE_ZONE and DATA["zone_owner"] == PlayerData.player_saved_zone_owner:
|
||||||
|
if dist < 25.0: safe_message(user_id, user_color, user_message, true, lucy_user, lucy_msg)
|
||||||
|
|
||||||
|
# don't process it again!
|
||||||
|
return true
|
||||||
|
|
||||||
|
# lucy punchback :3
|
||||||
|
"player_punch":
|
||||||
|
if not DATA.has("nya"): punched(PACKET_SENDER, DATA["punch_type"])
|
||||||
|
# still get punched!
|
||||||
|
return false
|
||||||
|
|
||||||
|
# fall through to default code
|
||||||
|
return false
|
||||||
|
|
||||||
func bbcode_changes():
|
func bbcode_changes():
|
||||||
if srv_allow_bbcode and allow_intrusive_bbcode:
|
if allow_intrusive_bbcode:
|
||||||
allowed_tags = [
|
allowed_tags = [
|
||||||
"b", "i", "u", "s", "color",
|
"b", "i", "u", "s", "color",
|
||||||
"wave", "rainbow", "shake", "tornado", "font"]
|
"wave", "rainbow", "shake", "tornado", "font"]
|
||||||
@ -123,32 +232,12 @@ func set_log_messages(val):
|
|||||||
|
|
||||||
func set_allow_intrusive_bbcode(bbcode):
|
func set_allow_intrusive_bbcode(bbcode):
|
||||||
allow_intrusive_bbcode = bbcode
|
allow_intrusive_bbcode = bbcode
|
||||||
if Network.GAME_MASTER or not ingame:
|
|
||||||
self.srv_allow_bbcode = bbcode
|
|
||||||
else: bbcode_changes()
|
|
||||||
func set_srv_bbcode(bbcode):
|
|
||||||
if Network.GAME_MASTER and not Network.PLAYING_OFFLINE: send_server_sync_actor()
|
|
||||||
srv_allow_bbcode = bbcode
|
|
||||||
bbcode_changes()
|
bbcode_changes()
|
||||||
func set_server_name(name):
|
func set_server_name(name):
|
||||||
custom_server_name = name
|
custom_server_name = name
|
||||||
Network.LUCY_SRV_NAME = name
|
Network.LUCY_SRV_NAME = name
|
||||||
func set_join_message(msg):
|
func set_join_message(msg):
|
||||||
server_join_message = msg
|
server_join_message = msg
|
||||||
func set_frame_packets(val):
|
|
||||||
frame_packets = val
|
|
||||||
Network.LUCY_FRAME_PACKETS = val
|
|
||||||
func set_bulk_packets(val):
|
|
||||||
bulk_packets = val
|
|
||||||
Network.LUCY_BULK_PACKETS = val
|
|
||||||
func set_bulk_interval(val):
|
|
||||||
bulk_interval = val
|
|
||||||
Network.LUCY_BULK_INTERVAL = val
|
|
||||||
Network.BULK_PACKET_READ_TIMER = 0
|
|
||||||
func set_full_interval(val):
|
|
||||||
full_interval = val
|
|
||||||
Network.LUCY_BULK_FULL_INTERVAL = val
|
|
||||||
Network.LUCY_BULK_FULL_TIMER = 0
|
|
||||||
func set_custom_color(val):
|
func set_custom_color(val):
|
||||||
custom_color = Color(val) if Color(val) != Color("d5aa73") else Color("739ed5")
|
custom_color = Color(val) if Color(val) != Color("d5aa73") else Color("739ed5")
|
||||||
custom_color.a = 1
|
custom_color.a = 1
|
||||||
@ -158,23 +247,17 @@ func _ready():
|
|||||||
load_settings()
|
load_settings()
|
||||||
root.connect("child_entered_tree", self, "_on_enter")
|
root.connect("child_entered_tree", self, "_on_enter")
|
||||||
Network.connect("_new_player_join", self, "new_player")
|
Network.connect("_new_player_join", self, "new_player")
|
||||||
PlayerData.connect("_punched", self, "punched")
|
Steam.connect("lobby_created", self, "inject_lobby_data")
|
||||||
Network.connect("_instance_actor", self, "_instance_actor")
|
|
||||||
|
|
||||||
func send_server_sync_actor(to = "peers"):
|
func inject_lobby_data(connect, lobby_id):
|
||||||
|
if connect != 1: return
|
||||||
|
|
||||||
|
if custom_server_name != "":
|
||||||
|
Steam.setLobbyData(lobby_id, "bbcode_lobby_name", custom_server_name)
|
||||||
|
|
||||||
|
func send_lucy_sync(to = "peers"):
|
||||||
if not Network.GAME_MASTER: return
|
if not Network.GAME_MASTER: return
|
||||||
var dict = {"actor_type": "lucy_fake_actor", "at": Vector3.ZERO, "zone": "", "actor_id": 0, "creator_id": Network.STEAM_ID, "data": {
|
Network._send_P2P_Packet({"type": "lucy_packet"}, to, Network.CHANNELS.GAME_STATE)
|
||||||
"allow_bbcode": allow_bbcode
|
|
||||||
}}
|
|
||||||
Network._send_P2P_Packet({"type": "instance_actor", "params": dict}, to, 2)
|
|
||||||
|
|
||||||
func _instance_actor(dict):
|
|
||||||
if dict["actor_type"] != "lucy_fake_actor": return
|
|
||||||
var sender = Network.LUCY_INSTANCE_SENDER
|
|
||||||
Network.LUCY_INSTANCE_SENDER = 0
|
|
||||||
if sender != Network.KNOWN_GAME_MASTER or Network.GAME_MASTER: return
|
|
||||||
var data = dict["data"]
|
|
||||||
self.srv_allow_bbcode = data["allow_bbcode"]
|
|
||||||
|
|
||||||
func get_player() -> Actor:
|
func get_player() -> Actor:
|
||||||
for p in get_tree().get_nodes_in_group("player"):
|
for p in get_tree().get_nodes_in_group("player"):
|
||||||
@ -182,26 +265,20 @@ func get_player() -> Actor:
|
|||||||
return p
|
return p
|
||||||
return null
|
return null
|
||||||
|
|
||||||
func punched(from, type):
|
func punched(puncher_id, type):
|
||||||
print("[LUCY] punched!")
|
print("[LUCY] punch from ", Network._get_username_from_id(puncher_id))
|
||||||
if not do_punchback: return
|
if not do_punchback: return
|
||||||
if Network.LUCY_PUNCHED_ME == 0 or Network.LUCY_PUNCHED_ME == Network.STEAM_ID: return
|
if puncher_id == 0 or puncher_id == Network.STEAM_ID: return
|
||||||
var punched_me = null
|
|
||||||
for p in get_tree().get_nodes_in_group("player"):
|
|
||||||
if p.owner_id == Network.LUCY_PUNCHED_ME: punched_me = p
|
|
||||||
if punched_me == null: return
|
|
||||||
if punched_me.controlled: return
|
|
||||||
print("[LUCY] punching back...")
|
print("[LUCY] punching back...")
|
||||||
Network.LUCY_PUNCHED_ME = 0
|
Network._send_P2P_Packet({"type": "player_punch", "from_pos": get_player().global_transform.origin, "punch_type": type, "nya": "nya"}, str(puncher_id), 2, Network.CHANNELS.ACTOR_ACTION)
|
||||||
Network._send_P2P_Packet({"type": "player_punch", "from": get_player().global_transform.origin, "player": Network.STEAM_ID, "punch_type": type, "nya": "nya"}, str(punched_me.owner_id), 2)
|
|
||||||
|
|
||||||
|
|
||||||
func new_player(id):
|
func new_player(id):
|
||||||
print("[LUCY] new player!")
|
print("[LUCY] new player!")
|
||||||
if server_join_message.empty() or not Network.GAME_MASTER: return
|
if server_join_message.empty() or not Network.GAME_MASTER: return
|
||||||
print("[LUCY] sending join message")
|
print("[LUCY] sending join message")
|
||||||
Network._send_message(server_join_message)
|
var bb_msg = bbcode_process(server_join_message)
|
||||||
send_server_sync_actor(str(id))
|
lucy_send_message(bb_msg.fin, bb_msg.stripped, false)
|
||||||
|
send_lucy_sync(str(id))
|
||||||
|
|
||||||
func _on_enter(node: Node):
|
func _on_enter(node: Node):
|
||||||
if node.name == "main_menu":
|
if node.name == "main_menu":
|
||||||
@ -215,16 +292,12 @@ func _on_enter(node: Node):
|
|||||||
lucys_menu.MANAGER = self
|
lucys_menu.MANAGER = self
|
||||||
node.add_child(lucys_menu)
|
node.add_child(lucys_menu)
|
||||||
ingame = true
|
ingame = true
|
||||||
# retrigger setter
|
|
||||||
self.srv_allow_bbcode = false
|
|
||||||
self.allow_intrusive_bbcode = allow_intrusive_bbcode
|
self.allow_intrusive_bbcode = allow_intrusive_bbcode
|
||||||
lucys_menu.setup()
|
lucys_menu.setup()
|
||||||
|
|
||||||
const save_keys = [
|
const save_keys = [
|
||||||
"do_punchback", "allow_bbcode",
|
"do_punchback", "allow_bbcode",
|
||||||
"custom_server_name", "server_join_message",
|
"custom_server_name", "server_join_message",
|
||||||
"frame_packets", "bulk_packets",
|
|
||||||
"bulk_interval", "full_interval",
|
|
||||||
"custom_color_enabled", "custom_color",
|
"custom_color_enabled", "custom_color",
|
||||||
"log_messages", "custom_name",
|
"log_messages", "custom_name",
|
||||||
"allow_intrusive_bbcode"
|
"allow_intrusive_bbcode"
|
||||||
|
@ -14,6 +14,8 @@ public class Mod : IMod {
|
|||||||
ModInterface = modInterface;
|
ModInterface = modInterface;
|
||||||
modInterface.RegisterScriptMod(new LucysChatChanges());
|
modInterface.RegisterScriptMod(new LucysChatChanges());
|
||||||
modInterface.RegisterScriptMod(new LucysNetFixes());
|
modInterface.RegisterScriptMod(new LucysNetFixes());
|
||||||
|
modInterface.RegisterScriptMod(new LucyServerBrowserChanges());
|
||||||
|
modInterface.RegisterScriptMod(new LucyMainMenuChanges());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Dispose(){}
|
public void Dispose(){}
|
||||||
@ -25,6 +27,186 @@ public record CodeChange {
|
|||||||
public required Token[] code_to_add;
|
public required Token[] code_to_add;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class LucyServerBrowserChanges: IScriptMod
|
||||||
|
{
|
||||||
|
bool IScriptMod.ShouldRun(string path) => path == "res://Scenes/Menus/Main Menu/ServerButton/server_button.gdc";
|
||||||
|
|
||||||
|
CodeChange[] changes = {
|
||||||
|
new CodeChange {
|
||||||
|
name = "server button arg",
|
||||||
|
// , age_limit, dated, banned END
|
||||||
|
multitoken_prefix = new Func<Token, bool>[] {
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "age_limit"},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "dated"},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "banned"},
|
||||||
|
},
|
||||||
|
// , lucy_display
|
||||||
|
code_to_add = new Token[] {
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
new CodeChange {
|
||||||
|
name = "server button load",
|
||||||
|
// display_name.replace(']', '')
|
||||||
|
// END
|
||||||
|
multitoken_prefix = new Func<Token, bool>[] {
|
||||||
|
t => t is IdentifierToken {Name: "display_name"},
|
||||||
|
t => t.Type == TokenType.Period,
|
||||||
|
t => t is IdentifierToken {Name: "replace"},
|
||||||
|
t => t.Type == TokenType.ParenthesisOpen,
|
||||||
|
t => t is ConstantToken {Value:StringVariant{Value:"]"}},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is ConstantToken,
|
||||||
|
t => t.Type == TokenType.ParenthesisClose,
|
||||||
|
t => t.Type == TokenType.Newline,
|
||||||
|
},
|
||||||
|
// if lucy_display != "": display_name = lucy_display
|
||||||
|
code_to_add = new Token[] {
|
||||||
|
new Token(TokenType.CfIf),
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
new Token(TokenType.OpNotEqual),
|
||||||
|
new ConstantToken(new StringVariant("")),
|
||||||
|
new Token(TokenType.Colon),
|
||||||
|
new IdentifierToken("display_name"),
|
||||||
|
new Token(TokenType.OpAssign),
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
new Token(TokenType.Newline, 1),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
IEnumerable<Token> IScriptMod.Modify(string path, IEnumerable<Token> tokens)
|
||||||
|
{
|
||||||
|
var pending_changes = changes
|
||||||
|
.Select(c => (c, new MultiTokenWaiter(c.multitoken_prefix)))
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
// I'm sure there's a better way to do this
|
||||||
|
// with list comprehension stuff, but my
|
||||||
|
// C# is too rusty
|
||||||
|
foreach (var token in tokens) {
|
||||||
|
var had_change = false;
|
||||||
|
foreach (var (change, waiter) in pending_changes) {
|
||||||
|
if (waiter.Check(token)) {
|
||||||
|
Mod.ModInterface.Logger.Information($"Adding Lucy server button mod {change.name}");
|
||||||
|
|
||||||
|
yield return token;
|
||||||
|
foreach (var t in change.code_to_add) yield return t;
|
||||||
|
|
||||||
|
had_change = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!had_change) yield return token;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class LucyMainMenuChanges: IScriptMod
|
||||||
|
{
|
||||||
|
bool IScriptMod.ShouldRun(string path) => path == "res://Scenes/Menus/Main Menu/main_menu.gdc";
|
||||||
|
|
||||||
|
CodeChange[] changes = {
|
||||||
|
new CodeChange {
|
||||||
|
name = "server button lucy_display get",
|
||||||
|
// if $"%hidenames".pressed: lobby_custom_name = ""
|
||||||
|
// END
|
||||||
|
multitoken_prefix = new Func<Token, bool>[] {
|
||||||
|
t => t.Type == TokenType.CfIf,
|
||||||
|
t => t.Type == TokenType.Dollar,
|
||||||
|
t => t is ConstantToken {Value:StringVariant{Value:"%hidenames"}},
|
||||||
|
t => t.Type == TokenType.Period,
|
||||||
|
t => t is IdentifierToken {Name: "pressed"},
|
||||||
|
t => t.Type == TokenType.Colon,
|
||||||
|
t => t is IdentifierToken {Name: "lobby_custom_name"},
|
||||||
|
t => t.Type == TokenType.OpAssign,
|
||||||
|
t => t.Type == TokenType.Constant,
|
||||||
|
t => t.Type == TokenType.Newline,
|
||||||
|
},
|
||||||
|
// var lucy_display = ""
|
||||||
|
// if not $"%hidenames".pressed:
|
||||||
|
// lucy_display = Steam.getLobbyData(lobby, "bbcode_lobby_name")
|
||||||
|
code_to_add = new Token[] {
|
||||||
|
new Token(TokenType.PrVar),
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
new Token(TokenType.OpAssign),
|
||||||
|
new ConstantToken(new StringVariant("")),
|
||||||
|
new Token(TokenType.Newline, 2),
|
||||||
|
|
||||||
|
new Token(TokenType.CfIf),
|
||||||
|
new Token(TokenType.OpNot),
|
||||||
|
new Token(TokenType.Dollar),
|
||||||
|
new ConstantToken(new StringVariant("%hidenames")),
|
||||||
|
new Token(TokenType.Period),
|
||||||
|
new IdentifierToken("pressed"),
|
||||||
|
new Token(TokenType.Colon),
|
||||||
|
new Token(TokenType.Newline, 3),
|
||||||
|
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
new Token(TokenType.OpAssign),
|
||||||
|
new IdentifierToken("Steam"),
|
||||||
|
new Token(TokenType.Period),
|
||||||
|
new IdentifierToken("getLobbyData"),
|
||||||
|
new Token(TokenType.ParenthesisOpen),
|
||||||
|
new IdentifierToken("lobby"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new ConstantToken(new StringVariant("bbcode_lobby_name")),
|
||||||
|
new Token(TokenType.ParenthesisClose),
|
||||||
|
new Token(TokenType.Newline, 2)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
new CodeChange {
|
||||||
|
name = "server button lucy_display arg",
|
||||||
|
// lobby_cap, lobby_age, dated, banned END
|
||||||
|
multitoken_prefix = new Func<Token, bool>[] {
|
||||||
|
t => t is IdentifierToken {Name: "lobby_cap"},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "lobby_age"},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "dated"},
|
||||||
|
t => t.Type == TokenType.Comma,
|
||||||
|
t => t is IdentifierToken {Name: "banned"},
|
||||||
|
},
|
||||||
|
// , lucy_display END
|
||||||
|
code_to_add = new Token[] {
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("lucy_display"),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
IEnumerable<Token> IScriptMod.Modify(string path, IEnumerable<Token> tokens)
|
||||||
|
{
|
||||||
|
var pending_changes = changes
|
||||||
|
.Select(c => (c, new MultiTokenWaiter(c.multitoken_prefix)))
|
||||||
|
.ToList();
|
||||||
|
|
||||||
|
// I'm sure there's a better way to do this
|
||||||
|
// with list comprehension stuff, but my
|
||||||
|
// C# is too rusty
|
||||||
|
foreach (var token in tokens) {
|
||||||
|
var had_change = false;
|
||||||
|
foreach (var (change, waiter) in pending_changes) {
|
||||||
|
if (waiter.Check(token)) {
|
||||||
|
Mod.ModInterface.Logger.Information($"Adding Lucy server button mod {change.name}");
|
||||||
|
|
||||||
|
yield return token;
|
||||||
|
foreach (var t in change.code_to_add) yield return t;
|
||||||
|
|
||||||
|
had_change = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!had_change) yield return token;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public class LucysChatChanges : IScriptMod
|
public class LucysChatChanges : IScriptMod
|
||||||
{
|
{
|
||||||
bool IScriptMod.ShouldRun(string path) => path == "res://Scenes/HUD/playerhud.gdc";
|
bool IScriptMod.ShouldRun(string path) => path == "res://Scenes/HUD/playerhud.gdc";
|
||||||
@ -66,10 +248,10 @@ public class LucysChatChanges : IScriptMod
|
|||||||
t => t is IdentifierToken {Name: "suffix"},
|
t => t is IdentifierToken {Name: "suffix"},
|
||||||
t => t.Type == TokenType.Newline,
|
t => t.Type == TokenType.Newline,
|
||||||
},
|
},
|
||||||
// if $"/root/LucyLucysTools":
|
// if $"/root/LucyLucysTools".INTERCEPT_SEND_MSG:
|
||||||
// var tmp = $"/root/LucyLucysTools".process_message(lit_text, final_text, prefix, suffix, endcap, username, spoken_text)
|
// var tmp = $"/root/LucyLucysTools".process_message(lit_text, final, prefix, suffix, endcap, final_color, spoken_text, chat_local, colon, self)
|
||||||
// final = tmp[0]
|
// if tmp[0]: return
|
||||||
// spoken_text = tmp[1]
|
// final_color = tmp[1]
|
||||||
// END
|
// END
|
||||||
code_to_add = new Token[] {
|
code_to_add = new Token[] {
|
||||||
new Token(TokenType.CfIf),
|
new Token(TokenType.CfIf),
|
||||||
@ -88,7 +270,7 @@ public class LucysChatChanges : IScriptMod
|
|||||||
new Token(TokenType.ParenthesisOpen),
|
new Token(TokenType.ParenthesisOpen),
|
||||||
new IdentifierToken("lit_text"),
|
new IdentifierToken("lit_text"),
|
||||||
new Token(TokenType.Comma),
|
new Token(TokenType.Comma),
|
||||||
new IdentifierToken("final_text"),
|
new IdentifierToken("final"),
|
||||||
new Token(TokenType.Comma),
|
new Token(TokenType.Comma),
|
||||||
new IdentifierToken("prefix"),
|
new IdentifierToken("prefix"),
|
||||||
new Token(TokenType.Comma),
|
new Token(TokenType.Comma),
|
||||||
@ -96,23 +278,26 @@ public class LucysChatChanges : IScriptMod
|
|||||||
new Token(TokenType.Comma),
|
new Token(TokenType.Comma),
|
||||||
new IdentifierToken("endcap"),
|
new IdentifierToken("endcap"),
|
||||||
new Token(TokenType.Comma),
|
new Token(TokenType.Comma),
|
||||||
new IdentifierToken("username"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("final_color"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("spoken_text"),
|
new IdentifierToken("spoken_text"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("chat_local"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("colon"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new Token(TokenType.Self),
|
||||||
new Token(TokenType.ParenthesisClose),
|
new Token(TokenType.ParenthesisClose),
|
||||||
new Token(TokenType.Newline, 2),
|
new Token(TokenType.Newline, 2),
|
||||||
|
|
||||||
new IdentifierToken("final"),
|
new Token(TokenType.CfIf),
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("tmp"),
|
new IdentifierToken("tmp"),
|
||||||
new Token(TokenType.BracketOpen),
|
new Token(TokenType.BracketOpen),
|
||||||
new ConstantToken(new IntVariant(0)),
|
new ConstantToken(new IntVariant(0)),
|
||||||
new Token(TokenType.BracketClose),
|
new Token(TokenType.BracketClose),
|
||||||
|
new Token(TokenType.Colon),
|
||||||
|
new Token(TokenType.CfReturn),
|
||||||
new Token(TokenType.Newline, 2),
|
new Token(TokenType.Newline, 2),
|
||||||
|
|
||||||
new IdentifierToken("spoken_text"),
|
new IdentifierToken("final_color"),
|
||||||
new Token(TokenType.OpAssign),
|
new Token(TokenType.OpAssign),
|
||||||
new IdentifierToken("tmp"),
|
new IdentifierToken("tmp"),
|
||||||
new Token(TokenType.BracketOpen),
|
new Token(TokenType.BracketOpen),
|
||||||
@ -155,656 +340,36 @@ public class LucysNetFixes : IScriptMod {
|
|||||||
|
|
||||||
CodeChange[] changes = {
|
CodeChange[] changes = {
|
||||||
new CodeChange {
|
new CodeChange {
|
||||||
name = "send_message channel 2",
|
name = "read packet intercept",
|
||||||
// MESSAGE_ZONE, "zone_owner": PlayerData.player_saved_zone_owner}, "peers", 2)
|
// FLUSH_PACKET_INFORMATION[PACKET_SENDER] += 1
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is IdentifierToken {Name: "MESSAGE_ZONE"},
|
|
||||||
t => t.Type == TokenType.Comma,
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "zone_owner"}},
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t is IdentifierToken {Name: "PlayerData"},
|
|
||||||
t => t.Type == TokenType.Period,
|
|
||||||
t => t is IdentifierToken {Name: "player_saved_zone_owner"},
|
|
||||||
t => t.Type == TokenType.CurlyBracketClose,
|
|
||||||
t => t.Type == TokenType.Comma,
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "peers"}},
|
|
||||||
t => t.Type == TokenType.Comma,
|
|
||||||
t => t is ConstantToken {Value:IntVariant{Value: 2}},
|
|
||||||
},
|
|
||||||
// , 2 END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new IntVariant(2)),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "instance_actor",
|
|
||||||
// "instance_actor":
|
|
||||||
// END
|
// END
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
multitoken_prefix = new Func<Token, bool>[] {
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "instance_actor"}},
|
t => t is IdentifierToken {Name: "FLUSH_PACKET_INFORMATION"},
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
},
|
|
||||||
// LUCY_INSTANCE_SENDER = packet_sender
|
|
||||||
// END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new IdentifierToken("LUCY_INSTANCE_SENDER"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "kick",
|
|
||||||
// "kick":
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "kick"}},
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline
|
|
||||||
},
|
|
||||||
// if LUCY_LOG_MESSAGES: print("[KICK from", _get_username_from_id(packet_sender), " (", packet_sender, ")]")
|
|
||||||
// if GAME_MASTER: return
|
|
||||||
// if packet_sender != KNOWN_GAME_MASTER: return
|
|
||||||
// END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("LUCY_LOG_MESSAGES"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("[KICK from ")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("_get_username_from_id"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(" (")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(")]")),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("GAME_MASTER"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.OpNotEqual),
|
|
||||||
new IdentifierToken("KNOWN_GAME_MASTER"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "ban",
|
|
||||||
// "ban":
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "ban"}},
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline
|
|
||||||
},
|
|
||||||
// if LUCY_LOG_MESSAGES: print("[BAN from", _get_username_from_id(packet_sender), " (", packet_sender, ")]")
|
|
||||||
// if GAME_MASTER: return
|
|
||||||
// if packet_sender != KNOWN_GAME_MASTER: return
|
|
||||||
// END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("LUCY_LOG_MESSAGES"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("[BAN from ")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("_get_username_from_id"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(" (")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(")]")),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("GAME_MASTER"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.OpNotEqual),
|
|
||||||
new IdentifierToken("KNOWN_GAME_MASTER"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "punch",
|
|
||||||
// "player_punch":
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "player_punch"}},
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline
|
|
||||||
},
|
|
||||||
// if not DATA.has("nya"): LUCY_PUNCHED_ME = packet_sender
|
|
||||||
// END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new Token(TokenType.OpNot),
|
|
||||||
new IdentifierToken("DATA"),
|
|
||||||
new Token(TokenType.Period),
|
|
||||||
new IdentifierToken("has"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("nya")),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
|
|
||||||
new IdentifierToken("LUCY_PUNCHED_ME"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.Newline,4),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "message",
|
|
||||||
// "message":
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is ConstantToken {Value:StringVariant{Value: "message"}},
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline
|
|
||||||
},
|
|
||||||
// if LUCY_LOG_MESSAGES: print("[msg ", _get_username_from_id(packet_sender), "] ", DATA.message)
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("LUCY_LOG_MESSAGES"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("[msg ")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("_get_username_from_id"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(" (")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new StringVariant(")] ")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("DATA"),
|
|
||||||
new Token(TokenType.Period),
|
|
||||||
new IdentifierToken("message"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 4),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "_read_all_P2P_packets",
|
|
||||||
// func _read_all_P2P_packets(channel = 0 END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t.Type == TokenType.PrFunction,
|
|
||||||
t => t is IdentifierToken {Name: "_read_all_P2P_packets"},
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.OpAssign,
|
|
||||||
t => t.Type == TokenType.Constant,
|
|
||||||
},
|
|
||||||
// , limit = 64):
|
|
||||||
// var read_count = 0
|
|
||||||
// while Steam.getAvailableP2PPacketSize(channel) > 0 and read_count < limit:
|
|
||||||
// _read_P2P_Packet(channel)
|
|
||||||
// read_count += 1
|
|
||||||
// LUCY_PACKETS_READ += read_count
|
|
||||||
// func _old_read_all_P2P_packets(channel = 0 END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("limit"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(64)),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("read_count"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new Token(TokenType.CfWhile),
|
|
||||||
new IdentifierToken("Steam"),
|
|
||||||
new Token(TokenType.Period),
|
|
||||||
new IdentifierToken("getAvailableP2PPacketSize"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("channel"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.OpGreater),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.OpAnd),
|
|
||||||
new IdentifierToken("read_count"),
|
|
||||||
new Token(TokenType.OpLess),
|
|
||||||
new IdentifierToken("limit"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("_read_P2P_Packet"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("channel"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("read_count"),
|
|
||||||
new Token(TokenType.OpAssignAdd),
|
|
||||||
new ConstantToken(new IntVariant(1)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new IdentifierToken("LUCY_PACKETS_READ"),
|
|
||||||
new Token(TokenType.OpAssignAdd),
|
|
||||||
new IdentifierToken("read_count"),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
// Give old function new signature, it'll come after in token stream
|
|
||||||
new Token(TokenType.PrFunction),
|
|
||||||
new IdentifierToken("_old_read_all_P2P_packets"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("channel"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "_process",
|
|
||||||
// func _process(delta):
|
|
||||||
// if not STEAM_ENABLED: return
|
|
||||||
// Steam.run_callbacks()
|
|
||||||
// if STEAM_LOBBY_ID > 0:
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t.Type == TokenType.PrFunction,
|
|
||||||
t => t is IdentifierToken {Name: "_process"},
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
t => t.Type == TokenType.CfIf,
|
|
||||||
t => t.Type == TokenType.OpNot,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.CfReturn,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.Period,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
t => t.Type == TokenType.CfIf,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.OpGreater,
|
|
||||||
t => t.Type == TokenType.Constant,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
},
|
|
||||||
// for i in 3: _read_all_P2P_packets(i,LUCY_FRAME_PACKETS)
|
|
||||||
// return
|
|
||||||
// if false:
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.CfFor),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.OpIn),
|
|
||||||
new ConstantToken(new IntVariant(3)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new IdentifierToken("_read_all_P2P_packets"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("LUCY_FRAME_PACKETS"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new ConstantToken(new BoolVariant(false)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "_physics_process",
|
|
||||||
// func _physics_process(delta):
|
|
||||||
// if not STEAM_ENABLED: return
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t.Type == TokenType.PrFunction,
|
|
||||||
t => t is IdentifierToken {Name: "_physics_process"},
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
t => t.Type == TokenType.CfIf,
|
|
||||||
t => t.Type == TokenType.OpNot,
|
|
||||||
t => t.Type == TokenType.Identifier,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.CfReturn,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
},
|
|
||||||
// var do_print = false
|
|
||||||
// BULK_PACKET_READ_TIMER -= delta
|
|
||||||
// if BULK_PACKET_READ_TIMER <= 0:
|
|
||||||
// print("Bulk Reading Packets.")
|
|
||||||
// for i in 3: _read_all_P2P_packets(i,LUCY_BULK_PACKETS)
|
|
||||||
// BULK_PACKET_READ_TIMER = LUCY_BULK_INTERVAL
|
|
||||||
// do_print = true
|
|
||||||
// LUCY_BULK_FULL_TIMER -= delta
|
|
||||||
// if LUCY_BULK_FULL_TIMER <= 0:
|
|
||||||
// print("Reading all packets.")
|
|
||||||
// for i in 3: _read_all_P2P_packets(i,1000000)
|
|
||||||
// LUCY_BULK_FULL_TIMER = LUCY_BULK_FULL_INTERVAL
|
|
||||||
// do_print = true
|
|
||||||
// if do_print:
|
|
||||||
// print("PACKETS ", LUCY_PACKETS_READ)
|
|
||||||
// LUCY_PACKETS_READ = 0
|
|
||||||
// return
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
// var do_print = false
|
|
||||||
// BULK_PACKET_READ_TIMER -= delta
|
|
||||||
// if BULK_PACKET_READ_TIMER <= 0:
|
|
||||||
// print("Bulk Reading Packets.")
|
|
||||||
// for i in 3: _read_all_P2P_packets(i,LUCY_BULK_PACKETS)
|
|
||||||
// BULK_PACKET_READ_TIMER = LUCY_BULK_INTERVAL
|
|
||||||
// do_print = true
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("do_print"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new BoolVariant(false)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new IdentifierToken("BULK_PACKET_READ_TIMER"),
|
|
||||||
new Token(TokenType.OpAssignSub),
|
|
||||||
new IdentifierToken("delta"),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("BULK_PACKET_READ_TIMER"),
|
|
||||||
new Token(TokenType.OpLessEqual),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("Bulk Reading Packets.")),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new Token(TokenType.CfFor),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.OpIn),
|
|
||||||
new ConstantToken(new IntVariant(3)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new IdentifierToken("_read_all_P2P_packets"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("LUCY_BULK_PACKETS"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("BULK_PACKET_READ_TIMER"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("LUCY_BULK_INTERVAL"),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("do_print"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new BoolVariant(true)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
// LUCY_BULK_FULL_TIMER -= delta
|
|
||||||
// if LUCY_BULK_FULL_TIMER <= 0:
|
|
||||||
// print("Reading all packets.")
|
|
||||||
// for i in 3: _read_all_P2P_packets(i,1000000)
|
|
||||||
// LUCY_BULK_FULL_TIMER = LUCY_BULK_FULL_INTERVAL
|
|
||||||
// do_print = true
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_TIMER"),
|
|
||||||
new Token(TokenType.OpAssignSub),
|
|
||||||
new IdentifierToken("delta"),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_TIMER"),
|
|
||||||
new Token(TokenType.OpLessEqual),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("Reading all packets.")),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new Token(TokenType.CfFor),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.OpIn),
|
|
||||||
new ConstantToken(new IntVariant(3)),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new IdentifierToken("_read_all_P2P_packets"),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new IdentifierToken("i"),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new ConstantToken(new IntVariant(1000000)),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_TIMER"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_INTERVAL"),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("do_print"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new BoolVariant(true)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
// if do_print:
|
|
||||||
// print("PACKETS ", LUCY_PACKETS_READ)
|
|
||||||
// LUCY_PACKETS_READ = 0
|
|
||||||
new Token(TokenType.CfIf),
|
|
||||||
new IdentifierToken("do_print"),
|
|
||||||
new Token(TokenType.Colon),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new Token(TokenType.BuiltInFunc, (uint)BuiltinFunction.TextPrint),
|
|
||||||
new Token(TokenType.ParenthesisOpen),
|
|
||||||
new ConstantToken(new StringVariant("PACKETS ")),
|
|
||||||
new Token(TokenType.Comma),
|
|
||||||
new IdentifierToken("LUCY_PACKETS_READ"),
|
|
||||||
new Token(TokenType.ParenthesisClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
|
|
||||||
new IdentifierToken("LUCY_PACKETS_READ"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
|
|
||||||
// return
|
|
||||||
new Token(TokenType.CfReturn),
|
|
||||||
new Token(TokenType.Newline, 1),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "new globals",
|
|
||||||
// var REPLICATIONS_RECIEVED = []
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t.Type == TokenType.PrVar,
|
|
||||||
t => t is IdentifierToken {Name: "REPLICATIONS_RECIEVED"},
|
|
||||||
t => t.Type == TokenType.OpAssign,
|
|
||||||
t => t.Type == TokenType.BracketOpen,
|
t => t.Type == TokenType.BracketOpen,
|
||||||
|
t => t is IdentifierToken {Name: "PACKET_SENDER"},
|
||||||
t => t.Type == TokenType.BracketClose,
|
t => t.Type == TokenType.BracketClose,
|
||||||
|
t => t.Type == TokenType.OpAssignAdd,
|
||||||
|
t => t is ConstantToken {Value:IntVariant{Value: 1}},
|
||||||
t => t.Type == TokenType.Newline,
|
t => t.Type == TokenType.Newline,
|
||||||
},
|
},
|
||||||
// var LUCY_PACKETS_READ = 0
|
// if $"/root/LucyLucysTools".process_read(DATA, PACKET_SENDER, from_host): return
|
||||||
// var LUCY_BULK_FULL_TIMER = 0
|
|
||||||
// var LUCY_FRAME_PACKETS = 32
|
|
||||||
// var LUCY_BULK_PACKETS = 128
|
|
||||||
// var LUCY_BULK_INTERVAL = 0.8
|
|
||||||
// var LUCY_BULK_FULL_INTERVAL = 6.4
|
|
||||||
// var LUCY_SRV_NAME = ""
|
|
||||||
// var LUCY_PUNCHED_ME = 0
|
|
||||||
// var LUCY_INSTANCE_SENDER = 0
|
|
||||||
// var LUCY_LOG_MESSAGES = false
|
|
||||||
// END
|
// END
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_PACKETS_READ"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_TIMER"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_FRAME_PACKETS"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(32)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_BULK_PACKETS"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(128)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_BULK_INTERVAL"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new RealVariant(0.8)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_BULK_FULL_INTERVAL"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new RealVariant(6.4)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_SRV_NAME"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new StringVariant("")),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_PUNCHED_ME"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_INSTANCE_SENDER"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new IntVariant(0)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("LUCY_LOG_MESSAGES"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new ConstantToken(new BoolVariant(false)),
|
|
||||||
new Token(TokenType.Newline, 0),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "packet sender",
|
|
||||||
// if PACKET.empty():
|
|
||||||
// print("Error! Empty Packet!")
|
|
||||||
// END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is IdentifierToken {Name: "PACKET"},
|
|
||||||
t => t.Type == TokenType.Period,
|
|
||||||
t => t is IdentifierToken {Name: "empty"},
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
t => t.Type == TokenType.Colon,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
t => t.Type == TokenType.BuiltInFunc,
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t.Type == TokenType.Constant,
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
t => t.Type == TokenType.Newline,
|
|
||||||
},
|
|
||||||
// var packet_sender = PACKET['steam_id_remote']
|
|
||||||
// END
|
|
||||||
code_to_add = new Token[] {
|
|
||||||
new Token(TokenType.PrVar),
|
|
||||||
new IdentifierToken("packet_sender"),
|
|
||||||
new Token(TokenType.OpAssign),
|
|
||||||
new IdentifierToken("PACKET"),
|
|
||||||
new Token(TokenType.BracketOpen),
|
|
||||||
new ConstantToken(new StringVariant("steam_id_remote")),
|
|
||||||
new Token(TokenType.BracketClose),
|
|
||||||
new Token(TokenType.Newline, 2),
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
new CodeChange {
|
|
||||||
name = "set lobby name",
|
|
||||||
// Steam.setLobbyData(lobby_id, "name", str(STEAM_USERNAME) END
|
|
||||||
multitoken_prefix = new Func<Token, bool>[] {
|
|
||||||
t => t is IdentifierToken {Name: "setLobbyData"},
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t is IdentifierToken {Name: "lobby_id"},
|
|
||||||
t => t.Type == TokenType.Comma,
|
|
||||||
t => t.Type == TokenType.Constant,
|
|
||||||
t => t.Type == TokenType.Comma,
|
|
||||||
t => t.Type == TokenType.BuiltInFunc,
|
|
||||||
t => t.Type == TokenType.ParenthesisOpen,
|
|
||||||
t => t is IdentifierToken {Name: "STEAM_USERNAME"},
|
|
||||||
t => t.Type == TokenType.ParenthesisClose,
|
|
||||||
},
|
|
||||||
// if LUCY_SRV_NAME == "" else LUCY_SRV_NAME END
|
|
||||||
code_to_add = new Token[] {
|
code_to_add = new Token[] {
|
||||||
new Token(TokenType.CfIf),
|
new Token(TokenType.CfIf),
|
||||||
new IdentifierToken("LUCY_SRV_NAME"),
|
new Token(TokenType.Dollar),
|
||||||
new Token(TokenType.OpEqual),
|
new ConstantToken(new StringVariant("/root/LucyLucysTools")),
|
||||||
new ConstantToken(new StringVariant("")),
|
new Token(TokenType.Period),
|
||||||
new Token(TokenType.CfElse),
|
new IdentifierToken("process_read"),
|
||||||
new IdentifierToken("LUCY_SRV_NAME"),
|
new Token(TokenType.ParenthesisOpen),
|
||||||
|
new IdentifierToken("DATA"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("PACKET_SENDER"),
|
||||||
|
new Token(TokenType.Comma),
|
||||||
|
new IdentifierToken("from_host"),
|
||||||
|
new Token(TokenType.ParenthesisClose),
|
||||||
|
new Token(TokenType.Colon),
|
||||||
|
new Token(TokenType.CfReturn),
|
||||||
|
new Token(TokenType.Newline, 2),
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
24
README.md
24
README.md
@ -3,33 +3,25 @@ LucysTools
|
|||||||
Uses GDWeave.
|
Uses GDWeave.
|
||||||
|
|
||||||
Client Features:
|
Client Features:
|
||||||
- Makes the client (tunably) read all packets. This fixes chat messages dropping.
|
|
||||||
- Optionally knocks people back when they punch you.
|
- Optionally knocks people back when they punch you.
|
||||||
- Lets you clear gamechat
|
- Lets you clear gamechat
|
||||||
- Sends messages on P2P channel 2 (This should make your messages more reliable for users who don't have LucysTools)
|
- Allows custom name color (for all users)
|
||||||
- Only the game host can kick/ban you
|
- Allows custom name BBCode (for compatible peers)
|
||||||
- Allows custom name bbcode (and/or custom color)
|
- Allows BBCode in chat (for compatible peers)
|
||||||
- Allows some BBCode in chat: [b], [i], [u], [s], [color] Make sure to close your tags!
|
|
||||||
|
|
||||||
Host Features:
|
Host Features:
|
||||||
- Lets you set a custom server name and message that will be sent when someone joins.
|
- Lets you set a message that will be sent when someone joins.
|
||||||
- Lets you spawn rainclouds & meteors.
|
- Lets you spawn rainclouds & meteors.
|
||||||
- Lets you enable intrusive BBCode ([rainbow], [tornado], [shake], [wave], [font]) in messages. If enabled, other players on the server can use these too. (Not secure or anything, implemented client side)
|
- If intrusive BBCode is enabled, as host 'raw' messages can be sent with a % prefix
|
||||||
- If intrusive BBCode is enabled, 'raw' messages can be sent with a % prefix
|
|
||||||
|
|
||||||
Log Features:
|
Info for Modders:
|
||||||
- If you enable "log_messages" in the config file, messages, kicks, and bans will be logged to godot.log along with the user who sent the packet.
|
- If you'd like to make things compatible, servers get a "bbcode_lobby_name" property, and messages have additional "bb_msg" and "bb_user" fields. DM me!
|
||||||
|
|
||||||
More coming soon!
|
More coming soon!
|
||||||
Probably certainly full of bugs.
|
Probably certainly full of bugs.
|
||||||
|
|
||||||
Packet options:
|
|
||||||
- 'Per Frame Packets' is the number of net packets your client will attempt to read per frame.
|
|
||||||
- 'Bulk Read Packets' is the number of net packets your client will attempt to read per 'Bulk Read Interval' (in seconds)
|
|
||||||
- 'Full Read Interval' is how often your client will attempt to read *all* net packets (in seconds).
|
|
||||||
|
|
||||||
Compatibility:
|
Compatibility:
|
||||||
- Works *only* with WEBFISHING 1.08
|
- Works *only* with WEBFISHING 1.09
|
||||||
- I haven't tested any other mods with this, but I'm happy to try to make things compatible, submit a bug report with the incompatible mod! (Only mods that have source available)
|
- I haven't tested any other mods with this, but I'm happy to try to make things compatible, submit a bug report with the incompatible mod! (Only mods that have source available)
|
||||||
|
|
||||||
Bugs:
|
Bugs:
|
||||||
|
Loading…
Reference in New Issue
Block a user