mirror of
https://github.com/salsa-rs/salsa.git
synced 2025-01-23 13:10:19 +00:00
show SharedState in Debug for Runtime
This should be useful to debug deadlocks due to bad forking.
This commit is contained in:
parent
31789ec7ef
commit
52206d5421
1 changed files with 22 additions and 1 deletions
|
@ -56,7 +56,8 @@ where
|
||||||
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
fmt.debug_struct("Runtime")
|
fmt.debug_struct("Runtime")
|
||||||
.field("id", &self.id())
|
.field("id", &self.id())
|
||||||
.field("revision", &self.current_revision())
|
.field("forked", &self.revision_guard.is_some())
|
||||||
|
.field("shared_state", &self.shared_state)
|
||||||
.finish()
|
.finish()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -398,6 +399,26 @@ impl<DB: Database> Default for SharedState<DB> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<DB> std::fmt::Debug for SharedState<DB>
|
||||||
|
where
|
||||||
|
DB: Database,
|
||||||
|
{
|
||||||
|
fn fmt(&self, fmt: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
let query_lock = if self.query_lock.try_write().is_some() {
|
||||||
|
"<unlocked>"
|
||||||
|
} else if self.query_lock.try_read().is_some() {
|
||||||
|
"<rlocked>"
|
||||||
|
} else {
|
||||||
|
"<wlocked>"
|
||||||
|
};
|
||||||
|
fmt.debug_struct("SharedState")
|
||||||
|
.field("query_lock", &query_lock)
|
||||||
|
.field("revision", &self.revision)
|
||||||
|
.field("pending_revision_increments", &self.pending_revision_increments)
|
||||||
|
.finish()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// State that will be specific to a single execution threads (when we
|
/// State that will be specific to a single execution threads (when we
|
||||||
/// support multiple threads)
|
/// support multiple threads)
|
||||||
struct LocalState<DB: Database> {
|
struct LocalState<DB: Database> {
|
||||||
|
|
Loading…
Reference in a new issue