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

Automatically enable required-features #4663

Open
mystor opened this issue Oct 26, 2017 · 14 comments
Open

Automatically enable required-features #4663

mystor opened this issue Oct 26, 2017 · 14 comments
Labels
A-features Area: features — conditional compilation A-required-features Area: required-features setting C-feature-request Category: proposal for a feature. Before PR, ping rust-lang/cargo if this is not `Feature accepted` S-needs-team-input Status: Needs input from team on whether/how to proceed.

Comments

@mystor
Copy link

mystor commented Oct 26, 2017

If I have a crate like:

[package]
name = "foo"

[features]
myfeature = []
another = []

[[example]]
name = "myexample"
required-features = ["myfeature", "another"]

It would be awesome if cargo run --example myexample automatically enabled the myfeature feature for me, rather than producing an error message like it does today. There is no situation where I can do anything useful without padding the additional --features myfeature flag.

This is the current message:

error: target `myexample` requires the features: `myfeature`, `another`
Consider enabling them by passing e.g. `--features="myfeature another"`

See also #2911

@alexcrichton alexcrichton added the C-feature-request Category: proposal for a feature. Before PR, ping rust-lang/cargo if this is not `Feature accepted` label Oct 27, 2017
@brendanzab
Copy link
Member

brendanzab commented Feb 13, 2018

Is there a possibility to alter this issue to also include binaries? I currently have:

[package]
name = "lambdapi"

[features]
cli = ["rustyline", "structopt"]

[[bin]]
name = "lambdapi"
required-features = ["cli"]

[dependencies]
rustyline = { version = "1.0.0", optional = true }
structopt = { version = "0.2.2", optional = true }

At the moment running: cargo run gives:

error: target `lambdapi` requires the features: `cli`
Consider enabling them by passing e.g. `--features="cli"`

Instead I have to run: cargo run --features=cli, which feels kinda clunky. It seems weird from a user perspective that cargo knows it requires them, but doesn't fill them in for you.

@kvark
Copy link

kvark commented May 2, 2018

Joining the request - we are hitting this in three-rs with "gltf-loader" feature.

@aturon
Copy link
Member

aturon commented May 2, 2018

@gankro is looking for mentors, cc @rust-lang/cargo

@matklad
Copy link
Member

matklad commented May 2, 2018

So, unfortunately this, while it sounds like an E-should-not-be-that-hard bug, is actually pretty tricky to fix properly! However we probably could get a 80% working solution without too too much effort.

The error originates from this function, whose job is to determine which targets should be compiled, based on the CLI flags (filter and packages). Unfortunately, it is too late to enable additional features by this time. This is because Cargo selects features early in the build cycle, during initial dependency resolution, so resolve: &Resolve, argument holds info not only about dependencies between packages, but about activated features as well.

The proper solution here I believe is to remove features from resolve, and instead do feature selection later, exactly in the generate_targets function, which should fix #4463, a number of similar bugs, and quite probably break some builds which relay on the current behavior.

The 80% solution would be to enable required features before we construct resolve. This happens over here:

let method = Method::Required {
dev_deps: ws.require_optional_deps() || filter.need_dev_deps(mode),
features: &features,
all_features,
uses_default_features: !no_default_features,
};
let resolve = ops::resolve_ws_with_method(ws, source, method, &specs)?;

(and we get there from this code, specific to cargo run)

I think, for cargo run specifically, we can push missing features to features vec. Note, however, that this features apply only to the "current" package, that is, package at the working directory. So, the 80% fix would be

  • if we are in cargo run
  • and the user hasn't requested any features explicitly (no --feature, --all-features, --no-deafult-features arguments)
  • and the user is running binary from the current package (that is, not cargo run -p foo --bin bar)
  • then we add all required features.

I think that with some amount of legwork we could get rid of current package restriction as well, but that would make certain cargo run invocations enable feature configurations, which are impossible with explicit --feature flags, and that makes me feel uneasy.

If we don't want to fix current package limitation, then, implementation wise, I think we should express this as desugaring of cli arguments, by modifying options.features here, and that should tickle down to that resolve construction code.

@elichai
Copy link

elichai commented Jan 9, 2020

Any updates on this?

@ehuss ehuss added A-features Area: features — conditional compilation A-required-features Area: required-features setting labels Feb 1, 2020
@clarfonthey
Copy link
Contributor

This would also be nice for crates which offer optional binaries, where there are features that don't have to be there by default for the library but are required for binaries.

@pksunkara
Copy link

Just wanted to point that the feature proposal from rust-lang/rfcs#2887 will fix this if implemented.

@Synthetica9
Copy link

Synthetica9 commented Dec 9, 2020

I haven't seen it mentioned here, but the current behaviour is anti-useful:

$ cargo run --example widget_gallery
error: target `widget_gallery` in package `druid` requires the features: `svg`, `im`, `image`, `png`
Consider enabling them by passing, e.g., `--features="svg im image png"`
$ cargo run --example widget_gallery --features="svg im image png"
error: --features is not allowed in the root of a virtual workspace
note: while this was previously accepted, it didn't actually do anything
$ cargo --version
cargo 1.47.0

@rnag
Copy link

rnag commented Apr 1, 2022

Just to add that I've currently come up with a project cargo-rx which abstracts away cargo run --example, and by default enables --required-features when running examples.

FWIW, I agree it'd be nice to see this feature supported by default in cargo as well.

@WaffleLapkin
Copy link
Member

fyi: Rust Analyzer "Run" action (F1 -> Rust Analyzer: Run in vscode) enables required features for examples.

@bkolligs
Copy link

bkolligs commented Feb 5, 2023

Any updates on this issue?

@weihanglo
Copy link
Member

Any updates on this issue?

See rust-lang/rfcs#3374

@colleen05
Copy link

Well, we didn't get enable-features as suggested in rust-lang/rfcs#3374 ...

What now? 😕

@Skgland
Copy link

Skgland commented Jul 26, 2024

As #10409 was closed in favor of this issue could the title maybe be adjusted to also mention bins?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-features Area: features — conditional compilation A-required-features Area: required-features setting C-feature-request Category: proposal for a feature. Before PR, ping rust-lang/cargo if this is not `Feature accepted` S-needs-team-input Status: Needs input from team on whether/how to proceed.
Projects
None yet
Development

No branches or pull requests