Joomla Platform  13.1
Documentation des API du framework Joomla Platform
 Tout Classes Espaces de nommage Fichiers Fonctions Variables Pages
Référence de la classe JArchiveGzip
+ Graphe d'héritage de JArchiveGzip:
+ Graphe de collaboration de JArchiveGzip:

Liste de tous les membres

Fonctions membres publiques

 extract ($archive, $destination, array $options=array())
 _getFilePosition ()

Fonctions membres publiques statiques

static isSupported ()

Attributs privés

 $_flags = array('FTEXT' => 0x01, 'FHCRC' => 0x02, 'FEXTRA' => 0x04, 'FNAME' => 0x08, 'FCOMMENT' => 0x10)
 $_data = null

Description détaillée

Définition à la ligne 27 du fichier gzip.php.


Documentation des fonctions membres

JArchiveGzip::_getFilePosition ( )

Get file data offset for archive

Renvoie:
integer Data position marker for archive
Depuis:
11.1
Exceptions:
RuntimeException

Définition à la ligne 201 du fichier gzip.php.

Références JError\raiseWarning().

{
// Gzipped file... unpack it first
$position = 0;
$info = @ unpack('CCM/CFLG/VTime/CXFL/COS', substr($this->_data, $position + 2));
if (!$info)
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to decompress data.');
}
else
{
throw new RuntimeException('Unable to decompress data.');
}
}
$position += 10;
if ($info['FLG'] & $this->_flags['FEXTRA'])
{
$XLEN = unpack('vLength', substr($this->_data, $position + 0, 2));
$XLEN = $XLEN['Length'];
$position += $XLEN + 2;
}
if ($info['FLG'] & $this->_flags['FNAME'])
{
$filenamePos = strpos($this->_data, "\x0", $position);
$position = $filenamePos + 1;
}
if ($info['FLG'] & $this->_flags['FCOMMENT'])
{
$commentPos = strpos($this->_data, "\x0", $position);
$position = $commentPos + 1;
}
if ($info['FLG'] & $this->_flags['FHCRC'])
{
$hcrc = unpack('vCRC', substr($this->_data, $position + 0, 2));
$hcrc = $hcrc['CRC'];
$position += 2;
}
return $position;
}

+ Voici le graphe d'appel pour cette fonction :

JArchiveGzip::extract (   $archive,
  $destination,
array  $options = array () 
)

Extract a Gzip compressed file to a given path

Paramètres:
string$archivePath to ZIP archive to extract
string$destinationPath to extract archive to
array$optionsExtraction options [unused]
Renvoie:
boolean True if successful
Depuis:
11.1
Exceptions:
RuntimeException

Implémente JArchiveExtractable.

Définition à la ligne 57 du fichier gzip.php.

Références JFactory\getStream(), JError\raiseWarning(), et JFile\write().

{
$this->_data = null;
if (!extension_loaded('zlib'))
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'The zlib extension is not available.');
}
else
{
throw new RuntimeException('The zlib extension is not available.');
}
}
if (!isset($options['use_streams']) || $options['use_streams'] == false)
{
$this->_data = file_get_contents($archive);
if (!$this->_data)
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to read archive');
}
else
{
throw new RuntimeException('Unable to read archive');
}
}
$position = $this->_getFilePosition();
$buffer = gzinflate(substr($this->_data, $position, strlen($this->_data) - $position));
if (empty($buffer))
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to decompress data');
}
else
{
throw new RuntimeException('Unable to decompress data');
}
}
if (JFile::write($destination, $buffer) === false)
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to write archive');
}
else
{
throw new RuntimeException('Unable to write archive');
}
}
}
else
{
// New style! streams!
$input = JFactory::getStream();
// Use gz
$input->set('processingmethod', 'gz');
if (!$input->open($archive))
{
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to read archive (gz)');
}
else
{
throw new RuntimeException('Unable to read archive (gz)');
}
}
$output = JFactory::getStream();
if (!$output->open($destination, 'w'))
{
$input->close();
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to write archive (gz)');
}
else
{
throw new RuntimeException('Unable to write archive (gz)');
}
}
do
{
$this->_data = $input->read($input->get('chunksize', 8196));
if ($this->_data)
{
if (!$output->write($this->_data))
{
$input->close();
if (class_exists('JError'))
{
return JError::raiseWarning(100, 'Unable to write file (gz)');
}
else
{
throw new RuntimeException('Unable to write file (gz)');
}
}
}
}
while ($this->_data);
$output->close();
$input->close();
}
return true;
}

+ Voici le graphe d'appel pour cette fonction :

static JArchiveGzip::isSupported ( )
static

Tests whether this adapter can unpack files on this computer.

Renvoie:
boolean True if supported
Depuis:
11.3

Implémente JArchiveExtractable.

Définition à la ligne 188 du fichier gzip.php.

{
return extension_loaded('zlib');
}

Documentation des données membres

JArchiveGzip::$_data = null
private

Définition à la ligne 43 du fichier gzip.php.

JArchiveGzip::$_flags = array('FTEXT' => 0x01, 'FHCRC' => 0x02, 'FEXTRA' => 0x04, 'FNAME' => 0x08, 'FCOMMENT' => 0x10)
private

Définition à la ligne 35 du fichier gzip.php.


La documentation de cette classe a été générée à partir du fichier suivant :