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

Make the paths stored in precompiled-cache Stack-root relative #2215

Merged
merged 1 commit into from
Jun 4, 2016

Conversation

da-x
Copy link
Contributor

@da-x da-x commented May 31, 2016

Because these paths always point inside the Stack root, better make them relative to the Stack root, making the Stack root more easily relocatable, in the future.

This change is backward-compatible.

Because these paths always point inside the Stack root, better
make them relative to the Stack root, making the Stack root
more easily relocatable, in the future.

This change is backward-compatible.
@mgsloan
Copy link
Contributor

mgsloan commented May 31, 2016

Makes sense! Stack roots probably aren't going to be relocatable any time very soon though, unfortunately, cabal package build results have absolute paths.

This is a good change anyway, though. In the future this stuff could be relocatable, and this will save some bytes in the precompiled cache.

@da-x
Copy link
Contributor Author

da-x commented May 31, 2016

Apart from this, we have the Cabal conf files that you mentioned, the GHC pkgdb, some shell wrappers and RPATH in DSOs. All of these are easier and known formats that are easy to deal with. Only the precompiled-cache is very much Stack-specific.

BTW, I'm working on a 'stack relocate' command. I'm designing it to be used under rpmbuild mock chroot. @juhp

@mgsloan
Copy link
Contributor

mgsloan commented May 31, 2016

That's awesome! I'd love to be able to copy build directories for #1634 , but I'm not sure how this would get around binary dependencies on the Paths_* module (getDataFile). Still handy for those packages that don't depend on it.

See these stack issues on relocatable data files: #1262 #848

(compiled in absolute path dependencies on these data files is the issue)

Considerations that only apply to relocatable-work-dir not relocatable-root: Since stack causes .ddump-hi files to be generated, I think it actually would be theoretically feasible to remove all object files that have a dependency on the Paths_ module. Bonus points would also be to delete executables that have a dep on a Paths_ module. Rather tricky to trace back from obj file -> cabal component invalidation, though.

@da-x
Copy link
Contributor Author

da-x commented May 31, 2016

There's a partially working for binaries that assumes that the path you are relocating to is shorter or of the same length, and that there are no checksums or signatures. This is mostly the case in build servers, which tend to build under paths that are quite long, e.g. /build/rpmbuild/[sometimes-long-rpm-package-name-plus-version/build-root/..., verifiably longer than the usual install destination /usr. The trick is to assume null termination of the strings, pad the right side with zero characters, and do binary replacement inside the generated files. It's a bit nasty, though.

@mgsloan
Copy link
Contributor

mgsloan commented May 31, 2016

That's rather clever! Better hope some machine code doesn't magically resemble a filepath! :D

@da-x
Copy link
Contributor Author

da-x commented May 31, 2016

The package.cache file proved stubborn with the zero padding, but I've realized that for the UNIX case I can pad the beginning of the path with /, since /////usr is as valid a path as /usr. So now stack relocate works (implementation).

@mgsloan mgsloan merged commit 3103ebe into commercialhaskell:master Jun 4, 2016
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

Successfully merging this pull request may close these issues.

2 participants