rfcs/text/1260-main-reexport.md

58 lines
1.5 KiB
Markdown
Raw Normal View History

2015-08-19 15:17:20 +00:00
- Feature Name: main_reexport
- Start Date: 2015-08-19
- RFC PR: https://github.com/rust-lang/rfcs/pull/1260
- Rust Issue: https://github.com/rust-lang/rust/issues/28937
2015-08-19 15:17:20 +00:00
# Summary
Allow a re-export of a function as entry point `main`.
# Motivation
Functions and re-exports of functions usually behave the same way, but they do
not for the program entry point `main`. This RFC aims to fix this inconsistency.
The above mentioned inconsistency means that e.g. you currently cannot use a
library's exported function as your main function.
Example:
pub mod foo {
pub fn bar() {
println!("Hello world!");
}
}
2015-10-02 20:44:13 +00:00
use foo::bar as main;
Example 2:
extern crate main_functions;
pub use main_functions::rmdir as main;
See also https://github.com/rust-lang/rust/issues/27640 for the corresponding
issue discussion.
2015-10-02 20:44:13 +00:00
The `#[main]` attribute can also be used to change the entry point of the
generated binary. This is largely irrelevant for this RFC as this RFC tries to
fix an inconsistency with re-exports and directly defined functions.
Nevertheless, it can be pointed out that the `#[main]` attribute does not cover
all the above-mentioned use cases.
2015-08-19 15:17:20 +00:00
# Detailed design
Use the symbol `main` at the top-level of a crate that is compiled as a program
(`--crate-type=bin`) instead of explicitly only accepting directly-defined
2015-10-02 20:44:13 +00:00
functions, also allow (possibly non-`pub`) re-exports.
2015-08-19 15:17:20 +00:00
# Drawbacks
None.
# Alternatives
None.
# Unresolved questions
None.