| @@ -1,10 +1,12 @@ discard block | ||
| 1 | 1 | <?php exit; | 
| 2 | 2 | |
| 3 | 3 | //Check everything exists before using it | 
| 4 | -if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 4 | +if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) { | |
| 5 | 5 | $_SERVER['HTTP_ACCEPT_ENCODING'] = ''; | 
| 6 | -if(!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 6 | +} | |
| 7 | +if(!isset($_SERVER['HTTP_USER_AGENT'])) { | |
| 7 | 8 | $_SERVER['HTTP_USER_AGENT'] = ''; | 
| 9 | +} | |
| 8 | 10 | |
| 9 | 11 | // Determine supported compression method | 
| 10 | 12 | $gzip = strstr($_SERVER['HTTP_ACCEPT_ENCODING'], 'gzip'); | 
| @@ -19,16 +21,19 @@ discard block | ||
| 19 | 21 |  { | 
| 20 | 22 | $version = floatval($matches[1]); | 
| 21 | 23 | |
| 22 | - if ($version < 6) | |
| 23 | - $encoding = 'none'; | |
| 24 | +	if ($version < 6) { | |
| 25 | + $encoding = 'none'; | |
| 26 | + } | |
| 24 | 27 | |
| 25 | - if ($version == 6 && !strstr($_SERVER['HTTP_USER_AGENT'], 'EV1')) | |
| 26 | - $encoding = 'none'; | |
| 27 | -} | |
| 28 | +	if ($version == 6 && !strstr($_SERVER['HTTP_USER_AGENT'], 'EV1')) { | |
| 29 | + $encoding = 'none'; | |
| 30 | + } | |
| 31 | + } | |
| 28 | 32 | |
| 29 | 33 | //Some servers compress the output of PHP - Don't break in those cases | 
| 30 | -if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 34 | +if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) { | |
| 31 | 35 | $encoding = 'none'; | 
| 36 | +} | |
| 32 | 37 | |
| 33 | 38 | //Get data | 
| 34 | 39 | $contents = file_get_contents(__FILE__.'.'.$encoding); | 
| @@ -1,9 +1,9 @@ discard block | ||
| 1 | 1 | <?php exit; | 
| 2 | 2 | |
| 3 | 3 | //Check everything exists before using it | 
| 4 | -if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 4 | +if (!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 5 | 5 | $_SERVER['HTTP_ACCEPT_ENCODING'] = ''; | 
| 6 | -if(!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 6 | +if (!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 7 | 7 | $_SERVER['HTTP_USER_AGENT'] = ''; | 
| 8 | 8 | |
| 9 | 9 | // Determine supported compression method | 
| @@ -27,28 +27,28 @@ discard block | ||
| 27 | 27 | } | 
| 28 | 28 | |
| 29 | 29 | //Some servers compress the output of PHP - Don't break in those cases | 
| 30 | -if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 30 | +if (ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 31 | 31 | $encoding = 'none'; | 
| 32 | 32 | |
| 33 | 33 | //Get data | 
| 34 | 34 | $contents = file_get_contents(__FILE__.'.'.$encoding); | 
| 35 | 35 | |
| 36 | 36 | // first check if we have to send 304 | 
| 37 | -$eTag=md5($contents); | |
| 38 | -$modTime=filemtime(__FILE__.'.none'); | |
| 37 | +$eTag = md5($contents); | |
| 38 | +$modTime = filemtime(__FILE__.'.none'); | |
| 39 | 39 | |
| 40 | 40 |  date_default_timezone_set("UTC"); | 
| 41 | -$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'],$eTag)); | |
| 41 | +$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'], $eTag)); | |
| 42 | 42 | $modTimeMatch = (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) === $modTime); | 
| 43 | 43 | |
| 44 | -if (($modTimeMatch)||($eTagMatch)) { | |
| 44 | +if (($modTimeMatch) || ($eTagMatch)) { | |
| 45 | 45 |  	header('HTTP/1.1 304 Not Modified'); | 
| 46 | 46 |  	header('Connection: close'); | 
| 47 | 47 |  } else { | 
| 48 | 48 | // send all sorts of headers | 
| 49 | - $expireTime=60*60*24*356; // 1y max according to RFC | |
| 49 | + $expireTime = 60*60*24*356; // 1y max according to RFC | |
| 50 | 50 | |
| 51 | - if(isset($encoding) && $encoding != 'none') | |
| 51 | + if (isset($encoding) && $encoding != 'none') | |
| 52 | 52 |  	{ | 
| 53 | 53 |  		header('Content-Encoding: '.$encoding); | 
| 54 | 54 | } | 
| @@ -57,7 +57,7 @@ discard block | ||
| 57 | 57 |  	header('Content-type: %%CONTENT%%; charset=utf-8'); | 
| 58 | 58 |  	header('Cache-Control: max-age='.$expireTime.', public, immutable'); | 
| 59 | 59 |  	header('Expires: '.gmdate('D, d M Y H:i:s', time() + $expireTime).' GMT'); //10 years | 
| 60 | -	header('ETag: ' . $eTag); | |
| 60 | +	header('ETag: '.$eTag); | |
| 61 | 61 |  	header('Last-Modified: '.gmdate('D, d M Y H:i:s', $modTime).' GMT'); | 
| 62 | 62 | |
| 63 | 63 | // send output | 
| @@ -1,10 +1,12 @@ discard block | ||
| 1 | 1 | <?php exit; | 
| 2 | 2 | |
| 3 | 3 | //Check everything exists before using it | 
| 4 | -if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 4 | +if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) { | |
| 5 | 5 | $_SERVER['HTTP_ACCEPT_ENCODING'] = ''; | 
| 6 | -if(!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 6 | +} | |
| 7 | +if(!isset($_SERVER['HTTP_USER_AGENT'])) { | |
| 7 | 8 | $_SERVER['HTTP_USER_AGENT'] = ''; | 
| 9 | +} | |
| 8 | 10 | |
| 9 | 11 | // Determine supported compression method | 
| 10 | 12 | $gzip = strstr($_SERVER['HTTP_ACCEPT_ENCODING'], 'gzip'); | 
| @@ -19,16 +21,19 @@ discard block | ||
| 19 | 21 |  { | 
| 20 | 22 | $version = floatval($matches[1]); | 
| 21 | 23 | |
| 22 | - if ($version < 6) | |
| 23 | - $encoding = 'none'; | |
| 24 | +	if ($version < 6) { | |
| 25 | + $encoding = 'none'; | |
| 26 | + } | |
| 24 | 27 | |
| 25 | - if ($version == 6 && !strstr($_SERVER['HTTP_USER_AGENT'], 'EV1')) | |
| 26 | - $encoding = 'none'; | |
| 27 | -} | |
| 28 | +	if ($version == 6 && !strstr($_SERVER['HTTP_USER_AGENT'], 'EV1')) { | |
| 29 | + $encoding = 'none'; | |
| 30 | + } | |
| 31 | + } | |
| 28 | 32 | |
| 29 | 33 | //Some servers compress the output of PHP - Don't break in those cases | 
| 30 | -if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 34 | +if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) { | |
| 31 | 35 | $encoding = 'none'; | 
| 36 | +} | |
| 32 | 37 | |
| 33 | 38 | $iscompressed = file_exists(__FILE__.'.'.$encoding); | 
| 34 | 39 | if($encoding != 'none' && $iscompressed == false) | 
| @@ -36,7 +41,7 @@ discard block | ||
| 36 | 41 | $flag = ($encoding == 'gzip' ? FORCE_GZIP : FORCE_DEFLATE); | 
| 37 | 42 | $code = file_get_contents(__FILE__.'.none'); | 
| 38 | 43 | $contents = gzencode($code,9,$flag); | 
| 39 | -}else{ | |
| 44 | +} else{ | |
| 40 | 45 | //Get data | 
| 41 | 46 | $contents = file_get_contents(__FILE__.'.'.$encoding); | 
| 42 | 47 | } | 
| @@ -1,9 +1,9 @@ discard block | ||
| 1 | 1 | <?php exit; | 
| 2 | 2 | |
| 3 | 3 | //Check everything exists before using it | 
| 4 | -if(!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 4 | +if (!isset($_SERVER['HTTP_ACCEPT_ENCODING'])) | |
| 5 | 5 | $_SERVER['HTTP_ACCEPT_ENCODING'] = ''; | 
| 6 | -if(!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 6 | +if (!isset($_SERVER['HTTP_USER_AGENT'])) | |
| 7 | 7 | $_SERVER['HTTP_USER_AGENT'] = ''; | 
| 8 | 8 | |
| 9 | 9 | // Determine supported compression method | 
| @@ -27,16 +27,16 @@ discard block | ||
| 27 | 27 | } | 
| 28 | 28 | |
| 29 | 29 | //Some servers compress the output of PHP - Don't break in those cases | 
| 30 | -if(ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 30 | +if (ini_get('output_handler') == 'ob_gzhandler' || ini_get('zlib.output_compression') == 1) | |
| 31 | 31 | $encoding = 'none'; | 
| 32 | 32 | |
| 33 | 33 | $iscompressed = file_exists(__FILE__.'.'.$encoding); | 
| 34 | -if($encoding != 'none' && $iscompressed == false) | |
| 34 | +if ($encoding != 'none' && $iscompressed == false) | |
| 35 | 35 |  { | 
| 36 | 36 | $flag = ($encoding == 'gzip' ? FORCE_GZIP : FORCE_DEFLATE); | 
| 37 | 37 | $code = file_get_contents(__FILE__.'.none'); | 
| 38 | - $contents = gzencode($code,9,$flag); | |
| 39 | -}else{ | |
| 38 | + $contents = gzencode($code, 9, $flag); | |
| 39 | +} else { | |
| 40 | 40 | //Get data | 
| 41 | 41 | $contents = file_get_contents(__FILE__.'.'.$encoding); | 
| 42 | 42 | } | 
| @@ -44,19 +44,19 @@ discard block | ||
| 44 | 44 | // first check if we have to send 304 | 
| 45 | 45 | // inspired by http://www.jonasjohn.de/snippets/php/caching.htm | 
| 46 | 46 | |
| 47 | -$eTag=md5($contents); | |
| 48 | -$modTime=filemtime(__FILE__.'.none'); | |
| 47 | +$eTag = md5($contents); | |
| 48 | +$modTime = filemtime(__FILE__.'.none'); | |
| 49 | 49 | |
| 50 | 50 |  date_default_timezone_set("UTC"); | 
| 51 | -$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'],$eTag)); | |
| 51 | +$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'], $eTag)); | |
| 52 | 52 | $modTimeMatch = (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) === $modTime); | 
| 53 | 53 | |
| 54 | -if (($modTimeMatch)||($eTagMatch)) { | |
| 54 | +if (($modTimeMatch) || ($eTagMatch)) { | |
| 55 | 55 |  	header('HTTP/1.1 304 Not Modified'); | 
| 56 | 56 |  	header('Connection: close'); | 
| 57 | 57 |  } else { | 
| 58 | 58 | // send all sorts of headers | 
| 59 | - $expireTime=60*60*24*355; // 1y max according to RFC | |
| 59 | + $expireTime = 60*60*24*355; // 1y max according to RFC | |
| 60 | 60 |  	if ($encoding != 'none') { | 
| 61 | 61 |  		header('Content-Encoding: '.$encoding); | 
| 62 | 62 | } | 
| @@ -65,22 +65,22 @@ discard block | ||
| 65 | 65 |  	header('Content-type: %%CONTENT%%; charset=utf-8'); | 
| 66 | 66 |  	header('Cache-Control: max-age='.$expireTime.', public, immutable'); | 
| 67 | 67 |  	header('Expires: '.gmdate('D, d M Y H:i:s', time() + $expireTime).' GMT'); | 
| 68 | -	header('ETag: ' . $eTag); | |
| 68 | +	header('ETag: '.$eTag); | |
| 69 | 69 |  	header('Last-Modified: '.gmdate('D, d M Y H:i:s', $modTime).' GMT'); | 
| 70 | 70 | |
| 71 | 71 | // send output | 
| 72 | 72 | echo $contents; | 
| 73 | 73 | |
| 74 | 74 | //And write to filesystem cache if not done yet | 
| 75 | - if($encoding != 'none' && $iscompressed == false) | |
| 75 | + if ($encoding != 'none' && $iscompressed == false) | |
| 76 | 76 |  	{ | 
| 77 | 77 | //Write the content we sent | 
| 78 | - file_put_contents(__FILE__.'.'.$encoding,$contents); | |
| 78 | + file_put_contents(__FILE__.'.'.$encoding, $contents); | |
| 79 | 79 | |
| 80 | 80 | //And write the new content | 
| 81 | 81 | $flag = ($encoding == 'gzip' ? FORCE_DEFLATE : FORCE_GZIP); | 
| 82 | 82 | $ext = ($encoding == 'gzip' ? 'deflate' : 'gzip'); | 
| 83 | - $contents = gzencode($code,9,$flag); | |
| 84 | - file_put_contents(__FILE__.'.'.$ext,$contents); | |
| 83 | + $contents = gzencode($code, 9, $flag); | |
| 84 | + file_put_contents(__FILE__.'.'.$ext, $contents); | |
| 85 | 85 | } | 
| 86 | 86 | } | 
| @@ -1,5 +1,8 @@ | ||
| 1 | 1 | <?php | 
| 2 | -if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly | |
| 2 | +if ( ! defined( 'ABSPATH' ) ) { | |
| 3 | + exit; | |
| 4 | +} | |
| 5 | +// Exit if accessed directly | |
| 3 | 6 | |
| 4 | 7 |  class autoptimizeCache { | 
| 5 | 8 | private $filename; | 
| @@ -1,5 +1,5 @@ discard block | ||
| 1 | 1 | <?php | 
| 2 | -if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly | |
| 2 | +if (!defined('ABSPATH')) exit; // Exit if accessed directly | |
| 3 | 3 | |
| 4 | 4 |  class autoptimizeCache { | 
| 5 | 5 | private $filename; | 
| @@ -7,14 +7,14 @@ discard block | ||
| 7 | 7 | private $cachedir; | 
| 8 | 8 | private $delayed; | 
| 9 | 9 | |
| 10 | -    public function __construct($md5,$ext='php') { | |
| 10 | +    public function __construct($md5, $ext = 'php') { | |
| 11 | 11 | $this->cachedir = AUTOPTIMIZE_CACHE_DIR; | 
| 12 | 12 | $this->delayed = AUTOPTIMIZE_CACHE_DELAY; | 
| 13 | 13 | $this->nogzip = AUTOPTIMIZE_CACHE_NOGZIP; | 
| 14 | -        if($this->nogzip == false) { | |
| 14 | +        if ($this->nogzip == false) { | |
| 15 | 15 | $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.php'; | 
| 16 | 16 |          } else { | 
| 17 | -            if (in_array($ext, array("js","css")))     { | |
| 17 | +            if (in_array($ext, array("js", "css"))) { | |
| 18 | 18 | $this->filename = $ext.'/'.AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext; | 
| 19 | 19 |              } else { | 
| 20 | 20 | $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext; | 
| @@ -23,7 +23,7 @@ discard block | ||
| 23 | 23 | } | 
| 24 | 24 | |
| 25 | 25 |      public function check() { | 
| 26 | -        if(!file_exists($this->cachedir.$this->filename)) { | |
| 26 | +        if (!file_exists($this->cachedir.$this->filename)) { | |
| 27 | 27 | // No cached file, sorry | 
| 28 | 28 | return false; | 
| 29 | 29 | } | 
| @@ -32,8 +32,8 @@ discard block | ||
| 32 | 32 | } | 
| 33 | 33 | |
| 34 | 34 |      public function retrieve() { | 
| 35 | -        if($this->check()) { | |
| 36 | -            if($this->nogzip == false) { | |
| 35 | +        if ($this->check()) { | |
| 36 | +            if ($this->nogzip == false) { | |
| 37 | 37 | return file_get_contents($this->cachedir.$this->filename.'.none'); | 
| 38 | 38 |              } else { | 
| 39 | 39 | return file_get_contents($this->cachedir.$this->filename); | 
| @@ -42,48 +42,48 @@ discard block | ||
| 42 | 42 | return false; | 
| 43 | 43 | } | 
| 44 | 44 | |
| 45 | -    public function cache($code,$mime) { | |
| 46 | -        if($this->nogzip == false) { | |
| 45 | +    public function cache($code, $mime) { | |
| 46 | +        if ($this->nogzip == false) { | |
| 47 | 47 | $file = ($this->delayed ? 'delayed.php' : 'default.php'); | 
| 48 | 48 | $phpcode = file_get_contents(AUTOPTIMIZE_PLUGIN_DIR.'/config/'.$file); | 
| 49 | -            $phpcode = str_replace(array('%%CONTENT%%','exit;'),array($mime,''),$phpcode); | |
| 50 | - file_put_contents($this->cachedir.$this->filename,$phpcode, LOCK_EX); | |
| 51 | - file_put_contents($this->cachedir.$this->filename.'.none',$code, LOCK_EX); | |
| 52 | -            if(!$this->delayed) { | |
| 49 | +            $phpcode = str_replace(array('%%CONTENT%%', 'exit;'), array($mime, ''), $phpcode); | |
| 50 | + file_put_contents($this->cachedir.$this->filename, $phpcode, LOCK_EX); | |
| 51 | + file_put_contents($this->cachedir.$this->filename.'.none', $code, LOCK_EX); | |
| 52 | +            if (!$this->delayed) { | |
| 53 | 53 | // Compress now! | 
| 54 | - file_put_contents($this->cachedir.$this->filename.'.deflate',gzencode($code,9,FORCE_DEFLATE), LOCK_EX); | |
| 55 | - file_put_contents($this->cachedir.$this->filename.'.gzip',gzencode($code,9,FORCE_GZIP), LOCK_EX); | |
| 54 | + file_put_contents($this->cachedir.$this->filename.'.deflate', gzencode($code, 9, FORCE_DEFLATE), LOCK_EX); | |
| 55 | + file_put_contents($this->cachedir.$this->filename.'.gzip', gzencode($code, 9, FORCE_GZIP), LOCK_EX); | |
| 56 | 56 | } | 
| 57 | 57 |          } else { | 
| 58 | 58 | // Write code to cache without doing anything else | 
| 59 | - file_put_contents($this->cachedir.$this->filename,$code, LOCK_EX); | |
| 59 | + file_put_contents($this->cachedir.$this->filename, $code, LOCK_EX); | |
| 60 | 60 |              if (apply_filters('autoptimize_filter_cache_create_static_gzip', false)) { | 
| 61 | 61 | // Create an additional cached gzip file | 
| 62 | - file_put_contents($this->cachedir.$this->filename.'.gz', gzencode($code,9,FORCE_GZIP), LOCK_EX); | |
| 62 | + file_put_contents($this->cachedir.$this->filename.'.gz', gzencode($code, 9, FORCE_GZIP), LOCK_EX); | |
| 63 | 63 | } | 
| 64 | 64 | } | 
| 65 | 65 | } | 
| 66 | 66 | |
| 67 | 67 |      public function getname() { | 
| 68 | -        apply_filters('autoptimize_filter_cache_getname',AUTOPTIMIZE_CACHE_URL.$this->filename); | |
| 68 | +        apply_filters('autoptimize_filter_cache_getname', AUTOPTIMIZE_CACHE_URL.$this->filename); | |
| 69 | 69 | return $this->filename; | 
| 70 | 70 | } | 
| 71 | 71 | |
| 72 | 72 |      static function clearall() { | 
| 73 | -        if(!autoptimizeCache::cacheavail()) { | |
| 73 | +        if (!autoptimizeCache::cacheavail()) { | |
| 74 | 74 | return false; | 
| 75 | 75 | } | 
| 76 | 76 | |
| 77 | 77 | // scan the cachedirs | 
| 78 | -        foreach (array("","js","css") as $scandirName) { | |
| 78 | +        foreach (array("", "js", "css") as $scandirName) { | |
| 79 | 79 | $scan[$scandirName] = scandir(AUTOPTIMIZE_CACHE_DIR.$scandirName); | 
| 80 | 80 | } | 
| 81 | 81 | |
| 82 | 82 | // clear the cachedirs | 
| 83 | 83 |          foreach ($scan as $scandirName=>$scanneddir) { | 
| 84 | - $thisAoCacheDir=rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName,"/")."/"; | |
| 85 | -            foreach($scanneddir as $file) { | |
| 86 | -                if(!in_array($file,array('.','..')) && strpos($file,AUTOPTIMIZE_CACHEFILE_PREFIX) !== false && is_file($thisAoCacheDir.$file)) { | |
| 84 | + $thisAoCacheDir = rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName, "/")."/"; | |
| 85 | +            foreach ($scanneddir as $file) { | |
| 86 | +                if (!in_array($file, array('.', '..')) && strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) !== false && is_file($thisAoCacheDir.$file)) { | |
| 87 | 87 | @unlink($thisAoCacheDir.$file); | 
| 88 | 88 | } | 
| 89 | 89 | } | 
| @@ -98,15 +98,15 @@ discard block | ||
| 98 | 98 |                  do_action("autoptimize_action_cachepurged"); | 
| 99 | 99 | } | 
| 100 | 100 | } | 
| 101 | -        add_action("shutdown","autoptimize_do_cachepurged_action",11); | |
| 101 | +        add_action("shutdown", "autoptimize_do_cachepurged_action", 11); | |
| 102 | 102 | |
| 103 | 103 | // try to purge caching plugins cache-files? | 
| 104 | 104 | include_once(AUTOPTIMIZE_PLUGIN_DIR.'classlesses/autoptimizePageCacheFlush.php'); | 
| 105 | -        add_action("autoptimize_action_cachepurged","autoptimize_flush_pagecache",10,0); | |
| 105 | +        add_action("autoptimize_action_cachepurged", "autoptimize_flush_pagecache", 10, 0); | |
| 106 | 106 | |
| 107 | 107 | // warm cache (part of speedupper)? | 
| 108 | -        if ( apply_filters('autoptimize_filter_speedupper', true) ) { | |
| 109 | - $warmCacheUrl = site_url()."/?ao_speedup_cachebuster=".rand(1,100000); | |
| 108 | +        if (apply_filters('autoptimize_filter_speedupper', true)) { | |
| 109 | + $warmCacheUrl = site_url()."/?ao_speedup_cachebuster=".rand(1, 100000); | |
| 110 | 110 | $warmCache = @wp_remote_get($warmCacheUrl); | 
| 111 | 111 | unset($warmCache); | 
| 112 | 112 | } | 
| @@ -114,12 +114,12 @@ discard block | ||
| 114 | 114 | return true; | 
| 115 | 115 | } | 
| 116 | 116 | |
| 117 | -    static function stats()    { | |
| 118 | -        $AOstats=get_transient("autoptimize_stats"); | |
| 117 | +    static function stats() { | |
| 118 | +        $AOstats = get_transient("autoptimize_stats"); | |
| 119 | 119 | |
| 120 | 120 |          if (empty($AOstats)) { | 
| 121 | 121 | // Cache not available :( | 
| 122 | -            if(!autoptimizeCache::cacheavail()) { | |
| 122 | +            if (!autoptimizeCache::cacheavail()) { | |
| 123 | 123 | return 0; | 
| 124 | 124 | } | 
| 125 | 125 | |
| @@ -128,28 +128,28 @@ discard block | ||
| 128 | 128 | $size = 0; | 
| 129 | 129 | |
| 130 | 130 | // scan the cachedirs | 
| 131 | -            foreach (array("","js","css") as $scandirName) { | |
| 131 | +            foreach (array("", "js", "css") as $scandirName) { | |
| 132 | 132 | $scan[$scandirName] = scandir(AUTOPTIMIZE_CACHE_DIR.$scandirName); | 
| 133 | 133 | } | 
| 134 | 134 | |
| 135 | 135 |              foreach ($scan as $scandirName=>$scanneddir) { | 
| 136 | - $thisAoCacheDir=rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName,"/")."/"; | |
| 137 | -                foreach($scanneddir as $file) { | |
| 138 | -                    if(!in_array($file,array('.','..')) && strpos($file,AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) { | |
| 139 | -                        if(is_file($thisAoCacheDir.$file)) { | |
| 140 | -                            if(AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file,'.js') !== false || strpos($file,'.css') !== false || strpos($file,'.img') !== false || strpos($file,'.txt') !== false )) { | |
| 136 | + $thisAoCacheDir = rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName, "/")."/"; | |
| 137 | +                foreach ($scanneddir as $file) { | |
| 138 | +                    if (!in_array($file, array('.', '..')) && strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) { | |
| 139 | +                        if (is_file($thisAoCacheDir.$file)) { | |
| 140 | +                            if (AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file, '.js') !== false || strpos($file, '.css') !== false || strpos($file, '.img') !== false || strpos($file, '.txt') !== false)) { | |
| 141 | 141 | $count++; | 
| 142 | -                            } elseif(!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file,'.none') !== false) { | |
| 142 | +                            } elseif (!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file, '.none') !== false) { | |
| 143 | 143 | $count++; | 
| 144 | 144 | } | 
| 145 | - $size+=filesize($thisAoCacheDir.$file); | |
| 145 | + $size += filesize($thisAoCacheDir.$file); | |
| 146 | 146 | } | 
| 147 | 147 | } | 
| 148 | 148 | } | 
| 149 | 149 | } | 
| 150 | - $AOstats=array($count,$size,time()); | |
| 151 | -            if ($count>100) { | |
| 152 | - set_transient( "autoptimize_stats", $AOstats, apply_filters( 'autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS ) ); | |
| 150 | + $AOstats = array($count, $size, time()); | |
| 151 | +            if ($count > 100) { | |
| 152 | +                set_transient("autoptimize_stats", $AOstats, apply_filters('autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS)); | |
| 153 | 153 | } | 
| 154 | 154 | } | 
| 155 | 155 | // print the number of instances | 
| @@ -157,36 +157,36 @@ discard block | ||
| 157 | 157 | } | 
| 158 | 158 | |
| 159 | 159 |      static function cacheavail() { | 
| 160 | -        if(!defined('AUTOPTIMIZE_CACHE_DIR')) { | |
| 160 | +        if (!defined('AUTOPTIMIZE_CACHE_DIR')) { | |
| 161 | 161 | // We didn't set a cache | 
| 162 | 162 | return false; | 
| 163 | 163 | } | 
| 164 | 164 | |
| 165 | -        foreach (array("","js","css") as $checkDir) { | |
| 166 | -            if(!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) { | |
| 165 | +        foreach (array("", "js", "css") as $checkDir) { | |
| 166 | +            if (!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) { | |
| 167 | 167 | return false; | 
| 168 | 168 | } | 
| 169 | 169 | } | 
| 170 | 170 | |
| 171 | 171 | /** write index.html here to avoid prying eyes */ | 
| 172 | - $indexFile=AUTOPTIMIZE_CACHE_DIR.'/index.html'; | |
| 173 | -        if(!is_file($indexFile)) { | |
| 174 | - @file_put_contents($indexFile,'<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>'); | |
| 172 | + $indexFile = AUTOPTIMIZE_CACHE_DIR.'/index.html'; | |
| 173 | +        if (!is_file($indexFile)) { | |
| 174 | + @file_put_contents($indexFile, '<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>'); | |
| 175 | 175 | } | 
| 176 | 176 | |
| 177 | 177 | /** write .htaccess here to overrule wp_super_cache */ | 
| 178 | - $htAccess=AUTOPTIMIZE_CACHE_DIR.'/.htaccess'; | |
| 179 | -        if(!is_file($htAccess)) { | |
| 178 | + $htAccess = AUTOPTIMIZE_CACHE_DIR.'/.htaccess'; | |
| 179 | +        if (!is_file($htAccess)) { | |
| 180 | 180 | /** | 
| 181 | 181 | * create wp-content/AO_htaccess_tmpl with | 
| 182 | 182 | * whatever htaccess rules you might need | 
| 183 | 183 | * if you want to override default AO htaccess | 
| 184 | 184 | */ | 
| 185 | - $htaccess_tmpl=WP_CONTENT_DIR."/AO_htaccess_tmpl"; | |
| 185 | + $htaccess_tmpl = WP_CONTENT_DIR."/AO_htaccess_tmpl"; | |
| 186 | 186 |              if (is_file($htaccess_tmpl)) {  | 
| 187 | - $htAccessContent=file_get_contents($htaccess_tmpl); | |
| 187 | + $htAccessContent = file_get_contents($htaccess_tmpl); | |
| 188 | 188 |              } else if (is_multisite() || AUTOPTIMIZE_CACHE_NOGZIP == false) { | 
| 189 | - $htAccessContent='<IfModule mod_expires.c> | |
| 189 | + $htAccessContent = '<IfModule mod_expires.c> | |
| 190 | 190 | ExpiresActive On | 
| 191 | 191 | ExpiresByType text/css A30672000 | 
| 192 | 192 | ExpiresByType text/javascript A30672000 | 
| @@ -212,7 +212,7 @@ discard block | ||
| 212 | 212 | </Files> | 
| 213 | 213 | </IfModule>'; | 
| 214 | 214 |              } else { | 
| 215 | - $htAccessContent='<IfModule mod_expires.c> | |
| 215 | + $htAccessContent = '<IfModule mod_expires.c> | |
| 216 | 216 | ExpiresActive On | 
| 217 | 217 | ExpiresByType text/css A30672000 | 
| 218 | 218 | ExpiresByType text/javascript A30672000 | 
| @@ -238,7 +238,7 @@ discard block | ||
| 238 | 238 | </Files> | 
| 239 | 239 | </IfModule>'; | 
| 240 | 240 | } | 
| 241 | - @file_put_contents($htAccess,$htAccessContent); | |
| 241 | + @file_put_contents($htAccess, $htAccessContent); | |
| 242 | 242 | } | 
| 243 | 243 | |
| 244 | 244 | // All OK | 
| @@ -247,22 +247,22 @@ discard block | ||
| 247 | 247 | |
| 248 | 248 |      static function checkCacheDir($dir) { | 
| 249 | 249 | // Check and create if not exists | 
| 250 | -        if(!file_exists($dir))    { | |
| 251 | - @mkdir($dir,0775,true); | |
| 252 | -            if(!file_exists($dir))    { | |
| 250 | +        if (!file_exists($dir)) { | |
| 251 | + @mkdir($dir, 0775, true); | |
| 252 | +            if (!file_exists($dir)) { | |
| 253 | 253 | return false; | 
| 254 | 254 | } | 
| 255 | 255 | } | 
| 256 | 256 | |
| 257 | 257 | // check if we can now write | 
| 258 | -        if(!is_writable($dir))    { | |
| 258 | +        if (!is_writable($dir)) { | |
| 259 | 259 | return false; | 
| 260 | 260 | } | 
| 261 | 261 | |
| 262 | 262 | // and write index.html here to avoid prying eyes | 
| 263 | - $indexFile=$dir.'/index.html'; | |
| 264 | -        if(!is_file($indexFile)) { | |
| 265 | - @file_put_contents($indexFile,'<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>'); | |
| 263 | + $indexFile = $dir.'/index.html'; | |
| 264 | +        if (!is_file($indexFile)) { | |
| 265 | + @file_put_contents($indexFile, '<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>'); | |
| 266 | 266 | } | 
| 267 | 267 | |
| 268 | 268 | return true; | 
| @@ -1,5 +1,8 @@ discard block | ||
| 1 | 1 | <?php | 
| 2 | -if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly | |
| 2 | +if ( ! defined( 'ABSPATH' ) ) { | |
| 3 | + exit; | |
| 4 | +} | |
| 5 | +// Exit if accessed directly | |
| 3 | 6 | |
| 4 | 7 |  class autoptimizeHTML extends autoptimizeBase { | 
| 5 | 8 | private $keepcomments = false; | 
| @@ -26,8 +29,9 @@ discard block | ||
| 26 | 29 | //Joins and optimizes CSS | 
| 27 | 30 |      public function minify() { | 
| 28 | 31 | $noptimizeHTML = apply_filters( 'autoptimize_filter_html_noptimize', false, $this->content ); | 
| 29 | - if ($noptimizeHTML) | |
| 30 | - return false; | |
| 32 | +        if ($noptimizeHTML) { | |
| 33 | + return false; | |
| 34 | + } | |
| 31 | 35 | |
| 32 | 36 |          if(class_exists('Minify_HTML')) { | 
| 33 | 37 | // wrap the to-be-excluded strings in noptimize tags | 
| @@ -1,5 +1,5 @@ discard block | ||
| 1 | 1 | <?php | 
| 2 | -if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly | |
| 2 | +if (!defined('ABSPATH')) exit; // Exit if accessed directly | |
| 3 | 3 | |
| 4 | 4 |  class autoptimizeHTML extends autoptimizeBase { | 
| 5 | 5 | private $keepcomments = false; | 
| @@ -10,13 +10,13 @@ discard block | ||
| 10 | 10 | $this->keepcomments = (bool) $options['keepcomments']; | 
| 11 | 11 | |
| 12 | 12 | // filter to force xhtml | 
| 13 | - $this->forcexhtml = (bool) apply_filters( 'autoptimize_filter_html_forcexhtml', false ); | |
| 13 | +        $this->forcexhtml = (bool) apply_filters('autoptimize_filter_html_forcexhtml', false); | |
| 14 | 14 | |
| 15 | 15 | // filter to add strings to be excluded from HTML minification | 
| 16 | - $excludeHTML = apply_filters( 'autoptimize_filter_html_exclude','' ); | |
| 17 | -        if ($excludeHTML!=="") { | |
| 18 | -            $exclHTMLArr = array_filter(array_map('trim',explode(",",$excludeHTML))); | |
| 19 | - $this->exclude = array_merge($exclHTMLArr,$this->exclude); | |
| 16 | +        $excludeHTML = apply_filters('autoptimize_filter_html_exclude', ''); | |
| 17 | +        if ($excludeHTML !== "") { | |
| 18 | +            $exclHTMLArr = array_filter(array_map('trim', explode(",", $excludeHTML))); | |
| 19 | + $this->exclude = array_merge($exclHTMLArr, $this->exclude); | |
| 20 | 20 | } | 
| 21 | 21 | |
| 22 | 22 | // Nothing else for HTML | 
| @@ -25,16 +25,16 @@ discard block | ||
| 25 | 25 | |
| 26 | 26 | //Joins and optimizes CSS | 
| 27 | 27 |      public function minify() { | 
| 28 | - $noptimizeHTML = apply_filters( 'autoptimize_filter_html_noptimize', false, $this->content ); | |
| 28 | +        $noptimizeHTML = apply_filters('autoptimize_filter_html_noptimize', false, $this->content); | |
| 29 | 29 | if ($noptimizeHTML) | 
| 30 | 30 | return false; | 
| 31 | 31 | |
| 32 | -        if(class_exists('Minify_HTML')) { | |
| 32 | +        if (class_exists('Minify_HTML')) { | |
| 33 | 33 | // wrap the to-be-excluded strings in noptimize tags | 
| 34 | 34 |              foreach ($this->exclude as $exclString) { | 
| 35 | -                if (strpos($this->content,$exclString)!==false) { | |
| 36 | - $replString="<!--noptimize-->".$exclString."<!--/noptimize-->"; | |
| 37 | - $this->content=str_replace($exclString,$replString,$this->content); | |
| 35 | +                if (strpos($this->content, $exclString) !== false) { | |
| 36 | + $replString = "<!--noptimize-->".$exclString."<!--/noptimize-->"; | |
| 37 | + $this->content = str_replace($exclString, $replString, $this->content); | |
| 38 | 38 | } | 
| 39 | 39 | } | 
| 40 | 40 | |
| @@ -47,8 +47,8 @@ discard block | ||
| 47 | 47 | $options['xhtml'] = true; | 
| 48 | 48 | } | 
| 49 | 49 | |
| 50 | -            if (@is_callable(array("Minify_HTML","minify"))) { | |
| 51 | - $tmp_content = Minify_HTML::minify($this->content,$options); | |
| 50 | +            if (@is_callable(array("Minify_HTML", "minify"))) { | |
| 51 | + $tmp_content = Minify_HTML::minify($this->content, $options); | |
| 52 | 52 |                  if (!empty($tmp_content)) { | 
| 53 | 53 | $this->content = $tmp_content; | 
| 54 | 54 | unset($tmp_content); | 
| @@ -60,16 +60,16 @@ discard block | ||
| 60 | 60 | |
| 61 | 61 | // remove the noptimize-wrapper from around the excluded strings | 
| 62 | 62 |              foreach ($this->exclude as $exclString) { | 
| 63 | - $replString="<!--noptimize-->".$exclString."<!--/noptimize-->"; | |
| 64 | -                if (strpos($this->content,$replString)!==false) { | |
| 65 | - $this->content=str_replace($replString,$exclString,$this->content); | |
| 63 | + $replString = "<!--noptimize-->".$exclString."<!--/noptimize-->"; | |
| 64 | +                if (strpos($this->content, $replString) !== false) { | |
| 65 | + $this->content = str_replace($replString, $exclString, $this->content); | |
| 66 | 66 | } | 
| 67 | 67 | } | 
| 68 | 68 | |
| 69 | 69 | // revslider data attribs somehow suffer from HTML optimization, this fixes that | 
| 70 | -            if ( class_exists('RevSlider') && apply_filters('autoptimize_filter_html_dataattrib_cleanup', false) ) { | |
| 71 | -                $this->content = preg_replace('#\n(data-.*$)\n#Um',' $1 ', $this->content); | |
| 72 | -                $this->content = preg_replace('#<[^>]*(=\"[^"\'<>\s]*\")(\w)#','$1 $2', $this->content); | |
| 70 | +            if (class_exists('RevSlider') && apply_filters('autoptimize_filter_html_dataattrib_cleanup', false)) { | |
| 71 | +                $this->content = preg_replace('#\n(data-.*$)\n#Um', ' $1 ', $this->content); | |
| 72 | +                $this->content = preg_replace('#<[^>]*(=\"[^"\'<>\s]*\")(\w)#', '$1 $2', $this->content); | |
| 73 | 73 | } | 
| 74 | 74 | |
| 75 | 75 | return true; | 
| @@ -68,7 +68,7 @@ discard block | ||
| 68 | 68 | protected $inputLength = 0; | 
| 69 | 69 | protected $lookAhead = null; | 
| 70 | 70 | protected $output = ''; | 
| 71 | - protected $lastByteOut = ''; | |
| 71 | + protected $lastByteOut = ''; | |
| 72 | 72 | protected $keptComment = ''; | 
| 73 | 73 | |
| 74 | 74 | /** | 
| @@ -104,7 +104,7 @@ discard block | ||
| 104 | 104 | } | 
| 105 | 105 | |
| 106 | 106 | $mbIntEnc = null; | 
| 107 | -        if (function_exists('mb_strlen') && ((int)ini_get('mbstring.func_overload') & 2)) {
 | |
| 107 | +        if (function_exists('mb_strlen') && ((int) ini_get('mbstring.func_overload') & 2)) {
 | |
| 108 | 108 | $mbIntEnc = mb_internal_encoding(); | 
| 109 | 109 |              mb_internal_encoding('8bit');
 | 
| 110 | 110 | } | 
| @@ -121,7 +121,7 @@ discard block | ||
| 121 | 121 |                          && ($this->b === $this->lastByteOut)) {
 | 
| 122 | 122 | // Don't delete this space. If we do, the addition/subtraction | 
| 123 | 123 | // could be parsed as a post-increment | 
| 124 | -                } elseif (! $this->isAlphaNum($this->b)) {
 | |
| 124 | +                } elseif (!$this->isAlphaNum($this->b)) {
 | |
| 125 | 125 | $command = self::ACTION_DELETE_A; | 
| 126 | 126 | } | 
| 127 | 127 |              } elseif ($this->a === "\n") {
 | 
| @@ -132,10 +132,10 @@ discard block | ||
| 132 | 132 | // otherwise mb_strpos will give WARNING | 
| 133 | 133 | } elseif ($this->b === null | 
| 134 | 134 |                            || (false === strpos('{[(+-!~', $this->b)
 | 
| 135 | -                              && ! $this->isAlphaNum($this->b))) {
 | |
| 135 | +                              && !$this->isAlphaNum($this->b))) {
 | |
| 136 | 136 | $command = self::ACTION_DELETE_A; | 
| 137 | 137 | } | 
| 138 | -            } elseif (! $this->isAlphaNum($this->a)) {
 | |
| 138 | +            } elseif (!$this->isAlphaNum($this->a)) {
 | |
| 139 | 139 | if ($this->b === ' ' | 
| 140 | 140 | || ($this->b === "\n" | 
| 141 | 141 |                          && (false === strpos('}])+-"\'', $this->a)))) {
 | 
| @@ -191,7 +191,7 @@ discard block | ||
| 191 | 191 | $this->a = $this->b; | 
| 192 | 192 |                  if ($this->a === "'" || $this->a === '"') { // string literal
 | 
| 193 | 193 | $str = $this->a; // in case needed for exception | 
| 194 | -                    for(;;) {
 | |
| 194 | +                    for (;;) {
 | |
| 195 | 195 | $this->output .= $this->a; | 
| 196 | 196 | $this->lastByteOut = $this->a; | 
| 197 | 197 | |
| @@ -218,13 +218,13 @@ discard block | ||
| 218 | 218 | case self::ACTION_DELETE_A_B: // 3 | 
| 219 | 219 | $this->b = $this->next(); | 
| 220 | 220 |                  if ($this->b === '/' && $this->isRegexpLiteral()) {
 | 
| 221 | - $this->output .= $this->a . $this->b; | |
| 221 | + $this->output .= $this->a.$this->b; | |
| 222 | 222 | $pattern = '/'; // keep entire pattern in case we need to report it in the exception | 
| 223 | -                    for(;;) {
 | |
| 223 | +                    for (;;) {
 | |
| 224 | 224 | $this->a = $this->get(); | 
| 225 | 225 | $pattern .= $this->a; | 
| 226 | 226 |                          if ($this->a === '[') {
 | 
| 227 | -                            for(;;) {
 | |
| 227 | +                            for (;;) {
 | |
| 228 | 228 | $this->output .= $this->a; | 
| 229 | 229 | $this->a = $this->get(); | 
| 230 | 230 | $pattern .= $this->a; | 
| @@ -239,7 +239,7 @@ discard block | ||
| 239 | 239 |                                  if ($this->isEOF($this->a)) {
 | 
| 240 | 240 | throw new JSMin_UnterminatedRegExpException( | 
| 241 | 241 | "JSMin: Unterminated set in RegExp at byte " | 
| 242 | -                                            . $this->inputIndex .": {$pattern}");
 | |
| 242 | +                                            . $this->inputIndex.": {$pattern}");
 | |
| 243 | 243 | } | 
| 244 | 244 | } | 
| 245 | 245 | } | 
| @@ -283,7 +283,7 @@ discard block | ||
| 283 | 283 | // certainly wasn't keyword | 
| 284 | 284 | continue; | 
| 285 | 285 | } | 
| 286 | -            if (preg_match("~(^|[\\s\\S])" . substr($keyword, 0, -1) . "$~", $recentOutput, $m)) {
 | |
| 286 | +            if (preg_match("~(^|[\\s\\S])".substr($keyword, 0, -1)."$~", $recentOutput, $m)) {
 | |
| 287 | 287 |                  if ($m[1] === '' || !$this->isAlphaNum($m[1])) {
 | 
| 288 | 288 | return true; | 
| 289 | 289 | } | 
| @@ -392,7 +392,7 @@ discard block | ||
| 392 | 392 |      {
 | 
| 393 | 393 | $this->get(); | 
| 394 | 394 | $comment = ''; | 
| 395 | -        for(;;) {
 | |
| 395 | +        for (;;) {
 | |
| 396 | 396 | $get = $this->get(); | 
| 397 | 397 |              if ($get === '*') {
 | 
| 398 | 398 |                  if ($this->peek() === '/') { // end of comment reached
 | 
| @@ -403,7 +403,7 @@ discard block | ||
| 403 | 403 | // don't prepend a newline if two comments right after one another | 
| 404 | 404 | $this->keptComment = "\n"; | 
| 405 | 405 | } | 
| 406 | - $this->keptComment .= "/*!" . substr($comment, 1) . "*/\n"; | |
| 406 | + $this->keptComment .= "/*!".substr($comment, 1)."*/\n"; | |
| 407 | 407 |                      } else if (preg_match('/^@(?:cc_on|if|elif|else|end)\\b/', $comment)) {
 | 
| 408 | 408 | // IE conditional | 
| 409 | 409 |                          $this->keptComment .= "/*{$comment}*/";
 | 
| @@ -68,7 +68,7 @@ discard block | ||
| 68 | 68 | protected $inputLength = 0; | 
| 69 | 69 | protected $lookAhead = null; | 
| 70 | 70 | protected $output = ''; | 
| 71 | - protected $lastByteOut = ''; | |
| 71 | + protected $lastByteOut = ''; | |
| 72 | 72 | protected $keptComment = ''; | 
| 73 | 73 | |
| 74 | 74 | /** | 
| @@ -104,7 +104,7 @@ discard block | ||
| 104 | 104 | } | 
| 105 | 105 | |
| 106 | 106 | $mbIntEnc = null; | 
| 107 | -        if (function_exists('mb_strlen') && ((int)ini_get('mbstring.func_overload') & 2)) { | |
| 107 | +        if (function_exists('mb_strlen') && ((int) ini_get('mbstring.func_overload') & 2)) { | |
| 108 | 108 | $mbIntEnc = mb_internal_encoding(); | 
| 109 | 109 |              mb_internal_encoding('8bit'); | 
| 110 | 110 | } | 
| @@ -126,7 +126,7 @@ discard block | ||
| 126 | 126 |                          && ($this->b === $this->lastByteOut)) { | 
| 127 | 127 | // Don't delete this space. If we do, the addition/subtraction | 
| 128 | 128 | // could be parsed as a post-increment | 
| 129 | -                } elseif (! $this->isAlphaNum($this->b)) { | |
| 129 | +                } elseif (!$this->isAlphaNum($this->b)) { | |
| 130 | 130 | $command = self::ACTION_DELETE_A; | 
| 131 | 131 | } | 
| 132 | 132 |              } elseif ($this->a === "\n") { | 
| @@ -137,10 +137,10 @@ discard block | ||
| 137 | 137 | // otherwise mb_strpos will give WARNING | 
| 138 | 138 | } elseif ($this->b === null | 
| 139 | 139 |                            || (false === strpos('{[(+-!~', $this->b) | 
| 140 | -                              && ! $this->isAlphaNum($this->b))) { | |
| 140 | +                              && !$this->isAlphaNum($this->b))) { | |
| 141 | 141 | $command = self::ACTION_DELETE_A; | 
| 142 | 142 | } | 
| 143 | -            } elseif (! $this->isAlphaNum($this->a)) { | |
| 143 | +            } elseif (!$this->isAlphaNum($this->a)) { | |
| 144 | 144 | if ($this->b === ' ' | 
| 145 | 145 | || ($this->b === "\n" | 
| 146 | 146 |                          && (false === strpos('}])+-"\'', $this->a)))) { | 
| @@ -197,7 +197,7 @@ discard block | ||
| 197 | 197 |                  if ($this->a === "'" || $this->a === '"' || $this->a === '`') { // string/template literal | 
| 198 | 198 | $delimiter = $this->a; | 
| 199 | 199 | $str = $this->a; // in case needed for exception | 
| 200 | -                    for(;;) { | |
| 200 | +                    for (;;) { | |
| 201 | 201 | $this->output .= $this->a; | 
| 202 | 202 | $this->lastByteOut = $this->a; | 
| 203 | 203 | $this->a = $this->get(); | 
| @@ -225,13 +225,13 @@ discard block | ||
| 225 | 225 | case self::ACTION_DELETE_A_B: // 3 | 
| 226 | 226 | $this->b = $this->next(); | 
| 227 | 227 |                  if ($this->b === '/' && $this->isRegexpLiteral()) { | 
| 228 | - $this->output .= $this->a . $this->b; | |
| 228 | + $this->output .= $this->a.$this->b; | |
| 229 | 229 | $pattern = '/'; // keep entire pattern in case we need to report it in the exception | 
| 230 | -                    for(;;) { | |
| 230 | +                    for (;;) { | |
| 231 | 231 | $this->a = $this->get(); | 
| 232 | 232 | $pattern .= $this->a; | 
| 233 | 233 |                          if ($this->a === '[') { | 
| 234 | -                            for(;;) { | |
| 234 | +                            for (;;) { | |
| 235 | 235 | $this->output .= $this->a; | 
| 236 | 236 | $this->a = $this->get(); | 
| 237 | 237 | $pattern .= $this->a; | 
| @@ -246,7 +246,7 @@ discard block | ||
| 246 | 246 |                                  if ($this->isEOF($this->a)) { | 
| 247 | 247 | throw new JSMin_UnterminatedRegExpException( | 
| 248 | 248 | "JSMin: Unterminated set in RegExp at byte " | 
| 249 | -                                            . $this->inputIndex .": {$pattern}"); | |
| 249 | +                                            . $this->inputIndex.": {$pattern}"); | |
| 250 | 250 | } | 
| 251 | 251 | } | 
| 252 | 252 | } | 
| @@ -291,7 +291,7 @@ discard block | ||
| 291 | 291 | |
| 292 | 292 | // if the "/" follows a keyword, it must be a regexp, otherwise it's best to assume division | 
| 293 | 293 | |
| 294 | - $subject = $this->output . trim($this->a); | |
| 294 | + $subject = $this->output.trim($this->a); | |
| 295 | 295 |          if (!preg_match('/(?:case|else|in|return|typeof)$/', $subject, $m)) { | 
| 296 | 296 | // not a keyword | 
| 297 | 297 | return false; | 
| @@ -402,7 +402,7 @@ discard block | ||
| 402 | 402 |      { | 
| 403 | 403 | $this->get(); | 
| 404 | 404 | $comment = ''; | 
| 405 | -        for(;;) { | |
| 405 | +        for (;;) { | |
| 406 | 406 | $get = $this->get(); | 
| 407 | 407 |              if ($get === '*') { | 
| 408 | 408 |                  if ($this->peek() === '/') { // end of comment reached | 
| @@ -413,7 +413,7 @@ discard block | ||
| 413 | 413 | // don't prepend a newline if two comments right after one another | 
| 414 | 414 | $this->keptComment = "\n"; | 
| 415 | 415 | } | 
| 416 | - $this->keptComment .= "/*!" . substr($comment, 1) . "*/\n"; | |
| 416 | + $this->keptComment .= "/*!".substr($comment, 1)."*/\n"; | |
| 417 | 417 |                      } else if (preg_match('/^@(?:cc_on|if|elif|else|end)\\b/', $comment)) { | 
| 418 | 418 | // IE conditional | 
| 419 | 419 |                          $this->keptComment .= "/*{$comment}*/"; | 
| @@ -74,7 +74,7 @@ discard block | ||
| 74 | 74 | // -- Protected Instance Methods --------------------------------------------- | 
| 75 | 75 | |
| 76 | 76 |    protected function action($d) {
 | 
| 77 | -    switch($d) {
 | |
| 77 | +    switch ($d) {
 | |
| 78 | 78 | case 1: | 
| 79 | 79 | $this->output .= $this->a; | 
| 80 | 80 | |
| @@ -109,7 +109,7 @@ discard block | ||
| 109 | 109 | $this->a === ':' || $this->a === '[' || $this->a === '!' || | 
| 110 | 110 |              $this->a === '&' || $this->a === '|' || $this->a === '?')) {
 | 
| 111 | 111 | |
| 112 | - $this->output .= $this->a . $this->b; | |
| 112 | + $this->output .= $this->a.$this->b; | |
| 113 | 113 | |
| 114 | 114 |            for (;;) {
 | 
| 115 | 115 | $this->a = $this->get(); | 
| @@ -245,7 +245,7 @@ discard block | ||
| 245 | 245 | $c = $this->get(); | 
| 246 | 246 | |
| 247 | 247 |      if ($c === '/') {
 | 
| 248 | -      switch($this->peek()) {
 | |
| 248 | +      switch ($this->peek()) {
 | |
| 249 | 249 | case '/': | 
| 250 | 250 |            for (;;) {
 | 
| 251 | 251 | $c = $this->get(); | 
| @@ -259,7 +259,7 @@ discard block | ||
| 259 | 259 | $this->get(); | 
| 260 | 260 | |
| 261 | 261 |            for (;;) {
 | 
| 262 | -            switch($this->get()) {
 | |
| 262 | +            switch ($this->get()) {
 | |
| 263 | 263 | case '*': | 
| 264 | 264 |                  if ($this->peek() === '/') {
 | 
| 265 | 265 | $this->get(); | 
| @@ -191,8 +191,7 @@ discard block | ||
| 191 | 191 | default: | 
| 192 | 192 |                if ($this->isAlphaNum($this->b)) {
 | 
| 193 | 193 | $this->action(1); | 
| 194 | - } | |
| 195 | -              else {
 | |
| 194 | +              } else {
 | |
| 196 | 195 | $this->action(2); | 
| 197 | 196 | } | 
| 198 | 197 | } | 
| @@ -224,8 +223,7 @@ discard block | ||
| 224 | 223 | default: | 
| 225 | 224 |                    if ($this->isAlphaNum($this->a)) {
 | 
| 226 | 225 | $this->action(1); | 
| 227 | - } | |
| 228 | -                  else {
 | |
| 226 | +                  } else {
 | |
| 229 | 227 | $this->action(3); | 
| 230 | 228 | } | 
| 231 | 229 | } | 
| @@ -70,7 +70,7 @@ discard block | ||
| 70 | 70 |      {
 | 
| 71 | 71 |          $this->_html = str_replace("\r\n", "\n", trim($html));
 | 
| 72 | 72 |          if (isset($options['xhtml'])) {
 | 
| 73 | - $this->_isXhtml = (bool)$options['xhtml']; | |
| 73 | + $this->_isXhtml = (bool) $options['xhtml']; | |
| 74 | 74 | } | 
| 75 | 75 |          if (isset($options['cssMinifier'])) {
 | 
| 76 | 76 | $this->_cssMinifier = $options['cssMinifier']; | 
| @@ -79,7 +79,7 @@ discard block | ||
| 79 | 79 | $this->_jsMinifier = $options['jsMinifier']; | 
| 80 | 80 | } | 
| 81 | 81 |          if (isset($options['jsCleanComments'])) {
 | 
| 82 | - $this->_jsCleanComments = (bool)$options['jsCleanComments']; | |
| 82 | + $this->_jsCleanComments = (bool) $options['jsCleanComments']; | |
| 83 | 83 | } | 
| 84 | 84 | } | 
| 85 | 85 | |
| @@ -95,7 +95,7 @@ discard block | ||
| 95 | 95 | $this->_isXhtml = (false !== strpos($this->_html, '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML')); | 
| 96 | 96 | } | 
| 97 | 97 | |
| 98 | - $this->_replacementHash = 'MINIFYHTML' . md5($_SERVER['REQUEST_TIME']); | |
| 98 | + $this->_replacementHash = 'MINIFYHTML'.md5($_SERVER['REQUEST_TIME']); | |
| 99 | 99 | $this->_placeholders = array(); | 
| 100 | 100 | |
| 101 | 101 | // replace SCRIPTs (and minify) with placeholders | 
| @@ -171,7 +171,7 @@ discard block | ||
| 171 | 171 | |
| 172 | 172 | protected function _reservePlace($content) | 
| 173 | 173 |      {
 | 
| 174 | - $placeholder = '%' . $this->_replacementHash . count($this->_placeholders) . '%'; | |
| 174 | + $placeholder = '%'.$this->_replacementHash.count($this->_placeholders).'%'; | |
| 175 | 175 | $this->_placeholders[$placeholder] = $content; | 
| 176 | 176 | return $placeholder; | 
| 177 | 177 | } | 
| @@ -245,6 +245,6 @@ | ||
| 245 | 245 | ) | 
| 246 | 246 | \\s* | 
| 247 | 247 | /x', '$1', $m[1]); | 
| 248 | - return 'font-family:' . $m[1] . $m[2]; | |
| 248 | + return 'font-family:'.$m[1].$m[2]; | |
| 249 | 249 | } | 
| 250 | 250 | } |