| @@ -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,27 +27,27 @@ 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 | -$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'],$eTag)); | |
| 40 | +$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'], $eTag)); | |
| 41 | 41 | $modTimeMatch = (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) === $modTime); | 
| 42 | 42 | |
| 43 | -if (($modTimeMatch)||($eTagMatch)) { | |
| 43 | +if (($modTimeMatch) || ($eTagMatch)) { | |
| 44 | 44 |  	header('HTTP/1.1 304 Not Modified'); | 
| 45 | 45 |  	header('Connection: close'); | 
| 46 | 46 |  } else { | 
| 47 | 47 | // send all sorts of headers | 
| 48 | - $expireTime=60*60*24*356; // 1y max according to RFC | |
| 48 | + $expireTime = 60*60*24*356; // 1y max according to RFC | |
| 49 | 49 | |
| 50 | - if(isset($encoding) && $encoding != 'none') | |
| 50 | + if (isset($encoding) && $encoding != 'none') | |
| 51 | 51 |  	{ | 
| 52 | 52 |  		header('Content-Encoding: '.$encoding); | 
| 53 | 53 | } | 
| @@ -56,7 +56,7 @@ discard block | ||
| 56 | 56 |  	header('Content-type: %%CONTENT%%; charset=utf-8'); | 
| 57 | 57 |  	header('Cache-Control: max-age='.$expireTime.', public, must-revalidate'); | 
| 58 | 58 |  	header('Expires: '.gmdate('D, d M Y H:i:s', time() + $expireTime).' GMT'); //10 years | 
| 59 | -	header('ETag: ' . $eTag); | |
| 59 | +	header('ETag: '.$eTag); | |
| 60 | 60 |  	header('Last-Modified: '.gmdate('D, d M Y H:i:s', $modTime).' GMT'); | 
| 61 | 61 | |
| 62 | 62 | // send output | 
| @@ -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,18 +44,18 @@ 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 | -$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'],$eTag)); | |
| 50 | +$eTagMatch = (isset($_SERVER['HTTP_IF_NONE_MATCH']) && strpos($_SERVER['HTTP_IF_NONE_MATCH'], $eTag)); | |
| 51 | 51 | $modTimeMatch = (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && strtotime($_SERVER['HTTP_IF_MODIFIED_SINCE']) === $modTime); | 
| 52 | 52 | |
| 53 | -if (($modTimeMatch)||($eTagMatch)) { | |
| 53 | +if (($modTimeMatch) || ($eTagMatch)) { | |
| 54 | 54 |  	header('HTTP/1.1 304 Not Modified'); | 
| 55 | 55 |  	header('Connection: close'); | 
| 56 | 56 |  } else { | 
| 57 | 57 | // send all sorts of headers | 
| 58 | - $expireTime=60*60*24*355; // 1y max according to RFC | |
| 58 | + $expireTime = 60*60*24*355; // 1y max according to RFC | |
| 59 | 59 |  	if ($encoding != 'none') { | 
| 60 | 60 |  		header('Content-Encoding: '.$encoding); | 
| 61 | 61 | } | 
| @@ -64,22 +64,22 @@ discard block | ||
| 64 | 64 |  	header('Content-type: %%CONTENT%%; charset=utf-8'); | 
| 65 | 65 |  	header('Cache-Control: max-age='.$expireTime.', public, must-revalidate'); | 
| 66 | 66 |  	header('Expires: '.gmdate('D, d M Y H:i:s', time() + $expireTime).' GMT'); | 
| 67 | -	header('ETag: ' . $eTag); | |
| 67 | +	header('ETag: '.$eTag); | |
| 68 | 68 |  	header('Last-Modified: '.gmdate('D, d M Y H:i:s', $modTime).' GMT'); | 
| 69 | 69 | |
| 70 | 70 | // send output | 
| 71 | 71 | echo $contents; | 
| 72 | 72 | |
| 73 | 73 | //And write to filesystem cache if not done yet | 
| 74 | - if($encoding != 'none' && $iscompressed == false) | |
| 74 | + if ($encoding != 'none' && $iscompressed == false) | |
| 75 | 75 |  	{ | 
| 76 | 76 | //Write the content we sent | 
| 77 | - file_put_contents(__FILE__.'.'.$encoding,$contents); | |
| 77 | + file_put_contents(__FILE__.'.'.$encoding, $contents); | |
| 78 | 78 | |
| 79 | 79 | //And write the new content | 
| 80 | 80 | $flag = ($encoding == 'gzip' ? FORCE_DEFLATE : FORCE_GZIP); | 
| 81 | 81 | $ext = ($encoding == 'gzip' ? 'deflate' : 'gzip'); | 
| 82 | - $contents = gzencode($code,9,$flag); | |
| 83 | - file_put_contents(__FILE__.'.'.$ext,$contents); | |
| 82 | + $contents = gzencode($code, 9, $flag); | |
| 83 | + file_put_contents(__FILE__.'.'.$ext, $contents); | |
| 84 | 84 | } | 
| 85 | 85 | } | 
| @@ -4,45 +4,45 @@ discard block | ||
| 4 | 4 | */ | 
| 5 | 5 | |
| 6 | 6 | $majorUp = false; | 
| 7 | -$autoptimize_major_version=substr($autoptimize_db_version,0,3); | |
| 7 | +$autoptimize_major_version = substr($autoptimize_db_version, 0, 3); | |
| 8 | 8 | |
| 9 | -switch($autoptimize_major_version) { | |
| 9 | +switch ($autoptimize_major_version) { | |
| 10 | 10 | case "1.6": | 
| 11 | 11 | // from back in the days when I did not yet consider multisite | 
| 12 | 12 | // if user was on version 1.6.x, force advanced options to be shown by default | 
| 13 | -        update_option('autoptimize_show_adv','1'); | |
| 13 | +        update_option('autoptimize_show_adv', '1'); | |
| 14 | 14 | |
| 15 | 15 | // and remove old options | 
| 16 | -        $to_delete_options=array("autoptimize_cdn_css","autoptimize_cdn_css_url","autoptimize_cdn_js","autoptimize_cdn_js_url","autoptimize_cdn_img","autoptimize_cdn_img_url","autoptimize_css_yui","autoptimize_js_yui"); | |
| 16 | +        $to_delete_options = array("autoptimize_cdn_css", "autoptimize_cdn_css_url", "autoptimize_cdn_js", "autoptimize_cdn_js_url", "autoptimize_cdn_img", "autoptimize_cdn_img_url", "autoptimize_css_yui", "autoptimize_js_yui"); | |
| 17 | 17 |          foreach ($to_delete_options as $del_opt) { | 
| 18 | - delete_option( $del_opt ); | |
| 18 | + delete_option($del_opt); | |
| 19 | 19 | } | 
| 20 | 20 | $majorUp = true; | 
| 21 | 21 | case "1.7": | 
| 22 | 22 | // force 3.8 dashicons in CSS exclude options when upgrading from 1.7 to 1.8 | 
| 23 | -        if ( !is_multisite() ) { | |
| 23 | +        if (!is_multisite()) { | |
| 24 | 24 |              $css_exclude = get_option('autoptimize_css_exclude'); | 
| 25 | 25 |              if (empty($css_exclude)) { | 
| 26 | 26 | $css_exclude = "admin-bar.min.css, dashicons.min.css"; | 
| 27 | -            } else if (strpos($css_exclude,"dashicons.min.css")===false) { | |
| 27 | +            } else if (strpos($css_exclude, "dashicons.min.css") === false) { | |
| 28 | 28 | $css_exclude .= ", dashicons.min.css"; | 
| 29 | 29 | } | 
| 30 | -            update_option('autoptimize_css_exclude',$css_exclude); | |
| 30 | +            update_option('autoptimize_css_exclude', $css_exclude); | |
| 31 | 31 |          } else { | 
| 32 | 32 | global $wpdb; | 
| 33 | - $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" ); | |
| 33 | +            $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs"); | |
| 34 | 34 | $original_blog_id = get_current_blog_id(); | 
| 35 | -            foreach ( $blog_ids as $blog_id ) { | |
| 36 | - switch_to_blog( $blog_id ); | |
| 35 | +            foreach ($blog_ids as $blog_id) { | |
| 36 | + switch_to_blog($blog_id); | |
| 37 | 37 |                  $css_exclude = get_option('autoptimize_css_exclude'); | 
| 38 | 38 |                  if (empty($css_exclude)) { | 
| 39 | 39 | $css_exclude = "admin-bar.min.css, dashicons.min.css"; | 
| 40 | -                } else if (strpos($css_exclude,"dashicons.min.css")===false) { | |
| 40 | +                } else if (strpos($css_exclude, "dashicons.min.css") === false) { | |
| 41 | 41 | $css_exclude .= ", dashicons.min.css"; | 
| 42 | 42 | } | 
| 43 | -                update_option('autoptimize_css_exclude',$css_exclude); | |
| 43 | +                update_option('autoptimize_css_exclude', $css_exclude); | |
| 44 | 44 | } | 
| 45 | - switch_to_blog( $original_blog_id ); | |
| 45 | + switch_to_blog($original_blog_id); | |
| 46 | 46 | } | 
| 47 | 47 | $majorUp = true; | 
| 48 | 48 | case "1.9": | 
| @@ -50,24 +50,24 @@ discard block | ||
| 50 | 50 | * 2.0 will not aggregate inline CSS/JS by default, but we want users | 
| 51 | 51 | * upgrading from 1.9 to keep their inline code aggregated by default. | 
| 52 | 52 | */ | 
| 53 | -        if ( !is_multisite() ) { | |
| 54 | -            update_option('autoptimize_css_include_inline','on'); | |
| 55 | -            update_option('autoptimize_js_include_inline','on'); | |
| 53 | +        if (!is_multisite()) { | |
| 54 | +            update_option('autoptimize_css_include_inline', 'on'); | |
| 55 | +            update_option('autoptimize_js_include_inline', 'on'); | |
| 56 | 56 |          } else { | 
| 57 | 57 | global $wpdb; | 
| 58 | - $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" ); | |
| 58 | +            $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs"); | |
| 59 | 59 | $original_blog_id = get_current_blog_id(); | 
| 60 | -            foreach ( $blog_ids as $blog_id ) { | |
| 61 | - switch_to_blog( $blog_id ); | |
| 62 | -                update_option('autoptimize_css_include_inline','on'); | |
| 63 | -                update_option('autoptimize_js_include_inline','on'); | |
| 60 | +            foreach ($blog_ids as $blog_id) { | |
| 61 | + switch_to_blog($blog_id); | |
| 62 | +                update_option('autoptimize_css_include_inline', 'on'); | |
| 63 | +                update_option('autoptimize_js_include_inline', 'on'); | |
| 64 | 64 | } | 
| 65 | - switch_to_blog( $original_blog_id ); | |
| 65 | + switch_to_blog($original_blog_id); | |
| 66 | 66 | } | 
| 67 | 67 | $majorUp = true; | 
| 68 | 68 | } | 
| 69 | 69 | |
| 70 | -if ( $majorUp === true ) { | |
| 70 | +if ($majorUp === true) { | |
| 71 | 71 | // clear cache and notify user to check result if major upgrade | 
| 72 | 72 | autoptimizeCache::clearall(); | 
| 73 | 73 |      add_action('admin_notices', 'autoptimize_update_config_notice'); | 
| @@ -3,52 +3,52 @@ | ||
| 3 | 3 | // hyper cache and gator cache hook into AO, so we don't need to :-) | 
| 4 | 4 | |
| 5 | 5 |  function autoptimize_flush_pagecache() { | 
| 6 | -    if(function_exists('wp_cache_clear_cache')) { | |
| 6 | +    if (function_exists('wp_cache_clear_cache')) { | |
| 7 | 7 |          if (is_multisite()) { | 
| 8 | 8 | $blog_id = get_current_blog_id(); | 
| 9 | 9 | wp_cache_clear_cache($blog_id); | 
| 10 | 10 |          } else { | 
| 11 | 11 | wp_cache_clear_cache(); | 
| 12 | 12 | } | 
| 13 | -    } else if ( has_action('cachify_flush_cache') ) { | |
| 13 | +    } else if (has_action('cachify_flush_cache')) { | |
| 14 | 14 |          do_action('cachify_flush_cache'); | 
| 15 | -    } else if ( function_exists('w3tc_pgcache_flush') ) { | |
| 15 | +    } else if (function_exists('w3tc_pgcache_flush')) { | |
| 16 | 16 | w3tc_pgcache_flush(); | 
| 17 | -    } else if ( function_exists('wp_fast_cache_bulk_delete_all') ) { | |
| 17 | +    } else if (function_exists('wp_fast_cache_bulk_delete_all')) { | |
| 18 | 18 | wp_fast_cache_bulk_delete_all(); // still to retest | 
| 19 | 19 |      } else if (class_exists("WpFastestCache")) { | 
| 20 | 20 | $wpfc = new WpFastestCache(); | 
| 21 | 21 | $wpfc -> deleteCache(); | 
| 22 | -    } else if ( class_exists("c_ws_plugin__qcache_purging_routines") ) { | |
| 22 | +    } else if (class_exists("c_ws_plugin__qcache_purging_routines")) { | |
| 23 | 23 | c_ws_plugin__qcache_purging_routines::purge_cache_dir(); // quick cache, still to retest | 
| 24 | -    } else if ( class_exists("zencache") ) { | |
| 24 | +    } else if (class_exists("zencache")) { | |
| 25 | 25 | zencache::clear(); | 
| 26 | -    } else if ( class_exists("comet_cache") ) { | |
| 26 | +    } else if (class_exists("comet_cache")) { | |
| 27 | 27 | comet_cache::clear(); | 
| 28 | -    } else if ( class_exists("WpeCommon") ) { | |
| 29 | -        if ( apply_filters('autoptimize_flush_wpengine_aggressive', false) ) { | |
| 30 | -            if ( method_exists( "WpeCommon", "purge_memcached" ) ) { | |
| 28 | +    } else if (class_exists("WpeCommon")) { | |
| 29 | +        if (apply_filters('autoptimize_flush_wpengine_aggressive', false)) { | |
| 30 | +            if (method_exists("WpeCommon", "purge_memcached")) { | |
| 31 | 31 | WpeCommon::purge_memcached(); | 
| 32 | 32 | } | 
| 33 | -            if ( method_exists( "WpeCommon", "clear_maxcdn_cache" ) ) {   | |
| 33 | +            if (method_exists("WpeCommon", "clear_maxcdn_cache")) {   | |
| 34 | 34 | WpeCommon::clear_maxcdn_cache(); | 
| 35 | 35 | } | 
| 36 | 36 | } | 
| 37 | -        if ( method_exists( "WpeCommon", "purge_varnish_cache" ) ) { | |
| 37 | +        if (method_exists("WpeCommon", "purge_varnish_cache")) { | |
| 38 | 38 | WpeCommon::purge_varnish_cache(); | 
| 39 | 39 | } | 
| 40 | -    } else if ( function_exists('sg_cachepress_purge_cache') ) { | |
| 40 | +    } else if (function_exists('sg_cachepress_purge_cache')) { | |
| 41 | 41 | sg_cachepress_purge_cache(); | 
| 42 | -    } else if(file_exists(WP_CONTENT_DIR.'/wp-cache-config.php') && function_exists('prune_super_cache')){ | |
| 42 | +    } else if (file_exists(WP_CONTENT_DIR.'/wp-cache-config.php') && function_exists('prune_super_cache')) { | |
| 43 | 43 | // fallback for WP-Super-Cache | 
| 44 | 44 | global $cache_path; | 
| 45 | 45 |          if (is_multisite()) { | 
| 46 | 46 | $blog_id = get_current_blog_id(); | 
| 47 | - prune_super_cache( get_supercache_dir( $blog_id ), true ); | |
| 48 | - prune_super_cache( $cache_path . 'blogs/', true ); | |
| 47 | + prune_super_cache(get_supercache_dir($blog_id), true); | |
| 48 | + prune_super_cache($cache_path.'blogs/', true); | |
| 49 | 49 |          } else { | 
| 50 | - prune_super_cache($cache_path.'supercache/',true); | |
| 51 | - prune_super_cache($cache_path,true); | |
| 50 | + prune_super_cache($cache_path.'supercache/', true); | |
| 51 | + prune_super_cache($cache_path, true); | |
| 52 | 52 | } | 
| 53 | 53 | } | 
| 54 | 54 | } | 
| 55 | 55 | \ No newline at end of file | 
| @@ -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 | /* | 
| 5 | 5 | * cachechecker code | 
| @@ -13,39 +13,39 @@ discard block | ||
| 13 | 13 | */ | 
| 14 | 14 | |
| 15 | 15 |  if (is_admin()) { | 
| 16 | -    add_action('plugins_loaded','ao_cachechecker_setup'); | |
| 16 | +    add_action('plugins_loaded', 'ao_cachechecker_setup'); | |
| 17 | 17 | } | 
| 18 | 18 | |
| 19 | 19 |  function ao_cachechecker_setup() { | 
| 20 | - $doCacheCheck = (bool) apply_filters( 'autoptimize_filter_cachecheck_do', true); | |
| 21 | - $cacheCheckSchedule = wp_get_schedule( 'ao_cachechecker' ); | |
| 22 | -    $AOCCfreq = apply_filters('autoptimize_filter_cachecheck_frequency','daily'); | |
| 23 | -    if (!in_array($AOCCfreq,array('hourly','daily','monthly'))) { | |
| 24 | - $AOCCfreq='daily'; | |
| 20 | +    $doCacheCheck = (bool) apply_filters('autoptimize_filter_cachecheck_do', true); | |
| 21 | +    $cacheCheckSchedule = wp_get_schedule('ao_cachechecker'); | |
| 22 | +    $AOCCfreq = apply_filters('autoptimize_filter_cachecheck_frequency', 'daily'); | |
| 23 | +    if (!in_array($AOCCfreq, array('hourly', 'daily', 'monthly'))) { | |
| 24 | + $AOCCfreq = 'daily'; | |
| 25 | 25 | } | 
| 26 | -    if ( $doCacheCheck && ( !$cacheCheckSchedule || $cacheCheckSchedule !== $AOCCfreq ) ) { | |
| 26 | +    if ($doCacheCheck && (!$cacheCheckSchedule || $cacheCheckSchedule !== $AOCCfreq)) { | |
| 27 | 27 | wp_schedule_event(time(), $AOCCfreq, 'ao_cachechecker'); | 
| 28 | -    } else if ( $cacheCheckSchedule && !$doCacheCheck ) { | |
| 29 | - wp_clear_scheduled_hook( 'ao_cachechecker' ); | |
| 28 | +    } else if ($cacheCheckSchedule && !$doCacheCheck) { | |
| 29 | +        wp_clear_scheduled_hook('ao_cachechecker'); | |
| 30 | 30 | } | 
| 31 | 31 | } | 
| 32 | 32 | |
| 33 | 33 |  add_action('ao_cachechecker', 'ao_cachechecker_cronjob'); | 
| 34 | 34 |  function ao_cachechecker_cronjob() { | 
| 35 | - $maxSize = (int) apply_filters( "autoptimize_filter_cachecheck_maxsize", 512000); | |
| 36 | - $doCacheCheck = (bool) apply_filters( "autoptimize_filter_cachecheck_do", true); | |
| 37 | - $statArr=autoptimizeCache::stats(); | |
| 38 | - $cacheSize=round($statArr[1]/1024); | |
| 39 | -    if (($cacheSize>$maxSize) && ($doCacheCheck)) { | |
| 40 | -        update_option("autoptimize_cachesize_notice",true); | |
| 41 | -        if (apply_filters('autoptimize_filter_cachecheck_sendmail',true)) { | |
| 42 | - $saniSiteUrl=esc_url(site_url()); | |
| 43 | -            $ao_mailto=apply_filters('autoptimize_filter_cachecheck_mailto',get_option('admin_email','')); | |
| 44 | -            $ao_mailsubject=__('Autoptimize cache size warning','autoptimize')." (".$saniSiteUrl.")"; | |
| 45 | -            $ao_mailbody=__('Autoptimize\'s cache size is getting big, consider purging the cache. Have a look at https://wordpress.org/plugins/autoptimize/faq/ to see how you can keep the cache size under control.', 'autoptimize')." (site: ".$saniSiteUrl.")"; | |
| 35 | +    $maxSize = (int) apply_filters("autoptimize_filter_cachecheck_maxsize", 512000); | |
| 36 | +    $doCacheCheck = (bool) apply_filters("autoptimize_filter_cachecheck_do", true); | |
| 37 | + $statArr = autoptimizeCache::stats(); | |
| 38 | + $cacheSize = round($statArr[1]/1024); | |
| 39 | +    if (($cacheSize > $maxSize) && ($doCacheCheck)) { | |
| 40 | +        update_option("autoptimize_cachesize_notice", true); | |
| 41 | +        if (apply_filters('autoptimize_filter_cachecheck_sendmail', true)) { | |
| 42 | + $saniSiteUrl = esc_url(site_url()); | |
| 43 | +            $ao_mailto = apply_filters('autoptimize_filter_cachecheck_mailto', get_option('admin_email', '')); | |
| 44 | +            $ao_mailsubject = __('Autoptimize cache size warning', 'autoptimize')." (".$saniSiteUrl.")"; | |
| 45 | +            $ao_mailbody = __('Autoptimize\'s cache size is getting big, consider purging the cache. Have a look at https://wordpress.org/plugins/autoptimize/faq/ to see how you can keep the cache size under control.', 'autoptimize')." (site: ".$saniSiteUrl.")"; | |
| 46 | 46 | |
| 47 | 47 |              if (!empty($ao_mailto)) { | 
| 48 | - $ao_mailresult=wp_mail($ao_mailto,$ao_mailsubject,$ao_mailbody); | |
| 48 | + $ao_mailresult = wp_mail($ao_mailto, $ao_mailsubject, $ao_mailbody); | |
| 49 | 49 |                  if (!$ao_mailresult) { | 
| 50 | 50 |                      error_log("Autoptimize could not send cache size warning mail."); | 
| 51 | 51 | } | 
| @@ -56,10 +56,10 @@ discard block | ||
| 56 | 56 | |
| 57 | 57 |  add_action('admin_notices', 'autoptimize_cachechecker_notice'); | 
| 58 | 58 |  function autoptimize_cachechecker_notice() { | 
| 59 | -    if ((bool) get_option("autoptimize_cachesize_notice",false)) { | |
| 59 | +    if ((bool) get_option("autoptimize_cachesize_notice", false)) { | |
| 60 | 60 | echo '<div class="notice notice-warning"><p>'; | 
| 61 | -        _e('<strong>Autoptimize\'s cache size is getting big</strong>, consider purging the cache. Have a look at <a href="https://wordpress.org/plugins/autoptimize/faq/" target="_blank">the Autoptimize FAQ</a> to see how you can keep the cache size under control.', 'autoptimize' ); | |
| 61 | +        _e('<strong>Autoptimize\'s cache size is getting big</strong>, consider purging the cache. Have a look at <a href="https://wordpress.org/plugins/autoptimize/faq/" target="_blank">the Autoptimize FAQ</a> to see how you can keep the cache size under control.', 'autoptimize'); | |
| 62 | 62 | echo '</p></div>'; | 
| 63 | -        update_option("autoptimize_cachesize_notice",false); | |
| 63 | +        update_option("autoptimize_cachesize_notice", false); | |
| 64 | 64 | } | 
| 65 | 65 | } | 
| @@ -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,21 +98,21 @@ 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 | return true; | 
| 108 | 108 | } | 
| 109 | 109 | |
| 110 | -    static function stats()    { | |
| 111 | -        $AOstats=get_transient("autoptimize_stats"); | |
| 110 | +    static function stats() { | |
| 111 | +        $AOstats = get_transient("autoptimize_stats"); | |
| 112 | 112 | |
| 113 | 113 |          if (empty($AOstats)) { | 
| 114 | 114 | // Cache not available :( | 
| 115 | -            if(!autoptimizeCache::cacheavail()) { | |
| 115 | +            if (!autoptimizeCache::cacheavail()) { | |
| 116 | 116 | return 0; | 
| 117 | 117 | } | 
| 118 | 118 | |
| @@ -121,28 +121,28 @@ discard block | ||
| 121 | 121 | $size = 0; | 
| 122 | 122 | |
| 123 | 123 | // scan the cachedirs | 
| 124 | -            foreach (array("","js","css") as $scandirName) { | |
| 124 | +            foreach (array("", "js", "css") as $scandirName) { | |
| 125 | 125 | $scan[$scandirName] = scandir(AUTOPTIMIZE_CACHE_DIR.$scandirName); | 
| 126 | 126 | } | 
| 127 | 127 | |
| 128 | 128 |              foreach ($scan as $scandirName=>$scanneddir) { | 
| 129 | - $thisAoCacheDir=rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName,"/")."/"; | |
| 130 | -                foreach($scanneddir as $file) { | |
| 131 | -                    if(!in_array($file,array('.','..')) && strpos($file,AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) { | |
| 132 | -                        if(is_file($thisAoCacheDir.$file)) { | |
| 133 | -                            if(AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file,'.js') !== false || strpos($file,'.css') !== false || strpos($file,'.img') !== false || strpos($file,'.txt') !== false )) { | |
| 129 | + $thisAoCacheDir = rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName, "/")."/"; | |
| 130 | +                foreach ($scanneddir as $file) { | |
| 131 | +                    if (!in_array($file, array('.', '..')) && strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) { | |
| 132 | +                        if (is_file($thisAoCacheDir.$file)) { | |
| 133 | +                            if (AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file, '.js') !== false || strpos($file, '.css') !== false || strpos($file, '.img') !== false || strpos($file, '.txt') !== false)) { | |
| 134 | 134 | $count++; | 
| 135 | -                            } elseif(!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file,'.none') !== false) { | |
| 135 | +                            } elseif (!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file, '.none') !== false) { | |
| 136 | 136 | $count++; | 
| 137 | 137 | } | 
| 138 | - $size+=filesize($thisAoCacheDir.$file); | |
| 138 | + $size += filesize($thisAoCacheDir.$file); | |
| 139 | 139 | } | 
| 140 | 140 | } | 
| 141 | 141 | } | 
| 142 | 142 | } | 
| 143 | - $AOstats=array($count,$size,time()); | |
| 144 | -            if ($count>100) { | |
| 145 | -                set_transient("autoptimize_stats",$AOstats,HOUR_IN_SECONDS); | |
| 143 | + $AOstats = array($count, $size, time()); | |
| 144 | +            if ($count > 100) { | |
| 145 | +                set_transient("autoptimize_stats", $AOstats, HOUR_IN_SECONDS); | |
| 146 | 146 | } | 
| 147 | 147 | } | 
| 148 | 148 | // print the number of instances | 
| @@ -150,36 +150,36 @@ discard block | ||
| 150 | 150 | } | 
| 151 | 151 | |
| 152 | 152 |      static function cacheavail() { | 
| 153 | -        if(!defined('AUTOPTIMIZE_CACHE_DIR')) { | |
| 153 | +        if (!defined('AUTOPTIMIZE_CACHE_DIR')) { | |
| 154 | 154 | // We didn't set a cache | 
| 155 | 155 | return false; | 
| 156 | 156 | } | 
| 157 | 157 | |
| 158 | -        foreach (array("","js","css") as $checkDir) { | |
| 159 | -            if(!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) { | |
| 158 | +        foreach (array("", "js", "css") as $checkDir) { | |
| 159 | +            if (!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) { | |
| 160 | 160 | return false; | 
| 161 | 161 | } | 
| 162 | 162 | } | 
| 163 | 163 | |
| 164 | 164 | /** write index.html here to avoid prying eyes */ | 
| 165 | - $indexFile=AUTOPTIMIZE_CACHE_DIR.'/index.html'; | |
| 166 | -        if(!is_file($indexFile)) { | |
| 167 | - @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>'); | |
| 165 | + $indexFile = AUTOPTIMIZE_CACHE_DIR.'/index.html'; | |
| 166 | +        if (!is_file($indexFile)) { | |
| 167 | + @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>'); | |
| 168 | 168 | } | 
| 169 | 169 | |
| 170 | 170 | /** write .htaccess here to overrule wp_super_cache */ | 
| 171 | - $htAccess=AUTOPTIMIZE_CACHE_DIR.'/.htaccess'; | |
| 172 | -        if(!is_file($htAccess)) { | |
| 171 | + $htAccess = AUTOPTIMIZE_CACHE_DIR.'/.htaccess'; | |
| 172 | +        if (!is_file($htAccess)) { | |
| 173 | 173 | /** | 
| 174 | 174 | * create wp-content/AO_htaccess_tmpl with | 
| 175 | 175 | * whatever htaccess rules you might need | 
| 176 | 176 | * if you want to override default AO htaccess | 
| 177 | 177 | */ | 
| 178 | - $htaccess_tmpl=WP_CONTENT_DIR."/AO_htaccess_tmpl"; | |
| 178 | + $htaccess_tmpl = WP_CONTENT_DIR."/AO_htaccess_tmpl"; | |
| 179 | 179 |              if (is_file($htaccess_tmpl)) {  | 
| 180 | - $htAccessContent=file_get_contents($htaccess_tmpl); | |
| 180 | + $htAccessContent = file_get_contents($htaccess_tmpl); | |
| 181 | 181 |              } else if (is_multisite() || AUTOPTIMIZE_CACHE_NOGZIP == false) { | 
| 182 | - $htAccessContent='<IfModule mod_headers.c> | |
| 182 | + $htAccessContent = '<IfModule mod_headers.c> | |
| 183 | 183 | Header set Vary "Accept-Encoding" | 
| 184 | 184 | Header set Cache-Control "max-age=10672000, must-revalidate" | 
| 185 | 185 | </IfModule> | 
| @@ -206,7 +206,7 @@ discard block | ||
| 206 | 206 | </Files> | 
| 207 | 207 | </IfModule>'; | 
| 208 | 208 |              } else { | 
| 209 | - $htAccessContent='<IfModule mod_headers.c> | |
| 209 | + $htAccessContent = '<IfModule mod_headers.c> | |
| 210 | 210 | Header set Vary "Accept-Encoding" | 
| 211 | 211 | Header set Cache-Control "max-age=10672000, must-revalidate" | 
| 212 | 212 | </IfModule> | 
| @@ -233,7 +233,7 @@ discard block | ||
| 233 | 233 | </Files> | 
| 234 | 234 | </IfModule>'; | 
| 235 | 235 | } | 
| 236 | - @file_put_contents($htAccess,$htAccessContent); | |
| 236 | + @file_put_contents($htAccess, $htAccessContent); | |
| 237 | 237 | } | 
| 238 | 238 | |
| 239 | 239 | // All OK | 
| @@ -242,22 +242,22 @@ discard block | ||
| 242 | 242 | |
| 243 | 243 |      static function checkCacheDir($dir) { | 
| 244 | 244 | // Check and create if not exists | 
| 245 | -        if(!file_exists($dir))    { | |
| 246 | - @mkdir($dir,0775,true); | |
| 247 | -            if(!file_exists($dir))    { | |
| 245 | +        if (!file_exists($dir)) { | |
| 246 | + @mkdir($dir, 0775, true); | |
| 247 | +            if (!file_exists($dir)) { | |
| 248 | 248 | return false; | 
| 249 | 249 | } | 
| 250 | 250 | } | 
| 251 | 251 | |
| 252 | 252 | // check if we can now write | 
| 253 | -        if(!is_writable($dir))    { | |
| 253 | +        if (!is_writable($dir)) { | |
| 254 | 254 | return false; | 
| 255 | 255 | } | 
| 256 | 256 | |
| 257 | 257 | // and write index.html here to avoid prying eyes | 
| 258 | - $indexFile=$dir.'/index.html'; | |
| 259 | -        if(!is_file($indexFile)) { | |
| 260 | - @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>'); | |
| 258 | + $indexFile = $dir.'/index.html'; | |
| 259 | +        if (!is_file($indexFile)) { | |
| 260 | + @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>'); | |
| 261 | 261 | } | 
| 262 | 262 | |
| 263 | 263 | return true; | 
| @@ -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,9 +60,9 @@ 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 | |
| @@ -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}*/"; |