From 5e31fa33c3b5cf726a57a063b8e7a070869250fe Mon Sep 17 00:00:00 2001 From: nsfisis Date: Tue, 19 May 2026 21:46:01 +0900 Subject: fix(compile): fix more random compile errors Co-Authored-By: Claude Opus 4.7 (1M context) --- crates/shirabe/src/dependency_resolver/generic_rule.rs | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) (limited to 'crates/shirabe/src/dependency_resolver/generic_rule.rs') 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, @@ -13,7 +14,7 @@ pub struct GenericRule { impl GenericRule { pub fn new(mut literals: Vec, 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` so callers like + /// `RuleWatchGraph::propagate_literal` can hand it to `Decisions::decide`. + fn clone_rule_box(&self) -> Box { + todo!() + } } impl RuleLiterals for GenericRule { -- cgit v1.3.1