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

Default behavior of nickel-lang-core's build script burns 100% CPU for minutes #2123

Open
cbiffle opened this issue Dec 14, 2024 · 1 comment
Assignees

Comments

@cbiffle
Copy link

cbiffle commented Dec 14, 2024

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.

Environment
Linux.
rustc 1.82.0 (f6e511eec 2024-10-15)

nickel-lang-core 0.10

@cbiffle 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
@yannham
Copy link
Member

yannham commented Dec 16, 2024

Hello

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.

In any case, thanks for bringing this up.

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

3 participants