diff options
| author | nsfisis <nsfisis@gmail.com> | 2026-05-12 04:14:04 +0900 |
|---|---|---|
| committer | nsfisis <nsfisis@gmail.com> | 2026-05-12 04:14:04 +0900 |
| commit | 315efbe6f3c8a249250deaf65d41939843141b32 (patch) | |
| tree | f96256be9ab7f4f51d20c7dd7bb387264b183395 /crates/shirabe/src/package/loader | |
| parent | 185c22f61cbf26947276c6cc8ea5da1019b7b117 (diff) | |
| download | php-shirabe-315efbe6f3c8a249250deaf65d41939843141b32.tar.gz php-shirabe-315efbe6f3c8a249250deaf65d41939843141b32.tar.zst php-shirabe-315efbe6f3c8a249250deaf65d41939843141b32.zip | |
feat(port): port InvalidPackageException.php
Diffstat (limited to 'crates/shirabe/src/package/loader')
| -rw-r--r-- | crates/shirabe/src/package/loader/invalid_package_exception.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/crates/shirabe/src/package/loader/invalid_package_exception.rs b/crates/shirabe/src/package/loader/invalid_package_exception.rs index 6574bd7..88a7f5f 100644 --- a/crates/shirabe/src/package/loader/invalid_package_exception.rs +++ b/crates/shirabe/src/package/loader/invalid_package_exception.rs @@ -1 +1,38 @@ //! ref: composer/src/Composer/Package/Loader/InvalidPackageException.php + +use shirabe_php_shim::{Exception, PhpMixed}; + +#[derive(Debug)] +pub struct InvalidPackageException { + inner: Exception, + errors: Vec<String>, + warnings: Vec<String>, + data: Vec<PhpMixed>, +} + +impl InvalidPackageException { + pub fn new(errors: Vec<String>, warnings: Vec<String>, data: Vec<PhpMixed>) -> Self { + let message = format!( + "Invalid package information: \n{}", + errors.iter().chain(warnings.iter()).cloned().collect::<Vec<_>>().join("\n") + ); + Self { + inner: Exception { message, code: 0 }, + errors, + warnings, + data, + } + } + + pub fn get_data(&self) -> &[PhpMixed] { + &self.data + } + + pub fn get_errors(&self) -> &[String] { + &self.errors + } + + pub fn get_warnings(&self) -> &[String] { + &self.warnings + } +} |
