You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
use slog::Drain;fnmain(){let drain = slog::Discard;let drain = slog_envlogger::LogBuilder::new(drain).build();// Does not help:// let drain = drain.fuse();let logger = slog::Logger::root(drain, slog::o!());}
error[E0277]: the type std::cell::UnsafeCell<std::option::Option<std::boxed::Box<std::cell::RefCell<regex::exec::ProgramCacheInner>>>> may contain interior mutability and a reference may not be safely transferrable across a catch_unwind boundary
--> src/main.rs:8:18
|
8 | let logger = slog::Logger::root(drain, slog::o!());
| ^^^^^^^^^^^^^^^^^^ std::cell::UnsafeCell<std::option::Option<std::boxed::Box<std::cell::RefCell<regex::exec::ProgramCacheInner>>>> may contain interior mutability and a reference may not be safely transferrable across a catch_unwind boundary
|
::: /.cargo/registry/src/gh.neting.cc-1ecc6299db9ec823/slog-2.5.2/src/lib.rs:1120:38
|
1120 | T: SendSyncRefUnwindSafeKV + 'static,
| ------- required by this bound in slog::Logger::<D>::root
|
= help: within slog_envlogger::EnvLogger<slog::Discard>, the trait std::panic::RefUnwindSafe is not implemented for std::cell::UnsafeCell<std::option::Option<std::boxed::Box<std::cell::RefCell<regex::exec::ProgramCacheInner>>>>
= note: required because it appears within the type thread_local::cached::CachedThreadLocal<std::cell::RefCell<regex::exec::ProgramCacheInner>>
= note: required because it appears within the type regex::cache::imp::Cached<std::cell::RefCell<regex::exec::ProgramCacheInner>>
= note: required because it appears within the type regex::exec::Exec
= note: required because it appears within the type regex::re_unicode::Regex
= note: required because it appears within the type slog_envlogger::filter::Filter
= note: required because it appears within the type std::option::Option<slog_envlogger::filter::Filter>
= note: required because it appears within the type slog_envlogger::EnvLogger<slog::Discard>
= note: required because of the requirements on the impl of slog::SendSyncRefUnwindSafeDrain for slog_envlogger::EnvLogger<slog::Discard>
This actually came up because I wanted the logging chain to be slog_envlogger -> slog_async instead of what is probably more common slog_async -> slog_envlogger.
The reason for that is that I don't want messages that don't match the envlogger filter to end up on the async channel at all so that a for example a library cannot fill up the channel with trace logs (leading to dropped logs) when they are going to be filtered out anyway.
Checking the log message against the filter probably has roughly similar performance as putting them on the channel in the first place.
Hmm, you could use AssertUnwindSafe as a quick-and-dirty fix.
I think in general the problem the compiler is worried about is that panicking may cause the logger to appear in an inconsistent state (because of interior mutability). Not sure if that's specifically a problem in slog_envlogger
I find this surprising. In one of the examples https://github.com/slog-rs/envlogger/blob/v2.2.0/examples/proper.rs the workaround seems to be that env_logger is wrapped in the async logger.
The text was updated successfully, but these errors were encountered: