Skip to content

Commit f4f2bf5

Browse files
committed
remove support for the #[start] attribute
1 parent a1740a9 commit f4f2bf5

File tree

171 files changed

+525
-1292
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

171 files changed

+525
-1292
lines changed

compiler/rustc_ast/src/entry.rs

Lines changed: 1 addition & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -19,12 +19,6 @@ pub enum EntryPointType {
1919
/// fn main() {}
2020
/// ```
2121
RustcMainAttr,
22-
/// This is a function with the `#[start]` attribute.
23-
/// ```ignore (clashes with test entrypoint)
24-
/// #[start]
25-
/// fn main() {}
26-
/// ```
27-
Start,
2822
/// This function is **not** an entrypoint but simply named `main` (not at the root).
2923
/// This is only used for diagnostics.
3024
/// ```
@@ -41,9 +35,7 @@ pub fn entry_point_type(
4135
at_root: bool,
4236
name: Option<Symbol>,
4337
) -> EntryPointType {
44-
if attr::contains_name(attrs, sym::start) {
45-
EntryPointType::Start
46-
} else if attr::contains_name(attrs, sym::rustc_main) {
38+
if attr::contains_name(attrs, sym::rustc_main) {
4739
EntryPointType::RustcMainAttr
4840
} else if let Some(name) = name
4941
&& name == sym::main

compiler/rustc_ast_passes/src/feature_gate.rs

Lines changed: 0 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -231,18 +231,6 @@ impl<'a> Visitor<'a> for PostExpansionVisitor<'a> {
231231
}
232232
}
233233

234-
ast::ItemKind::Fn(..) => {
235-
if attr::contains_name(&i.attrs, sym::start) {
236-
gate!(
237-
&self,
238-
start,
239-
i.span,
240-
"`#[start]` functions are experimental and their signature may change \
241-
over time"
242-
);
243-
}
244-
}
245-
246234
ast::ItemKind::Struct(..) => {
247235
for attr in attr::filter_by_name(&i.attrs, sym::repr) {
248236
for item in attr.meta_item_list().unwrap_or_else(ThinVec::new) {

compiler/rustc_builtin_macros/src/test_harness.rs

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -205,11 +205,11 @@ impl<'a> MutVisitor for EntryPointCleaner<'a> {
205205
ast::mut_visit::walk_item(self, item);
206206
self.depth -= 1;
207207

208-
// Remove any #[rustc_main] or #[start] from the AST so it doesn't
208+
// Remove any #[rustc_main] from the AST so it doesn't
209209
// clash with the one we're going to add, but mark it as
210210
// #[allow(dead_code)] to avoid printing warnings.
211211
match entry_point_type(&item, self.depth == 0) {
212-
EntryPointType::MainNamed | EntryPointType::RustcMainAttr | EntryPointType::Start => {
212+
EntryPointType::MainNamed | EntryPointType::RustcMainAttr => {
213213
let allow_dead_code = attr::mk_attr_nested_word(
214214
&self.sess.psess.attr_id_generator,
215215
ast::AttrStyle::Outer,
@@ -218,8 +218,7 @@ impl<'a> MutVisitor for EntryPointCleaner<'a> {
218218
sym::dead_code,
219219
self.def_site,
220220
);
221-
item.attrs
222-
.retain(|attr| !attr.has_name(sym::rustc_main) && !attr.has_name(sym::start));
221+
item.attrs.retain(|attr| !attr.has_name(sym::rustc_main));
223222
item.attrs.push(allow_dead_code);
224223
}
225224
EntryPointType::None | EntryPointType::OtherMain => {}

compiler/rustc_codegen_cranelift/example/alloc_example.rs

Lines changed: 0 additions & 44 deletions
This file was deleted.

compiler/rustc_codegen_cranelift/example/mod_bench.rs

Lines changed: 0 additions & 37 deletions
This file was deleted.

compiler/rustc_codegen_cranelift/src/main_shim.rs

Lines changed: 8 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
use cranelift_frontend::{FunctionBuilder, FunctionBuilderContext};
22
use rustc_hir::LangItem;
33
use rustc_middle::ty::{AssocKind, GenericArg};
4-
use rustc_session::config::{EntryFnType, sigpipe};
4+
use rustc_session::config::EntryFnType;
55
use rustc_span::DUMMY_SP;
66
use rustc_span::symbol::Ident;
77

@@ -15,10 +15,9 @@ pub(crate) fn maybe_create_entry_wrapper(
1515
is_jit: bool,
1616
is_primary_cgu: bool,
1717
) {
18-
let (main_def_id, (is_main_fn, sigpipe)) = match tcx.entry_fn(()) {
18+
let (main_def_id, sigpipe) = match tcx.entry_fn(()) {
1919
Some((def_id, entry_ty)) => (def_id, match entry_ty {
20-
EntryFnType::Main { sigpipe } => (true, sigpipe),
21-
EntryFnType::Start => (false, sigpipe::DEFAULT),
20+
EntryFnType::Main { sigpipe } => sigpipe,
2221
}),
2322
None => return,
2423
};
@@ -32,14 +31,13 @@ pub(crate) fn maybe_create_entry_wrapper(
3231
return;
3332
}
3433

35-
create_entry_fn(tcx, module, main_def_id, is_jit, is_main_fn, sigpipe);
34+
create_entry_fn(tcx, module, main_def_id, is_jit, sigpipe);
3635

3736
fn create_entry_fn(
3837
tcx: TyCtxt<'_>,
3938
m: &mut dyn Module,
4039
rust_main_def_id: DefId,
4140
ignore_lang_start_wrapper: bool,
42-
is_main_fn: bool,
4341
sigpipe: u8,
4442
) {
4543
let main_ret_ty = tcx.fn_sig(rust_main_def_id).no_bound_vars().unwrap().output();
@@ -95,8 +93,8 @@ pub(crate) fn maybe_create_entry_wrapper(
9593

9694
let main_func_ref = m.declare_func_in_func(main_func_id, &mut bcx.func);
9795

98-
let result = if is_main_fn && ignore_lang_start_wrapper {
99-
// regular main fn, but ignoring #[lang = "start"] as we are running in the jit
96+
let result = if ignore_lang_start_wrapper {
97+
// ignoring #[lang = "start"] as we are running in the jit
10098
// FIXME set program arguments somehow
10199
let call_inst = bcx.ins().call(main_func_ref, &[]);
102100
let call_results = bcx.func.dfg.inst_results(call_inst).to_owned();
@@ -134,7 +132,8 @@ pub(crate) fn maybe_create_entry_wrapper(
134132
types::I64 => bcx.ins().sextend(types::I64, res),
135133
_ => unimplemented!("16bit systems are not yet supported"),
136134
}
137-
} else if is_main_fn {
135+
} else {
136+
// Regular main fn invoked via start lang item.
138137
let start_def_id = tcx.require_lang_item(LangItem::Start, None);
139138
let start_instance = Instance::expect_resolve(
140139
tcx,
@@ -151,10 +150,6 @@ pub(crate) fn maybe_create_entry_wrapper(
151150
let call_inst =
152151
bcx.ins().call(func_ref, &[main_val, arg_argc, arg_argv, arg_sigpipe]);
153152
bcx.inst_results(call_inst)[0]
154-
} else {
155-
// using user-defined start fn
156-
let call_inst = bcx.ins().call(main_func_ref, &[arg_argc, arg_argv]);
157-
bcx.inst_results(call_inst)[0]
158153
};
159154

160155
bcx.ins().return_(&[result]);

compiler/rustc_codegen_gcc/example/alloc_example.rs

Lines changed: 0 additions & 48 deletions
This file was deleted.

compiler/rustc_codegen_gcc/example/mod_bench.rs

Lines changed: 0 additions & 36 deletions
This file was deleted.

compiler/rustc_codegen_gcc/src/context.rs

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -512,7 +512,6 @@ impl<'gcc, 'tcx> MiscCodegenMethods<'tcx> for CodegenCx<'gcc, 'tcx> {
512512
} else {
513513
// If the symbol already exists, it is an error: for example, the user wrote
514514
// #[no_mangle] extern "C" fn main(..) {..}
515-
// instead of #[start]
516515
None
517516
}
518517
}

compiler/rustc_codegen_gcc/tests/run/abort1.rs

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3,11 +3,12 @@
33
// Run-time:
44
// status: signal
55

6-
#![feature(auto_traits, lang_items, no_core, start, intrinsics, rustc_attrs)]
6+
#![feature(auto_traits, lang_items, no_core, intrinsics, rustc_attrs)]
77
#![allow(internal_features)]
88

99
#![no_std]
1010
#![no_core]
11+
#![no_main]
1112

1213
/*
1314
* Core
@@ -49,7 +50,7 @@ fn test_fail() -> ! {
4950
unsafe { intrinsics::abort() };
5051
}
5152

52-
#[start]
53-
fn main(mut argc: isize, _argv: *const *const u8) -> isize {
53+
#[no_mangle]
54+
extern "C" fn main(argc: i32, _argv: *const *const u8) -> i32 {
5455
test_fail();
5556
}

0 commit comments

Comments
 (0)