Put heavy dataframe dependencies behind feature flag (#9971)

Context from Discord:
https://discord.com/channels/601130461678272522/615962413203718156/1138694933545504819

I was working on Nu for the first time in a while and I noticed that
sometimes rust-analyzer takes a really long time to run `cargo check` on
the entire workspace. I dug in and it was checking a bunch of
dataframe-related dependencies even though the `dataframe` feature is
not built by default.

It looks like this is a regression of sorts, introduced by
https://github.com/nushell/nushell/pull/9241. Thankfully the fix is
pretty easy, we can make it so everything important in
`nu-cmd-dataframe` is only used when the `dataframe` feature is enabled.

### Impact on `cargo check --workspace`

Before this PR: 635 crates, 33.59s
After this PR: 498 crates, ~20s

(with the `mold` linker and a `cargo clean` before each run, the
relative difference for incremental checks will likely be much larger)
This commit is contained in:
Reilly Wood 2023-08-09 22:36:09 -07:00 committed by GitHub
parent f94df58486
commit d5fa7b8a55
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 2 deletions

View file

@ -56,8 +56,8 @@ optional = true
version = "0.30.0" version = "0.30.0"
[features] [features]
dataframe = ["default"] dataframe = ["num", "polars", "sqlparser"]
default = ["num", "polars", "sqlparser"] default = []
[dev-dependencies] [dev-dependencies]
nu-cmd-lang = { path = "../nu-cmd-lang", version = "0.83.2" } nu-cmd-lang = { path = "../nu-cmd-lang", version = "0.83.2" }

View file

@ -1,2 +1,4 @@
#[cfg(feature = "dataframe")]
pub mod dataframe; pub mod dataframe;
#[cfg(feature = "dataframe")]
pub use dataframe::*; pub use dataframe::*;