HEX
Server: Apache
System: Linux 185.122.168.184.host.secureserver.net 5.14.0-570.60.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Nov 5 05:00:59 EST 2025 x86_64
User: barbeatleanalyti (1024)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //proc/thread-self/root/opt/cpanel/ea-wappspector/vendor/rector/rector/src/Util/FileHasher.php
<?php

declare (strict_types=1);
namespace Rector\Util;

use Rector\Exception\ShouldNotHappenException;
/**
 * @see \Rector\Tests\Util\FileHasherTest
 */
final class FileHasher
{
    /**
     * cryptographic insecure hasing of a string
     */
    public function hash(string $string) : string
    {
        return \hash($this->getAlgo(), $string);
    }
    /**
     * cryptographic insecure hasing of files
     *
     * @param string[] $files
     */
    public function hashFiles(array $files) : string
    {
        $configHash = '';
        $algo = $this->getAlgo();
        foreach ($files as $file) {
            $hash = \hash_file($algo, $file);
            if ($hash === \false) {
                throw new ShouldNotHappenException(\sprintf('File %s is not readable', $file));
            }
            $configHash .= $hash;
        }
        return $configHash;
    }
    private function getAlgo() : string
    {
        //see https://php.watch/articles/php-hash-benchmark
        if (\PHP_VERSION_ID >= 80100) {
            // if xxh128 is available use it, as it is way faster
            return 'xxh128';
        }
        return 'md4';
    }
}