diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-05-12 04:01:08 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-05-12 04:01:08 +0900 |
| commit | 902afb512b99f241ad028780862fea0f08d2bb9d (patch) | |
| tree | d5a2d283b1744b9ed696060262f4dff8558f283f /crates/shirabe/src/dependency_resolver | |
| parent | 840ff9955a9597d13010d1e0056d1688edfde297 (diff) | |
| download | php-shirabe-902afb512b99f241ad028780862fea0f08d2bb9d.tar.gz php-shirabe-902afb512b99f241ad028780862fea0f08d2bb9d.tar.zst php-shirabe-902afb512b99f241ad028780862fea0f08d2bb9d.zip | |
feat(port): port MarkAliasInstalledOperation.php
Diffstat (limited to 'crates/shirabe/src/dependency_resolver')
| -rw-r--r-- | crates/shirabe/src/dependency_resolver/operation/mark_alias_installed_operation.rs | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/crates/shirabe/src/dependency_resolver/operation/mark_alias_installed_operation.rs b/crates/shirabe/src/dependency_resolver/operation/mark_alias_installed_operation.rs index 5a12856..6788c44 100644 --- a/crates/shirabe/src/dependency_resolver/operation/mark_alias_installed_operation.rs +++ b/crates/shirabe/src/dependency_resolver/operation/mark_alias_installed_operation.rs @@ -1 +1,44 @@ //! ref: composer/src/Composer/DependencyResolver/Operation/MarkAliasInstalledOperation.php + +use crate::dependency_resolver::operation::operation_interface::OperationInterface; +use crate::dependency_resolver::operation::solver_operation::SolverOperation; +use crate::package::alias_package::AliasPackage; + +#[derive(Debug)] +pub struct MarkAliasInstalledOperation { + pub(crate) package: AliasPackage, +} + +impl MarkAliasInstalledOperation { + pub fn new(package: AliasPackage) -> Self { + Self { package } + } + + pub fn get_package(&self) -> &AliasPackage { + &self.package + } +} + +impl SolverOperation for MarkAliasInstalledOperation { + const TYPE: &'static str = "markAliasInstalled"; +} + +impl OperationInterface for MarkAliasInstalledOperation { + fn get_operation_type(&self) -> String { + Self::TYPE.to_string() + } + + fn show(&self, _lock: bool) -> String { + format!( + "Marking <info>{}</info> (<comment>{}</comment>) as installed, alias of <info>{}</info> (<comment>{}</comment>)", + self.package.get_pretty_name(), + self.package.get_full_pretty_version(), + self.package.get_alias_of().get_pretty_name(), + self.package.get_alias_of().get_full_pretty_version(), + ) + } + + fn to_string(&self) -> String { + self.show(true) + } +} |
