-
-
Notifications
You must be signed in to change notification settings - Fork 229
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
Ignore --arch switch if it doesn't affect the build #2962
Conversation
✅ PR OK, no changes in deprecations or warnings Total deprecations: 8 Total warnings: 0 Build statistics: statistics (-before, +after)
-executable size=5293368 bin/dub
-rough build time=64s
+executable size=5297464 bin/dub
+rough build time=62s Full build output
|
Example of meson changes caused by this issue: https://github.com/mesonbuild/meson/pull/13550/files#diff-a0eb8ae9cfbf214701a150d556ecba59c3776cff6c5ba9c1f712a2d6a6616443 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for doing this. It is indeed a problem if dub
behave differently when an --arch
that matches the default is passed as opposed to not provided. I made a few comments about the approach but the underlying goal is 💯
source/dub/compilers/compiler.d
Outdated
@@ -212,6 +214,23 @@ interface Compiler { | |||
} | |||
} | |||
|
|||
if (arch_flags.length) { | |||
auto result_without_arch = execute(compiler_binary ~ args ~ fileArg); | |||
with (result_without_arch) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please don't use with
. We can just shorten the name here (res_noarch
?)
source/dub/compilers/compiler.d
Outdated
*/ | ||
protected final BuildPlatform probePlatform(string compiler_binary, string[] args, string arch_override) | ||
protected final BuildPlatform probePlatform(string compiler_binary, string[] args, string[] arch_flags, string arch_override, out bool arch_override_does_something) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should look into simplifying this. Having 3 parameters around arch is a red flag.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let me think about this for a little bit, enough time has passed since I first wrote this and I changed my mind on some implementations details. I'll make the changes that I want and see if I can reduce the number of flags here in order not to have a garbage API.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for the delay - I can also try to take a look. At the end of the day, if this solves a problem you have, I would be happy to go ahead with it to avoid another great delay.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The only thing that I care for changing is modifying the algorithm to preserve -arch x86_64-unknown-linux-gnu
like flags, so fully specifying the target, but try to strip flags like -arch x86_64
since those just map to -m64
. I'm just a little worried that stripping the triple will lead to some obscure errors on weird setups but stripping -m32
and whatnot should always be safe.
I'm not sure I'll get it done by the end of the day and I'm not the one affected by this issue so I also don't care that much for getting this merged ASAP.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So I went with another approach. To determine if the platform changes I just call probePlatform
twice in each compiler's determinePlatform
.
I've also taken the warning about the architecture not applying from probePlatform
and put it into dmd.d
since it seems to be mostly relevant for x86_mscoff
vs x86_omf
, which gdc doesn't suffer from. This, along side moving the default probe compiler flags (-o- -v -c
) into a separate function, reduced the number of parameters to probePlatform
to only two: the compiler and the arch flags.
Like I've said that I wanted now full triples like x86_64-unknown-linux-gnu
are not stripped.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The new code looks better, my only concern is calling probePlatform twice, do you know how much time that would add to the build time ? I assume the platform file is fairly easily parsed / analyzed but I never actually measured how much it takes on my system.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did a quick check on my system, got min/max/med of 7/11/10 with LDC
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The new code looks better, my only concern is calling probePlatform twice, do you know how much time that would add to the build time ? I assume the platform file is fairly easily parsed / analyzed but I never actually measured how much it takes on my system.
Using a stopwatch to time determinePlatform
on my system gives, roughly:
compiler | Without --arch | With --arch |
---|---|---|
dmd | 3.5ms | 6.5ms |
gdc | 9ms | 17ms |
ldc | 15ms | 28ms |
The old code also invoked the compiler twice to determine if the arch changed, it just did that in the probePlatform
function in order to reuse the probe file. Timing that probe file generation gives me 0.038ms so, since it keeps the code cleaner I think it's better to simply recall probePlatform
. I don't think we have a way to check if the architecture changes without reinvoking the compiler, maybe there's a way to do it simply by looking at compiler -v
and guessing the default architecture from that but it sounds very brittle.
ff90dc1
to
f0f8047
Compare
source/dub/compilers/compiler.d
Outdated
return build_platform; | ||
} | ||
|
||
/// Adds the given flags to the build settings if desired, otherwise informs the user | ||
final void maybeAddArchFlags(bool keep_arch, ref BuildSettings settings, string[] arch_flags, string arch_override) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe this can become protected static
instead of public final
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Or move it outside the class
:
package void maybeAddArchFlags(ref BuildSettings settings, bool keep_arch, string[] arch_flags, string arch_override)
Reordering args to make it UFCS-friendly.
@the-horo : This is ready to be merged. LMK if you want to act on #2962 (comment) and maybe rebase on master. |
f0f8047
to
5016ec5
Compare
This change has two consequences, one it can improve caching as specifying `--arch=<default_arch>` will lead to the same build id as not specifying it at all but, more importantly, it improves the usability of external tools that rely on dub generated files. Take as an example the meson build system. It supports for a project to depend on a dub build library. The internal code calls `dub describe --build=... --compiler=... --arch=...` and gathers the cache artifact file from that. Because of always specifying `--arch` the package will always need to be rebuilt when used by meson. This is not intuitive to someone who doesn't know how the --arch switch is used internally in dub. This has come up as an issue in meson's CI system. The CI system is setup to build test images to be used in a container, periodically, which include all the needed dependencies and common files that are shared across test runs to improve test times. For dub this implies that dub packages that are needed during the tests are fetched + built during the building of the CI images, not when running tests. However, the packages were built with `dub build --compiler=... <pkg>` which would log to stdout that it built <pkg> debug configuration with <comp> on x86_64. During the tests meson would fail to find the built packages because of the `--arch` switch it used internally and it recommended that the package should be built with `--compiler=<comp> --build=debug --arch=x86_64` witch is exactly what dub reported the package was built with. This has lead to frustrating debugging and the install scripts calling dub like `dub run --yes dub-build-deep -- <pkg> --arch=x86_64 --compiler=<comp> --build=debug` because nobody can figure out what flags are actually needed. Signed-off-by: Andrei Horodniceanu <[email protected]>
5016ec5
to
af5687e
Compare
Rebased and made the change |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks!
BTW @the-horo any way I can reach you ? Are you on the Dlang Slack / an email I can use ? |
I'm not on, what I assume is, https://dlang.slack.com but I wouldn't mind joining. Email's fine otherwise, it's the same as the one I sign-off my commits with: [email protected]. Pings on github also work. |
This change has two consequences, one it can improve caching as specifying
--arch=<default_arch>
will lead to the same build id as not specifying it at all but, more importantly, it improves the usability of external tools that rely on dub generated files.Take as an example the meson build system. It supports for a project to depend on a dub build library. The internal code calls
dub describe --build=... --compiler=... --arch=...
and gathers the cache artifact file from that. Because of always specifying--arch
the package will always need to be rebuilt when used by meson. This is not intuitive to someone who doesn't know how the --arch switch is used internally in dub.This has come up as an issue in meson's CI system. The CI system is setup to build test images to be used in a container, periodically, which include all the needed dependencies and common files that are shared across test runs to improve test times. For dub this implies that dub packages that are needed during the tests are fetched + built during the building of the CI images, not when running tests.
However, the packages were built with
dub build --compiler=... <pkg>
which would log to stdout that it built<pkg>
debug configuration with<comp>
on x86_64. During the tests meson would fail to find the built packages because of the--arch
switch it used internally and it recommended that the package should be built with--compiler=<comp> --build=debug --arch=x86_64
witch is exactly what dub reported the package was built with. This has lead to frustrating debugging and the install scripts calling dub likedub run --yes dub-build-deep -- <pkg> --arch=x86_64 --compiler=<comp> --build=debug
because nobody can figure out what flags are actually needed.