-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Add --lib and status message for completion #2921
Conversation
(rust_highfive has picked a reviewer for you, use r? to override) |
Hm, when we made cargo, we assumed the opposite. What's the basis here? On Jul 26, 2016, 15:02 -0700, Rust highfive robot notifications@github.com, wrote:
|
Also, while Cargo is technically nightly, we've considered the CLI pretty On Tue, Jul 26, 2016 at 6:29 PM, Steve Klabnik steve@steveklabnik.com
|
@steveklabnik - Cargo is at "0.13.0-nightly (dc12479 2016-07-22)", so we're still pre-1.0. I agree that we don't want to go breaking things willy-nilly... It looks like the hunch that most people would make libraries doesn't seem to play out from the results we're seeing. The 2016 survey puts "contributes to crates.io" as a minority of our users (roughly 550 of the 2000 active Rust users in the survey). There's another intuition that if you're trying to make a library, you already have a bit of Rust experience under your belt. You know how to look up documentation and how to set up additional settings. I'd argue even into your first few days as a Rust developer you may not have created a library yet, but likely would have created a few small apps. If the minority of users create libraries, and we're making users go down less ergonomic paths because of it, this seems like a good reason to change the default. |
One possibility for sequencing this as well is to add the I agree with @steveklabnik that despite cargo being "pre 1.0" it's basically defacto stable in many respects. I'm not too worried about breakage here, but it may be best to head it off by moving slowly. I don't personally recall the exact reasons why we chose libraries as the default, but I'm sympathetic to the data just being the other way around so don't mind changing on that basis. |
} | ||
else { | ||
flag_bin | ||
}; |
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.
Here we should just pass through flag_bin
, right?
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.
Oh I see, yeah let's just pass through these flags as-is and have the "default logic" kick in during the implementation below
cc @rust-lang/tools, thoughts about changing the default? |
+1 on adding --lib, +0.5 on changing the default - It annoys me personally, I nearly always want --bin, but Cargo is de facto pretty stable, so we should do this gently rather than flicking the switch. In addition to Alex's suggestion, could we warn when doing |
I think I agree that I'm unsure the best way to proceed, or if the breakage is worth it. Another way we could transition is by temporarily changing |
So it sounds like we're leaning towards making it the default but with caution. Maybe we can switch the default but also just add a general result message for any new/init? Something like:
|
I think the motivation for this PR from @jonathandturner was to simplify the newbie experience with just
This... seems like a great idea! @jonathandturner what do you think of this? The idea of a status message also seems fine to me, it's arguably just missing today. |
I lean towards the status message. Putting both in works on one level, since it doesn't have a preference. But what I'm trying to fix is that there's a happy path for users, especially new users. If a new user types "cargo new foo", they'll end up getting more than they have today that they need to read and understand. I'd rather have a simple starter template. |
I'm comfortable with adding |
Switched to using @wycats/@nrc's suggestion, so I now warn if you do a cargo new without a target. Default is back to --lib. I also added a status message for successful completion of a new/init. |
Started a thread here: https://internals.rust-lang.org/t/should-cargo-new-default-to-applications/3772 to see if we should change the default. For the time being, leaving the PR as a simple "add --lib and add a status message". |
|
||
try!(config.shell().status("Created", format!("{} project", | ||
if is_lib { "library" } | ||
else {"binary (application)"}))); |
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.
Can this be pushed into ops
to deduplicate betwen here and new
? (same with the if
block above
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 messages are different between init and new, so I'm not sure how much that would buy us.
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.
Oh ok, in that case maybe it could be pushed down into the init
and new
functions? (would be good to deduplicate the if
above in any case)
@alexcrichton Fixed and squished. Defaulting now happens in a constructor that's shared by both functions. |
Ah right one last thing is could you add a test where both |
@alexcrichton - done. |
Add --lib and status message for completion This PR adds a --lib flag for creating a library with new/init. It also adds a status message for a successful completion.
☀️ Test successful - cargo-cross-linux, cargo-linux-32, cargo-linux-64, cargo-mac-32, cargo-mac-64, cargo-win-gnu-32, cargo-win-gnu-64, cargo-win-msvc-32, cargo-win-msvc-64 |
Why can't specify both bin and lib? You /can/ have both lib.rs and main.rs... (Should I be opening a new issue instead of hijacking a merged PR?) |
@SoniEx2 ah yeah in general you should be able to combine any number of |
This PR adds a --lib flag for creating a library with new/init. It also adds a status message for a successful completion.