UnzipTask.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php
  2. /*
  3. *
  4. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  5. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  6. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  7. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  8. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  9. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  10. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  11. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  12. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  13. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  14. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  15. *
  16. * This software consists of voluntary contributions made by many individuals
  17. * and is licensed under the LGPL. For more information please see
  18. * <http://phing.info>.
  19. */
  20. require_once 'phing/tasks/ext/ExtractBaseTask.php';
  21. require_once 'phing/system/io/FileSystem.php';
  22. /**
  23. * Extracts one or several zip archives using ZipArchive class.
  24. *
  25. * @author Joakim Bodin <joakim.bodin+phing@gmail.com>
  26. * @author George Miroshnikov <laggy.luke@gmail.com>
  27. * @version $Id: UnzipTask.php 905 2010-10-05 16:28:03Z mrook $
  28. * @package phing.tasks.ext
  29. */
  30. class UnzipTask extends ExtractBaseTask
  31. {
  32. /**
  33. * Extract archive content into $this->todir directory
  34. * @param PhingFile Zip file to extract
  35. * @return boolean
  36. */
  37. protected function extractArchive(PhingFile $zipfile)
  38. {
  39. $this->log("Extracting zip: " . $zipfile->__toString() . ' to ' . $this->todir->__toString(), Project::MSG_INFO);
  40. $zip = new ZipArchive();
  41. $result = $zip->open($zipfile->getAbsolutePath());
  42. if (!$result) {
  43. $this->log("Unable to open zipfile " . $zipfile->__toString(), Project::MSG_ERR);
  44. return false;
  45. }
  46. $result = $zip->extractTo($this->todir->getAbsolutePath());
  47. if (!$result) {
  48. $this->log("Unable to extract zipfile " . $zipfile->__toString(), Project::MSG_ERR);
  49. return false;
  50. }
  51. return true;
  52. }
  53. /**
  54. * List archive content
  55. * @param PhingFile Zip file to list content
  56. * @return array List of files inside $zipfile
  57. */
  58. protected function listArchiveContent(PhingFile $zipfile)
  59. {
  60. $zip = new ZipArchive();
  61. $zip->open($zipfile->getAbsolutePath());
  62. $content = array();
  63. for ($i = 0; $i < $zip->numFiles; $i++) {
  64. $content[] = $zip->getNameIndex($i);
  65. }
  66. return $content;
  67. }
  68. }