You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
1. Describe the bug
The AL language editor host executable has an internal cache where it holds things like referenced symbols and project symbols and so on. I assume for performance reasons. This cache however is not always refreshed correctly and requires the user to run a "Reload Window" or reload the entire project workspace to refresh it.
I have a few scenarios where this happens and is a problem for me:
When I externally download symbols they are not detected by AL language.
Modifying the app.json triggers a cache refresh, but only when done so from inside VS Code. If app.json is modified externally, AL language does not detect a change to it and thus does not refresh anything.
Switching branches in git causes the cache of the AL language to become stale. The symbols in it's cache still refer to the old version of my objects. This until I either reload the project (as described above) or I open the object in question. This however refreshes the cache for this object only.
2. To Reproduce
Steps to reproduce the behavior:
Scenario 1:
Download a symbol package manually from somewhere and place it in the .alpackages folder.
The new symbol package is not detected.
Scenario 2:
Use a project with a dependency to an app that you already have in your .alpackages folder.
Update the minimum version to something higher that is not available.
You correctly get an error stating that symbols are missing.
Externally modify app.json and reset the version to what it was before.
The symbol is still missing according to AL language.
Scenario 3:
Work on a feature branch where you removed a method from an object.
Close the editor for that object.
Switch back to a different branch where the method from 1 still exists.
Go to a different object and reference this method.
AL language argues that this method does not exist, but it does.
3. Expected behavior
Option 1: detect file changes even when made from outside the project. There are numerous tools around now that interface with AL projects, tying it's caching mechanism to only what happens under AL languages watch is very limiting. You could, for example, bind this to the app.json file only. Anyone who wants to cause a cache refresh from outside VS Code then just has to touch that file and you would not have to watch all project files for changes.
Option 2: give us a command that let's us explicitly cause a cache refresh without having to reload the entire editor. This command would then also be required to be callable from other extensions, pretty please.
4. Actual behavior
The cache often becomes stale and requires me to reload my editor, causing lots of reload times.
I'll accept this since I think it's worth investing into this. However, the issue is not caching. The problem is that the extension and VSCode are not processing external changes properly.
We'll definitely work on improving the GitHub branch change scenario. For the symbols, it is possible that this is a larger investment which might take more time.
Agree with @BazookaMusic . We will try to make github branch changes not to blow up the language server and the diagnostics service.
Exposing the command is a bit more complicated. There are more then just what you wrote. There are coupling to other subsystems like the project system, diagnostics service, tracking compilation. It makes things a bit more complicated to be treated as a simple bug.
1. Describe the bug
The AL language editor host executable has an internal cache where it holds things like referenced symbols and project symbols and so on. I assume for performance reasons. This cache however is not always refreshed correctly and requires the user to run a "Reload Window" or reload the entire project workspace to refresh it.
I have a few scenarios where this happens and is a problem for me:
app.json
triggers a cache refresh, but only when done so from inside VS Code. Ifapp.json
is modified externally, AL language does not detect a change to it and thus does not refresh anything.2. To Reproduce
Steps to reproduce the behavior:
Scenario 1:
.alpackages
folder.Scenario 2:
.alpackages
folder.app.json
and reset the version to what it was before.Scenario 3:
3. Expected behavior
Option 1: detect file changes even when made from outside the project. There are numerous tools around now that interface with AL projects, tying it's caching mechanism to only what happens under AL languages watch is very limiting. You could, for example, bind this to the
app.json
file only. Anyone who wants to cause a cache refresh from outside VS Code then just has to touch that file and you would not have to watch all project files for changes.Option 2: give us a command that let's us explicitly cause a cache refresh without having to reload the entire editor. This command would then also be required to be callable from other extensions, pretty please.
4. Actual behavior
The cache often becomes stale and requires me to reload my editor, causing lots of reload times.
5. Versions:
Internal work item: AB#556873
The text was updated successfully, but these errors were encountered: