@@ -9,11 +9,12 @@ extern crate rustc_data_structures;
9
9
extern crate rustc_driver;
10
10
extern crate rustc_hir;
11
11
extern crate rustc_interface;
12
+ extern crate rustc_log;
12
13
extern crate rustc_metadata;
13
14
extern crate rustc_middle;
14
15
extern crate rustc_session;
15
16
16
- use std:: env;
17
+ use std:: env:: { self , VarError } ;
17
18
use std:: num:: NonZeroU64 ;
18
19
use std:: path:: PathBuf ;
19
20
use std:: str:: FromStr ;
@@ -183,45 +184,54 @@ macro_rules! show_error {
183
184
( $( $tt: tt) * ) => { show_error( & format_args!( $( $tt) * ) ) } ;
184
185
}
185
186
186
- fn init_early_loggers ( handler : & EarlyErrorHandler ) {
187
- // Note that our `extern crate log` is *not* the same as rustc's; as a result, we have to
188
- // initialize them both, and we always initialize `miri`'s first.
189
- let env = env_logger:: Env :: new ( ) . filter ( "MIRI_LOG" ) . write_style ( "MIRI_LOG_STYLE" ) ;
190
- env_logger:: init_from_env ( env) ;
191
- // Enable verbose entry/exit logging by default if MIRI_LOG is set.
192
- if env:: var_os ( "MIRI_LOG" ) . is_some ( ) && env:: var_os ( "RUSTC_LOG_ENTRY_EXIT" ) . is_none ( ) {
193
- env:: set_var ( "RUSTC_LOG_ENTRY_EXIT" , "1" ) ;
194
- }
195
- // We only initialize `rustc` if the env var is set (so the user asked for it).
196
- // If it is not set, we avoid initializing now so that we can initialize
197
- // later with our custom settings, and *not* log anything for what happens before
198
- // `miri` gets started.
199
- if env:: var_os ( "RUSTC_LOG" ) . is_some ( ) {
200
- rustc_driver:: init_rustc_env_logger ( handler) ;
201
- }
202
- }
187
+ fn rustc_logger_config ( ) -> rustc_log:: LoggerConfig {
188
+ // Start with the usual env vars.
189
+ let mut cfg = rustc_log:: LoggerConfig :: from_env ( "RUSTC_LOG" ) ;
203
190
204
- fn init_late_loggers ( handler : & EarlyErrorHandler , tcx : TyCtxt < ' _ > ) {
205
- // We initialize loggers right before we start evaluation. We overwrite the `RUSTC_LOG`
206
- // env var if it is not set, control it based on `MIRI_LOG`.
207
- // (FIXME: use `var_os`, but then we need to manually concatenate instead of `format!`.)
191
+ // Overwrite if MIRI_LOG is set.
208
192
if let Ok ( var) = env:: var ( "MIRI_LOG" ) {
209
- if env:: var_os ( "RUSTC_LOG" ) . is_none ( ) {
193
+ // MIRI_LOG serves as default for RUSTC_LOG, if that is not set.
194
+ if matches ! ( cfg. filter, Err ( VarError :: NotPresent ) ) {
210
195
// We try to be a bit clever here: if `MIRI_LOG` is just a single level
211
196
// used for everything, we only apply it to the parts of rustc that are
212
197
// CTFE-related. Otherwise, we use it verbatim for `RUSTC_LOG`.
213
198
// This way, if you set `MIRI_LOG=trace`, you get only the right parts of
214
199
// rustc traced, but you can also do `MIRI_LOG=miri=trace,rustc_const_eval::interpret=debug`.
215
200
if log:: Level :: from_str ( & var) . is_ok ( ) {
216
- env:: set_var (
217
- "RUSTC_LOG" ,
218
- format ! ( "rustc_middle::mir::interpret={var},rustc_const_eval::interpret={var}" ) ,
219
- ) ;
201
+ cfg. filter = Ok ( format ! (
202
+ "rustc_middle::mir::interpret={var},rustc_const_eval::interpret={var}"
203
+ ) ) ;
220
204
} else {
221
- env :: set_var ( "RUSTC_LOG" , & var) ;
205
+ cfg . filter = Ok ( var) ;
222
206
}
223
- rustc_driver:: init_rustc_env_logger ( handler) ;
224
207
}
208
+ // Enable verbose entry/exit logging by default if MIRI_LOG is set.
209
+ if matches ! ( cfg. verbose_entry_exit, Err ( VarError :: NotPresent ) ) {
210
+ cfg. verbose_entry_exit = Ok ( format ! ( "1" ) ) ;
211
+ }
212
+ }
213
+
214
+ cfg
215
+ }
216
+
217
+ fn init_early_loggers ( handler : & EarlyErrorHandler ) {
218
+ // Note that our `extern crate log` is *not* the same as rustc's; as a result, we have to
219
+ // initialize them both, and we always initialize `miri`'s first.
220
+ let env = env_logger:: Env :: new ( ) . filter ( "MIRI_LOG" ) . write_style ( "MIRI_LOG_STYLE" ) ;
221
+ env_logger:: init_from_env ( env) ;
222
+ // Now for rustc. We only initialize `rustc` if the env var is set (so the user asked for it).
223
+ // If it is not set, we avoid initializing now so that we can initialize later with our custom
224
+ // settings, and *not* log anything for what happens before `miri` gets started.
225
+ if env:: var_os ( "RUSTC_LOG" ) . is_some ( ) {
226
+ rustc_driver:: init_logger ( handler, rustc_logger_config ( ) ) ;
227
+ }
228
+ }
229
+
230
+ fn init_late_loggers ( handler : & EarlyErrorHandler , tcx : TyCtxt < ' _ > ) {
231
+ // If `RUSTC_LOG` is not set, then `init_early_loggers` did not call
232
+ // `rustc_driver::init_logger`, so we have to do this now.
233
+ if env:: var_os ( "RUSTC_LOG" ) . is_none ( ) {
234
+ rustc_driver:: init_logger ( handler, rustc_logger_config ( ) ) ;
225
235
}
226
236
227
237
// If `MIRI_BACKTRACE` is set and `RUSTC_CTFE_BACKTRACE` is not, set `RUSTC_CTFE_BACKTRACE`.
0 commit comments