aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--crates/shirabe/src/dependency_resolver/operation/install_operation.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/crates/shirabe/src/dependency_resolver/operation/install_operation.rs b/crates/shirabe/src/dependency_resolver/operation/install_operation.rs
index 3476e4a..c51271b 100644
--- a/crates/shirabe/src/dependency_resolver/operation/install_operation.rs
+++ b/crates/shirabe/src/dependency_resolver/operation/install_operation.rs
@@ -1 +1,47 @@
//! ref: composer/src/Composer/DependencyResolver/Operation/InstallOperation.php
+
+use crate::dependency_resolver::operation::operation_interface::OperationInterface;
+use crate::dependency_resolver::operation::solver_operation::SolverOperation;
+use crate::package::package_interface::PackageInterface;
+
+#[derive(Debug)]
+pub struct InstallOperation {
+ pub(crate) package: Box<dyn PackageInterface>,
+}
+
+impl InstallOperation {
+ pub fn new(package: Box<dyn PackageInterface>) -> Self {
+ Self { package }
+ }
+
+ pub fn get_package(&self) -> &dyn PackageInterface {
+ self.package.as_ref()
+ }
+
+ pub fn format(package: &dyn PackageInterface, lock: bool) -> String {
+ format!(
+ "{}<info>{}</info> (<comment>{}</comment>)",
+ if lock { "Locking " } else { "Installing " },
+ package.get_pretty_name(),
+ package.get_full_pretty_version(),
+ )
+ }
+}
+
+impl SolverOperation for InstallOperation {
+ const TYPE: &'static str = "install";
+}
+
+impl OperationInterface for InstallOperation {
+ fn get_operation_type(&self) -> String {
+ Self::TYPE.to_string()
+ }
+
+ fn show(&self, lock: bool) -> String {
+ Self::format(self.package.as_ref(), lock)
+ }
+
+ fn to_string(&self) -> String {
+ self.show(true)
+ }
+}