aboutsummaryrefslogtreecommitdiffhomepage
path: root/crates/shirabe/src/command/repository_command.rs
diff options
context:
space:
mode:
Diffstat (limited to 'crates/shirabe/src/command/repository_command.rs')
-rw-r--r--crates/shirabe/src/command/repository_command.rs92
1 files changed, 91 insertions, 1 deletions
diff --git a/crates/shirabe/src/command/repository_command.rs b/crates/shirabe/src/command/repository_command.rs
index cfe9065..86afe80 100644
--- a/crates/shirabe/src/command/repository_command.rs
+++ b/crates/shirabe/src/command/repository_command.rs
@@ -2,6 +2,7 @@
use indexmap::IndexMap;
use shirabe_external_packages::composer::pcre::preg::Preg;
+use shirabe_external_packages::symfony::component::console::command::command::Command;
use shirabe_external_packages::symfony::console::completion::completion_input::CompletionInput;
use shirabe_external_packages::symfony::console::input::input_interface::InputInterface;
use shirabe_external_packages::symfony::console::output::output_interface::OutputInterface;
@@ -9,15 +10,26 @@ use shirabe_php_shim::{
InvalidArgumentException, PHP_URL_HOST, PhpMixed, RuntimeException, parse_url, strtolower,
};
+use crate::command::base_command::BaseCommand;
use crate::command::base_config_command::BaseConfigCommand;
+use crate::composer::Composer;
+use crate::config::Config;
+use crate::config::json_config_source::JsonConfigSource;
use crate::console::input::input_argument::InputArgument;
use crate::console::input::input_option::InputOption;
use crate::factory::Factory;
+use crate::io::io_interface::IOInterface;
use crate::json::json_file::JsonFile;
#[derive(Debug)]
pub struct RepositoryCommand {
- inner: BaseConfigCommand,
+ inner: Command,
+ composer: Option<Composer>,
+ io: Option<Box<dyn IOInterface>>,
+
+ config: Option<Config>,
+ config_file: Option<JsonFile>,
+ config_source: Option<JsonConfigSource>,
}
impl RepositoryCommand {
@@ -436,3 +448,81 @@ impl RepositoryCommand {
})
}
}
+
+impl BaseCommand for RepositoryCommand {
+ fn inner(&self) -> &Command {
+ &self.inner
+ }
+
+ fn inner_mut(&mut self) -> &mut Command {
+ &mut self.inner
+ }
+
+ fn composer(&self) -> Option<&Composer> {
+ self.composer.as_ref()
+ }
+
+ fn composer_mut(&mut self) -> Option<&mut Composer> {
+ self.composer.as_mut()
+ }
+
+ fn io(&self) -> Option<&dyn IOInterface> {
+ self.io.as_ref()
+ }
+
+ fn io_mut(&mut self) -> Option<&mut dyn IOInterface> {
+ self.io.as_mut()
+ }
+}
+
+impl BaseCommand for RepositoryCommand {
+ fn inner(&self) -> &Command {
+ &self.inner
+ }
+
+ fn inner_mut(&mut self) -> &mut Command {
+ &mut self.inner
+ }
+
+ fn composer(&self) -> Option<&Composer> {
+ self.composer.as_ref()
+ }
+
+ fn composer_mut(&mut self) -> &mut Option<Composer> {
+ &mut self.composer
+ }
+
+ fn io(&self) -> Option<&dyn IOInterface> {
+ self.io.as_deref()
+ }
+
+ fn io_mut(&mut self) -> &mut Option<Box<dyn IOInterface>> {
+ &mut self.io
+ }
+}
+
+impl BaseConfigCommand for RepositoryCommand {
+ fn config(&self) -> Option<&Config> {
+ self.config.as_ref()
+ }
+
+ fn config_mut(&mut self) -> Option<&mut Config> {
+ self.config.as_mut()
+ }
+
+ fn config_file(&self) -> Option<&JsonFile> {
+ self.config_file.as_ref()
+ }
+
+ fn config_file_mut(&mut self) -> Option<&mut JsonFile> {
+ self.config_file.as_mut()
+ }
+
+ fn config_source(&self) -> Option<&JsonConfigSource> {
+ self.config_source.as_ref()
+ }
+
+ fn config_source_mut(&mut self) -> Option<&mut JsonConfigSource> {
+ self.config_source.as_mut()
+ }
+}