diff options
Diffstat (limited to 'crates/shirabe/src/dependency_resolver/generic_rule.rs')
| -rw-r--r-- | crates/shirabe/src/dependency_resolver/generic_rule.rs | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/crates/shirabe/src/dependency_resolver/generic_rule.rs b/crates/shirabe/src/dependency_resolver/generic_rule.rs index 19974b6..c0381ef 100644 --- a/crates/shirabe/src/dependency_resolver/generic_rule.rs +++ b/crates/shirabe/src/dependency_resolver/generic_rule.rs @@ -6,6 +6,7 @@ use shirabe_php_shim::{PHP_VERSION_ID, PhpMixed, RuntimeException, hash_raw, imp use super::{request::Request, rule::ReasonData}; +#[derive(Debug)] pub struct GenericRule { inner: RuleBase, pub(crate) literals: Vec<i64>, @@ -13,7 +14,7 @@ pub struct GenericRule { impl GenericRule { pub fn new(mut literals: Vec<i64>, reason: PhpMixed, reason_data: PhpMixed) -> Self { - let inner = RuleBase::new(reason, reason_data); + let inner = RuleBase::new(reason.as_int().unwrap_or(0), ReasonData::from(reason_data)); literals.sort(); Self { inner, literals } } @@ -70,6 +71,20 @@ pub trait RuleLiterals { fn is_multi_conflict_rule(&self) -> bool { false } + fn is_assertion(&self) -> bool { + false + } + fn is_disabled(&self) -> bool { + false + } + fn as_any(&self) -> &dyn std::any::Any { + todo!() + } + /// Clone this rule into an owned `Box<dyn Rule>` so callers like + /// `RuleWatchGraph::propagate_literal` can hand it to `Decisions::decide`. + fn clone_rule_box(&self) -> Box<dyn Rule> { + todo!() + } } impl RuleLiterals for GenericRule { |
