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
Describe the bug
If you are (say) attempting to try out Nickel by adding nickel-lang-core to a project, your next build will not go well.
To Reproduce
cargo new nickeltest
cd nickeltest
cargo add nickel-lang-core
cargo build
This will burn at least one core at 100% for at least minutes (I wound up killing it). GDB attached to the build script shows it's off doing something in lalrpop.
I notice that your workspace has opt overrides for lalrpop in the top-level Cargo.toml; these won't apply to anyone trying to use your package, and it may be worth figuring out a way to avoid needing them. I wonder if there's a way to check in the results of whatever it is lalrpop is doing.
Adding a profile override to my package's Cargo.toml "fixes" this problem, but I'm attempting to write a library crate, and I can't expect all of my downstream users to do that.
Expected behavior
The build completes without taking 100% CPU for minutes on end without making apparent progress.
The text was updated successfully, but these errors were encountered:
cbiffle
changed the title
Default behavior of nickel-lang-core's build script is
Default behavior of nickel-lang-core's build script burns 100% CPU for minutes
Dec 14, 2024
I think the bottom line is that LALRPOP is just doing a lot of work at build time to generate Rust source files from the declarative grammar. By default, build dependencies are built without optimizations to favor compilation speed - but for LALRPOP experience shows that it's better to pay the price of optimizing when compiling LALRPOP itself, as running LALRPOP as part of the build process is much faster.
I wasn't aware that overrides don't apply transitively, that is indeed an issue (and I suspect why compilation from scratch is taking forever for Topiary cc @Xophmeister ). I'll look into the possibility of pre-checking a LALRPOP generated grammar, if there is a clean way to do that without having a risk of a drift.
Describe the bug
If you are (say) attempting to try out Nickel by adding
nickel-lang-core
to a project, your next build will not go well.To Reproduce
This will burn at least one core at 100% for at least minutes (I wound up killing it). GDB attached to the build script shows it's off doing something in lalrpop.
I notice that your workspace has opt overrides for lalrpop in the top-level Cargo.toml; these won't apply to anyone trying to use your package, and it may be worth figuring out a way to avoid needing them. I wonder if there's a way to check in the results of whatever it is lalrpop is doing.
Adding a profile override to my package's Cargo.toml "fixes" this problem, but I'm attempting to write a library crate, and I can't expect all of my downstream users to do that.
Expected behavior
The build completes without taking 100% CPU for minutes on end without making apparent progress.
Environment
Linux.
rustc 1.82.0 (f6e511eec 2024-10-15)
nickel-lang-core 0.10
The text was updated successfully, but these errors were encountered: