Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Stack rebuilds whole application in file-watch mode, when it should be able to incrementally recompile #5233

Open
danbroooks opened this issue Mar 22, 2020 · 1 comment

Comments

@danbroooks
Copy link
Contributor

danbroooks commented Mar 22, 2020

I have opened this issue from yesodweb/yesod#1661, where the context of my issue is I wish to switch between yesod-devel for my yesod application, and run stack test, without needing to re-compile the whole of my app. Doing so currently seems to trigger a full re-build, and I have narrowed down my problem to the stack commands I believe are being executed in this context.

If I build my application with tests like so:

stack build --fast --test --flag myapp:library-only --flag myapp:dev

-- outputs:
myapp> build (lib + exe + test)

And then run this command (which is the raw command from yesod devel, minus the --exec "/home/dan/.local/bin/yesod devel-signal" flag):

stack build --fast --file-watch myapp:lib --flag myapp:dev --flag myapp:library-only

I get this output:

Success! Waiting for next file change.
Type help for available commands. Press enter to force a rebuild.

Then when I make a file change, this results in the whole lib project needing to be rebuilt, and the following output:

myapp> build (lib)

My thought process here though is that the whole library has been built as part of the first test command, and therefore should not need to trigger an entire re-build from scratch, and instead should be able to incrementally re-compile from the file I have changed and onwards.


As part of my troubleshooting with stack I have been adding logging here and there to some of the files in src/Stack/Build, and have shifted a few things around in order to make the code a bit easier to follow, and also get at certain values in different places.

Would a refactor PR be welcomed with these changes to the project?

@danbroooks danbroooks changed the title Stack rebuilds whole application in file-watch mode, it should be able to recompile Stack rebuilds whole application in file-watch mode, when it should be able to incrementally recompile Mar 22, 2020
@MaciekFlis
Copy link

Could this be related to #4977 ?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants