Arquivos
hhvm/hphp/runtime/base/zip_file.cpp
T
Kyle Delong a8e3321fbd HPHP/XHP: 'mixed' type in attribute declarations
We'd like to start using ##mixed## instead of ##var## for attribute types to be consistent with Hack. As a followup to this (once released), we would codemod all ##var## to ##mixed##.
2013-07-18 17:28:37 -07:00

121 linhas
3.4 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
| Copyright (c) 1998-2010 Zend Technologies Ltd. (http://www.zend.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 2.00 of the Zend license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.zend.com/license/2_00.txt. |
| If you did not receive a copy of the Zend license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@zend.com so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#include "hphp/runtime/base/zip_file.h"
#include "hphp/runtime/base/complex_types.h"
#include "hphp/runtime/base/runtime_error.h"
namespace HPHP {
IMPLEMENT_OBJECT_ALLOCATION_NO_DEFAULT_SWEEP(ZipFile);
///////////////////////////////////////////////////////////////////////////////
StaticString ZipFile::s_class_name("ZipFile");
///////////////////////////////////////////////////////////////////////////////
ZipFile::ZipFile() : m_gzFile(nullptr) {
m_innerFile = NEWOBJ(PlainFile)();
m_innerFile->unregister(); // so Sweepable won't touch my child
}
ZipFile::~ZipFile() {
closeImpl();
DELETEOBJ(HPHP, PlainFile, m_innerFile);
}
void ZipFile::sweep() {
closeImpl();
File::closeImpl();
}
bool ZipFile::open(CStrRef filename, CStrRef mode) {
assert(m_gzFile == nullptr);
if (strchr(mode.c_str(), '+')) {
raise_warning("cannot open a zlib stream for reading and writing "
"at the same time!");
return false;
}
return m_innerFile->open(filename, mode) &&
(m_gzFile = gzdopen(dup(m_innerFile->fd()), mode.data()));
}
bool ZipFile::close() {
return closeImpl();
}
bool ZipFile::closeImpl() {
bool ret = true;
s_file_data->m_pcloseRet = 0;
if (!m_closed) {
if (m_gzFile) {
s_file_data->m_pcloseRet = gzclose(m_gzFile);
ret = (s_file_data->m_pcloseRet == 0);
m_gzFile = nullptr;
}
m_closed = true;
m_innerFile->close();
}
File::closeImpl();
return ret;
}
///////////////////////////////////////////////////////////////////////////////
int64_t ZipFile::readImpl(char *buffer, int64_t length) {
assert(m_gzFile);
int64_t nread = gzread(m_gzFile, buffer, length);
return (nread < 0) ? 0 : nread;
}
int64_t ZipFile::writeImpl(const char *buffer, int64_t length) {
assert(m_gzFile);
return gzwrite(m_gzFile, buffer, length);
}
bool ZipFile::seek(int64_t offset, int whence /* = SEEK_SET */) {
assert(m_gzFile);
int64_t newoffset = gzseek(m_gzFile, offset, whence);
return (newoffset < 0) ? -1 : 0;
}
int64_t ZipFile::tell() {
assert(m_gzFile);
return gztell(m_gzFile);
}
bool ZipFile::eof() {
assert(m_gzFile);
return gzeof(m_gzFile);
}
bool ZipFile::rewind() {
assert(m_gzFile);
gzrewind(m_gzFile);
return true;
}
bool ZipFile::flush() {
assert(m_gzFile);
return gzflush(m_gzFile, Z_SYNC_FLUSH);
}
///////////////////////////////////////////////////////////////////////////////
}