1
0
mirror of https://github.com/Ne-Lexa/php-zip.git synced 2025-07-25 17:51:13 +02:00

Merge branch 'release/2.2.0'

This commit is contained in:
wapplay-home-linux
2017-03-02 00:17:06 +03:00
5 changed files with 50 additions and 9 deletions

5
CHANGELOG.md Normal file
View File

@@ -0,0 +1,5 @@
## 2.2.0 (2017-03-02)
Features:
- create output object `ZipOutputFile` from `ZipFile` in method `ZipFile::edit()`.
- create output object `ZipOutputFile` from filename in static method `ZipOutputFile::openFromFile(string $filename)`.

View File

@@ -149,6 +149,10 @@ Get entry content.
```php ```php
$data = $zipFile->getEntryContent($entryName); $data = $zipFile->getEntryContent($entryName);
``` ```
Edit zip archive
```php
$zipOutputFile = $zipFile->edit();
```
Close zip archive. Close zip archive.
```php ```php
$zipFile->close(); $zipFile->close();
@@ -162,6 +166,11 @@ $zipOutputFile = \PhpZip\ZipOutputFile::create();
``` ```
Open zip file from update. Open zip file from update.
```php ```php
$filename = "file.zip";
$zipOutputFile = \PhpZip\ZipOutputFile::openFromFile($filename);
```
or
```php
// initial ZipFile // initial ZipFile
$zipFile = \PhpZip\ZipFile::openFromFile($filename); $zipFile = \PhpZip\ZipFile::openFromFile($filename);
@@ -169,23 +178,28 @@ $zipFile = \PhpZip\ZipFile::openFromFile($filename);
$zipOutputFile = new \PhpZip\ZipOutputFile($zipFile); $zipOutputFile = new \PhpZip\ZipOutputFile($zipFile);
// or // or
$zipOutputFile = \PhpZip\ZipOutputFile::openFromZipFile($zipFile); $zipOutputFile = \PhpZip\ZipOutputFile::openFromZipFile($zipFile);
// or
$zipOutputFile = $zipFile->edit();
``` ```
Add entry from file. Add entry from file.
```php ```php
$zipOutputFile->addFromFile($filename); // $entryName == basename($filename); $zipOutputFile->addFromFile($filename); // $entryName == basename($filename);
$zipOutputFile->addFromFile($filename, $entryName); $zipOutputFile->addFromFile($filename, $entryName);
$zipOutputFile->addFromFile($filename, $entryName, ZipEntry::METHOD_DEFLATED); $zipOutputFile->addFromFile($filename, $entryName, ZipEntry::METHOD_DEFLATED);
$zipOutputFile->addFromFile($filename, $entryName, ZipEntry::METHOD_STORED); // no compress
$zipOutputFile->addFromFile($filename, null, ZipEntry::METHOD_BZIP2); // $entryName == basename($filename); $zipOutputFile->addFromFile($filename, null, ZipEntry::METHOD_BZIP2); // $entryName == basename($filename);
``` ```
Add entry from string data. Add entry from string data.
```php ```php
$zipOutputFile->addFromString($entryName, $data) $zipOutputFile->addFromString($entryName, $data);
$zipOutputFile->addFromString($entryName, $data, ZipEntry::METHOD_DEFLATED) $zipOutputFile->addFromString($entryName, $data, ZipEntry::METHOD_DEFLATED);
$zipOutputFile->addFromString($entryName, $data, ZipEntry::METHOD_STORED); // no compress
``` ```
Add entry from stream. Add entry from stream.
```php ```php
$zipOutputFile->addFromStream($stream, $entryName) $zipOutputFile->addFromStream($stream, $entryName);
$zipOutputFile->addFromStream($stream, $entryName, ZipEntry::METHOD_DEFLATED) $zipOutputFile->addFromStream($stream, $entryName, ZipEntry::METHOD_DEFLATED);
$zipOutputFile->addFromStream($stream, $entryName, ZipEntry::METHOD_STORED); // no compress
``` ```
Add empty dir Add empty dir
```php ```php
@@ -446,7 +460,7 @@ $zipOutputFile->close(); // close output file, release all streams
$zipFile = \PhpZip\ZipFile::openFromFile($outputFilename); // open zip archive from file $zipFile = \PhpZip\ZipFile::openFromFile($outputFilename); // open zip archive from file
$zipFile->extractTo($outputDirExtract); // extract files to dir $zipFile->extractTo($outputDirExtract); // extract files to dir
$zipOutputFile = \PhpZip\ZipOutputFile::openFromZipFile($zipFile); // create zip output archive for update $zipOutputFile = $zipFile->edit(); // create zip output archive for update
$zipOutputFile->deleteFromRegex('~^\.~'); // delete all hidden (Unix) files $zipOutputFile->deleteFromRegex('~^\.~'); // delete all hidden (Unix) files
$zipOutputFile->addFromString('dir/file.txt', 'Test file'); // add files from string contents $zipOutputFile->addFromString('dir/file.txt', 'Test file'); // add files from string contents
$zipOutputFile->saveAsFile($outputFilename); // update zip file $zipOutputFile->saveAsFile($outputFilename); // update zip file

View File

@@ -157,6 +157,13 @@ class ZipFile implements \Countable, \ArrayAccess, \Iterator, ZipConstants
return $zipFile; return $zipFile;
} }
/**
* @return ZipOutputFile
*/
public function edit(){
return ZipOutputFile::openFromZipFile($this);
}
/** /**
* Check zip file signature * Check zip file signature
* *

View File

@@ -152,6 +152,22 @@ class ZipOutputFile implements \Countable, \ArrayAccess, \Iterator, ZipConstants
return new self($zipFile); return new self($zipFile);
} }
/**
* Open zip file from update.
*
* @param string $filename
* @return ZipOutputFile
* @throws IllegalArgumentException
* @see ZipOutputFile::__construct()
*/
public static function openFromFile($filename)
{
if (empty($filename)) {
throw new IllegalArgumentException("Zip file is null");
}
return new self(ZipFile::openFromFile($filename));
}
/** /**
* Count zip entries. * Count zip entries.
* *

View File

@@ -279,11 +279,9 @@ class ZipTest extends ZipTestCase
self::assertCorrectZipArchive($this->outputFilename); self::assertCorrectZipArchive($this->outputFilename);
$zipFile = ZipFile::openFromFile($this->outputFilename); $outputZipFile = ZipOutputFile::openFromFile($this->outputFilename);
$outputZipFile = new ZipOutputFile($zipFile);
$outputZipFile->rename($oldName, $newName); $outputZipFile->rename($oldName, $newName);
$outputZipFile->saveAsFile($this->outputFilename); $outputZipFile->saveAsFile($this->outputFilename);
$zipFile->close();
self::assertCorrectZipArchive($this->outputFilename); self::assertCorrectZipArchive($this->outputFilename);
@@ -309,7 +307,7 @@ class ZipTest extends ZipTestCase
self::assertCorrectZipArchive($this->outputFilename); self::assertCorrectZipArchive($this->outputFilename);
$zipFile = ZipFile::openFromFile($this->outputFilename); $zipFile = ZipFile::openFromFile($this->outputFilename);
$outputZipFile = new ZipOutputFile($zipFile); $outputZipFile = $zipFile->edit();
$outputZipFile->deleteFromName($deleteEntryName); $outputZipFile->deleteFromName($deleteEntryName);
$outputZipFile->saveAsFile($this->outputFilename); $outputZipFile->saveAsFile($this->outputFilename);
$zipFile->close(); $zipFile->close();
@@ -1087,6 +1085,7 @@ class ZipTest extends ZipTestCase
$zipFile = ZipFile::openFromFile($this->outputFilename); $zipFile = ZipFile::openFromFile($this->outputFilename);
self::assertEquals($zipFile->count(), $countFiles); self::assertEquals($zipFile->count(), $countFiles);
foreach ($zipFile as $entry => $content) { foreach ($zipFile as $entry => $content) {
strlen($content);
} }
$zipFile->close(); $zipFile->close();
} }