diff options
| author | Nicholas Nethercote <n.nethercote@gmail.com> | 2023-07-14 16:32:10 +1000 |
|---|---|---|
| committer | Nicholas Nethercote <n.nethercote@gmail.com> | 2023-07-17 08:44:48 +1000 |
| commit | 46f74fb4d28d90dd7e1fa0b52e84ba9a9d8a4d0d (patch) | |
| tree | 3dc57f6846bb076d19cf6402c1741cee6e9ca7a6 | |
| parent | 4f16abdff63db2eb8f4342837a18d997e8e394e7 (diff) | |
| download | rust-46f74fb4d28d90dd7e1fa0b52e84ba9a9d8a4d0d.tar.gz rust-46f74fb4d28d90dd7e1fa0b52e84ba9a9d8a4d0d.zip | |
Introduce `MonoItemData`.
It replaces `(Linkage, Visibility)`, making the code nicer. Plus the next commit will add another field.
| -rw-r--r-- | src/driver/mod.rs | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/src/driver/mod.rs b/src/driver/mod.rs index 5c52c9c18ad..12e90b58410 100644 --- a/src/driver/mod.rs +++ b/src/driver/mod.rs @@ -5,7 +5,7 @@ //! [`codegen_static`]: crate::constant::codegen_static use rustc_data_structures::profiling::SelfProfilerRef; -use rustc_middle::mir::mono::{Linkage as RLinkage, MonoItem, Visibility}; +use rustc_middle::mir::mono::{MonoItem, MonoItemData}; use crate::prelude::*; @@ -16,11 +16,11 @@ pub(crate) mod jit; fn predefine_mono_items<'tcx>( tcx: TyCtxt<'tcx>, module: &mut dyn Module, - mono_items: &[(MonoItem<'tcx>, (RLinkage, Visibility))], + mono_items: &[(MonoItem<'tcx>, MonoItemData)], ) { tcx.prof.generic_activity("predefine functions").run(|| { let is_compiler_builtins = tcx.is_compiler_builtins(LOCAL_CRATE); - for &(mono_item, (linkage, visibility)) in mono_items { + for &(mono_item, data) in mono_items { match mono_item { MonoItem::Fn(instance) => { let name = tcx.symbol_name(instance).name; @@ -29,8 +29,8 @@ fn predefine_mono_items<'tcx>( get_function_sig(tcx, module.target_config().default_call_conv, instance); let linkage = crate::linkage::get_clif_linkage( mono_item, - linkage, - visibility, + data.linkage, + data.visibility, is_compiler_builtins, ); module.declare_function(name, linkage, &sig).unwrap(); |
