-
Notifications
You must be signed in to change notification settings - Fork 174
Expand file tree
/
Copy pathsession.rs
More file actions
70 lines (58 loc) · 2.05 KB
/
Copy pathsession.rs
File metadata and controls
70 lines (58 loc) · 2.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// SPDX-License-Identifier: Apache-2.0
// SPDX-FileCopyrightText: Copyright the Vortex contributors
//! Session state for stats rewrite rules.
use std::any::Any;
use std::sync::Arc;
use parking_lot::RwLock;
use vortex_session::Ref;
use vortex_session::SessionExt;
use vortex_session::SessionVar;
use vortex_utils::aliases::hash_map::HashMap;
use crate::scalar_fn::ScalarFnId;
use crate::stats::rewrite::StatsRewriteRule;
use crate::stats::rewrite::StatsRewriteRuleRef;
type StatsRewriteRuleSet = Arc<[StatsRewriteRuleRef]>;
/// Session state for stats rewrite rules.
#[derive(Debug, Default)]
pub struct StatsRewriteSession {
rules: RwLock<HashMap<ScalarFnId, StatsRewriteRuleSet>>,
}
impl StatsRewriteSession {
/// Register a stats rewrite rule.
#[allow(dead_code)]
pub(crate) fn register<R: StatsRewriteRule>(&self, rule: R) {
self.register_ref(Arc::new(rule));
}
/// Register a shared stats rewrite rule.
#[allow(dead_code)]
pub(crate) fn register_ref(&self, rule: StatsRewriteRuleRef) {
let mut rules = self.rules.write();
let rule_id = rule.scalar_fn_id();
let mut updated_rules = rules
.get(&rule_id)
.map(|rules| rules.iter().cloned().collect::<Vec<_>>())
.unwrap_or_default();
updated_rules.push(rule);
rules.insert(rule_id, updated_rules.into());
}
/// Return the rewrite rules registered for `scalar_fn_id`.
pub(crate) fn rules_for(&self, scalar_fn_id: ScalarFnId) -> Option<StatsRewriteRuleSet> {
self.rules.read().get(&scalar_fn_id).cloned()
}
}
impl SessionVar for StatsRewriteSession {
fn as_any(&self) -> &dyn Any {
self
}
fn as_any_mut(&mut self) -> &mut dyn Any {
self
}
}
/// Extension trait for accessing stats rewrite session data.
pub(crate) trait StatsRewriteSessionExt: SessionExt {
/// Returns the stats rewrite rule registry.
fn stats_rewrites(&self) -> Ref<'_, StatsRewriteSession> {
self.get::<StatsRewriteSession>()
}
}
impl<S: SessionExt> StatsRewriteSessionExt for S {}