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:
5
CHANGELOG.md
Normal file
5
CHANGELOG.md
Normal 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)`.
|
24
README.md
24
README.md
@@ -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
|
||||||
|
@@ -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
|
||||||
*
|
*
|
||||||
|
@@ -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.
|
||||||
*
|
*
|
||||||
|
@@ -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();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user