-
-
Notifications
You must be signed in to change notification settings - Fork 21.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Hot-reloading of scripts ("Synchronize Script Changes") doesn't work when using external editor (VSCode) #72825
Comments
I don't want to turn this into a "me too!" comment stream, but I will say it's not just VS Code. I have this problem with Neovim as well, so it is very likely simply Godot isn't monitoring for inotify events or whatever equivalents on non-Unix systems. I'm guessing the integrated editor runs some code on save that initiates the reloading, which would certainly be more efficient than monitoring the filesystem when applicable so it is very understandable. But it would be great if it did monitor the filesystem when users work with external editors. |
I did some digging into this and I believe I've found the underlying cause as well as a potential fix. This code in godot/editor/plugins/script_text_editor.cpp Lines 728 to 739 in 013a457
Separately: When an external editor is connected to the language server, it sends a
This in turn causes the script's Since the I did not have time to investigate fully, but I suspect this issue was introduced by #66867 as it introduced reloading the script within I found that I can fix the issue by calling (As an added bonus this also fixes #73808, but only if you're connected to the language server) However today is the first time I've ever really used Godot, so it's not immediately clear to me whether this is the most appropriate fix. (If it is, would be more than happy to clean things up and make a PR!) |
Thank you so much for the code snippet here @PathogenDavid . I've been using a custom build of Godot 4 with your patch and it has significantly improved my workflow. It would be great to have a PR for this. Maybe this could even only run if EDIT: Actually there is one potential issue: if you are typing in VSCode, and save incorrect syntax, the editor will come into focus. You then need to click on the editor, then click back on VSCode. |
In #75550 we use the build-in GDScript editor which @dakennedyd thinks relates to this issue. Does it? |
Is there any reason for not making the fix @PathogenDavid made into a PR? PathogenDavid@210edab |
@Dexterminator I mainly left my comment to share my findings for someone who wishes to investigate this further and to share my quick and dirty fix (and perhaps learn if someone more involved with Godot's development thought it was good enough as-is.) Based on the quirk @OmarShehata ran into, I suspect the real fix will need to be more complicated. A lot has changed for me in the past 6 months and I'm no longer using Godot, so I most likely won't be the one to investigate further. |
@PathogenDavid I think it's a good change. You should open a PR so that people may test the change easily and maintainers can get a chance to review it. |
From the Godot contribution guidelines:
My understanding is this is the appropriate and preferred place to discuss the change. I don't think my fix will be the whole fix--at the very least the issue Omar ran into needs to be addressed. Additionally, I don't see how making a PR would make it any easier for people to test the change. |
A PR is the best way to discuss a code change in the engine. It is the normal review process to checkout a PR and test a change locally. Checking out a commit that is out of tree is more involved. The issue of the editor requesting focus after a script error is, IMHO a minor inconvenience VS having no reload. Anyway, if you want to discuss this change with somebody that knows the ins and outs of the engine, you have a better chance with a PR than waiting for one of those people to stumble into a code change mentioned in an issue. |
Just to share my 2 cents here: I think it's clear David is no longer able to commit time/resources to this. His snippet posted above is super valuable for anyone wanting to pick this up, and anyone is free to do so and open a PR. It makes sense that whoever opens a PR will likely also be the one to collect feedback from engine maintainer/test it/update it etc. Anyway, since I do have an interest in seeing this fixed, and have been testing it locally with a patched version of the engine, I'd be happy to open a PR sometime next week if no one gets to it before then. |
Seems like there is already an pr about this?#82113 (comment) |
@eterlan I think that is maybe fixing a slightly different situation? I just started re-testing this with the latest version of Godot. Had some trouble initially but turns out it was just the language server not properly connecting. The fix described in the patch above still works. The obvious thing needed before merging would be figuring out a proper way to force reload the script (currently the patch just makes a private function public). I'm still familiarizing myself with these files, one thing I wanted to try is whether we just need to flip this boolean in the case where an external editor is being used:
I also wanted to double check what the flow is for updating when you save inside the Godot editor, and if it makes sense to match that when saving with an external editor. If I can't make progress I'll just open the PR and ask in the engine devs chat for further guidance |
Godot version
4.0.beta17
System information
MacOS
Issue description
When the "Synchronize Script Changes" option is selected, scripts should hot-reload when changes are saved. However, this does not work when using Godot 4 with an external editor (only tested on VSCode). It does work when using the in-built text editor, or when using Godot 3.
Steps to reproduce
Minimal reproduction project
N/A
The text was updated successfully, but these errors were encountered: