-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
RFC: Syntax for embedding cargo-script manifests #3503
Conversation
In PL/Rust (a Rust subset that works as a postgres procedural language handler) we use a somewhat hacky syntax like (see https://github.com/tcdi/plrust/blob/main/doc/src/dependencies.md for example source) [dependencies]
rand = "0.8"
[code]
use rand::Rng;
Ok(Some(rand::thread_rng().gen())) I greatly prefer the approach in this RFC (and will likely push PL/Rust transition to it if the RFC is accepted) but it's probably worth noting as prior art. |
This comment was marked as resolved.
This comment was marked as resolved.
If you think this RFC a little bit further, then you could generalize this to make rustc ignore all ``` delimitered blocks, to say that rustc should just ignore all these sections and leave them to other tools similarly to how it does it already for the shebang. And then you'd see how similar triple backtick blocks are to IMO it's bad style to add cargo specific extensions to Rust's syntax. Just say that ``` delimitered blocks are ignored by rustc and that parser implementations are suggested to add them. |
Thanks! I've added this as prior art and would love more interoperability (one of the stated motivations for the cargo script RFC) |
text/3503-frontmatter.md
Outdated
### Alternative 7: Extended Shebang | ||
|
||
````rust | ||
#!/usr/bin/env cargo | ||
# ```cargo | ||
# [dependencies] | ||
# foo = "1.2.3" | ||
# ``` | ||
|
||
fn main() {} | ||
```` |
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.
@bstrie (moved here for context / easier to follow)
I would like to consider alternative 7, the extended shebang. I don't think the backticks and the redundant
cargo
specifier should be necessary, producing this:#!/usr/bin/env cargo # [dependencies] # foo = "1.2.3" fn main() {}
I think this looks quite good. It's fewer lines than the proposed syntax, and mirrors both the shebang syntax and the attribute syntax.
I understand that people might want this to be generalizable/extensible, but this could suffice for now and any discussion about how to generalize the "info" portion can be left for a future discussion. If people think that it's important to make it generalizable right now, then I'd be interested to hear some concrete use cases.
EDIT: although I suppose an unmentioned downside of this is that
# [dependencies]
might look a bit too much like an attribute.
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.
As you mentioned, there is the syntax ambiguity and backticks let us "escape" this block of #
lines.
Yes, the cargo specifier is redundant to the reader but each use of cargo
is for a different purpose
- One is for execution
- One is for parsing
I've noted in the Future Possibilities that we could relax the requirement on having cargo
in the infostring in the future. I would lean towards defaulting to cargo rather than parsing the shebang because shebang parsing is messy.
We also wanted to leave the door open (slightly) for adding additional frontmatter blocks, like if we decide to embed lockfiles.
Is this meant to positive suggest something or to point out a slipper slope? I'm not too sure the intent.
I'm not seeing how this is different than the suggested future state. We are starting with it being locked to cargo initially as we work out the design / usage and then can remove that restriction which is noted Future Possibilities. |
text/3503-frontmatter.md
Outdated
[drawbacks]: #drawbacks | ||
|
||
- A new concept for Rust syntax, adding to overall cognitive load | ||
- Requires people escape markdown code fences with an extra backtick which they are likely not used to doing (or aware even exists) |
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.
Does this refer to markdown inside multiline TOML strings? It's not really clear. Do any of Cargo's manifest fields even support markdown syntax?
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.
It may be referring to general usage outside of Rust source files, for example if I wanted to express this syntax here in this comment I would have to escape the backticks somehow (or indent by four spaces, but that doesn't allow syntax highlighting).
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.
Ooohh I see. In that case there's also the option of using the (older, I think?) syntax of prefixing the .rs
snippet with four spaces instead of ````
, though I'm not sure it it's as well-known as code fences, and it has the downside of not supporting language tags.
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.
394387b adds some context. This is about sharing snippets over github or zulip. Since you are putting a code fence inside of a code fence, the outer one needs to use 4 backticks
text/3503-frontmatter.md
Outdated
- Parsers are available to make this work (e.g. `syn`) | ||
|
||
Downsides | ||
- The `cargo` macro would need to come from somewhere (`std`?) which means it is taking on `cargo`-specific knowledge |
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.
For the macro approach, I don't think it would be necessary to embed any Cargo-specific knowledge in std. In every other approach the data here is stored in a glorified comment, which means we're fine if it gets thrown away as far as Rust is concerned. The macro here could simply expand to nothing, and trust that other tooling will parse the macro body as needed (which is easier than it sounds, since the macro body should just be treated as raw tokens rather than anything that needs parsing). Rather than calling it cargo, call it build!
or meta!
or something. Although I suppose the fact that it will still need to lex to Rust tokens might be limiting compared to a string or a comment, unless we want to make it magical.
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.
I added mention of meta!
in 42077b7. I don't bother exploring it due to the other problems with macros.
text/3503-frontmatter.md
Outdated
# Future possibilities | ||
[future-possibilities]: #future-possibilities | ||
|
||
- Treat `cargo` as the default infostring |
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.
What is the main reason for not including this in this proposal?
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.
I clarified this a little in 842f722
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.
Basically, we want to start with the absolute minimal approach and see what we feel needs to be relaxed from there (which is backwards compatible) rather than make a lot of assumptions and then regret them,
This comment was marked as resolved.
This comment was marked as resolved.
This does not solve any of problems laid out in the RFC
Besides shebang, which has syntactic meaning, the Rust ecosystem doesn't rely on this precedence. For example, |
A good argument against embedding the manifest in comments is that it will make it harder for tooling like treesitter (used in various text editors for syntax handling) to handle them properly. For example, many editors have no issues highlighting code blocks in Markdown with the appropriate language, since code blocks are a separate syntactical element from the rest. However, as of today I think only a couple editors (I'm only aware of VS Code) highlights markdown syntax embedded in Rust doc-comments, which is harder to do since it's embedded inside of an existing syntactical element (comments), which are commonly line-based and not block-based as well. (How many people write Additionally, changing and controlling (e.g. where it can appear, etc.) a separate syntax element on Rust's side of the equation is a lot easier than trying to do the same with comments. Allowing tools to provide good integration with the feature without technical compromises is an important aspect of this feature's design after all. |
🔔 This is now entering its final comment period, as per the review above. 🔔 |
The final comment period, with a disposition to merge, as per the review above, is now complete. As the automated representative of the governance process, I would like to thank the author for their work and everyone else who contributed. This will be merged soon. |
This all looks great and my initial questions and concerns were all addressed by the text of the rfc itself. My principle concern is that we can support non cargo, both so that non cargo can ignore this and also make use of the machinery for its own purposes. I think the infostrings will be fine though I guess "missing" will default to cargo, or maybe depend on that the interpreter is. For cargo, isn't config.toml also a plausible thing here? For example for target specific code, or use of special rustc flags? |
I suppose that has been addressed in the Future possibilities part. #!/usr/bin/env -S cargo +nightly -Zscript
--- Cargo.toml
[dependencies]
serde = "1"
---
--- .cargo/config.toml
[profile.dev]
panic = "abort"
---
use serde::Deserialize;
... |
The important part for this RFC is that we leave room for future expansion if its needed. If nothing else, there is the chance of needing support for For what gets supported for embedding, the more relevant RFC is #3502. Specifically, the Cargo team wanted all of this to focus more on an MVP. We don't even support workspaces in the first iteration. On that RFC, configs are worthwhile to discuss as for how likely of a future possibility they are. My quick note on that though is they are unlikely to ever be supported. Configs are environmental and not project configuration. It doesn't make sense to embed them in the project and it mixes up their roles (which are already muddled enough as-is). Instead, the focus should be on rust-lang/cargo#12738. Again, if you want to discuss this further, #3502 is a better place for this. |
Really I was just commenting on the wording:
"Only" seems pretty strong there. But you're right that's in the weeds as far as this RFC goes. |
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.
This has passed FCP. Merging. Thank you!
I have a question about the alternatives that use macros (4 and 6). These are blocked on:
I agree that I hope I'm understanding correctly that this would work similarly to how you can run (aside: sorry if it's bad etiquette to discuss an RFC after it's accepted, I can take this elsewhere if necessary) |
Some approaches to parsing include
In my experience, re-litigating RFCs without there being dramatically new information is not very productive. |
This is definitely an issue. The output of
Understood, I really don't want to waste everyone's time. I don't have new information beyond the concerns raised previously and should have gotten involved before the FCP. I'll stick my concern at the bottom of this comment but don't really want to restart discussion here. I suppose a new RFC would be needed to propose an alternative. My concern is that this syntax feels unlike any existing concept in Rust. It conflicts with prior art, by which I mean other tools ( Apologies if this is too critical of the proposal that I know you put a lot of time and work into. |
Have you used it in practice or is this from only reading the RFC? |
Just the examples in the RFC. I'm enjoying cargo-script but haven't tried the frontmatter syntax. |
I'd recommend having first hand experience with it as well as making sure you are familiar with all of the background information in the section leading up to describing each of the options. For context where I'm coming from, I used the doc comment syntax for about 6 months with 4 months for backtick and dash frontmatter each. Just over the last 8 months, I've written about 50 scripts from scratch as I use it to reproduce nearly every bug report I get. |
fix(toml): Remove unstable rejrected frontmatter syntax for cargo script ### What does this PR try to resolve? With rust-lang/rfcs#3503 approved, we no longer need to allow easy, high fidelity experiments with alternative cargo script syntax. ### How should we test and review this PR? ### Additional information We still need to improve the experience for users writing bad syntax but that can come later.
Rendered
This is for the T-lang side of #3502
Example:
FCP