Completed
Push — master ( 888448...89a848 )
by frank
07:21 queued 03:15
created
php/persist-admin-notices-dismissal/persist-admin-notices-dismissal.php 1 patch
Spacing   +30 added lines, -30 removed lines patch added patch discarded remove patch
@@ -28,11 +28,11 @@  discard block
 block discarded – undo
28 28
 /**
29 29
  * Exit if called directly.
30 30
  */
31
-if ( ! defined( 'ABSPATH' ) ) {
31
+if (!defined('ABSPATH')) {
32 32
 	die;
33 33
 }
34 34
 
35
-if ( ! class_exists( 'PAnD' ) ) {
35
+if (!class_exists('PAnD')) {
36 36
 
37 37
 	/**
38 38
 	 * Class PAnD
@@ -43,8 +43,8 @@  discard block
 block discarded – undo
43 43
 		 * Init hooks.
44 44
 		 */
45 45
 		public static function init() {
46
-			add_action( 'admin_enqueue_scripts', array( __CLASS__, 'load_script' ) );
47
-			add_action( 'wp_ajax_dismiss_admin_notice', array( __CLASS__, 'dismiss_admin_notice' ) );
46
+			add_action('admin_enqueue_scripts', array(__CLASS__, 'load_script'));
47
+			add_action('wp_ajax_dismiss_admin_notice', array(__CLASS__, 'dismiss_admin_notice'));
48 48
 		}
49 49
 
50 50
 		/**
@@ -52,14 +52,14 @@  discard block
 block discarded – undo
52 52
 		 */
53 53
 		public static function load_script() {
54 54
 
55
-			if ( is_customize_preview() ) {
55
+			if (is_customize_preview()) {
56 56
 				return;
57 57
 			}
58 58
 
59 59
 			wp_enqueue_script(
60 60
 				'dismissible-notices',
61
-				plugins_url( 'dismiss-notice.js', __FILE__ ),
62
-				array( 'jquery', 'common' ),
61
+				plugins_url('dismiss-notice.js', __FILE__),
62
+				array('jquery', 'common'),
63 63
 				false,
64 64
 				true
65 65
 			);
@@ -68,7 +68,7 @@  discard block
 block discarded – undo
68 68
 				'dismissible-notices',
69 69
 				'dismissible_notice',
70 70
 				array(
71
-					'nonce' => wp_create_nonce( 'dismissible-notice' ),
71
+					'nonce' => wp_create_nonce('dismissible-notice'),
72 72
 				)
73 73
 			);
74 74
 		}
@@ -78,17 +78,17 @@  discard block
 block discarded – undo
78 78
 		 * Uses check_ajax_referer to verify nonce.
79 79
 		 */
80 80
 		public static function dismiss_admin_notice() {
81
-			$option_name        = sanitize_text_field( $_POST['option_name'] );
82
-			$dismissible_length = sanitize_text_field( $_POST['dismissible_length'] );
81
+			$option_name        = sanitize_text_field($_POST['option_name']);
82
+			$dismissible_length = sanitize_text_field($_POST['dismissible_length']);
83 83
 
84
-			if ( 'forever' != $dismissible_length ) {
84
+			if ('forever' != $dismissible_length) {
85 85
 				// If $dismissible_length is not an integer default to 1
86
-				$dismissible_length = ( 0 == absint( $dismissible_length ) ) ? 1 : $dismissible_length;
87
-				$dismissible_length = strtotime( absint( $dismissible_length ) . ' days' );
86
+				$dismissible_length = (0 == absint($dismissible_length)) ? 1 : $dismissible_length;
87
+				$dismissible_length = strtotime(absint($dismissible_length).' days');
88 88
 			}
89 89
 
90
-			check_ajax_referer( 'dismissible-notice', 'nonce' );
91
-			self::set_admin_notice_cache( $option_name, $dismissible_length );
90
+			check_ajax_referer('dismissible-notice', 'nonce');
91
+			self::set_admin_notice_cache($option_name, $dismissible_length);
92 92
 			wp_die();
93 93
 		}
94 94
 
@@ -99,14 +99,14 @@  discard block
 block discarded – undo
99 99
 		 *
100 100
 		 * @return bool
101 101
 		 */
102
-		public static function is_admin_notice_active( $arg ) {
103
-			$array       = explode( '-', $arg );
104
-			$length      = array_pop( $array );
105
-			$option_name = implode( '-', $array );
106
-			$db_record   = self::get_admin_notice_cache( $option_name );
107
-			if ( 'forever' == $db_record ) {
102
+		public static function is_admin_notice_active($arg) {
103
+			$array       = explode('-', $arg);
104
+			$length      = array_pop($array);
105
+			$option_name = implode('-', $array);
106
+			$db_record   = self::get_admin_notice_cache($option_name);
107
+			if ('forever' == $db_record) {
108 108
 				return false;
109
-			} elseif ( absint( $db_record ) >= time() ) {
109
+			} elseif (absint($db_record) >= time()) {
110 110
 				return false;
111 111
 			} else {
112 112
 				return true;
@@ -122,15 +122,15 @@  discard block
 block discarded – undo
122 122
 		 *
123 123
 		 * @return array|bool The timeout. False if expired.
124 124
 		 */
125
-		public static function get_admin_notice_cache( $id = false ) {
126
-			if ( ! $id ) {
125
+		public static function get_admin_notice_cache($id = false) {
126
+			if (!$id) {
127 127
 				return false;
128 128
 			}
129
-			$cache_key = 'pand-' . md5( $id );
130
-			$timeout   = get_site_option( $cache_key );
129
+			$cache_key = 'pand-'.md5($id);
130
+			$timeout   = get_site_option($cache_key);
131 131
 			$timeout   = 'forever' === $timeout ? time() + 60 : $timeout;
132 132
 
133
-			if ( empty( $timeout ) || time() > $timeout ) {
133
+			if (empty($timeout) || time() > $timeout) {
134 134
 				return false;
135 135
 			}
136 136
 
@@ -147,9 +147,9 @@  discard block
 block discarded – undo
147 147
 		 *
148 148
 		 * @return bool
149 149
 		 */
150
-		public static function set_admin_notice_cache( $id, $timeout ) {
151
-			$cache_key = 'pand-' . md5( $id );
152
-			update_site_option( $cache_key, $timeout );
150
+		public static function set_admin_notice_cache($id, $timeout) {
151
+			$cache_key = 'pand-'.md5($id);
152
+			update_site_option($cache_key, $timeout);
153 153
 
154 154
 			return true;
155 155
 		}
Please login to merge, or discard this patch.
classes/external/php/jsmin.php 1 patch
Spacing   +13 added lines, -13 removed lines patch added patch discarded remove patch
@@ -70,7 +70,7 @@  discard block
 block discarded – undo
70 70
     protected $inputLength = 0;
71 71
     protected $lookAhead   = null;
72 72
     protected $output      = '';
73
-    protected $lastByteOut  = '';
73
+    protected $lastByteOut = '';
74 74
     protected $keptComment = '';
75 75
 
76 76
     /**
@@ -106,7 +106,7 @@  discard block
 block discarded – undo
106 106
         }
107 107
 
108 108
         $mbIntEnc = null;
109
-        if (function_exists('mb_strlen') && ((int)ini_get('mbstring.func_overload') & 2)) {
109
+        if (function_exists('mb_strlen') && ((int) ini_get('mbstring.func_overload') & 2)) {
110 110
             $mbIntEnc = mb_internal_encoding();
111 111
             mb_internal_encoding('8bit');
112 112
         }
@@ -128,7 +128,7 @@  discard block
 block discarded – undo
128 128
                         && ($this->b === $this->lastByteOut)) {
129 129
                     // Don't delete this space. If we do, the addition/subtraction
130 130
                     // could be parsed as a post-increment
131
-                } elseif (! $this->isAlphaNum($this->b)) {
131
+                } elseif (!$this->isAlphaNum($this->b)) {
132 132
                     $command = self::ACTION_DELETE_A;
133 133
                 }
134 134
             } elseif ($this->a === "\n") {
@@ -139,10 +139,10 @@  discard block
 block discarded – undo
139 139
                     // otherwise mb_strpos will give WARNING
140 140
                 } elseif ($this->b === null
141 141
                           || (false === strpos('{[(+-!~', $this->b)
142
-                              && ! $this->isAlphaNum($this->b))) {
142
+                              && !$this->isAlphaNum($this->b))) {
143 143
                     $command = self::ACTION_DELETE_A;
144 144
                 }
145
-            } elseif (! $this->isAlphaNum($this->a)) {
145
+            } elseif (!$this->isAlphaNum($this->a)) {
146 146
                 if ($this->b === ' '
147 147
                     || ($this->b === "\n"
148 148
                         && (false === strpos('}])+-"\'', $this->a)))) {
@@ -199,7 +199,7 @@  discard block
 block discarded – undo
199 199
                 if ($this->a === "'" || $this->a === '"' || $this->a === '`') { // string/template literal
200 200
                     $delimiter = $this->a;
201 201
                     $str = $this->a; // in case needed for exception
202
-                    for(;;) {
202
+                    for (;;) {
203 203
                         $this->output .= $this->a;
204 204
                         $this->lastByteOut = $this->a;
205 205
 
@@ -229,13 +229,13 @@  discard block
 block discarded – undo
229 229
             case self::ACTION_DELETE_A_B: // 3
230 230
                 $this->b = $this->next();
231 231
                 if ($this->b === '/' && $this->isRegexpLiteral()) {
232
-                    $this->output .= $this->a . $this->b;
232
+                    $this->output .= $this->a.$this->b;
233 233
                     $pattern = '/'; // keep entire pattern in case we need to report it in the exception
234
-                    for(;;) {
234
+                    for (;;) {
235 235
                         $this->a = $this->get();
236 236
                         $pattern .= $this->a;
237 237
                         if ($this->a === '[') {
238
-                            for(;;) {
238
+                            for (;;) {
239 239
                                 $this->output .= $this->a;
240 240
                                 $this->a = $this->get();
241 241
                                 $pattern .= $this->a;
@@ -250,7 +250,7 @@  discard block
 block discarded – undo
250 250
                                 if ($this->isEOF($this->a)) {
251 251
                                     throw new JSMin_UnterminatedRegExpException(
252 252
                                         "JSMin: Unterminated set in RegExp at byte "
253
-                                            . $this->inputIndex .": {$pattern}");
253
+                                            . $this->inputIndex.": {$pattern}");
254 254
                                 }
255 255
                             }
256 256
                         }
@@ -295,7 +295,7 @@  discard block
 block discarded – undo
295 295
 
296 296
         // if the "/" follows a keyword, it must be a regexp, otherwise it's best to assume division
297 297
 
298
-        $subject = $this->output . trim($this->a);
298
+        $subject = $this->output.trim($this->a);
299 299
         if (!preg_match('/(?:case|else|in|return|typeof)$/', $subject, $m)) {
300 300
             // not a keyword
301 301
             return false;
@@ -406,7 +406,7 @@  discard block
 block discarded – undo
406 406
     {
407 407
         $this->get();
408 408
         $comment = '';
409
-        for(;;) {
409
+        for (;;) {
410 410
             $get = $this->get();
411 411
             if ($get === '*') {
412 412
                 if ($this->peek() === '/') { // end of comment reached
@@ -417,7 +417,7 @@  discard block
 block discarded – undo
417 417
                             // don't prepend a newline if two comments right after one another
418 418
                             $this->keptComment = "\n";
419 419
                         }
420
-                        $this->keptComment .= "/*!" . substr($comment, 1) . "*/\n";
420
+                        $this->keptComment .= "/*!".substr($comment, 1)."*/\n";
421 421
                     } else if (preg_match('/^@(?:cc_on|if|elif|else|end)\\b/', $comment)) {
422 422
                         // IE conditional
423 423
                         $this->keptComment .= "/*{$comment}*/";
Please login to merge, or discard this patch.
tests/test-ao.php 1 patch
Spacing   +378 added lines, -378 removed lines patch added patch discarded remove patch
@@ -10,17 +10,17 @@  discard block
 block discarded – undo
10 10
     protected $ao;
11 11
 
12 12
     protected static $flexible_url_parts_js = [
13
-        'default'          => 'wp-content/cache/autoptimize/js/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
14
-        'custom'           => 'wp-content/c/ao/js/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
15
-        'multisite'        => 'wp-content/cache/autoptimize/1/js/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
16
-        'multisite_custom' => 'wp-content/c/ao/1/js/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
13
+        'default'          => 'wp-content/cache/autoptimize/js/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
14
+        'custom'           => 'wp-content/c/ao/js/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
15
+        'multisite'        => 'wp-content/cache/autoptimize/1/js/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
16
+        'multisite_custom' => 'wp-content/c/ao/1/js/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
17 17
     ];
18 18
 
19 19
     protected static $flexible_url_parts_css = [
20
-        'default'          => 'wp-content/cache/autoptimize/css/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
21
-        'custom'           => 'wp-content/c/ao/css/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
22
-        'multisite'        => 'wp-content/cache/autoptimize/1/css/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
23
-        'multisite_custom' => 'wp-content/c/ao/1/css/' . AUTOPTIMIZE_CACHEFILE_PREFIX,
20
+        'default'          => 'wp-content/cache/autoptimize/css/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
21
+        'custom'           => 'wp-content/c/ao/css/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
22
+        'multisite'        => 'wp-content/cache/autoptimize/1/css/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
23
+        'multisite_custom' => 'wp-content/c/ao/1/css/'.AUTOPTIMIZE_CACHEFILE_PREFIX,
24 24
     ];
25 25
 
26 26
     protected function getAoStylesDefaultOptions()
@@ -28,16 +28,16 @@  discard block
 block discarded – undo
28 28
         $conf = autoptimizeConfig::instance();
29 29
 
30 30
         return [
31
-            'aggregate'      => $conf->get( 'autoptimize_css_aggregate' ),
32
-            'justhead'       => $conf->get( 'autoptimize_css_justhead' ),
33
-            'datauris'       => $conf->get( 'autoptimize_css_datauris' ),
34
-            'defer'          => $conf->get( 'autoptimize_css_defer' ),
35
-            'defer_inline'   => $conf->get( 'autoptimize_css_defer_inline' ),
36
-            'inline'         => $conf->get( 'autoptimize_css_inline' ),
37
-            'css_exclude'    => $conf->get( 'autoptimize_css_exclude' ),
38
-            'cdn_url'        => $conf->get( 'autoptimize_cdn_url' ),
39
-            'include_inline' => $conf->get( 'autoptimize_css_include_inline' ),
40
-            'nogooglefont'   => $conf->get( 'autoptimize_css_nogooglefont' ),
31
+            'aggregate'      => $conf->get('autoptimize_css_aggregate'),
32
+            'justhead'       => $conf->get('autoptimize_css_justhead'),
33
+            'datauris'       => $conf->get('autoptimize_css_datauris'),
34
+            'defer'          => $conf->get('autoptimize_css_defer'),
35
+            'defer_inline'   => $conf->get('autoptimize_css_defer_inline'),
36
+            'inline'         => $conf->get('autoptimize_css_inline'),
37
+            'css_exclude'    => $conf->get('autoptimize_css_exclude'),
38
+            'cdn_url'        => $conf->get('autoptimize_cdn_url'),
39
+            'include_inline' => $conf->get('autoptimize_css_include_inline'),
40
+            'nogooglefont'   => $conf->get('autoptimize_css_nogooglefont'),
41 41
         ];
42 42
     }
43 43
 
@@ -46,13 +46,13 @@  discard block
 block discarded – undo
46 46
         $conf = autoptimizeConfig::instance();
47 47
 
48 48
         return [
49
-            'aggregate'      => $conf->get( 'autoptimize_js_aggregate' ),
50
-            'justhead'       => $conf->get( 'autoptimize_js_justhead' ),
51
-            'forcehead'      => $conf->get( 'autoptimize_js_forcehead' ),
52
-            'trycatch'       => $conf->get( 'autoptimize_js_trycatch' ),
53
-            'js_exclude'     => $conf->get( 'autoptimize_js_exclude' ),
54
-            'cdn_url'        => $conf->get( 'autoptimize_cdn_url' ),
55
-            'include_inline' => $conf->get( 'autoptimize_js_include_inline' ),
49
+            'aggregate'      => $conf->get('autoptimize_js_aggregate'),
50
+            'justhead'       => $conf->get('autoptimize_js_justhead'),
51
+            'forcehead'      => $conf->get('autoptimize_js_forcehead'),
52
+            'trycatch'       => $conf->get('autoptimize_js_trycatch'),
53
+            'js_exclude'     => $conf->get('autoptimize_js_exclude'),
54
+            'cdn_url'        => $conf->get('autoptimize_cdn_url'),
55
+            'include_inline' => $conf->get('autoptimize_js_include_inline'),
56 56
         ];
57 57
     }
58 58
 
@@ -62,34 +62,34 @@  discard block
 block discarded – undo
62 62
     protected function get_urls()
63 63
     {
64 64
         static $site_url = null;
65
-        if ( null === $site_url ) {
65
+        if (null === $site_url) {
66 66
             $site_url = site_url();
67 67
         }
68 68
 
69 69
         static $cdn_url = null;
70
-        if ( null === $cdn_url ) {
71
-            $cdn_url = get_option( 'autoptimize_cdn_url' );
70
+        if (null === $cdn_url) {
71
+            $cdn_url = get_option('autoptimize_cdn_url');
72 72
         }
73 73
 
74 74
         static $imgopt_host = null;
75
-        if ( null === $imgopt_host ) {
76
-            $imgopt_host = rtrim( autoptimizeExtra::get_imgopt_host_wrapper(), '/' );
75
+        if (null === $imgopt_host) {
76
+            $imgopt_host = rtrim(autoptimizeExtra::get_imgopt_host_wrapper(), '/');
77 77
         }
78 78
 
79 79
         static $urls = [];
80 80
 
81
-        if ( empty( $urls ) ) {
81
+        if (empty($urls)) {
82 82
             $parts = autoptimizeUtils::get_ao_wp_site_url_parts();
83 83
             $urls  = [
84 84
                 'siteurl'    => $site_url,
85
-                'prsiteurl'  => '//' . str_replace( array( 'http://', 'https://' ), '', $site_url ),
86
-                'wwwsiteurl' => $parts['scheme'] . '://www.' . str_replace( 'www.', '', $parts['host'] ),
85
+                'prsiteurl'  => '//'.str_replace(array('http://', 'https://'), '', $site_url),
86
+                'wwwsiteurl' => $parts['scheme'].'://www.'.str_replace('www.', '', $parts['host']),
87 87
                 'cdnurl'     => $cdn_url,
88 88
                 'imgopthost' => $imgopt_host,
89 89
                 'subfolder'  => '',
90 90
             ];
91 91
 
92
-            if ( AO_TEST_SUBFOLDER_INSTALL ) {
92
+            if (AO_TEST_SUBFOLDER_INSTALL) {
93 93
                 $urls['subfolder'] = 'wordpress/';
94 94
             }
95 95
         }
@@ -102,7 +102,7 @@  discard block
 block discarded – undo
102 102
      */
103 103
     public function setUp()
104 104
     {
105
-        $this->ao = new autoptimizeMain( AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE );
105
+        $this->ao = new autoptimizeMain(AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE);
106 106
 
107 107
         parent::setUp();
108 108
     }
@@ -121,8 +121,8 @@  discard block
 block discarded – undo
121 121
             'autoptimize_filter_css_inlinesize',
122 122
             'autoptimize_filter_css_fonts_cdn',
123 123
         );
124
-        foreach ( $filter_tags as $filter_tag ) {
125
-            remove_all_filters( $filter_tag );
124
+        foreach ($filter_tags as $filter_tag) {
125
+            remove_all_filters($filter_tag);
126 126
         }
127 127
 
128 128
         parent::tearDown();
@@ -246,15 +246,15 @@  discard block
 block discarded – undo
246 246
     protected function get_test_markup_output()
247 247
     {
248 248
         $key = 'default';
249
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
249
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
250 250
             $key = 'custom';
251 251
         }
252 252
 
253
-        $csspart = self::$flexible_url_parts_css[ $key ];
254
-        $jspart  = self::$flexible_url_parts_js[ $key ];
253
+        $csspart = self::$flexible_url_parts_css[$key];
254
+        $jspart  = self::$flexible_url_parts_js[$key];
255 255
 
256 256
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
257
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
257
+        if (AO_TEST_SUBFOLDER_INSTALL) {
258 258
             $csshash = '56398de576d59887e88e3011715250e0';
259 259
         }
260 260
 
@@ -313,15 +313,15 @@  discard block
 block discarded – undo
313 313
     protected function get_test_markup_output_ms()
314 314
     {
315 315
         $key = 'multisite';
316
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
316
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
317 317
             $key = 'multisite_custom';
318 318
         }
319 319
 
320
-        $csspart = self::$flexible_url_parts_css[ $key ];
321
-        $jspart  = self::$flexible_url_parts_js[ $key ];
320
+        $csspart = self::$flexible_url_parts_css[$key];
321
+        $jspart  = self::$flexible_url_parts_js[$key];
322 322
 
323 323
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
324
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
324
+        if (AO_TEST_SUBFOLDER_INSTALL) {
325 325
             $csshash = '56398de576d59887e88e3011715250e0';
326 326
         }
327 327
 
@@ -380,15 +380,15 @@  discard block
 block discarded – undo
380 380
     protected function get_test_markup_output_inline_defer()
381 381
     {
382 382
         $key = 'default';
383
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
383
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
384 384
             $key = 'custom';
385 385
         }
386 386
 
387
-        $csspart = self::$flexible_url_parts_css[ $key ];
388
-        $jspart  = self::$flexible_url_parts_js[ $key ];
387
+        $csspart = self::$flexible_url_parts_css[$key];
388
+        $jspart  = self::$flexible_url_parts_js[$key];
389 389
 
390 390
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
391
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
391
+        if (AO_TEST_SUBFOLDER_INSTALL) {
392 392
             $csshash = '56398de576d59887e88e3011715250e0';
393 393
         }
394 394
 
@@ -447,15 +447,15 @@  discard block
 block discarded – undo
447 447
     protected function get_test_markup_output_inline_defer_ms()
448 448
     {
449 449
         $key = 'multisite';
450
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
450
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
451 451
             $key = 'multisite_custom';
452 452
         }
453 453
 
454
-        $csspart = self::$flexible_url_parts_css[ $key ];
455
-        $jspart  = self::$flexible_url_parts_js[ $key ];
454
+        $csspart = self::$flexible_url_parts_css[$key];
455
+        $jspart  = self::$flexible_url_parts_js[$key];
456 456
 
457 457
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
458
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
458
+        if (AO_TEST_SUBFOLDER_INSTALL) {
459 459
             $csshash = '56398de576d59887e88e3011715250e0';
460 460
         }
461 461
 
@@ -514,11 +514,11 @@  discard block
 block discarded – undo
514 514
     /**
515 515
      * @dataProvider provider_test_rewrite_markup_with_cdn
516 516
      */
517
-    function test_rewrite_markup_with_cdn( $input, $expected )
517
+    function test_rewrite_markup_with_cdn($input, $expected)
518 518
     {
519
-        $actual = $this->ao->end_buffering( $input );
519
+        $actual = $this->ao->end_buffering($input);
520 520
 
521
-        $this->assertEquals( $expected, $actual );
521
+        $this->assertEquals($expected, $actual);
522 522
     }
523 523
 
524 524
     public function provider_test_rewrite_markup_with_cdn()
@@ -530,7 +530,7 @@  discard block
 block discarded – undo
530 530
                 $this->get_test_markup(),
531 531
                 // Expected output.
532 532
                 // TODO/FIXME: This seemed like the fastest way to get MS crude test to pass...
533
-                ( is_multisite() ? $this->get_test_markup_output_ms() : $this->get_test_markup_output() ),
533
+                (is_multisite() ? $this->get_test_markup_output_ms() : $this->get_test_markup_output()),
534 534
             ),
535 535
 
536 536
         );
@@ -590,12 +590,12 @@  discard block
 block discarded – undo
590 590
 }
591 591
 CSS;
592 592
 
593
-        $instance = new autoptimizeStyles( $css_in );
594
-        $instance->setOption( 'cdn_url', $cdnurl );
593
+        $instance = new autoptimizeStyles($css_in);
594
+        $instance->setOption('cdn_url', $cdnurl);
595 595
 
596
-        $css_actual = $instance->rewrite_assets( $css_in );
596
+        $css_actual = $instance->rewrite_assets($css_in);
597 597
 
598
-        $this->assertEquals( $css_expected, $css_actual );
598
+        $this->assertEquals($css_expected, $css_actual);
599 599
     }
600 600
 
601 601
     public function test_default_cssmin_minifier()
@@ -629,21 +629,21 @@  discard block
 block discarded – undo
629 629
 .bg{background:url('img/something.svg')}.bg-no-quote{background:url(img/something.svg)}.bg-double-quotes{background:url("img/something.svg")}.whitespaces{background:url ("../../somewhere-else/svg.svg")}.host-relative{background:url("/img/something.svg")}.protocol-relative{background:url("//something/somewhere/example.png")}@font-face{font-family:'Roboto';font-style:normal;font-weight:100;src:url(../fonts/roboto-v15-latin-ext_latin-100.eot);src:local('Roboto Thin'),local('Roboto-Thin'),url(../fonts/roboto-v15-latin-ext_latin-100.eot?#iefix) format('embedded-opentype'),url(../fonts/roboto-v15-latin-ext_latin-100.woff2) format('woff2'),url(../fonts/roboto-v15-latin-ext_latin-100.woff) format('woff'),url(../fonts/roboto-v15-latin-ext_latin-100.ttf) format('truetype'),url(../fonts/roboto-v15-latin-ext_latin-100.svg#Roboto) format('svg')}
630 630
 CSS;
631 631
 
632
-        $instance = new autoptimizeStyles( $css );
633
-        $minified = $instance->run_minifier_on( $css );
632
+        $instance = new autoptimizeStyles($css);
633
+        $minified = $instance->run_minifier_on($css);
634 634
 
635
-        $this->assertEquals( $expected, $minified );
635
+        $this->assertEquals($expected, $minified);
636 636
     }
637 637
 
638 638
     /**
639 639
      * @dataProvider provider_test_should_aggregate_script_types
640 640
      */
641
-    public function test_should_aggregate_script_types( $input, $expected )
641
+    public function test_should_aggregate_script_types($input, $expected)
642 642
     {
643
-        $instance = new autoptimizeScripts( '' );
644
-        $actual   = $instance->should_aggregate( $input );
643
+        $instance = new autoptimizeScripts('');
644
+        $actual   = $instance->should_aggregate($input);
645 645
 
646
-        $this->assertEquals( $expected, $actual );
646
+        $this->assertEquals($expected, $actual);
647 647
     }
648 648
 
649 649
     public function provider_test_should_aggregate_script_types()
@@ -705,11 +705,11 @@  discard block
 block discarded – undo
705 705
     /**
706 706
      * @dataProvider provider_is_valid_buffer
707 707
      */
708
-    public function test_valid_buffers( $input, $expected )
708
+    public function test_valid_buffers($input, $expected)
709 709
     {
710
-        $actual = $this->ao->is_valid_buffer( $input );
710
+        $actual = $this->ao->is_valid_buffer($input);
711 711
 
712
-        $this->assertEquals( $expected, $actual );
712
+        $this->assertEquals($expected, $actual);
713 713
     }
714 714
 
715 715
     public function provider_is_valid_buffer()
@@ -771,11 +771,11 @@  discard block
 block discarded – undo
771 771
     /**
772 772
      * @dataProvider provider_is_amp_markup
773 773
      */
774
-    public function test_autoptimize_is_amp_markup( $input, $expected )
774
+    public function test_autoptimize_is_amp_markup($input, $expected)
775 775
     {
776
-        $actual = autoptimizeMain::is_amp_markup( $input );
776
+        $actual = autoptimizeMain::is_amp_markup($input);
777 777
 
778
-        $this->assertEquals( $expected, $actual );
778
+        $this->assertEquals($expected, $actual);
779 779
     }
780 780
 
781 781
     public function provider_is_amp_markup()
@@ -806,31 +806,31 @@  discard block
 block discarded – undo
806 806
     public function test_skips_buffering_when_ao_noptimize_filter_is_true()
807 807
     {
808 808
         // True => disable autoptimize.
809
-        add_filter( 'autoptimize_filter_noptimize', '__return_true' );
809
+        add_filter('autoptimize_filter_noptimize', '__return_true');
810 810
 
811 811
         // Buffering should not run due to the above filter.
812 812
         $expected = false;
813
-        $actual   = $this->ao->should_buffer( $doing_tests = true );
813
+        $actual   = $this->ao->should_buffer($doing_tests = true);
814 814
 
815
-        $this->assertEquals( $expected, $actual );
815
+        $this->assertEquals($expected, $actual);
816 816
     }
817 817
 
818 818
     public function test_does_buffering_when_ao_noptimize_filter_is_false()
819 819
     {
820 820
         // False => disable noptimize, aka, run normally (weird, yes...).
821
-        add_filter( 'autoptimize_filter_noptimize', '__return_false' );
821
+        add_filter('autoptimize_filter_noptimize', '__return_false');
822 822
 
823 823
         // Buffering should run because of above.
824 824
         $expected = true;
825
-        $actual   = $this->ao->should_buffer( $doing_tests = true );
825
+        $actual   = $this->ao->should_buffer($doing_tests = true);
826 826
 
827
-        $this->assertEquals( $expected, $actual );
827
+        $this->assertEquals($expected, $actual);
828 828
     }
829 829
 
830 830
     public function test_ignores_ao_noptimize_qs_when_instructed()
831 831
     {
832 832
         // Should skip checking for the qs completely due to filter.
833
-        add_filter( 'autoptimize_filter_honor_qs_noptimize', '__return_false' );
833
+        add_filter('autoptimize_filter_honor_qs_noptimize', '__return_false');
834 834
 
835 835
         /**
836 836
          * The above should then result in the "current" value being `false`
@@ -841,23 +841,23 @@  discard block
 block discarded – undo
841 841
          */
842 842
 
843 843
         $that = $this; // Makes it work on php 5.3!
844
-        add_filter( 'autoptimize_filter_noptimize', function ( $current_value ) use ( $that ) {
844
+        add_filter('autoptimize_filter_noptimize', function($current_value) use ($that) {
845 845
             $expected = false;
846
-            if ( defined( 'DONOTMINIFY' ) && DONOTMINIFY ) {
846
+            if (defined('DONOTMINIFY') && DONOTMINIFY) {
847 847
                 $expected = true;
848 848
             }
849 849
 
850
-            $that->assertEquals( $expected, $current_value );
850
+            $that->assertEquals($expected, $current_value);
851 851
         });
852 852
 
853
-        $this->ao->should_buffer( $doing_tests = true );
853
+        $this->ao->should_buffer($doing_tests = true);
854 854
     }
855 855
 
856 856
     public function test_wpengine_cache_flush()
857 857
     {
858 858
         // Creating a mock so that we can get past class_exists() and method_exists() checks present
859 859
         // in `autoptimizeCache::flushPageCache()`...
860
-        $stub = $this->getMockBuilder( 'WpeCommon' )->disableAutoload()
860
+        $stub = $this->getMockBuilder('WpeCommon')->disableAutoload()
861 861
                 ->disableOriginalConstructor()->setMethods(
862 862
                     array(
863 863
                         'purge_varnish_cache',
@@ -866,9 +866,9 @@  discard block
 block discarded – undo
866 866
                 ->getMock();
867 867
 
868 868
         $that = $this;
869
-        add_filter( 'autoptimize_flush_wpengine_methods', function( $methods ) use ( $that ) {
870
-            $expected_methods = array( 'purge_varnish_cache' );
871
-            $that->assertEquals( $methods, $expected_methods );
869
+        add_filter('autoptimize_flush_wpengine_methods', function($methods) use ($that) {
870
+            $expected_methods = array('purge_varnish_cache');
871
+            $that->assertEquals($methods, $expected_methods);
872 872
 
873 873
             return $methods;
874 874
         });
@@ -882,7 +882,7 @@  discard block
 block discarded – undo
882 882
     public function test_wpengine_cache_flush_agressive()
883 883
     {
884 884
         // Creating a mock so that we can get past class_exists() and method_exists() checks `autoptimize_flush_pagecache()`...
885
-        $stub = $this->getMockBuilder( 'WpeCommon' )->disableAutoload()
885
+        $stub = $this->getMockBuilder('WpeCommon')->disableAutoload()
886 886
                 ->disableOriginalConstructor()->setMethods(
887 887
                     array(
888 888
                         'purge_varnish_cache',
@@ -892,19 +892,19 @@  discard block
 block discarded – undo
892 892
                 )
893 893
                 ->getMock();
894 894
 
895
-        add_filter( 'autoptimize_flush_wpengine_aggressive', function() {
895
+        add_filter('autoptimize_flush_wpengine_aggressive', function() {
896 896
             return true;
897 897
         });
898 898
 
899 899
         $that = $this;
900
-        add_filter( 'autoptimize_flush_wpengine_methods', function( $methods ) use ( $that ) {
900
+        add_filter('autoptimize_flush_wpengine_methods', function($methods) use ($that) {
901 901
             $expected_methods = array(
902 902
                 'purge_varnish_cache',
903 903
                 'purge_memcached',
904 904
                 'clear_maxcdn_cache',
905 905
             );
906 906
 
907
-            $that->assertEquals( $methods, $expected_methods );
907
+            $that->assertEquals($methods, $expected_methods);
908 908
 
909 909
             return $methods;
910 910
         });
@@ -915,15 +915,15 @@  discard block
 block discarded – undo
915 915
     /**
916 916
      * @dataProvider provider_test_url_replace_cdn
917 917
      */
918
-    public function test_url_replace_cdn( $cdn_url, $input, $expected )
918
+    public function test_url_replace_cdn($cdn_url, $input, $expected)
919 919
     {
920
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )
920
+        $mock = $this->getMockBuilder('autoptimizeBase')
921 921
                 ->disableOriginalConstructor()
922 922
                 ->getMockForAbstractClass();
923 923
 
924 924
         $mock->cdn_url = $cdn_url;
925
-        $actual        = $mock->url_replace_cdn( $input );
926
-        $this->assertEquals( $expected, $actual );
925
+        $actual        = $mock->url_replace_cdn($input);
926
+        $this->assertEquals($expected, $actual);
927 927
     }
928 928
 
929 929
     public function provider_test_url_replace_cdn()
@@ -940,13 +940,13 @@  discard block
 block discarded – undo
940 940
                 // CDN base url, url, expected result...
941 941
                 'http://cdn-test.example.org',
942 942
                 '/a.jpg',
943
-                'http://cdn-test.example.org/' . $subfolder . 'a.jpg',
943
+                'http://cdn-test.example.org/'.$subfolder.'a.jpg',
944 944
             ),
945 945
             // Full link with a matching AUTOPTIMIZE_WP_SITE_URL gets properly replaced...
946 946
             array(
947 947
                 'http://cdn-test.example.org',
948
-                $siteurl . '/wp-content/themes/something/example.svg',
949
-                'http://cdn-test.example.org/' . $subfolder . 'wp-content/themes/something/example.svg',
948
+                $siteurl.'/wp-content/themes/something/example.svg',
949
+                'http://cdn-test.example.org/'.$subfolder.'wp-content/themes/something/example.svg',
950 950
             ),
951 951
             // Protocol-relative url with a "local" hostname that doesn't match example.org (AUTOPTIMIZE_WP_SITE_URL)...
952 952
             array(
@@ -957,59 +957,59 @@  discard block
 block discarded – undo
957 957
             // www.example.org does not match example.org (AUTOPTIMIZE_WP_SITE_URL) so it's left alone...
958 958
             array(
959 959
                 'http://cdn-test.example.org',
960
-                $wwwsiteurl . '/wp-content/themes/something/example.svg',
961
-                $wwwsiteurl . '/wp-content/themes/something/example.svg',
960
+                $wwwsiteurl.'/wp-content/themes/something/example.svg',
961
+                $wwwsiteurl.'/wp-content/themes/something/example.svg',
962 962
             ),
963 963
             // SSL cdn url + host-relative link...
964 964
             array(
965 965
                 'https://cdn.example.org',
966 966
                 '/a.jpg',
967
-                'https://cdn.example.org/' . $subfolder . 'a.jpg',
967
+                'https://cdn.example.org/'.$subfolder.'a.jpg',
968 968
             ),
969 969
             // SSL cdn url + http site url that matches AUTOPTIMIZE_WP_SITE_URL is properly replaced...
970 970
             array(
971 971
                 'https://cdn.example.org',
972
-                $siteurl . '/wp-content/themes/something/example.svg',
973
-                'https://cdn.example.org/' . $subfolder . 'wp-content/themes/something/example.svg',
972
+                $siteurl.'/wp-content/themes/something/example.svg',
973
+                'https://cdn.example.org/'.$subfolder.'wp-content/themes/something/example.svg',
974 974
             ),
975 975
             // Protocol-relative cdn url given with protocol relative link that matches AUTOPTIMIZE_WP_SITE_URL host...
976 976
             array(
977 977
                 '//cdn.example.org',
978
-                $protorelativesiteurl . '/something.jpg',
979
-                '//cdn.example.org/' . $subfolder . 'something.jpg',
978
+                $protorelativesiteurl.'/something.jpg',
979
+                '//cdn.example.org/'.$subfolder.'something.jpg',
980 980
             ),
981 981
             // Protocol-relative cdn url given a http link that matches AUTOPTIMIZE_WP_SITE_URL host...
982 982
             array(
983 983
                 '//cdn.example.org',
984
-                $siteurl . '/something.png',
985
-                '//cdn.example.org/' . $subfolder . 'something.png',
984
+                $siteurl.'/something.png',
985
+                '//cdn.example.org/'.$subfolder.'something.png',
986 986
             ),
987 987
             // Protocol-relative cdn url with a host-relative link...
988 988
             array(
989 989
                 '//cdn.example.org',
990 990
                 '/a.jpg',
991
-                '//cdn.example.org/' . $subfolder . 'a.jpg',
991
+                '//cdn.example.org/'.$subfolder.'a.jpg',
992 992
             ),
993 993
             // Testing cdn urls with an explicit port number...
994 994
             array(
995 995
                 'http://cdn.com:8080',
996 996
                 '/a.jpg',
997
-                'http://cdn.com:8080/' . $subfolder . 'a.jpg',
997
+                'http://cdn.com:8080/'.$subfolder.'a.jpg',
998 998
             ),
999 999
             array(
1000 1000
                 '//cdn.com:4433',
1001 1001
                 '/a.jpg',
1002
-                '//cdn.com:4433/' . $subfolder . 'a.jpg',
1002
+                '//cdn.com:4433/'.$subfolder.'a.jpg',
1003 1003
             ),
1004 1004
             array(
1005 1005
                 '//cdn.com:4433',
1006
-                $siteurl . '/something.jpg',
1007
-                '//cdn.com:4433/' . $subfolder . 'something.jpg',
1006
+                $siteurl.'/something.jpg',
1007
+                '//cdn.com:4433/'.$subfolder.'something.jpg',
1008 1008
             ),
1009 1009
             array(
1010 1010
                 '//cdn.com:1234',
1011
-                $protorelativesiteurl . '/something.jpg',
1012
-                '//cdn.com:1234/' . $subfolder . 'something.jpg',
1011
+                $protorelativesiteurl.'/something.jpg',
1012
+                '//cdn.com:1234/'.$subfolder.'something.jpg',
1013 1013
             ),
1014 1014
             // Relative links should not be touched by url_replace_cdn()...
1015 1015
             array(
@@ -1034,8 +1034,8 @@  discard block
 block discarded – undo
1034 1034
             // even though they are really strange...
1035 1035
             array(
1036 1036
                 $siteurl, // example.org or http://localhost or http://localhost/wordpress
1037
-                $siteurl . '/something.jpg',
1038
-                $siteurl . '/something.jpg',
1037
+                $siteurl.'/something.jpg',
1038
+                $siteurl.'/something.jpg',
1039 1039
             ),
1040 1040
             // These shouldn't really be changed, or even if replacements do
1041 1041
             // happen, they shouldn't be destructive...
@@ -1074,31 +1074,31 @@  discard block
 block discarded – undo
1074 1074
         $test_link = '/a.jpg';
1075 1075
         $cdn_url   = '//cdn.example.org';
1076 1076
 
1077
-        $with_ssl = function( $cdn ) {
1077
+        $with_ssl = function($cdn) {
1078 1078
             return '';
1079 1079
         };
1080 1080
         $expected_with_ssl = '/a.jpg';
1081 1081
 
1082
-        $without_ssl = function( $cdn ) {
1082
+        $without_ssl = function($cdn) {
1083 1083
             return $cdn;
1084 1084
         };
1085
-        $expected_without_ssl = '//cdn.example.org/' . $sub . 'a.jpg';
1085
+        $expected_without_ssl = '//cdn.example.org/'.$sub.'a.jpg';
1086 1086
 
1087 1087
         // With a filter that returns something considered "empty", cdn replacement shouldn't occur...
1088
-        add_filter( 'autoptimize_filter_base_cdnurl', $with_ssl );
1089
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )
1088
+        add_filter('autoptimize_filter_base_cdnurl', $with_ssl);
1089
+        $mock = $this->getMockBuilder('autoptimizeBase')
1090 1090
                 ->disableOriginalConstructor()
1091 1091
                 ->getMockForAbstractClass();
1092 1092
 
1093 1093
         $mock->cdn_url   = $cdn_url;
1094
-        $actual_with_ssl = $mock->url_replace_cdn( $test_link );
1095
-        $this->assertEquals( $expected_with_ssl, $actual_with_ssl );
1096
-        remove_filter( 'autoptimize_filter_base_cdnurl', $with_ssl );
1094
+        $actual_with_ssl = $mock->url_replace_cdn($test_link);
1095
+        $this->assertEquals($expected_with_ssl, $actual_with_ssl);
1096
+        remove_filter('autoptimize_filter_base_cdnurl', $with_ssl);
1097 1097
 
1098 1098
         // With a filter that returns an actual cdn url, cdn replacement should occur.
1099
-        add_filter( 'autoptimize_filter_base_cdnurl', $without_ssl );
1100
-        $actual_without_ssl = $mock->url_replace_cdn( $test_link );
1101
-        $this->assertEquals( $expected_without_ssl, $actual_without_ssl );
1099
+        add_filter('autoptimize_filter_base_cdnurl', $without_ssl);
1100
+        $actual_without_ssl = $mock->url_replace_cdn($test_link);
1101
+        $this->assertEquals($expected_without_ssl, $actual_without_ssl);
1102 1102
     }
1103 1103
 
1104 1104
     public function provider_cssmin_issues()
@@ -1137,11 +1137,11 @@  discard block
 block discarded – undo
1137 1137
     /**
1138 1138
      * @dataProvider provider_cssmin_issues
1139 1139
      */
1140
-    public function test_cssmin_issues( $input, $expected )
1140
+    public function test_cssmin_issues($input, $expected)
1141 1141
     {
1142
-        $minifier = new autoptimizeCSSmin( false ); // No need to raise limits for now.
1143
-        $actual   = $minifier->run( $input );
1144
-        $this->assertEquals( $expected, $actual );
1142
+        $minifier = new autoptimizeCSSmin(false); // No need to raise limits for now.
1143
+        $actual   = $minifier->run($input);
1144
+        $this->assertEquals($expected, $actual);
1145 1145
     }
1146 1146
 
1147 1147
     public function provider_getpath()
@@ -1166,7 +1166,7 @@  discard block
 block discarded – undo
1166 1166
             // This file comes with core, so should exist...
1167 1167
             array(
1168 1168
                 '/wp-includes/js/jquery/jquery.js',
1169
-                WP_ROOT_DIR . '/wp-includes/js/jquery/jquery.js',
1169
+                WP_ROOT_DIR.'/wp-includes/js/jquery/jquery.js',
1170 1170
             ),
1171 1171
             // Empty $url should return false.
1172 1172
             array(
@@ -1191,12 +1191,12 @@  discard block
 block discarded – undo
1191 1191
     /**
1192 1192
      * @dataProvider provider_getpath
1193 1193
      */
1194
-    public function test_getpath( $input, $expected )
1194
+    public function test_getpath($input, $expected)
1195 1195
     {
1196
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )->disableOriginalConstructor()->getMockForAbstractClass();
1196
+        $mock = $this->getMockBuilder('autoptimizeBase')->disableOriginalConstructor()->getMockForAbstractClass();
1197 1197
 
1198
-        $actual = $mock->getpath( $input );
1199
-        $this->assertEquals( $expected, $actual );
1198
+        $actual = $mock->getpath($input);
1199
+        $this->assertEquals($expected, $actual);
1200 1200
     }
1201 1201
 
1202 1202
     /**
@@ -1210,7 +1210,7 @@  discard block
 block discarded – undo
1210 1210
 
1211 1211
         $protorelativesiteurl = $urls['prsiteurl'];
1212 1212
 
1213
-        $css_orig     = <<<CSS
1213
+        $css_orig = <<<CSS
1214 1214
 header{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90px' height='110px' viewBox='0 0 90 110'%3E%3Cstyle%3E.a%7Bstop-color:%23FFF;%7D.b%7Bstop-color:%23B2D235;%7D.c%7Bstop-color:%23BEE7FA;%7D.d%7Bfill:%23590C15;%7D%3C/style%3E%3ClinearGradient id='c' y2='135.4' gradientUnits='userSpaceOnUse' x2='209.1' gradientTransform='rotate(-1.467 -4082.888 7786.794)' y1='205.8' x1='262'%3E%3Cstop class='b' offset='0'/%3E%3Cstop class='b' offset='.48'/%3E%3Cstop stop-color='%23829D25' offset='1'/%3E%3C/linearGradient%3E%3Cpath stroke-width='.3' d='M77.3 45.4c-3-3.5-7.1-6.5-11.6-7.8-5.1-1.5-10-.1-14.9 1.5C52 35.4 54.3 29 60 24l-4.8-5.5c-3.4 3-5.8 6.3-7.5 9.4-1.7-4.3-4.1-8.4-7.5-12C33.4 8.6 24.3 4.7 15.1 4.2c-.2 9.3 3.1 18.6 9.9 25.9 5.2 5.6 11.8 9.2 18.7 10.8-2.5.2-4.9-.1-7.7-.9-5.2-1.4-10.5-2.8-15.8-1C10.6 42.3 4.5 51.9 4 61.7c-.5 11.6 3.8 23.8 9.9 33.5 3.9 6.3 9.6 13.7 17.7 13.4 3.8-.1 7-2.1 10.7-2.7 5.2-.8 9.1 1.2 14.1 1.8 16.4 2 24.4-23.6 26.4-35.9 1.2-9.1.8-19.1-5.5-26.4z' stroke='%233E6D1F' fill='url(%23c)'/%3E%3C/svg%3E")}
1215 1215
 section.clipped.clippedTop {clip-path:url("#clipPolygonTop")}
1216 1216
 section.clipped.clippedBottom {clip-path:url("#clipPolygonBottom")}
@@ -1223,13 +1223,13 @@  discard block
 block discarded – undo
1223 1223
 .myimg {background-image: url($protorelativesiteurl/wp-content/themes/my-theme/images/under-left-leaf.png), url($protorelativesiteurl/wp-content/themes/my-theme/images/over-blue-bird.png), url($protorelativesiteurl/wp-content/themes/my-theme/images/under-top.png), url($protorelativesiteurl/wp-content/themes/my-theme/images/bg-top-grunge.png);}
1224 1224
 CSS;
1225 1225
 
1226
-        $fixurls_result = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $css_orig );
1227
-        $this->assertEquals( $css_expected, $fixurls_result );
1226
+        $fixurls_result = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $css_orig);
1227
+        $this->assertEquals($css_expected, $fixurls_result);
1228 1228
     }
1229 1229
 
1230 1230
     public function test_background_datauri_sprites_with_fixurls()
1231 1231
     {
1232
-        $css_orig     = <<<CSS
1232
+        $css_orig = <<<CSS
1233 1233
 .shadow { background:url(img/1x1.png) top center; }
1234 1234
 .shadow1 { background-image:url(img/1x1.png) 0 -767px repeat-x; }
1235 1235
 .shadow2 {background:url(img/1x1.png) top center}
@@ -1281,27 +1281,27 @@  discard block
 block discarded – undo
1281 1281
 CSS;
1282 1282
 
1283 1283
         // For test purposes, ALL images in the css are being inline with a 1x1 trans png string/datauri.
1284
-        add_filter( 'autoptimize_filter_css_is_datauri_candidate', function( $is_candidate, $path ) {
1284
+        add_filter('autoptimize_filter_css_is_datauri_candidate', function($is_candidate, $path) {
1285 1285
             return true;
1286
-        }, 10, 2 );
1286
+        }, 10, 2);
1287 1287
 
1288 1288
         // For test purposes, ALL images in the css are being inline with a 1x1 trans png string/datauri.
1289
-        add_filter( 'autoptimize_filter_css_datauri_image', function( $base64array, $path ) {
1289
+        add_filter('autoptimize_filter_css_datauri_image', function($base64array, $path) {
1290 1290
             $head = 'data:image/png;base64,';
1291 1291
             $data = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=';
1292 1292
 
1293
-            $result['full']       = $head . $data;
1293
+            $result['full']       = $head.$data;
1294 1294
             $result['base64data'] = $data;
1295 1295
             return $result;
1296
-        }, 10, 2 );
1296
+        }, 10, 2);
1297 1297
 
1298
-        $instance = new autoptimizeStyles( $css_orig );
1299
-        $instance->setOption( 'datauris', true );
1298
+        $instance = new autoptimizeStyles($css_orig);
1299
+        $instance->setOption('datauris', true);
1300 1300
 
1301
-        $fixurls_result = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $css_orig );
1302
-        $css_actual     = $instance->rewrite_assets( $fixurls_result );
1301
+        $fixurls_result = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $css_orig);
1302
+        $css_actual     = $instance->rewrite_assets($fixurls_result);
1303 1303
 
1304
-        $this->assertEquals( $css_expected, $css_actual );
1304
+        $this->assertEquals($css_expected, $css_actual);
1305 1305
     }
1306 1306
 
1307 1307
     /**
@@ -1321,7 +1321,7 @@  discard block
 block discarded – undo
1321 1321
      */
1322 1322
     public function test_background_datauri_sprites_without_fixurls()
1323 1323
     {
1324
-        $css_orig     = <<<CSS
1324
+        $css_orig = <<<CSS
1325 1325
 .shadow { background:url(img/1x1.png) top center; }
1326 1326
 .shadow1 { background-image:url(img/1x1.png) 0 -767px repeat-x; }
1327 1327
 .shadow2 {background:url(img/1x1.png) top center}
@@ -1365,24 +1365,24 @@  discard block
 block discarded – undo
1365 1365
 CSS;
1366 1366
 
1367 1367
         // For test purposes, ALL images in the css are being inlined with a 1x1 trans png string/datauri.
1368
-        add_filter( 'autoptimize_filter_css_is_datauri_candidate', function( $is_candidate, $path ) {
1368
+        add_filter('autoptimize_filter_css_is_datauri_candidate', function($is_candidate, $path) {
1369 1369
             return true;
1370
-        }, 10, 2 );
1370
+        }, 10, 2);
1371 1371
 
1372 1372
         // For test purposes, ALL images in the css are being inlined with a 1x1 trans png string/datauri.
1373
-        add_filter( 'autoptimize_filter_css_datauri_image', function( $base64array, $path ) {
1373
+        add_filter('autoptimize_filter_css_datauri_image', function($base64array, $path) {
1374 1374
             $head = 'data:image/png;base64,';
1375 1375
             $data = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=';
1376 1376
 
1377
-            $result['full']       = $head . $data;
1377
+            $result['full']       = $head.$data;
1378 1378
             $result['base64data'] = $data;
1379 1379
             return $result;
1380
-        }, 10, 2 );
1380
+        }, 10, 2);
1381 1381
 
1382
-        $instance = new autoptimizeStyles( $css_orig );
1383
-        $instance->setOption( 'datauris', true );
1384
-        $css_actual = $instance->rewrite_assets( $css_orig );
1385
-        $this->assertEquals( $css_expected, $css_actual );
1382
+        $instance = new autoptimizeStyles($css_orig);
1383
+        $instance->setOption('datauris', true);
1384
+        $css_actual = $instance->rewrite_assets($css_orig);
1385
+        $this->assertEquals($css_expected, $css_actual);
1386 1386
     }
1387 1387
 
1388 1388
     /**
@@ -1502,12 +1502,12 @@  discard block
 block discarded – undo
1502 1502
 CSS;
1503 1503
 
1504 1504
         // Test with fonts pointed to the CDN + cdn option is set.
1505
-        add_filter( 'autoptimize_filter_css_fonts_cdn', '__return_true' );
1506
-        $instance = new autoptimizeStyles( $css_in );
1507
-        $instance->setOption( 'cdn_url', $cdnurl );
1508
-        $css_actual_fonts_cdn = $instance->rewrite_assets( $css_in );
1505
+        add_filter('autoptimize_filter_css_fonts_cdn', '__return_true');
1506
+        $instance = new autoptimizeStyles($css_in);
1507
+        $instance->setOption('cdn_url', $cdnurl);
1508
+        $css_actual_fonts_cdn = $instance->rewrite_assets($css_in);
1509 1509
 
1510
-        $this->assertEquals( $css_expected_fonts_cdn, $css_actual_fonts_cdn );
1510
+        $this->assertEquals($css_expected_fonts_cdn, $css_actual_fonts_cdn);
1511 1511
     }
1512 1512
 
1513 1513
     /**
@@ -1623,10 +1623,10 @@  discard block
 block discarded – undo
1623 1623
 }
1624 1624
 CSS;
1625 1625
         // Test without moving fonts to CDN, but cdn option is set.
1626
-        $instance = new autoptimizeStyles( $css_in );
1627
-        $instance->setOption( 'cdn_url', $urls['cdnurl'] );
1628
-        $css_actual = $instance->rewrite_assets( $css_in );
1629
-        $this->assertEquals( $css_expected, $css_actual );
1626
+        $instance = new autoptimizeStyles($css_in);
1627
+        $instance->setOption('cdn_url', $urls['cdnurl']);
1628
+        $css_actual = $instance->rewrite_assets($css_in);
1629
+        $this->assertEquals($css_expected, $css_actual);
1630 1630
     }
1631 1631
 
1632 1632
     public function test_assets_regex_replaces_multi_bg_images()
@@ -1647,16 +1647,16 @@  discard block
 block discarded – undo
1647 1647
 }
1648 1648
 CSS;
1649 1649
 
1650
-        $instance = new autoptimizeStyles( $in );
1651
-        $instance->setOption( 'cdn_url', $cdnurl );
1652
-        $actual = $instance->rewrite_assets( $in );
1650
+        $instance = new autoptimizeStyles($in);
1651
+        $instance->setOption('cdn_url', $cdnurl);
1652
+        $actual = $instance->rewrite_assets($in);
1653 1653
 
1654
-        $this->assertEquals( $expected, $actual );
1654
+        $this->assertEquals($expected, $actual);
1655 1655
     }
1656 1656
 
1657 1657
     public function test_at_supports_spacing_issue_110()
1658 1658
     {
1659
-        $in       = <<<CSS
1659
+        $in = <<<CSS
1660 1660
 @supports (-webkit-filter: blur(3px)) or (filter: blur(3px)) {
1661 1661
     .blur {
1662 1662
         filter:blur(3px);
@@ -1670,10 +1670,10 @@  discard block
 block discarded – undo
1670 1670
 @supports (-webkit-filter:blur(3px)) or (filter:blur(3px)){.blur{filter:blur(3px)}}@supports((position:-webkit-sticky) or (position:sticky)){.sticky{position:sticky}}
1671 1671
 CSS;
1672 1672
 
1673
-        $instance = new autoptimizeStyles( $in );
1674
-        $actual   = $instance->run_minifier_on( $in );
1673
+        $instance = new autoptimizeStyles($in);
1674
+        $actual   = $instance->run_minifier_on($in);
1675 1675
 
1676
-        $this->assertEquals( $expected, $actual );
1676
+        $this->assertEquals($expected, $actual);
1677 1677
     }
1678 1678
 
1679 1679
     public function test_css_import_semicolon_url_issue_122()
@@ -1689,18 +1689,18 @@  discard block
 block discarded – undo
1689 1689
 </style>
1690 1690
 HTML;
1691 1691
 
1692
-        $expected = '<style type="text/css" media="all">@import url(' . $cdnurl . '/' . $sub . 'foo.css?a&#038;b);@import url(' . $cdnurl . '/' . $sub . 'bar.css);</style><!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `title` missing --><!--/noptimize-->';
1692
+        $expected = '<style type="text/css" media="all">@import url('.$cdnurl.'/'.$sub.'foo.css?a&#038;b);@import url('.$cdnurl.'/'.$sub.'bar.css);</style><!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `title` missing --><!--/noptimize-->';
1693 1693
 
1694 1694
         $options = [
1695 1695
             'autoptimizeStyles' => $this->getAoStylesDefaultOptions(),
1696 1696
         ];
1697 1697
 
1698
-        $instance = new autoptimizeStyles( $in );
1699
-        $instance->read( $options['autoptimizeStyles'] );
1698
+        $instance = new autoptimizeStyles($in);
1699
+        $instance->read($options['autoptimizeStyles']);
1700 1700
         $instance->minify();
1701 1701
         $instance->cache();
1702 1702
         $actual = $instance->getcontent();
1703
-        $this->assertEquals( $expected, $actual );
1703
+        $this->assertEquals($expected, $actual);
1704 1704
     }
1705 1705
 
1706 1706
     public function test_fixurls_with_at_imports_and_media_queries()
@@ -1710,10 +1710,10 @@  discard block
 block discarded – undo
1710 1710
         $subfolder = $urls['subfolder'];
1711 1711
 
1712 1712
         $in  = '@import "foo.css"; @import "bar.css" (orientation:landscape);';
1713
-        $exp = '@import url(' . $prsiteurl . '/wp-content/themes/my-theme/foo.css); @import url(' . $prsiteurl . '/wp-content/themes/my-theme/bar.css) (orientation:landscape);';
1713
+        $exp = '@import url('.$prsiteurl.'/wp-content/themes/my-theme/foo.css); @import url('.$prsiteurl.'/wp-content/themes/my-theme/bar.css) (orientation:landscape);';
1714 1714
 
1715
-        $actual = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $in );
1716
-        $this->assertEquals( $exp, $actual );
1715
+        $actual = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $in);
1716
+        $this->assertEquals($exp, $actual);
1717 1717
     }
1718 1718
 
1719 1719
     public function test_aostyles_at_imports_with_media_queries()
@@ -1728,43 +1728,43 @@  discard block
 block discarded – undo
1728 1728
 </style>
1729 1729
 HTML;
1730 1730
 
1731
-        $expected = '<style type="text/css" media="all">@import url(' . $cdnurl . '/' . $sub . 'foo.css);@import url(' . $cdnurl . '/' . $sub . 'bar.css) (orientation:landscape);</style><!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `title` missing --><!--/noptimize-->';
1731
+        $expected = '<style type="text/css" media="all">@import url('.$cdnurl.'/'.$sub.'foo.css);@import url('.$cdnurl.'/'.$sub.'bar.css) (orientation:landscape);</style><!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `title` missing --><!--/noptimize-->';
1732 1732
 
1733 1733
         $options = [
1734 1734
             'autoptimizeStyles' => $this->getAoStylesDefaultOptions(),
1735 1735
         ];
1736 1736
 
1737
-        $instance = new autoptimizeStyles( $in );
1738
-        $instance->read( $options['autoptimizeStyles'] );
1737
+        $instance = new autoptimizeStyles($in);
1738
+        $instance->read($options['autoptimizeStyles']);
1739 1739
         $instance->minify();
1740 1740
         $instance->cache();
1741 1741
 
1742 1742
         $actual = $instance->getcontent();
1743
-        $this->assertEquals( $expected, $actual );
1743
+        $this->assertEquals($expected, $actual);
1744 1744
     }
1745 1745
 
1746 1746
     public function test_cache_size_checker_hooked_by_default()
1747 1747
     {
1748
-        $this->assertNotEmpty( autoptimizeCacheChecker::SCHEDULE_HOOK );
1748
+        $this->assertNotEmpty(autoptimizeCacheChecker::SCHEDULE_HOOK);
1749 1749
 
1750 1750
         // No schedule, because it's only added when is_admin() is true.
1751
-        $this->assertEquals( false, wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1751
+        $this->assertEquals(false, wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1752 1752
 
1753 1753
         // Proving that setup() sets the schedule as needed.
1754 1754
         $checker = new autoptimizeCacheChecker();
1755 1755
         $checker->setup();
1756
-        $this->assertEquals( 'twicedaily', wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1756
+        $this->assertEquals('twicedaily', wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1757 1757
     }
1758 1758
 
1759 1759
     public function test_cache_size_checker_disabled_with_filter()
1760 1760
     {
1761
-        add_filter( 'autoptimize_filter_cachecheck_do', '__return_false' );
1761
+        add_filter('autoptimize_filter_cachecheck_do', '__return_false');
1762 1762
 
1763 1763
         $checker = new autoptimizeCacheChecker();
1764 1764
         $checker->setup();
1765
-        $this->assertEquals( false, wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1765
+        $this->assertEquals(false, wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1766 1766
 
1767
-        remove_all_filters( 'autoptimize_filter_cachecheck_do' );
1767
+        remove_all_filters('autoptimize_filter_cachecheck_do');
1768 1768
     }
1769 1769
 
1770 1770
     public function test_is_start_buffering_hooked_properly()
@@ -1777,12 +1777,12 @@  discard block
 block discarded – undo
1777 1777
          * https://www.theaveragedev.com/mocking-constants-in-tests/.
1778 1778
          */
1779 1779
 
1780
-        if ( defined( 'AUTOPTIMIZE_INIT_EARLIER' ) ) {
1780
+        if (defined('AUTOPTIMIZE_INIT_EARLIER')) {
1781 1781
             $this->assertEquals(
1782 1782
                 autoptimizeMain::INIT_EARLIER_PRIORITY,
1783
-                has_action( 'init', array( $instance, 'start_buffering' ) )
1783
+                has_action('init', array($instance, 'start_buffering'))
1784 1784
             );
1785
-            $this->assertTrue( ! defined( 'AUTOPTIMIZE_HOOK_INTO' ) );
1785
+            $this->assertTrue(!defined('AUTOPTIMIZE_HOOK_INTO'));
1786 1786
         }
1787 1787
 
1788 1788
         /*
@@ -1799,18 +1799,18 @@  discard block
 block discarded – undo
1799 1799
 
1800 1800
     public function test_inline_and_defer_markup()
1801 1801
     {
1802
-        add_filter( 'autoptimize_filter_css_defer', '__return_true' );
1803
-        add_filter( 'autoptimize_filter_css_defer_inline', '__return_true' );
1802
+        add_filter('autoptimize_filter_css_defer', '__return_true');
1803
+        add_filter('autoptimize_filter_css_defer_inline', '__return_true');
1804 1804
 
1805
-        $actual = $this->ao->end_buffering( $this->get_test_markup() );
1806
-        if ( is_multisite() ) {
1807
-            $this->assertEquals( $this->get_test_markup_output_inline_defer_ms(), $actual );
1805
+        $actual = $this->ao->end_buffering($this->get_test_markup());
1806
+        if (is_multisite()) {
1807
+            $this->assertEquals($this->get_test_markup_output_inline_defer_ms(), $actual);
1808 1808
         } else {
1809
-            $this->assertEquals( $this->get_test_markup_output_inline_defer(), $actual );
1809
+            $this->assertEquals($this->get_test_markup_output_inline_defer(), $actual);
1810 1810
         }
1811 1811
 
1812
-        remove_all_filters( 'autoptimize_filter_css_defer' );
1813
-        remove_all_filters( 'autoptimize_filter_css_defer_inline' );
1812
+        remove_all_filters('autoptimize_filter_css_defer');
1813
+        remove_all_filters('autoptimize_filter_css_defer_inline');
1814 1814
     }
1815 1815
 
1816 1816
     public function test_js_aggregation_decision_and_dontaggregate_filter()
@@ -1818,47 +1818,47 @@  discard block
 block discarded – undo
1818 1818
         $opts = $this->getAoScriptsDefaultOptions();
1819 1819
 
1820 1820
         // Aggregating: true by default.
1821
-        $scripts = new autoptimizeScripts( '' );
1822
-        $scripts->read( $opts );
1823
-        $this->assertTrue( $scripts->aggregating() );
1821
+        $scripts = new autoptimizeScripts('');
1822
+        $scripts->read($opts);
1823
+        $this->assertTrue($scripts->aggregating());
1824 1824
 
1825 1825
         // Aggregating: option=true (dontaggregate=false by default).
1826 1826
         $opts['aggregate'] = true;
1827
-        $scripts           = new autoptimizeScripts( '' );
1828
-        $scripts->read( $opts );
1829
-        $this->assertTrue( $scripts->aggregating() );
1827
+        $scripts           = new autoptimizeScripts('');
1828
+        $scripts->read($opts);
1829
+        $this->assertTrue($scripts->aggregating());
1830 1830
 
1831 1831
         // Aggregating: option=true, dontaggregate=false explicit.
1832 1832
         $opts['aggregate'] = true;
1833
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_false' );
1834
-        $scripts = new autoptimizeScripts( '' );
1835
-        $scripts->read( $opts );
1836
-        $this->assertTrue( $scripts->aggregating() );
1837
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1833
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_false');
1834
+        $scripts = new autoptimizeScripts('');
1835
+        $scripts->read($opts);
1836
+        $this->assertTrue($scripts->aggregating());
1837
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1838 1838
 
1839 1839
         // Not aggregating: option=true, dontaggregate=true.
1840 1840
         $opts['aggregate'] = true;
1841
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_true' );
1842
-        $scripts = new autoptimizeScripts( '' );
1843
-        $scripts->read( $opts );
1844
-        $this->assertFalse( $scripts->aggregating() );
1845
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1841
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_true');
1842
+        $scripts = new autoptimizeScripts('');
1843
+        $scripts->read($opts);
1844
+        $this->assertFalse($scripts->aggregating());
1845
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1846 1846
 
1847 1847
         // Not aggregating: option=false, dontaggregate=false.
1848 1848
         $opts['aggregate'] = false;
1849
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_false' );
1850
-        $scripts = new autoptimizeScripts( '' );
1851
-        $scripts->read( $opts );
1852
-        $this->assertFalse( $scripts->aggregating() );
1853
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1849
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_false');
1850
+        $scripts = new autoptimizeScripts('');
1851
+        $scripts->read($opts);
1852
+        $this->assertFalse($scripts->aggregating());
1853
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1854 1854
 
1855 1855
         // Not aggregating: option=false, dontaggregate=true.
1856 1856
         $opts['aggregate'] = false;
1857
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_true' );
1858
-        $scripts = new autoptimizeScripts( '' );
1859
-        $scripts->read( $opts );
1860
-        $this->assertFalse( $scripts->aggregating() );
1861
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1857
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_true');
1858
+        $scripts = new autoptimizeScripts('');
1859
+        $scripts->read($opts);
1860
+        $this->assertFalse($scripts->aggregating());
1861
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1862 1862
     }
1863 1863
 
1864 1864
     public function test_css_aggregation_decision_and_dontaggregate_filter()
@@ -1866,78 +1866,78 @@  discard block
 block discarded – undo
1866 1866
         $opts = $this->getAoStylesDefaultOptions();
1867 1867
 
1868 1868
         // Aggregating: true by default.
1869
-        $styles = new autoptimizeStyles( '' );
1870
-        $this->assertTrue( $styles->aggregating() );
1869
+        $styles = new autoptimizeStyles('');
1870
+        $this->assertTrue($styles->aggregating());
1871 1871
 
1872 1872
         // Aggregating: option=true (dontaggregate=false by default).
1873 1873
         $opts['aggregate'] = true;
1874
-        $styles            = new autoptimizeStyles( '' );
1875
-        $styles->read( $opts );
1876
-        $this->assertTrue( $styles->aggregating() );
1874
+        $styles            = new autoptimizeStyles('');
1875
+        $styles->read($opts);
1876
+        $this->assertTrue($styles->aggregating());
1877 1877
 
1878 1878
         // Aggregating: option=true, dontaggregate=false explicit.
1879 1879
         $opts['aggregate'] = true;
1880
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_false' );
1881
-        $styles = new autoptimizeStyles( '' );
1882
-        $styles->read( $opts );
1883
-        $this->assertTrue( $styles->aggregating() );
1884
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1880
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_false');
1881
+        $styles = new autoptimizeStyles('');
1882
+        $styles->read($opts);
1883
+        $this->assertTrue($styles->aggregating());
1884
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1885 1885
 
1886 1886
         // Not aggregating: option=true, dontaggregate=true.
1887 1887
         $opts['aggregate'] = true;
1888
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_true' );
1889
-        $styles = new autoptimizeStyles( '' );
1890
-        $styles->read( $opts );
1891
-        $this->assertFalse( $styles->aggregating() );
1892
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1888
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_true');
1889
+        $styles = new autoptimizeStyles('');
1890
+        $styles->read($opts);
1891
+        $this->assertFalse($styles->aggregating());
1892
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1893 1893
 
1894 1894
         // Not aggregating: option=false, dontaggregate=false.
1895 1895
         $opts['aggregate'] = false;
1896
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_false' );
1897
-        $styles = new autoptimizeStyles( '' );
1898
-        $styles->read( $opts );
1899
-        $this->assertFalse( $styles->aggregating() );
1900
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1896
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_false');
1897
+        $styles = new autoptimizeStyles('');
1898
+        $styles->read($opts);
1899
+        $this->assertFalse($styles->aggregating());
1900
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1901 1901
 
1902 1902
         // Not aggregating: option=false, dontaggregate=true.
1903 1903
         $opts['aggregate'] = false;
1904
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_true' );
1905
-        $styles = new autoptimizeStyles( '' );
1906
-        $styles->read( $opts );
1907
-        $this->assertFalse( $styles->aggregating() );
1908
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1904
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_true');
1905
+        $styles = new autoptimizeStyles('');
1906
+        $styles->read($opts);
1907
+        $this->assertFalse($styles->aggregating());
1908
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1909 1909
     }
1910 1910
 
1911 1911
     public function test_css_minify_single_with_cdning()
1912 1912
     {
1913
-        $pathname = dirname( __FILE__ ) . '/fixtures/minify-single.css';
1913
+        $pathname = dirname(__FILE__).'/fixtures/minify-single.css';
1914 1914
         $opts     = $this->getAoStylesDefaultOptions();
1915
-        $styles   = new autoptimizeStyles( '' );
1916
-        $styles->read( $opts );
1915
+        $styles   = new autoptimizeStyles('');
1916
+        $styles->read($opts);
1917 1917
 
1918
-        $url = $styles->minify_single( $pathname, $cache_miss = true );
1918
+        $url = $styles->minify_single($pathname, $cache_miss = true);
1919 1919
 
1920 1920
         // Minified url filename + its pointed to cdn.
1921
-        $this->assertContains( AUTOPTIMIZE_CACHE_CHILD_DIR, $url );
1922
-        $this->assertContains( '/autoptimize_single_', $url );
1923
-        $this->assertContains( $styles->cdn_url, $url );
1921
+        $this->assertContains(AUTOPTIMIZE_CACHE_CHILD_DIR, $url);
1922
+        $this->assertContains('/autoptimize_single_', $url);
1923
+        $this->assertContains($styles->cdn_url, $url);
1924 1924
 
1925 1925
         // Actual minified css contents are minified and cdn-ed.
1926
-        $path     = $styles->getpath( $url );
1927
-        $contents = file_get_contents( $path );
1928
-        $this->assertContains( $styles->cdn_url, $contents );
1929
-        $this->assertContains( '.bg{background:url(' . $styles->cdn_url, $contents );
1926
+        $path     = $styles->getpath($url);
1927
+        $contents = file_get_contents($path);
1928
+        $this->assertContains($styles->cdn_url, $contents);
1929
+        $this->assertContains('.bg{background:url('.$styles->cdn_url, $contents);
1930 1930
     }
1931 1931
 
1932 1932
     public function test_ao_partners_instantiation_without_explicit_include()
1933 1933
     {
1934 1934
         $partners = new autoptimizePartners();
1935
-        $this->assertTrue( $partners instanceof autoptimizePartners );
1935
+        $this->assertTrue($partners instanceof autoptimizePartners);
1936 1936
     }
1937 1937
 
1938 1938
     public function test_html_minify_keep_html_comments_inside_script_blocks()
1939 1939
     {
1940
-        $markup   = <<<MARKUP
1940
+        $markup = <<<MARKUP
1941 1941
 <script>
1942 1942
 <!-- End Support AJAX add to cart -->
1943 1943
 var a = "b";
@@ -1967,23 +1967,23 @@  discard block
 block discarded – undo
1967 1967
             ],
1968 1968
         ];
1969 1969
 
1970
-        $instance = new autoptimizeHTML( $markup );
1971
-        $instance->read( $options['autoptimizeHTML'] );
1970
+        $instance = new autoptimizeHTML($markup);
1971
+        $instance->read($options['autoptimizeHTML']);
1972 1972
         $instance->minify();
1973 1973
         $actual = $instance->getcontent();
1974
-        $this->assertEquals( $expected, $actual );
1974
+        $this->assertEquals($expected, $actual);
1975 1975
 
1976
-        $instance = new autoptimizeHTML( $markup2 );
1977
-        $instance->read( $options['autoptimizeHTML'] );
1976
+        $instance = new autoptimizeHTML($markup2);
1977
+        $instance->read($options['autoptimizeHTML']);
1978 1978
         $instance->minify();
1979 1979
         $actual2 = $instance->getcontent();
1980
-        $this->assertEquals( $expected2, $actual2 );
1980
+        $this->assertEquals($expected2, $actual2);
1981 1981
     }
1982 1982
 
1983 1983
     public function test_html_minify_remove_html_comments_inside_script_blocks()
1984 1984
     {
1985 1985
         // Default case, html comments removed (keepcomments = false).
1986
-        $markup1   = <<<MARKUP
1986
+        $markup1 = <<<MARKUP
1987 1987
 <script>
1988 1988
 var a = "b";
1989 1989
 <!-- End Support AJAX add to cart -->
@@ -1994,7 +1994,7 @@  discard block
 block discarded – undo
1994 1994
 <!-- End Support AJAX add to cart</script>
1995 1995
 MARKUP;
1996 1996
 
1997
-        $markup2   = <<<MARKUP
1997
+        $markup2 = <<<MARKUP
1998 1998
 <script>
1999 1999
 <!-- End Support AJAX add to cart -->
2000 2000
 var a = "b";
@@ -2011,17 +2011,17 @@  discard block
 block discarded – undo
2011 2011
             ],
2012 2012
         ];
2013 2013
 
2014
-        $instance = new autoptimizeHTML( $markup1 );
2015
-        $instance->read( $options['autoptimizeHTML'] );
2014
+        $instance = new autoptimizeHTML($markup1);
2015
+        $instance->read($options['autoptimizeHTML']);
2016 2016
         $instance->minify();
2017 2017
         $actual = $instance->getcontent();
2018
-        $this->assertEquals( $expected1, $actual );
2018
+        $this->assertEquals($expected1, $actual);
2019 2019
 
2020
-        $instance = new autoptimizeHTML( $markup2 );
2021
-        $instance->read( $options['autoptimizeHTML'] );
2020
+        $instance = new autoptimizeHTML($markup2);
2021
+        $instance->read($options['autoptimizeHTML']);
2022 2022
         $instance->minify();
2023 2023
         $actual2 = $instance->getcontent();
2024
-        $this->assertEquals( $expected2, $actual2 );
2024
+        $this->assertEquals($expected2, $actual2);
2025 2025
     }
2026 2026
 
2027 2027
     public function test_html_minify_html_comments_inside_script_blocks_old_school_pattern()
@@ -2045,11 +2045,11 @@  discard block
 block discarded – undo
2045 2045
             ],
2046 2046
         ];
2047 2047
 
2048
-        $instance = new autoptimizeHTML( $markup );
2049
-        $instance->read( $options['autoptimizeHTML'] );
2048
+        $instance = new autoptimizeHTML($markup);
2049
+        $instance->read($options['autoptimizeHTML']);
2050 2050
         $instance->minify();
2051 2051
         $actual = $instance->getcontent();
2052
-        $this->assertEquals( $expected, $actual );
2052
+        $this->assertEquals($expected, $actual);
2053 2053
     }
2054 2054
 
2055 2055
     public function test_html_minify_html_comments_inside_script_blocks_old_school_pattern_untouched()
@@ -2074,49 +2074,49 @@  discard block
 block discarded – undo
2074 2074
             ],
2075 2075
         ];
2076 2076
 
2077
-        $instance = new autoptimizeHTML( $markup );
2078
-        $instance->read( $options['autoptimizeHTML'] );
2077
+        $instance = new autoptimizeHTML($markup);
2078
+        $instance->read($options['autoptimizeHTML']);
2079 2079
         $instance->minify();
2080 2080
         $actual = $instance->getcontent();
2081
-        $this->assertEquals( $expected, $actual );
2081
+        $this->assertEquals($expected, $actual);
2082 2082
     }
2083 2083
 
2084 2084
     public function test_utils_mbstring_availabilty_overriding()
2085 2085
     {
2086 2086
         $orig     = autoptimizeUtils::mbstring_available();
2087
-        $opposite = ! $orig;
2087
+        $opposite = !$orig;
2088 2088
 
2089
-        $this->assertSame( $orig, autoptimizeUtils::mbstring_available() );
2089
+        $this->assertSame($orig, autoptimizeUtils::mbstring_available());
2090 2090
         // Override works...
2091
-        $this->assertSame( $opposite, autoptimizeUtils::mbstring_available( $opposite ) );
2091
+        $this->assertSame($opposite, autoptimizeUtils::mbstring_available($opposite));
2092 2092
         // And override remains cached as the last version.
2093
-        $this->assertSame( $opposite, autoptimizeUtils::mbstring_available() );
2093
+        $this->assertSame($opposite, autoptimizeUtils::mbstring_available());
2094 2094
     }
2095 2095
 
2096 2096
     public function test_utils_mbstring_basics()
2097 2097
     {
2098 2098
         // Turn on mbstring usage.
2099
-        autoptimizeUtils::mbstring_available( true );
2099
+        autoptimizeUtils::mbstring_available(true);
2100 2100
 
2101
-        $this->assertSame( 2, autoptimizeUtils::strlen( "\x00\xFF", 'ASCII' ) );
2102
-        $this->assertSame( 2, autoptimizeUtils::strlen( "\x00\xFF", 'CP850' ) );
2103
-        $this->assertSame( 3, autoptimizeUtils::strlen( '한국어' ) );
2101
+        $this->assertSame(2, autoptimizeUtils::strlen("\x00\xFF", 'ASCII'));
2102
+        $this->assertSame(2, autoptimizeUtils::strlen("\x00\xFF", 'CP850'));
2103
+        $this->assertSame(3, autoptimizeUtils::strlen('한국어'));
2104 2104
 
2105
-        $this->assertFalse( @autoptimizeUtils::strpos( 'abc', '' ) );
2106
-        $this->assertFalse( @autoptimizeUtils::strpos( 'abc', 'a', -1 ) );
2107
-        $this->assertFalse( autoptimizeUtils::strpos( 'abc', 'd' ) );
2108
-        $this->assertFalse( autoptimizeUtils::strpos( 'abc', 'a', 3 ) );
2109
-        $this->assertSame( 1, autoptimizeUtils::strpos( '한국어', '국' ) );
2105
+        $this->assertFalse(@autoptimizeUtils::strpos('abc', ''));
2106
+        $this->assertFalse(@autoptimizeUtils::strpos('abc', 'a', -1));
2107
+        $this->assertFalse(autoptimizeUtils::strpos('abc', 'd'));
2108
+        $this->assertFalse(autoptimizeUtils::strpos('abc', 'a', 3));
2109
+        $this->assertSame(1, autoptimizeUtils::strpos('한국어', '국'));
2110 2110
     }
2111 2111
 
2112 2112
     /**
2113 2113
      * @dataProvider provider_utils_substr_replace
2114 2114
      */
2115
-    function test_utils_substr_replace_basics_mbstring( $s, $repl, $start, $len, $expected )
2115
+    function test_utils_substr_replace_basics_mbstring($s, $repl, $start, $len, $expected)
2116 2116
     {
2117 2117
         // Force mbstring code path...
2118
-        autoptimizeUtils::mbstring_available( true );
2119
-        $this->assertEquals( $expected, autoptimizeUtils::substr_replace( $s, $repl, $start, $len ) );
2118
+        autoptimizeUtils::mbstring_available(true);
2119
+        $this->assertEquals($expected, autoptimizeUtils::substr_replace($s, $repl, $start, $len));
2120 2120
     }
2121 2121
 
2122 2122
     public function provider_utils_substr_replace()
@@ -2158,48 +2158,48 @@  discard block
 block discarded – undo
2158 2158
 
2159 2159
     function test_mb_substr_replace_with_ascii_input_string()
2160 2160
     {
2161
-        autoptimizeUtils::mbstring_available( false );
2161
+        autoptimizeUtils::mbstring_available(false);
2162 2162
 
2163 2163
         $str = 'Ascii';
2164 2164
 
2165
-        $this->assertSame( 'Añ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) );
2166
-        $this->assertSame( 'ñcii', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2167
-        $this->assertSame( 'Asñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2168
-        $this->assertSame( 'Asz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) );
2169
-        $this->assertSame( 'Añii', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2165
+        $this->assertSame('Añ', autoptimizeUtils::substr_replace($str, 'ñ', 1));
2166
+        $this->assertSame('ñcii', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2167
+        $this->assertSame('Asñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2168
+        $this->assertSame('Asz', autoptimizeUtils::substr_replace($str, 'z', 2, 10));
2169
+        $this->assertSame('Añii', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2170 2170
     }
2171 2171
 
2172 2172
     function test_mb_substr_replace_with_utf8_input_string()
2173 2173
     {
2174
-        autoptimizeUtils::mbstring_available( true );
2174
+        autoptimizeUtils::mbstring_available(true);
2175 2175
 
2176 2176
         $str = 'âønæë';
2177 2177
 
2178
-        $this->assertSame( 'âñ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) ); // No length.
2179
-        $this->assertSame( 'ñnæë', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2180
-        $this->assertSame( 'âøñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2181
-        $this->assertSame( 'âøz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) ); // Length larger than possible...
2182
-        $this->assertSame( 'âñæë', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2178
+        $this->assertSame('âñ', autoptimizeUtils::substr_replace($str, 'ñ', 1)); // No length.
2179
+        $this->assertSame('ñnæë', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2180
+        $this->assertSame('âøñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2181
+        $this->assertSame('âøz', autoptimizeUtils::substr_replace($str, 'z', 2, 10)); // Length larger than possible...
2182
+        $this->assertSame('âñæë', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2183 2183
     }
2184 2184
 
2185 2185
     function test_default_substr_replace_with_ascii_input_string()
2186 2186
     {
2187 2187
         // Disable mbstring which should fall ack to substr_replace...
2188
-        autoptimizeUtils::mbstring_available( false );
2188
+        autoptimizeUtils::mbstring_available(false);
2189 2189
 
2190 2190
         $str = 'Ascii';
2191 2191
 
2192
-        $this->assertSame( 'Añ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) );
2193
-        $this->assertSame( 'ñcii', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2194
-        $this->assertSame( 'Asñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2195
-        $this->assertSame( 'Asz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) );
2196
-        $this->assertSame( 'Añii', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2192
+        $this->assertSame('Añ', autoptimizeUtils::substr_replace($str, 'ñ', 1));
2193
+        $this->assertSame('ñcii', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2194
+        $this->assertSame('Asñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2195
+        $this->assertSame('Asz', autoptimizeUtils::substr_replace($str, 'z', 2, 10));
2196
+        $this->assertSame('Añii', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2197 2197
     }
2198 2198
 
2199 2199
     function test_default_substr_replace_with_utf8_input_string()
2200 2200
     {
2201 2201
         // Disabling mbstring, falling back to substr_replace...
2202
-        autoptimizeUtils::mbstring_available( false );
2202
+        autoptimizeUtils::mbstring_available(false);
2203 2203
 
2204 2204
         // This is really impossible to make work properly, since
2205 2205
         // any start/len parameters we give are working with bytes instead
@@ -2208,55 +2208,55 @@  discard block
 block discarded – undo
2208 2208
 
2209 2209
         // $this->assertSame( '�ñ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) ); // No length.
2210 2210
         // $this->assertSame( 'ñ�næë', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2211
-        $this->assertSame( 'ñønæë', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2212
-        $this->assertSame( 'âñxæë', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2213
-        $this->assertSame( 'âz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) ); // Length larger than possible...
2211
+        $this->assertSame('ñønæë', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2212
+        $this->assertSame('âñxæë', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2213
+        $this->assertSame('âz', autoptimizeUtils::substr_replace($str, 'z', 2, 10)); // Length larger than possible...
2214 2214
     }
2215 2215
 
2216 2216
     public function test_cache_fast_delete()
2217 2217
     {
2218
-        add_filter( 'autoptimize_filter_cache_clear_advanced', '__return_true' );
2218
+        add_filter('autoptimize_filter_cache_clear_advanced', '__return_true');
2219 2219
 
2220 2220
         autoptimizeCache::clearall_actionless();
2221 2221
 
2222
-        remove_all_filters( 'autoptimize_filter_cache_clear_advanced' );
2222
+        remove_all_filters('autoptimize_filter_cache_clear_advanced');
2223 2223
     }
2224 2224
 
2225 2225
     public function test_delete_advanced_cache_clear_artifacts()
2226 2226
     {
2227
-        $this->assertTrue( autoptimizeCache::delete_advanced_cache_clear_artifacts() );
2227
+        $this->assertTrue(autoptimizeCache::delete_advanced_cache_clear_artifacts());
2228 2228
     }
2229 2229
 
2230 2230
     public function provider_canonicalization()
2231 2231
     {
2232 2232
         return array(
2233
-            array( '../common', 'common' ),
2234
-            array( '../what-does-this-mean/really?/', 'what-does-this-mean/really?/' ),
2235
-            array( '../../what/where/how', 'what/where/how' ),
2236
-            array( '/../more.dots.please/', '/more.dots.please/' ),
2237
-            array( '/../../what/where/how', '/what/where/how' ),
2238
-            array( '/a/b/c/../../../d/e/file.txt', '/d/e/file.txt' ),
2239
-            array( 'a/b/../c', 'a/c' ),
2240
-            array( './../../etc/passwd', './etc/passwd' ),
2241
-            array( '/var/.////./user/./././..//.//../////../././.././test/////', '/test/' ),
2242
-            array( '/var/user/./././.././../.././././test/', '/test/' ),
2243
-            array( '/hello/0//how/../are/../you', '/hello/0/you' ),
2244
-            array( '', '' ),
2245
-            array( '.', '.' ),
2246
-            array( '..', '..' ),
2247
-            array( './..', './..' ),
2248
-            array( '../.', '.' ),
2233
+            array('../common', 'common'),
2234
+            array('../what-does-this-mean/really?/', 'what-does-this-mean/really?/'),
2235
+            array('../../what/where/how', 'what/where/how'),
2236
+            array('/../more.dots.please/', '/more.dots.please/'),
2237
+            array('/../../what/where/how', '/what/where/how'),
2238
+            array('/a/b/c/../../../d/e/file.txt', '/d/e/file.txt'),
2239
+            array('a/b/../c', 'a/c'),
2240
+            array('./../../etc/passwd', './etc/passwd'),
2241
+            array('/var/.////./user/./././..//.//../////../././.././test/////', '/test/'),
2242
+            array('/var/user/./././.././../.././././test/', '/test/'),
2243
+            array('/hello/0//how/../are/../you', '/hello/0/you'),
2244
+            array('', ''),
2245
+            array('.', '.'),
2246
+            array('..', '..'),
2247
+            array('./..', './..'),
2248
+            array('../.', '.'),
2249 2249
             // This might be debatable...
2250
-            array( '../..', '..' ),
2250
+            array('../..', '..'),
2251 2251
         );
2252 2252
     }
2253 2253
 
2254 2254
     /**
2255 2255
      * @dataProvider provider_canonicalization
2256 2256
      */
2257
-    public function test_path_canonicalize( $path, $canonicalized )
2257
+    public function test_path_canonicalize($path, $canonicalized)
2258 2258
     {
2259
-        $this->assertSame( $canonicalized, autoptimizeUtils::path_canonicalize( $path ) );
2259
+        $this->assertSame($canonicalized, autoptimizeUtils::path_canonicalize($path));
2260 2260
     }
2261 2261
 
2262 2262
     /**
@@ -2270,16 +2270,16 @@  discard block
 block discarded – undo
2270 2270
     public function test_autoptimize_filter_cdn_magic_path_check()
2271 2271
     {
2272 2272
         $cdnurl = 'http://cdn.example.org';
2273
-        add_filter( 'autoptimize_filter_cdn_magic_path_check', '__return_false', 10, 2 );
2273
+        add_filter('autoptimize_filter_cdn_magic_path_check', '__return_false', 10, 2);
2274 2274
 
2275 2275
         // Even when site is in a subfolder, the resulting cdn-rewritten url
2276 2276
         // should not magically include it, due to the above filter.
2277 2277
         // The second parameter is here to force a cache miss and re-run
2278 2278
         // the filter since we're using the same cdn url all over the place,
2279 2279
         // but want to prove different things with it.
2280
-        $this->assertSame( $cdnurl, autoptimizeUtils::tweak_cdn_url_if_needed( $cdnurl, true ) );
2280
+        $this->assertSame($cdnurl, autoptimizeUtils::tweak_cdn_url_if_needed($cdnurl, true));
2281 2281
 
2282
-        remove_all_filters( 'autoptimize_filter_cdn_magic_path_check' );
2282
+        remove_all_filters('autoptimize_filter_cdn_magic_path_check');
2283 2283
     }
2284 2284
 
2285 2285
     /**
@@ -2302,8 +2302,8 @@  discard block
 block discarded – undo
2302 2302
 MARKUP;
2303 2303
 
2304 2304
         $instance = new autoptimizeExtra();
2305
-        $actual = $instance->filter_optimize_images( $markup );
2306
-        $this->assertEquals( $expected, $actual );
2305
+        $actual = $instance->filter_optimize_images($markup);
2306
+        $this->assertEquals($expected, $actual);
2307 2307
     }
2308 2308
 
2309 2309
     /**
@@ -2324,8 +2324,8 @@  discard block
 block discarded – undo
2324 2324
 MARKUP;
2325 2325
 
2326 2326
         $instance = new autoptimizeExtra();
2327
-        $actual = $instance->filter_optimize_images( $markup );
2328
-        $this->assertEquals( $expected, $actual );
2327
+        $actual = $instance->filter_optimize_images($markup);
2328
+        $this->assertEquals($expected, $actual);
2329 2329
     }
2330 2330
 
2331 2331
     /**
@@ -2348,8 +2348,8 @@  discard block
 block discarded – undo
2348 2348
 MARKUP;
2349 2349
 
2350 2350
         $instance = new autoptimizeExtra();
2351
-        $actual = $instance->filter_optimize_images( $markup );
2352
-        $this->assertEquals( $expected, $actual );
2351
+        $actual = $instance->filter_optimize_images($markup);
2352
+        $this->assertEquals($expected, $actual);
2353 2353
     }
2354 2354
 
2355 2355
     /**
@@ -2359,7 +2359,7 @@  discard block
 block discarded – undo
2359 2359
     {
2360 2360
         $actual = autoptimizeUtils::str_is_valid_regex($str);
2361 2361
 
2362
-        $this->assertEquals( $expected, $actual );
2362
+        $this->assertEquals($expected, $actual);
2363 2363
     }
2364 2364
 
2365 2365
     public function provider_str_is_valid_regex()
@@ -2375,11 +2375,11 @@  discard block
 block discarded – undo
2375 2375
     /**
2376 2376
      * @dataProvider provider_protocol_relative_tests
2377 2377
      */
2378
-    public function test_is_protocol_relative( $str, $expected )
2378
+    public function test_is_protocol_relative($str, $expected)
2379 2379
     {
2380
-        $actual = autoptimizeUtils::is_protocol_relative( $str );
2380
+        $actual = autoptimizeUtils::is_protocol_relative($str);
2381 2381
 
2382
-        $this->assertEquals( $expected, $actual );
2382
+        $this->assertEquals($expected, $actual);
2383 2383
     }
2384 2384
 
2385 2385
     public function provider_protocol_relative_tests()
@@ -2406,31 +2406,31 @@  discard block
 block discarded – undo
2406 2406
 
2407 2407
         $expected = 'img.centered,.aligncenter{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}';
2408 2408
 
2409
-        $instance = new autoptimizeStyles( $css );
2410
-        $minified = $instance->run_minifier_on( $css );
2409
+        $instance = new autoptimizeStyles($css);
2410
+        $minified = $instance->run_minifier_on($css);
2411 2411
 
2412
-        $this->assertEquals( $expected, $minified );
2412
+        $this->assertEquals($expected, $minified);
2413 2413
     }
2414 2414
 
2415 2415
     public function test_css_font_names_mangling()
2416 2416
     {
2417 2417
         // Properly quoted font names dont get mangled.
2418 2418
         $css      = 'h2{font-family:"Archivo Black"}';
2419
-        $instance = new autoptimizeStyles( $css );
2420
-        $actual   = $instance->run_minifier_on( $css );
2421
-        $this->assertEquals( $css, $actual );
2419
+        $instance = new autoptimizeStyles($css);
2420
+        $actual   = $instance->run_minifier_on($css);
2421
+        $this->assertEquals($css, $actual);
2422 2422
 
2423 2423
         // When not quoted, 'Black' used to become '#000', but not anymore... :)
2424 2424
         $css_unquoted = 'h2{font-family:Archivo Black;}';
2425 2425
         $expected     = 'h2{font-family:Archivo Black}';
2426
-        $instance     = new autoptimizeStyles( $css_unquoted );
2427
-        $actual       = $instance->run_minifier_on( $css_unquoted );
2428
-        $this->assertEquals( $expected, $actual );
2426
+        $instance     = new autoptimizeStyles($css_unquoted);
2427
+        $actual       = $instance->run_minifier_on($css_unquoted);
2428
+        $this->assertEquals($expected, $actual);
2429 2429
 
2430 2430
         $css_unquoted = 'h1{font:italic 1.2em Fira White,serif}';
2431
-        $instance     = new autoptimizeStyles( $css_unquoted );
2432
-        $actual       = $instance->run_minifier_on( $css_unquoted );
2433
-        $this->assertEquals( $css_unquoted, $actual );
2431
+        $instance     = new autoptimizeStyles($css_unquoted);
2432
+        $actual       = $instance->run_minifier_on($css_unquoted);
2433
+        $this->assertEquals($css_unquoted, $actual);
2434 2434
     }
2435 2435
 
2436 2436
     public function test_jsminphp_string_literal_minification()
@@ -2444,7 +2444,7 @@  discard block
 block discarded – undo
2444 2444
         $expected = '`line
2445 2445
 break`+`he  llo`;foo`hel( \'\');lo`;`he\nl\`lo`;(`he${one + two}`)';
2446 2446
 
2447
-        $actual = JSMin::minify( $js );
2448
-        $this->assertEquals( $expected, $actual );
2447
+        $actual = JSMin::minify($js);
2448
+        $this->assertEquals($expected, $actual);
2449 2449
     }
2450 2450
 }
Please login to merge, or discard this patch.
classes/autoptimizeUtils.php 1 patch
Spacing   +82 added lines, -82 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * General helpers.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -16,15 +16,15 @@  discard block
 block discarded – undo
16 16
      *
17 17
      * @return bool
18 18
      */
19
-    public static function mbstring_available( $override = null )
19
+    public static function mbstring_available($override = null)
20 20
     {
21 21
         static $available = null;
22 22
 
23
-        if ( null === $available ) {
24
-            $available = \extension_loaded( 'mbstring' );
23
+        if (null === $available) {
24
+            $available = \extension_loaded('mbstring');
25 25
         }
26 26
 
27
-        if ( null !== $override ) {
27
+        if (null !== $override) {
28 28
             $available = $override;
29 29
         }
30 30
 
@@ -42,12 +42,12 @@  discard block
 block discarded – undo
42 42
      *
43 43
      * @return int|false
44 44
      */
45
-    public static function strpos( $haystack, $needle, $offset = 0, $encoding = null )
45
+    public static function strpos($haystack, $needle, $offset = 0, $encoding = null)
46 46
     {
47
-        if ( self::mbstring_available() ) {
48
-            return ( null === $encoding ) ? \mb_strpos( $haystack, $needle, $offset ) : \mb_strlen( $haystack, $needle, $offset, $encoding );
47
+        if (self::mbstring_available()) {
48
+            return (null === $encoding) ? \mb_strpos($haystack, $needle, $offset) : \mb_strlen($haystack, $needle, $offset, $encoding);
49 49
         } else {
50
-            return \strpos( $haystack, $needle, $offset );
50
+            return \strpos($haystack, $needle, $offset);
51 51
         }
52 52
     }
53 53
 
@@ -62,12 +62,12 @@  discard block
 block discarded – undo
62 62
      * @return int Number of charcters or bytes in given $string
63 63
      *             (characters if/when supported, bytes otherwise).
64 64
      */
65
-    public static function strlen( $string, $encoding = null )
65
+    public static function strlen($string, $encoding = null)
66 66
     {
67
-        if ( self::mbstring_available() ) {
68
-            return ( null === $encoding ) ? \mb_strlen( $string ) : \mb_strlen( $string, $encoding );
67
+        if (self::mbstring_available()) {
68
+            return (null === $encoding) ? \mb_strlen($string) : \mb_strlen($string, $encoding);
69 69
         } else {
70
-            return \strlen( $string );
70
+            return \strlen($string);
71 71
         }
72 72
     }
73 73
 
@@ -85,44 +85,44 @@  discard block
 block discarded – undo
85 85
      *
86 86
      * @return string
87 87
      */
88
-    public static function substr_replace( $string, $replacement, $start, $length = null, $encoding = null )
88
+    public static function substr_replace($string, $replacement, $start, $length = null, $encoding = null)
89 89
     {
90
-        if ( self::mbstring_available() ) {
91
-            $strlen = self::strlen( $string, $encoding );
90
+        if (self::mbstring_available()) {
91
+            $strlen = self::strlen($string, $encoding);
92 92
 
93
-            if ( $start < 0 ) {
93
+            if ($start < 0) {
94 94
                 if ( -$start < $strlen ) {
95 95
                     $start = $strlen + $start;
96 96
                 } else {
97 97
                     $start = 0;
98 98
                 }
99
-            } elseif ( $start > $strlen ) {
99
+            } elseif ($start > $strlen) {
100 100
                 $start = $strlen;
101 101
             }
102 102
 
103
-            if ( null === $length || '' === $length ) {
103
+            if (null === $length || '' === $length) {
104 104
                 $start2 = $strlen;
105
-            } elseif ( $length < 0 ) {
105
+            } elseif ($length < 0) {
106 106
                 $start2 = $strlen + $length;
107
-                if ( $start2 < $start ) {
107
+                if ($start2 < $start) {
108 108
                     $start2 = $start;
109 109
                 }
110 110
             } else {
111 111
                 $start2 = $start + $length;
112 112
             }
113 113
 
114
-            if ( null === $encoding ) {
115
-                $leader  = $start ? \mb_substr( $string, 0, $start ) : '';
116
-                $trailer = ( $start2 < $strlen ) ? \mb_substr( $string, $start2, null ) : '';
114
+            if (null === $encoding) {
115
+                $leader  = $start ? \mb_substr($string, 0, $start) : '';
116
+                $trailer = ($start2 < $strlen) ? \mb_substr($string, $start2, null) : '';
117 117
             } else {
118
-                $leader  = $start ? \mb_substr( $string, 0, $start, $encoding ) : '';
119
-                $trailer = ( $start2 < $strlen ) ? \mb_substr( $string, $start2, null, $encoding ) : '';
118
+                $leader  = $start ? \mb_substr($string, 0, $start, $encoding) : '';
119
+                $trailer = ($start2 < $strlen) ? \mb_substr($string, $start2, null, $encoding) : '';
120 120
             }
121 121
 
122 122
             return "{$leader}{$replacement}{$trailer}";
123 123
         }
124 124
 
125
-        return ( null === $length ) ? \substr_replace( $string, $replacement, $start ) : \substr_replace( $string, $replacement, $start, $length );
125
+        return (null === $length) ? \substr_replace($string, $replacement, $start) : \substr_replace($string, $replacement, $start, $length);
126 126
     }
127 127
 
128 128
     /**
@@ -132,16 +132,16 @@  discard block
 block discarded – undo
132 132
      *
133 133
      * @return bool
134 134
      */
135
-    public static function siteurl_not_root( $override = null )
135
+    public static function siteurl_not_root($override = null)
136 136
     {
137 137
         static $subdir = null;
138 138
 
139
-        if ( null === $subdir ) {
139
+        if (null === $subdir) {
140 140
             $parts  = self::get_ao_wp_site_url_parts();
141
-            $subdir = ( isset( $parts['path'] ) && ( '/' !== $parts['path'] ) );
141
+            $subdir = (isset($parts['path']) && ('/' !== $parts['path']));
142 142
         }
143 143
 
144
-        if ( null !== $override ) {
144
+        if (null !== $override) {
145 145
             $subdir = $override;
146 146
         }
147 147
 
@@ -158,8 +158,8 @@  discard block
 block discarded – undo
158 158
     {
159 159
         static $parts = array();
160 160
 
161
-        if ( empty( $parts ) ) {
162
-            $parts = \parse_url( AUTOPTIMIZE_WP_SITE_URL );
161
+        if (empty($parts)) {
162
+            $parts = \parse_url(AUTOPTIMIZE_WP_SITE_URL);
163 163
         }
164 164
 
165 165
         return $parts;
@@ -174,33 +174,33 @@  discard block
 block discarded – undo
174 174
      *
175 175
      * @return string
176 176
      */
177
-    public static function tweak_cdn_url_if_needed( $cdn_url, $force_cache_miss = false )
177
+    public static function tweak_cdn_url_if_needed($cdn_url, $force_cache_miss = false)
178 178
     {
179 179
         static $results = array();
180 180
 
181
-        if ( ! isset( $results[ $cdn_url ] ) || $force_cache_miss ) {
181
+        if (!isset($results[$cdn_url]) || $force_cache_miss) {
182 182
 
183 183
             // In order to return unmodified input when there's no need to tweak.
184
-            $results[ $cdn_url ] = $cdn_url;
184
+            $results[$cdn_url] = $cdn_url;
185 185
 
186 186
             // Behind a default true filter for backcompat, and only for sites
187 187
             // in a subfolder/subdirectory, but still easily turned off if
188 188
             // not wanted/needed...
189
-            if ( autoptimizeUtils::siteurl_not_root() ) {
190
-                $check = apply_filters( 'autoptimize_filter_cdn_magic_path_check', true, $cdn_url );
191
-                if ( $check ) {
189
+            if (autoptimizeUtils::siteurl_not_root()) {
190
+                $check = apply_filters('autoptimize_filter_cdn_magic_path_check', true, $cdn_url);
191
+                if ($check) {
192 192
                     $site_url_parts = autoptimizeUtils::get_ao_wp_site_url_parts();
193
-                    $cdn_url_parts  = \parse_url( $cdn_url );
194
-                    $schemeless     = self::is_protocol_relative( $cdn_url );
195
-                    $cdn_url_parts  = self::maybe_replace_cdn_path( $site_url_parts, $cdn_url_parts );
196
-                    if ( false !== $cdn_url_parts ) {
197
-                        $results[ $cdn_url ] = self::assemble_parsed_url( $cdn_url_parts, $schemeless );
193
+                    $cdn_url_parts  = \parse_url($cdn_url);
194
+                    $schemeless     = self::is_protocol_relative($cdn_url);
195
+                    $cdn_url_parts  = self::maybe_replace_cdn_path($site_url_parts, $cdn_url_parts);
196
+                    if (false !== $cdn_url_parts) {
197
+                        $results[$cdn_url] = self::assemble_parsed_url($cdn_url_parts, $schemeless);
198 198
                     }
199 199
                 }
200 200
             }
201 201
         }
202 202
 
203
-        return $results[ $cdn_url ];
203
+        return $results[$cdn_url];
204 204
     }
205 205
 
206 206
     /**
@@ -214,10 +214,10 @@  discard block
 block discarded – undo
214 214
      *
215 215
      * @return array|false
216 216
      */
217
-    public static function maybe_replace_cdn_path( array $site_url_parts, array $cdn_url_parts )
217
+    public static function maybe_replace_cdn_path(array $site_url_parts, array $cdn_url_parts)
218 218
     {
219
-        if ( isset( $site_url_parts['path'] ) && '/' !== $site_url_parts['path'] ) {
220
-            if ( ! isset( $cdn_url_parts['path'] ) || '/' === $cdn_url_parts['path'] ) {
219
+        if (isset($site_url_parts['path']) && '/' !== $site_url_parts['path']) {
220
+            if (!isset($cdn_url_parts['path']) || '/' === $cdn_url_parts['path']) {
221 221
                 $cdn_url_parts['path'] = $site_url_parts['path'];
222 222
                 return $cdn_url_parts;
223 223
             }
@@ -237,20 +237,20 @@  discard block
 block discarded – undo
237 237
      *
238 238
      * @return string
239 239
      */
240
-    public static function assemble_parsed_url( array $parsed_url, $schemeless = false )
240
+    public static function assemble_parsed_url(array $parsed_url, $schemeless = false)
241 241
     {
242
-        $scheme = isset( $parsed_url['scheme'] ) ? $parsed_url['scheme'] . '://' : '';
243
-        if ( $schemeless ) {
242
+        $scheme = isset($parsed_url['scheme']) ? $parsed_url['scheme'].'://' : '';
243
+        if ($schemeless) {
244 244
             $scheme = '//';
245 245
         }
246
-        $host     = isset( $parsed_url['host'] ) ? $parsed_url['host'] : '';
247
-        $port     = isset( $parsed_url['port'] ) ? ':' . $parsed_url['port'] : '';
248
-        $user     = isset( $parsed_url['user'] ) ? $parsed_url['user'] : '';
249
-        $pass     = isset( $parsed_url['pass'] ) ? ':' . $parsed_url['pass'] : '';
250
-        $pass     = ( $user || $pass ) ? "$pass@" : '';
251
-        $path     = isset( $parsed_url['path'] ) ? $parsed_url['path'] : '';
252
-        $query    = isset( $parsed_url['query'] ) ? '?' . $parsed_url['query'] : '';
253
-        $fragment = isset( $parsed_url['fragment'] ) ? '#' . $parsed_url['fragment'] : '';
246
+        $host     = isset($parsed_url['host']) ? $parsed_url['host'] : '';
247
+        $port     = isset($parsed_url['port']) ? ':'.$parsed_url['port'] : '';
248
+        $user     = isset($parsed_url['user']) ? $parsed_url['user'] : '';
249
+        $pass     = isset($parsed_url['pass']) ? ':'.$parsed_url['pass'] : '';
250
+        $pass     = ($user || $pass) ? "$pass@" : '';
251
+        $path     = isset($parsed_url['path']) ? $parsed_url['path'] : '';
252
+        $query    = isset($parsed_url['query']) ? '?'.$parsed_url['query'] : '';
253
+        $fragment = isset($parsed_url['fragment']) ? '#'.$parsed_url['fragment'] : '';
254 254
 
255 255
         return "$scheme$user$pass$host$port$path$query$fragment";
256 256
     }
@@ -262,12 +262,12 @@  discard block
 block discarded – undo
262 262
      *
263 263
      * @return bool
264 264
      */
265
-    public static function is_protocol_relative( $url )
265
+    public static function is_protocol_relative($url)
266 266
     {
267 267
         $result = false;
268 268
 
269
-        if ( ! empty( $url ) ) {
270
-            $result = ( 0 === strpos( $url, '//' ) );
269
+        if (!empty($url)) {
270
+            $result = (0 === strpos($url, '//'));
271 271
         }
272 272
 
273 273
         return $result;
@@ -280,9 +280,9 @@  discard block
 block discarded – undo
280 280
      *
281 281
      * @return string
282 282
      */
283
-    public static function path_canonicalize( $path )
283
+    public static function path_canonicalize($path)
284 284
     {
285
-        $patterns     = array(
285
+        $patterns = array(
286 286
             '~/{2,}~',
287 287
             '~/(\./)+~',
288 288
             '~([^/\.]+/(?R)*\.{2,}/)~',
@@ -295,7 +295,7 @@  discard block
 block discarded – undo
295 295
             '',
296 296
         );
297 297
 
298
-        return preg_replace( $patterns, $replacements, $path );
298
+        return preg_replace($patterns, $replacements, $path);
299 299
     }
300 300
 
301 301
     /**
@@ -305,15 +305,15 @@  discard block
 block discarded – undo
305 305
      *
306 306
      * @return none if $return_result is false (default), array if $return_result is true.
307 307
      */
308
-    public static function check_service_availability( $return_result = false )
308
+    public static function check_service_availability($return_result = false)
309 309
     {
310
-        $service_availability_resp = wp_remote_get( 'https://misc.optimizingmatters.com/api/autoptimize_service_availablity.json?from=aomain&ver=' . AUTOPTIMIZE_PLUGIN_VERSION );
311
-        if ( ! is_wp_error( $service_availability_resp ) ) {
312
-            if ( '200' == wp_remote_retrieve_response_code( $service_availability_resp ) ) {
313
-                $availabilities = json_decode( wp_remote_retrieve_body( $service_availability_resp ), true );
314
-                if ( is_array( $availabilities ) ) {
315
-                    update_option( 'autoptimize_service_availablity', $availabilities );
316
-                    if ( $return_result ) {
310
+        $service_availability_resp = wp_remote_get('https://misc.optimizingmatters.com/api/autoptimize_service_availablity.json?from=aomain&ver='.AUTOPTIMIZE_PLUGIN_VERSION);
311
+        if (!is_wp_error($service_availability_resp)) {
312
+            if ('200' == wp_remote_retrieve_response_code($service_availability_resp)) {
313
+                $availabilities = json_decode(wp_remote_retrieve_body($service_availability_resp), true);
314
+                if (is_array($availabilities)) {
315
+                    update_option('autoptimize_service_availablity', $availabilities);
316
+                    if ($return_result) {
317 317
                         return $availabilities;
318 318
                     }
319 319
                 }
@@ -328,10 +328,10 @@  discard block
 block discarded – undo
328 328
      *
329 329
      * @return bool
330 330
      */
331
-    public static function str_is_valid_regex( $string )
331
+    public static function str_is_valid_regex($string)
332 332
     {
333
-        set_error_handler( function() {}, E_WARNING );
334
-        $is_regex = ( false !== preg_match( $string, '' ) );
333
+        set_error_handler(function() {}, E_WARNING);
334
+        $is_regex = (false !== preg_match($string, ''));
335 335
         restore_error_handler();
336 336
 
337 337
         return $is_regex;
@@ -344,16 +344,16 @@  discard block
 block discarded – undo
344 344
      *
345 345
      * @return bool
346 346
      */
347
-    public static function is_plugin_active( $plugin_file )
347
+    public static function is_plugin_active($plugin_file)
348 348
     {
349 349
         static $ipa_exists = null;
350
-        if ( null === $ipa_exists ) {
351
-            if ( ! function_exists( '\is_plugin_active' ) ) {
352
-                require_once ABSPATH . 'wp-admin/includes/plugin.php';
350
+        if (null === $ipa_exists) {
351
+            if (!function_exists('\is_plugin_active')) {
352
+                require_once ABSPATH.'wp-admin/includes/plugin.php';
353 353
             }
354
-            $ipa_exists = function_exists( '\is_plugin_active' );
354
+            $ipa_exists = function_exists('\is_plugin_active');
355 355
         }
356 356
 
357
-        return $ipa_exists && \is_plugin_active( $plugin_file );
357
+        return $ipa_exists && \is_plugin_active($plugin_file);
358 358
     }
359 359
 }
Please login to merge, or discard this patch.
classes/autoptimizeBase.php 1 patch
Spacing   +151 added lines, -151 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Base class other (more-specific) classes inherit from.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -23,7 +23,7 @@  discard block
 block discarded – undo
23 23
      */
24 24
     public $debug_log = false;
25 25
 
26
-    public function __construct( $content )
26
+    public function __construct($content)
27 27
     {
28 28
         $this->content = $content;
29 29
     }
@@ -35,7 +35,7 @@  discard block
 block discarded – undo
35 35
      *
36 36
      * @return bool
37 37
      */
38
-    abstract public function read( $options );
38
+    abstract public function read($options);
39 39
 
40 40
     /**
41 41
      * Joins and optimizes collected things.
@@ -66,40 +66,40 @@  discard block
 block discarded – undo
66 66
      *
67 67
      * @return bool|string
68 68
      */
69
-    public function getpath( $url )
69
+    public function getpath($url)
70 70
     {
71
-        $url = apply_filters( 'autoptimize_filter_cssjs_alter_url', $url );
71
+        $url = apply_filters('autoptimize_filter_cssjs_alter_url', $url);
72 72
 
73
-        if ( false !== strpos( $url, '%' ) ) {
74
-            $url = urldecode( $url );
73
+        if (false !== strpos($url, '%')) {
74
+            $url = urldecode($url);
75 75
         }
76 76
 
77
-        $site_host    = parse_url( AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST );
78
-        $content_host = parse_url( AUTOPTIMIZE_WP_ROOT_URL, PHP_URL_HOST );
77
+        $site_host    = parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST);
78
+        $content_host = parse_url(AUTOPTIMIZE_WP_ROOT_URL, PHP_URL_HOST);
79 79
 
80 80
         // Normalizing attempts...
81
-        $double_slash_position = strpos( $url, '//' );
82
-        if ( 0 === $double_slash_position ) {
83
-            if ( is_ssl() ) {
84
-                $url = 'https:' . $url;
81
+        $double_slash_position = strpos($url, '//');
82
+        if (0 === $double_slash_position) {
83
+            if (is_ssl()) {
84
+                $url = 'https:'.$url;
85 85
             } else {
86
-                $url = 'http:' . $url;
86
+                $url = 'http:'.$url;
87 87
             }
88
-        } elseif ( ( false === $double_slash_position ) && ( false === strpos( $url, $site_host ) ) ) {
89
-            if ( AUTOPTIMIZE_WP_SITE_URL === $site_host ) {
90
-                $url = AUTOPTIMIZE_WP_SITE_URL . $url;
88
+        } elseif ((false === $double_slash_position) && (false === strpos($url, $site_host))) {
89
+            if (AUTOPTIMIZE_WP_SITE_URL === $site_host) {
90
+                $url = AUTOPTIMIZE_WP_SITE_URL.$url;
91 91
             } else {
92
-                $url = AUTOPTIMIZE_WP_SITE_URL . autoptimizeUtils::path_canonicalize( $url );
92
+                $url = AUTOPTIMIZE_WP_SITE_URL.autoptimizeUtils::path_canonicalize($url);
93 93
             }
94 94
         }
95 95
 
96
-        if ( $site_host !== $content_host ) {
97
-            $url = str_replace( AUTOPTIMIZE_WP_CONTENT_URL, AUTOPTIMIZE_WP_SITE_URL . AUTOPTIMIZE_WP_CONTENT_NAME, $url );
96
+        if ($site_host !== $content_host) {
97
+            $url = str_replace(AUTOPTIMIZE_WP_CONTENT_URL, AUTOPTIMIZE_WP_SITE_URL.AUTOPTIMIZE_WP_CONTENT_NAME, $url);
98 98
         }
99 99
 
100 100
         // First check; hostname wp site should be hostname of url!
101
-        $url_host = @parse_url( $url, PHP_URL_HOST ); // @codingStandardsIgnoreLine
102
-        if ( $url_host !== $site_host ) {
101
+        $url_host = @parse_url($url, PHP_URL_HOST); // @codingStandardsIgnoreLine
102
+        if ($url_host !== $site_host) {
103 103
             /**
104 104
              * First try to get all domains from WPML (if available)
105 105
              * then explicitely declare $this->cdn_url as OK as well
@@ -108,20 +108,20 @@  discard block
 block discarded – undo
108 108
              */
109 109
             $multidomains = array();
110 110
 
111
-            $multidomains_wpml = apply_filters( 'wpml_setting', array(), 'language_domains' );
112
-            if ( ! empty( $multidomains_wpml ) ) {
113
-                $multidomains = array_map( array( $this, 'get_url_hostname' ), $multidomains_wpml );
111
+            $multidomains_wpml = apply_filters('wpml_setting', array(), 'language_domains');
112
+            if (!empty($multidomains_wpml)) {
113
+                $multidomains = array_map(array($this, 'get_url_hostname'), $multidomains_wpml);
114 114
             }
115 115
 
116
-            if ( ! empty( $this->cdn_url ) ) {
117
-                $multidomains[] = parse_url( $this->cdn_url, PHP_URL_HOST );
116
+            if (!empty($this->cdn_url)) {
117
+                $multidomains[] = parse_url($this->cdn_url, PHP_URL_HOST);
118 118
             }
119 119
 
120
-            $multidomains = apply_filters( 'autoptimize_filter_cssjs_multidomain', $multidomains );
120
+            $multidomains = apply_filters('autoptimize_filter_cssjs_multidomain', $multidomains);
121 121
 
122
-            if ( ! empty( $multidomains ) ) {
123
-                if ( in_array( $url_host, $multidomains ) ) {
124
-                    $url = str_replace( $url_host, $site_host, $url );
122
+            if (!empty($multidomains)) {
123
+                if (in_array($url_host, $multidomains)) {
124
+                    $url = str_replace($url_host, $site_host, $url);
125 125
                 } else {
126 126
                     return false;
127 127
                 }
@@ -131,28 +131,28 @@  discard block
 block discarded – undo
131 131
         }
132 132
 
133 133
         // Try to remove "wp root url" from url while not minding http<>https.
134
-        $tmp_ao_root = preg_replace( '/https?:/', '', AUTOPTIMIZE_WP_ROOT_URL );
134
+        $tmp_ao_root = preg_replace('/https?:/', '', AUTOPTIMIZE_WP_ROOT_URL);
135 135
 
136
-        if ( $site_host !== $content_host ) {
136
+        if ($site_host !== $content_host) {
137 137
             // As we replaced the content-domain with the site-domain, we should match against that.
138
-            $tmp_ao_root = preg_replace( '/https?:/', '', AUTOPTIMIZE_WP_SITE_URL );
138
+            $tmp_ao_root = preg_replace('/https?:/', '', AUTOPTIMIZE_WP_SITE_URL);
139 139
         }
140 140
 
141
-        $tmp_url = preg_replace( '/https?:/', '', $url );
142
-        $path    = str_replace( $tmp_ao_root, '', $tmp_url );
141
+        $tmp_url = preg_replace('/https?:/', '', $url);
142
+        $path    = str_replace($tmp_ao_root, '', $tmp_url);
143 143
 
144 144
         // If path starts with :// or //, this is not a URL in the WP context and
145 145
         // we have to assume we can't aggregate.
146
-        if ( preg_match( '#^:?//#', $path ) ) {
146
+        if (preg_match('#^:?//#', $path)) {
147 147
             // External script/css (adsense, etc).
148 148
             return false;
149 149
         }
150 150
 
151 151
         // Prepend with WP_ROOT_DIR to have full path to file.
152
-        $path = str_replace( '//', '/', WP_ROOT_DIR . $path );
152
+        $path = str_replace('//', '/', WP_ROOT_DIR.$path);
153 153
 
154 154
         // Final check: does file exist and is it readable?
155
-        if ( file_exists( $path ) && is_file( $path ) && is_readable( $path ) ) {
155
+        if (file_exists($path) && is_file($path) && is_readable($path)) {
156 156
             return $path;
157 157
         } else {
158 158
             return false;
@@ -169,18 +169,18 @@  discard block
 block discarded – undo
169 169
      *
170 170
      * @return string
171 171
      */
172
-    protected function get_url_hostname( $url )
172
+    protected function get_url_hostname($url)
173 173
     {
174 174
         // Checking that the url starts with something vaguely resembling a protocol.
175
-        if ( ( 0 !== strpos( $url, 'http' ) ) && ( 0 !== strpos( $url, '//' ) ) ) {
176
-            $url = 'http://' . $url;
175
+        if ((0 !== strpos($url, 'http')) && (0 !== strpos($url, '//'))) {
176
+            $url = 'http://'.$url;
177 177
         }
178 178
 
179 179
         // Grab the hostname.
180
-        $hostname = parse_url( $url, PHP_URL_HOST );
180
+        $hostname = parse_url($url, PHP_URL_HOST);
181 181
 
182 182
         // Fallback when parse_url() fails.
183
-        if ( empty( $hostname ) ) {
183
+        if (empty($hostname)) {
184 184
             $hostname = $url;
185 185
         }
186 186
 
@@ -194,7 +194,7 @@  discard block
 block discarded – undo
194 194
      *
195 195
      * @return string
196 196
      */
197
-    protected function hide_noptimize( $markup )
197
+    protected function hide_noptimize($markup)
198 198
     {
199 199
         return $this->replace_contents_with_marker_if_exists(
200 200
             'NOPTIMIZE',
@@ -211,9 +211,9 @@  discard block
 block discarded – undo
211 211
      *
212 212
      * @return string
213 213
      */
214
-    protected function restore_noptimize( $markup )
214
+    protected function restore_noptimize($markup)
215 215
     {
216
-        return $this->restore_marked_content( 'NOPTIMIZE', $markup );
216
+        return $this->restore_marked_content('NOPTIMIZE', $markup);
217 217
     }
218 218
 
219 219
     /**
@@ -223,7 +223,7 @@  discard block
 block discarded – undo
223 223
      *
224 224
      * @return string
225 225
      */
226
-    protected function hide_iehacks( $markup )
226
+    protected function hide_iehacks($markup)
227 227
     {
228 228
         return $this->replace_contents_with_marker_if_exists(
229 229
             'IEHACK', // Marker name...
@@ -240,9 +240,9 @@  discard block
 block discarded – undo
240 240
      *
241 241
      * @return string
242 242
      */
243
-    protected function restore_iehacks( $markup )
243
+    protected function restore_iehacks($markup)
244 244
     {
245
-        return $this->restore_marked_content( 'IEHACK', $markup );
245
+        return $this->restore_marked_content('IEHACK', $markup);
246 246
     }
247 247
 
248 248
     /**
@@ -254,7 +254,7 @@  discard block
 block discarded – undo
254 254
      *
255 255
      * @return string
256 256
      */
257
-    protected function hide_comments( $markup )
257
+    protected function hide_comments($markup)
258 258
     {
259 259
         return $this->replace_contents_with_marker_if_exists(
260 260
             'COMMENTS',
@@ -272,9 +272,9 @@  discard block
 block discarded – undo
272 272
      *
273 273
      * @return string
274 274
      */
275
-    protected function restore_comments( $markup )
275
+    protected function restore_comments($markup)
276 276
     {
277
-        return $this->restore_marked_content( 'COMMENTS', $markup );
277
+        return $this->restore_marked_content('COMMENTS', $markup);
278 278
     }
279 279
 
280 280
     /**
@@ -285,44 +285,44 @@  discard block
 block discarded – undo
285 285
      *
286 286
      * @return string
287 287
      */
288
-    public function url_replace_cdn( $url )
288
+    public function url_replace_cdn($url)
289 289
     {
290 290
         // For 2.3 back-compat in which cdn-ing appeared to be automatically
291 291
         // including WP subfolder/subdirectory into account as part of cdn-ing,
292 292
         // even though it might've caused serious troubles in certain edge-cases.
293
-        $cdn_url = autoptimizeUtils::tweak_cdn_url_if_needed( $this->cdn_url );
293
+        $cdn_url = autoptimizeUtils::tweak_cdn_url_if_needed($this->cdn_url);
294 294
 
295 295
         // Allows API/filter to further tweak the cdn url...
296
-        $cdn_url = apply_filters( 'autoptimize_filter_base_cdnurl', $cdn_url );
297
-        if ( ! empty( $cdn_url ) ) {
298
-            $this->debug_log( 'before=' . $url );
296
+        $cdn_url = apply_filters('autoptimize_filter_base_cdnurl', $cdn_url);
297
+        if (!empty($cdn_url)) {
298
+            $this->debug_log('before='.$url);
299 299
 
300 300
             // Simple str_replace-based approach fails when $url is protocol-or-host-relative.
301
-            $is_protocol_relative = autoptimizeUtils::is_protocol_relative( $url );
302
-            $is_host_relative     = ( ! $is_protocol_relative && ( '/' === $url{0} ) );
303
-            $cdn_url              = rtrim( $cdn_url, '/' );
301
+            $is_protocol_relative = autoptimizeUtils::is_protocol_relative($url);
302
+            $is_host_relative     = (!$is_protocol_relative && ('/' === $url{0} ));
303
+            $cdn_url              = rtrim($cdn_url, '/');
304 304
 
305
-            if ( $is_host_relative ) {
305
+            if ($is_host_relative) {
306 306
                 // Prepending host-relative urls with the cdn url.
307
-                $url = $cdn_url . $url;
307
+                $url = $cdn_url.$url;
308 308
             } else {
309 309
                 // Either a protocol-relative or "regular" url, replacing it either way.
310
-                if ( $is_protocol_relative ) {
310
+                if ($is_protocol_relative) {
311 311
                     // Massage $site_url so that simple str_replace() still "works" by
312 312
                     // searching for the protocol-relative version of AUTOPTIMIZE_WP_SITE_URL.
313
-                    $site_url = str_replace( array( 'http:', 'https:' ), '', AUTOPTIMIZE_WP_SITE_URL );
313
+                    $site_url = str_replace(array('http:', 'https:'), '', AUTOPTIMIZE_WP_SITE_URL);
314 314
                 } else {
315 315
                     $site_url = AUTOPTIMIZE_WP_SITE_URL;
316 316
                 }
317
-                $this->debug_log( '`' . $site_url . '` -> `' . $cdn_url . '` in `' . $url . '`' );
318
-                $url = str_replace( $site_url, $cdn_url, $url );
317
+                $this->debug_log('`'.$site_url.'` -> `'.$cdn_url.'` in `'.$url.'`');
318
+                $url = str_replace($site_url, $cdn_url, $url);
319 319
             }
320 320
 
321
-            $this->debug_log( 'after=' . $url );
321
+            $this->debug_log('after='.$url);
322 322
         }
323 323
 
324 324
         // Allow API filter to take further care of CDN replacement.
325
-        $url = apply_filters( 'autoptimize_filter_base_replace_cdn', $url );
325
+        $url = apply_filters('autoptimize_filter_base_replace_cdn', $url);
326 326
 
327 327
         return $url;
328 328
     }
@@ -340,18 +340,18 @@  discard block
 block discarded – undo
340 340
      *
341 341
      * @return void
342 342
      */
343
-    protected function inject_in_html( $payload, $where )
343
+    protected function inject_in_html($payload, $where)
344 344
     {
345 345
         $warned   = false;
346
-        $position = autoptimizeUtils::strpos( $this->content, $where[0] );
347
-        if ( false !== $position ) {
346
+        $position = autoptimizeUtils::strpos($this->content, $where[0]);
347
+        if (false !== $position) {
348 348
             // Found the tag, setup content/injection as specified.
349
-            if ( 'after' === $where[1] ) {
350
-                $content = $where[0] . $payload;
351
-            } elseif ( 'replace' === $where[1] ) {
349
+            if ('after' === $where[1]) {
350
+                $content = $where[0].$payload;
351
+            } elseif ('replace' === $where[1]) {
352 352
                 $content = $payload;
353 353
             } else {
354
-                $content = $payload . $where[0];
354
+                $content = $payload.$where[0];
355 355
             }
356 356
             // Place where specified.
357 357
             $this->content = autoptimizeUtils::substr_replace(
@@ -360,14 +360,14 @@  discard block
 block discarded – undo
360 360
                 $position,
361 361
                 // Using plain strlen() should be safe here for now, since
362 362
                 // we're not searching for multibyte chars here still...
363
-                strlen( $where[0] )
363
+                strlen($where[0])
364 364
             );
365 365
         } else {
366 366
             // Couldn't find what was specified, just append and add a warning.
367 367
             $this->content .= $payload;
368
-            if ( ! $warned ) {
369
-                $tag_display    = str_replace( array( '<', '>' ), '', $where[0] );
370
-                $this->content .= '<!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `' . $tag_display . '` missing --><!--/noptimize-->';
368
+            if (!$warned) {
369
+                $tag_display    = str_replace(array('<', '>'), '', $where[0]);
370
+                $this->content .= '<!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag `'.$tag_display.'` missing --><!--/noptimize-->';
371 371
                 $warned         = true;
372 372
             }
373 373
         }
@@ -381,10 +381,10 @@  discard block
 block discarded – undo
381 381
      *
382 382
      * @return bool
383 383
      */
384
-    protected function isremovable( $tag, $removables )
384
+    protected function isremovable($tag, $removables)
385 385
     {
386
-        foreach ( $removables as $match ) {
387
-            if ( false !== strpos( $tag, $match ) ) {
386
+        foreach ($removables as $match) {
387
+            if (false !== strpos($tag, $match)) {
388 388
                 return true;
389 389
             }
390 390
         }
@@ -399,10 +399,10 @@  discard block
 block discarded – undo
399 399
      *
400 400
      * @return string
401 401
      */
402
-    public function inject_minified_callback( $matches )
402
+    public function inject_minified_callback($matches)
403 403
     {
404 404
         static $conf = null;
405
-        if ( null === $conf ) {
405
+        if (null === $conf) {
406 406
             $conf = autoptimizeConfig::instance();
407 407
         }
408 408
 
@@ -417,62 +417,62 @@  discard block
 block discarded – undo
417 417
         $filehash = null;
418 418
 
419 419
         // Grab the parts we need.
420
-        $parts = explode( '|', $matches[1] );
421
-        if ( ! empty( $parts ) ) {
422
-            $filepath = isset( $parts[0] ) ? base64_decode( $parts[0] ) : null;
423
-            $filehash = isset( $parts[1] ) ? $parts[1] : null;
420
+        $parts = explode('|', $matches[1]);
421
+        if (!empty($parts)) {
422
+            $filepath = isset($parts[0]) ? base64_decode($parts[0]) : null;
423
+            $filehash = isset($parts[1]) ? $parts[1] : null;
424 424
         }
425 425
 
426 426
         // Bail early if something's not right...
427
-        if ( ! $filepath || ! $filehash ) {
427
+        if (!$filepath || !$filehash) {
428 428
             return "\n";
429 429
         }
430 430
 
431
-        $filecontent = file_get_contents( $filepath );
431
+        $filecontent = file_get_contents($filepath);
432 432
 
433 433
         // Some things are differently handled for css/js...
434
-        $is_js_file = ( '.js' === substr( $filepath, -3, 3 ) );
434
+        $is_js_file = ('.js' === substr($filepath, -3, 3));
435 435
 
436 436
         $is_css_file = false;
437
-        if ( ! $is_js_file ) {
438
-            $is_css_file = ( '.css' === substr( $filepath, -4, 4 ) );
437
+        if (!$is_js_file) {
438
+            $is_css_file = ('.css' === substr($filepath, -4, 4));
439 439
         }
440 440
 
441 441
         // BOMs being nuked here unconditionally (regardless of where they are)!
442
-        $filecontent = preg_replace( "#\x{EF}\x{BB}\x{BF}#", '', $filecontent );
442
+        $filecontent = preg_replace("#\x{EF}\x{BB}\x{BF}#", '', $filecontent);
443 443
 
444 444
         // Remove comments and blank lines.
445
-        if ( $is_js_file ) {
446
-            $filecontent = preg_replace( '#^\s*\/\/.*$#Um', '', $filecontent );
445
+        if ($is_js_file) {
446
+            $filecontent = preg_replace('#^\s*\/\/.*$#Um', '', $filecontent);
447 447
         }
448 448
 
449 449
         // Nuke un-important comments.
450
-        $filecontent = preg_replace( '#^\s*\/\*[^!].*\*\/\s?#Um', '', $filecontent );
450
+        $filecontent = preg_replace('#^\s*\/\*[^!].*\*\/\s?#Um', '', $filecontent);
451 451
 
452 452
         // Normalize newlines.
453
-        $filecontent = preg_replace( '#(^[\r\n]*|[\r\n]+)[\s\t]*[\r\n]+#', "\n", $filecontent );
453
+        $filecontent = preg_replace('#(^[\r\n]*|[\r\n]+)[\s\t]*[\r\n]+#', "\n", $filecontent);
454 454
 
455 455
         // JS specifics.
456
-        if ( $is_js_file ) {
456
+        if ($is_js_file) {
457 457
             // Append a semicolon at the end of js files if it's missing.
458
-            $last_char = substr( $filecontent, -1, 1 );
459
-            if ( ';' !== $last_char && '}' !== $last_char ) {
458
+            $last_char = substr($filecontent, -1, 1);
459
+            if (';' !== $last_char && '}' !== $last_char) {
460 460
                 $filecontent .= ';';
461 461
             }
462 462
             // Check if try/catch should be used.
463
-            $opt_js_try_catch = $conf->get( 'autoptimize_js_trycatch' );
464
-            if ( 'on' === $opt_js_try_catch ) {
463
+            $opt_js_try_catch = $conf->get('autoptimize_js_trycatch');
464
+            if ('on' === $opt_js_try_catch) {
465 465
                 // It should, wrap in try/catch.
466
-                $filecontent = 'try{' . $filecontent . '}catch(e){}';
466
+                $filecontent = 'try{'.$filecontent.'}catch(e){}';
467 467
             }
468
-        } elseif ( $is_css_file ) {
469
-            $filecontent = autoptimizeStyles::fixurls( $filepath, $filecontent );
468
+        } elseif ($is_css_file) {
469
+            $filecontent = autoptimizeStyles::fixurls($filepath, $filecontent);
470 470
         } else {
471 471
             $filecontent = '';
472 472
         }
473 473
 
474 474
         // Return modified (or empty!) code/content.
475
-        return "\n" . $filecontent;
475
+        return "\n".$filecontent;
476 476
     }
477 477
 
478 478
     /**
@@ -482,13 +482,13 @@  discard block
 block discarded – undo
482 482
      *
483 483
      * @return string
484 484
      */
485
-    protected function inject_minified( $in )
485
+    protected function inject_minified($in)
486 486
     {
487 487
         $out = $in;
488
-        if ( false !== strpos( $in, '%%INJECTLATER%%' ) ) {
488
+        if (false !== strpos($in, '%%INJECTLATER%%')) {
489 489
             $out = preg_replace_callback(
490
-                '#\/\*\!%%INJECTLATER' . AUTOPTIMIZE_HASH . '%%(.*?)%%INJECTLATER%%\*\/#is',
491
-                array( $this, 'inject_minified_callback' ),
490
+                '#\/\*\!%%INJECTLATER'.AUTOPTIMIZE_HASH.'%%(.*?)%%INJECTLATER%%\*\/#is',
491
+                array($this, 'inject_minified_callback'),
492 492
                 $in
493 493
             );
494 494
         }
@@ -508,9 +508,9 @@  discard block
 block discarded – undo
508 508
      *
509 509
      * @return string
510 510
      */
511
-    public static function build_injectlater_marker( $filepath, $hash )
511
+    public static function build_injectlater_marker($filepath, $hash)
512 512
     {
513
-        $contents = '/*!' . self::build_marker( 'INJECTLATER', $filepath, $hash ) . '*/';
513
+        $contents = '/*!'.self::build_marker('INJECTLATER', $filepath, $hash).'*/';
514 514
 
515 515
         return $contents;
516 516
     }
@@ -528,18 +528,18 @@  discard block
 block discarded – undo
528 528
      *
529 529
      * @return string
530 530
      */
531
-    public static function build_marker( $name, $data, $hash = null )
531
+    public static function build_marker($name, $data, $hash = null)
532 532
     {
533 533
         // Start the marker, add the data.
534
-        $marker = '%%' . $name . AUTOPTIMIZE_HASH . '%%' . base64_encode( $data );
534
+        $marker = '%%'.$name.AUTOPTIMIZE_HASH.'%%'.base64_encode($data);
535 535
 
536 536
         // Add the hash if provided.
537
-        if ( null !== $hash ) {
538
-            $marker .= '|' . $hash;
537
+        if (null !== $hash) {
538
+            $marker .= '|'.$hash;
539 539
         }
540 540
 
541 541
         // Close the marker.
542
-        $marker .= '%%' . $name . '%%';
542
+        $marker .= '%%'.$name.'%%';
543 543
 
544 544
         return $marker;
545 545
     }
@@ -559,22 +559,22 @@  discard block
 block discarded – undo
559 559
      *
560 560
      * @return string
561 561
      */
562
-    public static function replace_contents_with_marker_if_exists( $marker, $search, $re_replace_pattern, $content )
562
+    public static function replace_contents_with_marker_if_exists($marker, $search, $re_replace_pattern, $content)
563 563
     {
564 564
         $found = false;
565 565
 
566
-        $is_regex = autoptimizeUtils::str_is_valid_regex( $search );
567
-        if ( $is_regex ) {
568
-            $found = preg_match( $search, $content );
566
+        $is_regex = autoptimizeUtils::str_is_valid_regex($search);
567
+        if ($is_regex) {
568
+            $found = preg_match($search, $content);
569 569
         } else {
570
-            $found = ( false !== strpos( $content, $search ) );
570
+            $found = (false !== strpos($content, $search));
571 571
         }
572 572
 
573
-        if ( $found ) {
573
+        if ($found) {
574 574
             $content = preg_replace_callback(
575 575
                 $re_replace_pattern,
576
-                function( $matches ) use ( $marker ) {
577
-                    return autoptimizeBase::build_marker( $marker, $matches[0] );
576
+                function($matches) use ($marker) {
577
+                    return autoptimizeBase::build_marker($marker, $matches[0]);
578 578
                 },
579 579
                 $content
580 580
             );
@@ -591,13 +591,13 @@  discard block
 block discarded – undo
591 591
      *
592 592
      * @return string
593 593
      */
594
-    public static function restore_marked_content( $marker, $content )
594
+    public static function restore_marked_content($marker, $content)
595 595
     {
596
-        if ( false !== strpos( $content, $marker ) ) {
596
+        if (false !== strpos($content, $marker)) {
597 597
             $content = preg_replace_callback(
598
-                '#%%' . $marker . AUTOPTIMIZE_HASH . '%%(.*?)%%' . $marker . '%%#is',
599
-                function ( $matches ) {
600
-                    return base64_decode( $matches[1] );
598
+                '#%%'.$marker.AUTOPTIMIZE_HASH.'%%(.*?)%%'.$marker.'%%#is',
599
+                function($matches) {
600
+                    return base64_decode($matches[1]);
601 601
                 },
602 602
                 $content
603 603
             );
@@ -613,17 +613,17 @@  discard block
 block discarded – undo
613 613
      *
614 614
      * @return void
615 615
      */
616
-    protected function debug_log( $data )
616
+    protected function debug_log($data)
617 617
     {
618
-        if ( ! isset( $this->debug_log ) || ! $this->debug_log ) {
618
+        if (!isset($this->debug_log) || !$this->debug_log) {
619 619
             return;
620 620
         }
621 621
 
622
-        if ( ! is_string( $data ) && ! is_resource( $data ) ) {
623
-            $data = var_export( $data, true );
622
+        if (!is_string($data) && !is_resource($data)) {
623
+            $data = var_export($data, true);
624 624
         }
625 625
 
626
-        error_log( $data );
626
+        error_log($data);
627 627
     }
628 628
 
629 629
     /**
@@ -633,12 +633,12 @@  discard block
 block discarded – undo
633 633
      *
634 634
      * @return bool|string to be minified code or false.
635 635
      */
636
-    protected function prepare_minify_single( $filepath )
636
+    protected function prepare_minify_single($filepath)
637 637
     {
638 638
         // Decide what we're dealing with, return false if we don't know.
639
-        if ( $this->str_ends_in( $filepath, '.js' ) ) {
639
+        if ($this->str_ends_in($filepath, '.js')) {
640 640
             $type = 'js';
641
-        } elseif ( $this->str_ends_in( $filepath, '.css' ) ) {
641
+        } elseif ($this->str_ends_in($filepath, '.css')) {
642 642
             $type = 'css';
643 643
         } else {
644 644
             return false;
@@ -647,18 +647,18 @@  discard block
 block discarded – undo
647 647
         // Bail if it looks like its already minifed (by having -min or .min
648 648
         // in filename) or if it looks like WP jquery.js (which is minified).
649 649
         $minified_variants = array(
650
-            '-min.' . $type,
651
-            '.min.' . $type,
650
+            '-min.'.$type,
651
+            '.min.'.$type,
652 652
             'js/jquery/jquery.js',
653 653
         );
654
-        foreach ( $minified_variants as $ending ) {
655
-            if ( $this->str_ends_in( $filepath, $ending ) ) {
654
+        foreach ($minified_variants as $ending) {
655
+            if ($this->str_ends_in($filepath, $ending)) {
656 656
                 return false;
657 657
             }
658 658
         }
659 659
 
660 660
         // Get file contents, bail if empty.
661
-        $contents = file_get_contents( $filepath );
661
+        $contents = file_get_contents($filepath);
662 662
 
663 663
         return $contents;
664 664
     }
@@ -671,12 +671,12 @@  discard block
 block discarded – undo
671 671
      *
672 672
      * @return string
673 673
      */
674
-    protected function build_minify_single_url( autoptimizeCache $cache )
674
+    protected function build_minify_single_url(autoptimizeCache $cache)
675 675
     {
676
-        $url = AUTOPTIMIZE_CACHE_URL . $cache->getname();
676
+        $url = AUTOPTIMIZE_CACHE_URL.$cache->getname();
677 677
 
678 678
         // CDN-replace the resulting URL if needed...
679
-        $url = $this->url_replace_cdn( $url );
679
+        $url = $this->url_replace_cdn($url);
680 680
 
681 681
         return $url;
682 682
     }
@@ -689,15 +689,15 @@  discard block
 block discarded – undo
689 689
      *
690 690
      * @return bool
691 691
      */
692
-    protected function str_ends_in( $str, $test )
692
+    protected function str_ends_in($str, $test)
693 693
     {
694 694
         // @codingStandardsIgnoreStart
695 695
         // substr_compare() is bugged on 5.5.11: https://3v4l.org/qGYBH
696 696
         // return ( 0 === substr_compare( $str, $test, -strlen( $test ) ) );
697 697
         // @codingStandardsIgnoreEnd
698 698
 
699
-        $length = strlen( $test );
699
+        $length = strlen($test);
700 700
 
701
-        return ( substr( $str, -$length, $length ) === $test );
701
+        return (substr($str, -$length, $length) === $test);
702 702
     }
703 703
 }
Please login to merge, or discard this patch.
classes/autoptimizeVersionUpdatesHandler.php 1 patch
Spacing   +60 added lines, -60 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles version updates and should only be instantiated in autoptimize.php if/when needed.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -16,9 +16,9 @@  discard block
 block discarded – undo
16 16
      */
17 17
     protected $current_major_version = null;
18 18
 
19
-    public function __construct( $current_version )
19
+    public function __construct($current_version)
20 20
     {
21
-        $this->current_major_version = substr( $current_version, 0, 3 );
21
+        $this->current_major_version = substr($current_version, 0, 3);
22 22
     }
23 23
 
24 24
     /**
@@ -29,7 +29,7 @@  discard block
 block discarded – undo
29 29
     {
30 30
         $major_update = false;
31 31
 
32
-        switch ( $this->current_major_version ) {
32
+        switch ($this->current_major_version) {
33 33
             case '1.6':
34 34
                 $this->upgrade_from_1_6();
35 35
                 $major_update = true;
@@ -47,7 +47,7 @@  discard block
 block discarded – undo
47 47
                 $major_update = true;
48 48
                 // No break, intentionally, so all upgrades are ran during a single request...
49 49
             case '2.4':
50
-                if ( get_option( 'autoptimize_version', 'none' ) == '2.4.2' ) {
50
+                if (get_option('autoptimize_version', 'none') == '2.4.2') {
51 51
                     $this->upgrade_from_2_4_2();
52 52
                 }
53 53
                 $this->upgrade_from_2_4();
@@ -55,7 +55,7 @@  discard block
 block discarded – undo
55 55
                 // No break, intentionally, so all upgrades are ran during a single request...
56 56
         }
57 57
 
58
-        if ( true === $major_update ) {
58
+        if (true === $major_update) {
59 59
             $this->on_major_version_update();
60 60
         }
61 61
     }
@@ -67,19 +67,19 @@  discard block
 block discarded – undo
67 67
      *
68 68
      * @param string $target Target version to check against (ie., the currently running one).
69 69
      */
70
-    public static function check_installed_and_update( $target )
70
+    public static function check_installed_and_update($target)
71 71
     {
72
-        $db_version = get_option( 'autoptimize_version', 'none' );
73
-        if ( $db_version !== $target ) {
74
-            if ( 'none' === $db_version ) {
75
-                add_action( 'admin_notices', 'autoptimizeMain::notice_installed' );
72
+        $db_version = get_option('autoptimize_version', 'none');
73
+        if ($db_version !== $target) {
74
+            if ('none' === $db_version) {
75
+                add_action('admin_notices', 'autoptimizeMain::notice_installed');
76 76
             } else {
77
-                $updater = new self( $db_version );
77
+                $updater = new self($db_version);
78 78
                 $updater->run_needed_major_upgrades();
79 79
             }
80 80
 
81 81
             // Versions differed, upgrades happened if needed, store the new version.
82
-            update_option( 'autoptimize_version', $target );
82
+            update_option('autoptimize_version', $target);
83 83
         }
84 84
     }
85 85
 
@@ -90,10 +90,10 @@  discard block
 block discarded – undo
90 90
     protected function on_major_version_update()
91 91
     {
92 92
         // The transients guard here prevents stale object caches from busting the cache on every request.
93
-        if ( false == get_transient( 'autoptimize_stale_option_buster' ) ) {
94
-            set_transient( 'autoptimize_stale_option_buster', 'Mamsie & Liessie zehhe: ZWIJH!', HOUR_IN_SECONDS );
93
+        if (false == get_transient('autoptimize_stale_option_buster')) {
94
+            set_transient('autoptimize_stale_option_buster', 'Mamsie & Liessie zehhe: ZWIJH!', HOUR_IN_SECONDS);
95 95
             autoptimizeCache::clearall();
96
-            add_action( 'admin_notices', 'autoptimizeMain::notice_updated' );
96
+            add_action('admin_notices', 'autoptimizeMain::notice_updated');
97 97
         }
98 98
     }
99 99
 
@@ -103,7 +103,7 @@  discard block
 block discarded – undo
103 103
     private function upgrade_from_1_6()
104 104
     {
105 105
         // If user was on version 1.6.x, force advanced options to be shown by default.
106
-        update_option( 'autoptimize_show_adv', '1' );
106
+        update_option('autoptimize_show_adv', '1');
107 107
 
108 108
         // And remove old options.
109 109
         $to_delete_options = array(
@@ -115,8 +115,8 @@  discard block
 block discarded – undo
115 115
             'autoptimize_cdn_img_url',
116 116
             'autoptimize_css_yui',
117 117
         );
118
-        foreach ( $to_delete_options as $del_opt ) {
119
-            delete_option( $del_opt );
118
+        foreach ($to_delete_options as $del_opt) {
119
+            delete_option($del_opt);
120 120
         }
121 121
     }
122 122
 
@@ -127,29 +127,29 @@  discard block
 block discarded – undo
127 127
      */
128 128
     private function upgrade_from_1_7()
129 129
     {
130
-        if ( ! is_multisite() ) {
131
-            $css_exclude = get_option( 'autoptimize_css_exclude' );
132
-            if ( empty( $css_exclude ) ) {
130
+        if (!is_multisite()) {
131
+            $css_exclude = get_option('autoptimize_css_exclude');
132
+            if (empty($css_exclude)) {
133 133
                 $css_exclude = 'admin-bar.min.css, dashicons.min.css';
134
-            } elseif ( false === strpos( $css_exclude, 'dashicons.min.css' ) ) {
134
+            } elseif (false === strpos($css_exclude, 'dashicons.min.css')) {
135 135
                 $css_exclude .= ', dashicons.min.css';
136 136
             }
137
-            update_option( 'autoptimize_css_exclude', $css_exclude );
137
+            update_option('autoptimize_css_exclude', $css_exclude);
138 138
         } else {
139 139
             global $wpdb;
140
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
140
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
141 141
             $original_blog_id = get_current_blog_id();
142
-            foreach ( $blog_ids as $blog_id ) {
143
-                switch_to_blog( $blog_id );
144
-                $css_exclude = get_option( 'autoptimize_css_exclude' );
145
-                if ( empty( $css_exclude ) ) {
142
+            foreach ($blog_ids as $blog_id) {
143
+                switch_to_blog($blog_id);
144
+                $css_exclude = get_option('autoptimize_css_exclude');
145
+                if (empty($css_exclude)) {
146 146
                     $css_exclude = 'admin-bar.min.css, dashicons.min.css';
147
-                } elseif ( false === strpos( $css_exclude, 'dashicons.min.css' ) ) {
147
+                } elseif (false === strpos($css_exclude, 'dashicons.min.css')) {
148 148
                     $css_exclude .= ', dashicons.min.css';
149 149
                 }
150
-                update_option( 'autoptimize_css_exclude', $css_exclude );
150
+                update_option('autoptimize_css_exclude', $css_exclude);
151 151
             }
152
-            switch_to_blog( $original_blog_id );
152
+            switch_to_blog($original_blog_id);
153 153
         }
154 154
     }
155 155
 
@@ -161,19 +161,19 @@  discard block
 block discarded – undo
161 161
      */
162 162
     private function upgrade_from_1_9()
163 163
     {
164
-        if ( ! is_multisite() ) {
165
-            update_option( 'autoptimize_css_include_inline', 'on' );
166
-            update_option( 'autoptimize_js_include_inline', 'on' );
164
+        if (!is_multisite()) {
165
+            update_option('autoptimize_css_include_inline', 'on');
166
+            update_option('autoptimize_js_include_inline', 'on');
167 167
         } else {
168 168
             global $wpdb;
169
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
169
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
170 170
             $original_blog_id = get_current_blog_id();
171
-            foreach ( $blog_ids as $blog_id ) {
172
-                switch_to_blog( $blog_id );
173
-                update_option( 'autoptimize_css_include_inline', 'on' );
174
-                update_option( 'autoptimize_js_include_inline', 'on' );
171
+            foreach ($blog_ids as $blog_id) {
172
+                switch_to_blog($blog_id);
173
+                update_option('autoptimize_css_include_inline', 'on');
174
+                update_option('autoptimize_js_include_inline', 'on');
175 175
             }
176
-            switch_to_blog( $original_blog_id );
176
+            switch_to_blog($original_blog_id);
177 177
         }
178 178
     }
179 179
 
@@ -184,17 +184,17 @@  discard block
 block discarded – undo
184 184
      */
185 185
     private function upgrade_from_2_2()
186 186
     {
187
-        if ( ! is_multisite() ) {
187
+        if (!is_multisite()) {
188 188
             $this->do_2_2_settings_update();
189 189
         } else {
190 190
             global $wpdb;
191
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
191
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
192 192
             $original_blog_id = get_current_blog_id();
193
-            foreach ( $blog_ids as $blog_id ) {
194
-                switch_to_blog( $blog_id );
193
+            foreach ($blog_ids as $blog_id) {
194
+                switch_to_blog($blog_id);
195 195
                 $this->do_2_2_settings_update();
196 196
             }
197
-            switch_to_blog( $original_blog_id );
197
+            switch_to_blog($original_blog_id);
198 198
         }
199 199
     }
200 200
 
@@ -203,12 +203,12 @@  discard block
 block discarded – undo
203 203
      */
204 204
     private function do_2_2_settings_update()
205 205
     {
206
-        $nogooglefont    = get_option( 'autoptimize_css_nogooglefont', '' );
207
-        $ao_extrasetting = get_option( 'autoptimize_extra_settings', '' );
208
-        if ( ( $nogooglefont ) && ( empty( $ao_extrasetting ) ) ) {
209
-            update_option( 'autoptimize_extra_settings', autoptimizeConfig::get_ao_extra_default_options() );
206
+        $nogooglefont    = get_option('autoptimize_css_nogooglefont', '');
207
+        $ao_extrasetting = get_option('autoptimize_extra_settings', '');
208
+        if (($nogooglefont) && (empty($ao_extrasetting))) {
209
+            update_option('autoptimize_extra_settings', autoptimizeConfig::get_ao_extra_default_options());
210 210
         }
211
-        delete_option( 'autoptimize_css_nogooglefont' );
211
+        delete_option('autoptimize_css_nogooglefont');
212 212
     }
213 213
 
214 214
     /**
@@ -220,29 +220,29 @@  discard block
 block discarded – undo
220 220
         $jobs = _get_cron_array();
221 221
 
222 222
         // Remove all ao_cachechecker cron jobs (for now).
223
-        foreach ( $jobs as $when => $job ) {
224
-            $name = key( $job );
223
+        foreach ($jobs as $when => $job) {
224
+            $name = key($job);
225 225
 
226
-            if ( false !== strpos( $name, 'ao_cachechecker' ) ) {
227
-                unset( $jobs[ $when ] );
226
+            if (false !== strpos($name, 'ao_cachechecker')) {
227
+                unset($jobs[$when]);
228 228
             }
229 229
         }
230 230
 
231 231
         // Save the data.
232
-        _set_cron_array( $jobs );
232
+        _set_cron_array($jobs);
233 233
     }
234 234
 
235 235
     /**
236 236
      * Migrate imgopt options from autoptimize_extra_settings to autoptimize_imgopt_settings
237 237
      */
238 238
     private function upgrade_from_2_4() {
239
-        $extra_settings  = get_option( 'autoptimize_extra_settings' );
240
-        $imgopt_settings = get_option( 'autoptimize_imgopt_settings' );
241
-        if ( empty( $imgopt_settings ) ) {
239
+        $extra_settings  = get_option('autoptimize_extra_settings');
240
+        $imgopt_settings = get_option('autoptimize_imgopt_settings');
241
+        if (empty($imgopt_settings)) {
242 242
             $imgopt_settings                                        = autoptimizeConfig::get_ao_imgopt_default_options();
243 243
             $imgopt_settings['autoptimize_imgopt_checkbox_field_1'] = $extra_settings['autoptimize_extra_checkbox_field_5'];
244 244
             $imgopt_settings['autoptimize_imgopt_select_field_2']   = $extra_settings['autoptimize_extra_select_field_6'];
245
-            update_option( 'autoptimize_imgopt_settings', $imgopt_settings );
245
+            update_option('autoptimize_imgopt_settings', $imgopt_settings);
246 246
         }
247 247
     }
248 248
 }
Please login to merge, or discard this patch.
classes/autoptimizeStyles.php 1 patch
Spacing   +313 added lines, -313 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Class for CSS optimization.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -49,53 +49,53 @@  discard block
 block discarded – undo
49 49
     // public $cdn_url; // Used all over the place implicitly, so will have to be either public or protected :/ .
50 50
 
51 51
     // Reads the page and collects style tags.
52
-    public function read( $options )
52
+    public function read($options)
53 53
     {
54
-        $noptimizeCSS = apply_filters( 'autoptimize_filter_css_noptimize', false, $this->content );
55
-        if ( $noptimizeCSS ) {
54
+        $noptimizeCSS = apply_filters('autoptimize_filter_css_noptimize', false, $this->content);
55
+        if ($noptimizeCSS) {
56 56
             return false;
57 57
         }
58 58
 
59
-        $whitelistCSS = apply_filters( 'autoptimize_filter_css_whitelist', '', $this->content );
60
-        if ( ! empty( $whitelistCSS ) ) {
61
-            $this->whitelist = array_filter( array_map( 'trim', explode( ',', $whitelistCSS ) ) );
59
+        $whitelistCSS = apply_filters('autoptimize_filter_css_whitelist', '', $this->content);
60
+        if (!empty($whitelistCSS)) {
61
+            $this->whitelist = array_filter(array_map('trim', explode(',', $whitelistCSS)));
62 62
         }
63 63
 
64
-        $removableCSS = apply_filters( 'autoptimize_filter_css_removables', '' );
65
-        if ( ! empty( $removableCSS ) ) {
66
-            $this->cssremovables = array_filter( array_map( 'trim', explode( ',', $removableCSS ) ) );
64
+        $removableCSS = apply_filters('autoptimize_filter_css_removables', '');
65
+        if (!empty($removableCSS)) {
66
+            $this->cssremovables = array_filter(array_map('trim', explode(',', $removableCSS)));
67 67
         }
68 68
 
69
-        $this->cssinlinesize = apply_filters( 'autoptimize_filter_css_inlinesize', 256 );
69
+        $this->cssinlinesize = apply_filters('autoptimize_filter_css_inlinesize', 256);
70 70
 
71 71
         // filter to "late inject minified CSS", default to true for now (it is faster).
72
-        $this->inject_min_late = apply_filters( 'autoptimize_filter_css_inject_min_late', true );
72
+        $this->inject_min_late = apply_filters('autoptimize_filter_css_inject_min_late', true);
73 73
 
74 74
         // Remove everything that's not the header.
75
-        if ( apply_filters( 'autoptimize_filter_css_justhead', $options['justhead'] ) ) {
76
-            $content             = explode( '</head>', $this->content, 2 );
77
-            $this->content       = $content[0] . '</head>';
75
+        if (apply_filters('autoptimize_filter_css_justhead', $options['justhead'])) {
76
+            $content             = explode('</head>', $this->content, 2);
77
+            $this->content       = $content[0].'</head>';
78 78
             $this->restofcontent = $content[1];
79 79
         }
80 80
 
81 81
         // Determine whether we're doing CSS-files aggregation or not.
82
-        if ( isset( $options['aggregate'] ) && ! $options['aggregate'] ) {
82
+        if (isset($options['aggregate']) && !$options['aggregate']) {
83 83
             $this->aggregate = false;
84 84
         }
85 85
         // Returning true for "dontaggregate" turns off aggregation.
86
-        if ( $this->aggregate && apply_filters( 'autoptimize_filter_css_dontaggregate', false ) ) {
86
+        if ($this->aggregate && apply_filters('autoptimize_filter_css_dontaggregate', false)) {
87 87
             $this->aggregate = false;
88 88
         }
89 89
 
90 90
         // include inline?
91
-        if ( apply_filters( 'autoptimize_css_include_inline', $options['include_inline'] ) ) {
91
+        if (apply_filters('autoptimize_css_include_inline', $options['include_inline'])) {
92 92
             $this->include_inline = true;
93 93
         }
94 94
 
95 95
         // List of CSS strings which are excluded from autoptimization.
96
-        $excludeCSS = apply_filters( 'autoptimize_filter_css_exclude', $options['css_exclude'], $this->content );
97
-        if ( '' !== $excludeCSS ) {
98
-            $this->dontmove = array_filter( array_map( 'trim', explode( ',', $excludeCSS ) ) );
96
+        $excludeCSS = apply_filters('autoptimize_filter_css_exclude', $options['css_exclude'], $this->content);
97
+        if ('' !== $excludeCSS) {
98
+            $this->dontmove = array_filter(array_map('trim', explode(',', $excludeCSS)));
99 99
         } else {
100 100
             $this->dontmove = array();
101 101
         }
@@ -106,16 +106,16 @@  discard block
 block discarded – undo
106 106
         // Should we defer css?
107 107
         // value: true / false.
108 108
         $this->defer = $options['defer'];
109
-        $this->defer = apply_filters( 'autoptimize_filter_css_defer', $this->defer, $this->content );
109
+        $this->defer = apply_filters('autoptimize_filter_css_defer', $this->defer, $this->content);
110 110
 
111 111
         // Should we inline while deferring?
112 112
         // value: inlined CSS.
113
-        $this->defer_inline = apply_filters( 'autoptimize_filter_css_defer_inline', $options['defer_inline'], $this->content );
113
+        $this->defer_inline = apply_filters('autoptimize_filter_css_defer_inline', $options['defer_inline'], $this->content);
114 114
 
115 115
         // Should we inline?
116 116
         // value: true / false.
117 117
         $this->inline = $options['inline'];
118
-        $this->inline = apply_filters( 'autoptimize_filter_css_inline', $this->inline, $this->content );
118
+        $this->inline = apply_filters('autoptimize_filter_css_inline', $this->inline, $this->content);
119 119
 
120 120
         // Store cdn url.
121 121
         $this->cdn_url = $options['cdn_url'];
@@ -124,12 +124,12 @@  discard block
 block discarded – undo
124 124
         $this->datauris = $options['datauris'];
125 125
 
126 126
         // Determine whether excluded files should be minified if not yet so.
127
-        if ( ! $options['minify_excluded'] && $options['aggregate'] ) {
127
+        if (!$options['minify_excluded'] && $options['aggregate']) {
128 128
             $this->minify_excluded = false;
129 129
         }
130 130
 
131 131
         // noptimize me.
132
-        $this->content = $this->hide_noptimize( $this->content );
132
+        $this->content = $this->hide_noptimize($this->content);
133 133
 
134 134
         // Exclude (no)script, as those may contain CSS which should be left as is.
135 135
         $this->content = $this->replace_contents_with_marker_if_exists(
@@ -140,26 +140,26 @@  discard block
 block discarded – undo
140 140
         );
141 141
 
142 142
         // Save IE hacks.
143
-        $this->content = $this->hide_iehacks( $this->content );
143
+        $this->content = $this->hide_iehacks($this->content);
144 144
 
145 145
         // Hide HTML comments.
146
-        $this->content = $this->hide_comments( $this->content );
146
+        $this->content = $this->hide_comments($this->content);
147 147
 
148 148
         // Get <style> and <link>.
149
-        if ( preg_match_all( '#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi', $this->content, $matches ) ) {
149
+        if (preg_match_all('#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi', $this->content, $matches)) {
150 150
 
151
-            foreach ( $matches[0] as $tag ) {
152
-                if ( $this->isremovable( $tag, $this->cssremovables ) ) {
153
-                    $this->content = str_replace( $tag, '', $this->content );
154
-                } elseif ( $this->ismovable( $tag ) ) {
151
+            foreach ($matches[0] as $tag) {
152
+                if ($this->isremovable($tag, $this->cssremovables)) {
153
+                    $this->content = str_replace($tag, '', $this->content);
154
+                } elseif ($this->ismovable($tag)) {
155 155
                     // Get the media.
156
-                    if ( false !== strpos( $tag, 'media=' ) ) {
157
-                        preg_match( '#media=(?:"|\')([^>]*)(?:"|\')#Ui', $tag, $medias );
158
-                        $medias = explode( ',', $medias[1] );
156
+                    if (false !== strpos($tag, 'media=')) {
157
+                        preg_match('#media=(?:"|\')([^>]*)(?:"|\')#Ui', $tag, $medias);
158
+                        $medias = explode(',', $medias[1]);
159 159
                         $media = array();
160
-                        foreach ( $medias as $elem ) {
160
+                        foreach ($medias as $elem) {
161 161
                             /* $media[] = current(explode(' ',trim($elem),2)); */
162
-                            if ( empty( $elem ) ) {
162
+                            if (empty($elem)) {
163 163
                                 $elem = 'all';
164 164
                             }
165 165
 
@@ -167,69 +167,69 @@  discard block
 block discarded – undo
167 167
                         }
168 168
                     } else {
169 169
                         // No media specified - applies to all.
170
-                        $media = array( 'all' );
170
+                        $media = array('all');
171 171
                     }
172 172
 
173
-                    $media = apply_filters( 'autoptimize_filter_css_tagmedia', $media, $tag );
173
+                    $media = apply_filters('autoptimize_filter_css_tagmedia', $media, $tag);
174 174
 
175
-                    if ( preg_match( '#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source ) ) {
175
+                    if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
176 176
                         // <link>.
177
-                        $url  = current( explode( '?', $source[2], 2 ) );
178
-                        $path = $this->getpath( $url );
177
+                        $url  = current(explode('?', $source[2], 2));
178
+                        $path = $this->getpath($url);
179 179
 
180
-                        if ( false !== $path && preg_match( '#\.css$#', $path ) ) {
180
+                        if (false !== $path && preg_match('#\.css$#', $path)) {
181 181
                             // Good link.
182
-                            $this->css[] = array( $media, $path );
182
+                            $this->css[] = array($media, $path);
183 183
                         } else {
184 184
                             // Link is dynamic (.php etc).
185
-                            $new_tag = $this->optionally_defer_excluded( $tag, 'none' );
186
-                            if ( $new_tag !== $tag ) {
187
-                                $this->content = str_replace( $tag, $new_tag, $this->content );
185
+                            $new_tag = $this->optionally_defer_excluded($tag, 'none');
186
+                            if ($new_tag !== $tag) {
187
+                                $this->content = str_replace($tag, $new_tag, $this->content);
188 188
                             }
189 189
                             $tag = '';
190 190
                         }
191 191
                     } else {
192 192
                         // Inline css in style tags can be wrapped in comment tags, so restore comments.
193
-                        $tag = $this->restore_comments( $tag );
194
-                        preg_match( '#<style.*>(.*)</style>#Usmi', $tag, $code );
193
+                        $tag = $this->restore_comments($tag);
194
+                        preg_match('#<style.*>(.*)</style>#Usmi', $tag, $code);
195 195
 
196 196
                         // And re-hide them to be able to to the removal based on tag.
197
-                        $tag = $this->hide_comments( $tag );
197
+                        $tag = $this->hide_comments($tag);
198 198
 
199
-                        if ( $this->include_inline ) {
200
-                            $code = preg_replace( '#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm', '$1', $code[1] );
201
-                            $this->css[] = array( $media, 'INLINE;' . $code );
199
+                        if ($this->include_inline) {
200
+                            $code = preg_replace('#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm', '$1', $code[1]);
201
+                            $this->css[] = array($media, 'INLINE;'.$code);
202 202
                         } else {
203 203
                             $tag = '';
204 204
                         }
205 205
                     }
206 206
 
207 207
                     // Remove the original style tag.
208
-                    $this->content = str_replace( $tag, '', $this->content );
208
+                    $this->content = str_replace($tag, '', $this->content);
209 209
                 } else {
210 210
                     // Excluded CSS, minify that file:
211 211
                     // -> if aggregate is on and exclude minify is on
212 212
                     // -> if aggregate is off and the file is not in dontmove.
213
-                    if ( preg_match( '#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source ) ) {
214
-                        $exploded_url = explode( '?', $source[2], 2 );
213
+                    if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
214
+                        $exploded_url = explode('?', $source[2], 2);
215 215
                         $url          = $exploded_url[0];
216
-                        $path         = $this->getpath( $url );
216
+                        $path         = $this->getpath($url);
217 217
 
218
-                        if ( $path && ( $this->minify_excluded || apply_filters( 'autoptimize_filter_css_minify_excluded', false, $url ) ) ) {
219
-                            $consider_minified_array = apply_filters( 'autoptimize_filter_css_consider_minified', false );
220
-                            if ( ( false === $this->aggregate && str_replace( $this->dontmove, '', $path ) === $path ) || ( true === $this->aggregate && ( false === $consider_minified_array || str_replace( $consider_minified_array, '', $path ) === $path ) ) ) {
221
-                                $minified_url = $this->minify_single( $path );
222
-                                if ( ! empty( $minified_url ) ) {
218
+                        if ($path && ($this->minify_excluded || apply_filters('autoptimize_filter_css_minify_excluded', false, $url))) {
219
+                            $consider_minified_array = apply_filters('autoptimize_filter_css_consider_minified', false);
220
+                            if ((false === $this->aggregate && str_replace($this->dontmove, '', $path) === $path) || (true === $this->aggregate && (false === $consider_minified_array || str_replace($consider_minified_array, '', $path) === $path))) {
221
+                                $minified_url = $this->minify_single($path);
222
+                                if (!empty($minified_url)) {
223 223
                                     // Replace orig URL with cached minified URL.
224
-                                    $new_tag = str_replace( $url, $minified_url, $tag );
224
+                                    $new_tag = str_replace($url, $minified_url, $tag);
225 225
                                 } else {
226 226
                                     $new_tag = $tag;
227 227
                                 }
228 228
 
229
-                                $new_tag = $this->optionally_defer_excluded( $new_tag, $url );
229
+                                $new_tag = $this->optionally_defer_excluded($new_tag, $url);
230 230
 
231 231
                                 // And replace!
232
-                                $this->content = str_replace( $tag, $new_tag, $this->content );
232
+                                $this->content = str_replace($tag, $new_tag, $this->content);
233 233
                             }
234 234
                         }
235 235
                     }
@@ -251,10 +251,10 @@  discard block
 block discarded – undo
251 251
      *
252 252
      * @return string $new_tag
253 253
      */
254
-    private function optionally_defer_excluded( $new_tag, $url = '' )
254
+    private function optionally_defer_excluded($new_tag, $url = '')
255 255
     {
256 256
         // Defer single CSS if "inline & defer" is ON and there is inline CSS.
257
-        if ( $this->defer && ! empty( $this->defer_inline ) ) {
257
+        if ($this->defer && !empty($this->defer_inline)) {
258 258
             // Get/ set (via filter) the JS to be triggers onload of the preloaded CSS.
259 259
             $_preload_onload = apply_filters(
260 260
                 'autoptimize_filter_css_preload_onload',
@@ -262,12 +262,12 @@  discard block
 block discarded – undo
262 262
                 $url
263 263
             );
264 264
             // Adapt original <link> element for CSS to be preloaded and add <noscript>-version for fallback.
265
-            $new_tag = '<noscript>' . $new_tag . '</noscript>' . str_replace(
265
+            $new_tag = '<noscript>'.$new_tag.'</noscript>'.str_replace(
266 266
                 array(
267 267
                     "rel='stylesheet'",
268 268
                     'rel="stylesheet"',
269 269
                 ),
270
-                "rel='preload' as='style' onload=\"" . $_preload_onload . "\"",
270
+                "rel='preload' as='style' onload=\"".$_preload_onload."\"",
271 271
                 $new_tag
272 272
             );
273 273
         }
@@ -281,22 +281,22 @@  discard block
 block discarded – undo
281 281
      * @param string $path
282 282
      * @return boolean
283 283
      */
284
-    private function is_datauri_candidate( $path )
284
+    private function is_datauri_candidate($path)
285 285
     {
286 286
         // Call only once since it's called from a loop.
287 287
         static $max_size = null;
288
-        if ( null === $max_size ) {
288
+        if (null === $max_size) {
289 289
             $max_size = $this->get_datauri_maxsize();
290 290
         }
291 291
 
292
-        if ( $path && preg_match( '#\.(jpe?g|png|gif|webp|bmp)$#i', $path ) &&
293
-            file_exists( $path ) && is_readable( $path ) && filesize( $path ) <= $max_size ) {
292
+        if ($path && preg_match('#\.(jpe?g|png|gif|webp|bmp)$#i', $path) &&
293
+            file_exists($path) && is_readable($path) && filesize($path) <= $max_size) {
294 294
 
295 295
             // Seems we have a candidate.
296 296
             $is_candidate = true;
297 297
         } else {
298 298
             // Filter allows overriding default decision (which checks for local file existence).
299
-            $is_candidate = apply_filters( 'autoptimize_filter_css_is_datauri_candidate', false, $path );
299
+            $is_candidate = apply_filters('autoptimize_filter_css_is_datauri_candidate', false, $path);
300 300
         }
301 301
 
302 302
         return $is_candidate;
@@ -321,29 +321,29 @@  discard block
 block discarded – undo
321 321
          * of thing you're probably better of building assets completely
322 322
          * outside of WordPress anyway.
323 323
          */
324
-        if ( null === $max_size ) {
325
-            $max_size = (int) apply_filters( 'autoptimize_filter_css_datauri_maxsize', 4096 );
324
+        if (null === $max_size) {
325
+            $max_size = (int) apply_filters('autoptimize_filter_css_datauri_maxsize', 4096);
326 326
         }
327 327
 
328 328
         return $max_size;
329 329
     }
330 330
 
331
-    private function check_datauri_exclude_list( $url )
331
+    private function check_datauri_exclude_list($url)
332 332
     {
333 333
         static $exclude_list = null;
334 334
         $no_datauris         = array();
335 335
 
336 336
         // Again, skip doing certain stuff repeatedly when loop-called.
337
-        if ( null === $exclude_list ) {
338
-            $exclude_list = apply_filters( 'autoptimize_filter_css_datauri_exclude', '' );
339
-            $no_datauris = array_filter( array_map( 'trim', explode( ',', $exclude_list ) ) );
337
+        if (null === $exclude_list) {
338
+            $exclude_list = apply_filters('autoptimize_filter_css_datauri_exclude', '');
339
+            $no_datauris = array_filter(array_map('trim', explode(',', $exclude_list)));
340 340
         }
341 341
 
342 342
         $matched = false;
343 343
 
344
-        if ( ! empty( $exclude_list ) ) {
345
-            foreach ( $no_datauris as $no_datauri ) {
346
-                if ( false !== strpos( $url, $no_datauri ) ) {
344
+        if (!empty($exclude_list)) {
345
+            foreach ($no_datauris as $no_datauri) {
346
+                if (false !== strpos($url, $no_datauri)) {
347 347
                     $matched = true;
348 348
                     break;
349 349
                 }
@@ -353,7 +353,7 @@  discard block
 block discarded – undo
353 353
         return $matched;
354 354
     }
355 355
 
356
-    private function build_or_get_datauri_image( $path )
356
+    private function build_or_get_datauri_image($path)
357 357
     {
358 358
         /**
359 359
          * TODO/FIXME: document the required return array format, or better yet,
@@ -362,27 +362,27 @@  discard block
 block discarded – undo
362 362
          */
363 363
 
364 364
         // Allows short-circuiting datauri generation for an image.
365
-        $result = apply_filters( 'autoptimize_filter_css_datauri_image', array(), $path );
366
-        if ( ! empty( $result ) ) {
367
-            if ( is_array( $result ) && isset( $result['full'] ) && isset( $result['base64data'] ) ) {
365
+        $result = apply_filters('autoptimize_filter_css_datauri_image', array(), $path);
366
+        if (!empty($result)) {
367
+            if (is_array($result) && isset($result['full']) && isset($result['base64data'])) {
368 368
                 return $result;
369 369
             }
370 370
         }
371 371
 
372
-        $hash = md5( $path );
373
-        $check = new autoptimizeCache( $hash, 'img' );
374
-        if ( $check->check() ) {
372
+        $hash = md5($path);
373
+        $check = new autoptimizeCache($hash, 'img');
374
+        if ($check->check()) {
375 375
             // we have the base64 image in cache.
376 376
             $headAndData = $check->retrieve();
377
-            $_base64data = explode( ';base64,', $headAndData );
377
+            $_base64data = explode(';base64,', $headAndData);
378 378
             $base64data  = $_base64data[1];
379
-            unset( $_base64data );
379
+            unset($_base64data);
380 380
         } else {
381 381
             // It's an image and we don't have it in cache, get the type by extension.
382
-            $exploded_path = explode( '.', $path );
383
-            $type = end( $exploded_path );
382
+            $exploded_path = explode('.', $path);
383
+            $type = end($exploded_path);
384 384
 
385
-            switch ( $type ) {
385
+            switch ($type) {
386 386
                 case 'jpg':
387 387
                 case 'jpeg':
388 388
                     $dataurihead = 'data:image/jpeg;base64,';
@@ -404,15 +404,15 @@  discard block
 block discarded – undo
404 404
             }
405 405
 
406 406
             // Encode the data.
407
-            $base64data  = base64_encode( file_get_contents( $path ) );
408
-            $headAndData = $dataurihead . $base64data;
407
+            $base64data  = base64_encode(file_get_contents($path));
408
+            $headAndData = $dataurihead.$base64data;
409 409
 
410 410
             // Save in cache.
411
-            $check->cache( $headAndData, 'text/plain' );
411
+            $check->cache($headAndData, 'text/plain');
412 412
         }
413
-        unset( $check );
413
+        unset($check);
414 414
 
415
-        return array( 'full' => $headAndData, 'base64data' => $base64data );
415
+        return array('full' => $headAndData, 'base64data' => $base64data);
416 416
     }
417 417
 
418 418
     /**
@@ -424,13 +424,13 @@  discard block
 block discarded – undo
424 424
      *
425 425
      * @return string
426 426
      */
427
-    protected static function replace_longest_matches_first( $string, $replacements = array() )
427
+    protected static function replace_longest_matches_first($string, $replacements = array())
428 428
     {
429
-        if ( ! empty( $replacements ) ) {
429
+        if (!empty($replacements)) {
430 430
             // Sort the replacements array by key length in desc order (so that the longest strings are replaced first).
431
-            $keys = array_map( 'strlen', array_keys( $replacements ) );
432
-            array_multisort( $keys, SORT_DESC, $replacements );
433
-            $string = str_replace( array_keys( $replacements ), array_values( $replacements ), $string );
431
+            $keys = array_map('strlen', array_keys($replacements));
432
+            array_multisort($keys, SORT_DESC, $replacements);
433
+            $string = str_replace(array_keys($replacements), array_values($replacements), $string);
434 434
         }
435 435
 
436 436
         return $string;
@@ -446,15 +446,15 @@  discard block
 block discarded – undo
446 446
      *
447 447
      * @return string
448 448
      */
449
-    public function replace_urls( $code = '' )
449
+    public function replace_urls($code = '')
450 450
     {
451 451
         $replacements = array();
452 452
 
453
-        preg_match_all( self::ASSETS_REGEX, $code, $url_src_matches );
454
-        if ( is_array( $url_src_matches ) && ! empty( $url_src_matches ) ) {
455
-            foreach ( $url_src_matches[1] as $count => $original_url ) {
453
+        preg_match_all(self::ASSETS_REGEX, $code, $url_src_matches);
454
+        if (is_array($url_src_matches) && !empty($url_src_matches)) {
455
+            foreach ($url_src_matches[1] as $count => $original_url) {
456 456
                 // Removes quotes and other cruft.
457
-                $url = trim( $original_url, " \t\n\r\0\x0B\"'" );
457
+                $url = trim($original_url, " \t\n\r\0\x0B\"'");
458 458
 
459 459
                 /**
460 460
                  * TODO/FIXME: Add a way for other code / callable to be called here
@@ -472,17 +472,17 @@  discard block
 block discarded – undo
472 472
                  */
473 473
 
474 474
                 // Do CDN replacement if needed.
475
-                if ( ! empty( $this->cdn_url ) ) {
476
-                    $replacement_url = $this->url_replace_cdn( $url );
475
+                if (!empty($this->cdn_url)) {
476
+                    $replacement_url = $this->url_replace_cdn($url);
477 477
                     // Prepare replacements array.
478
-                    $replacements[ $url_src_matches[1][ $count ] ] = str_replace(
478
+                    $replacements[$url_src_matches[1][$count]] = str_replace(
479 479
                         $original_url, $replacement_url, $url_src_matches[1][$count]
480 480
                     );
481 481
                 }
482 482
             }
483 483
         }
484 484
 
485
-        $code = self::replace_longest_matches_first( $code, $replacements );
485
+        $code = self::replace_longest_matches_first($code, $replacements);
486 486
 
487 487
         return $code;
488 488
     }
@@ -495,26 +495,26 @@  discard block
 block discarded – undo
495 495
      * @param string $code
496 496
      * @return string
497 497
      */
498
-    public function hide_fontface_and_maybe_cdn( $code )
498
+    public function hide_fontface_and_maybe_cdn($code)
499 499
     {
500 500
         // Proceed only if @font-face declarations exist within $code.
501
-        preg_match_all( self::FONT_FACE_REGEX, $code, $fontfaces );
502
-        if ( isset( $fontfaces[0] ) ) {
501
+        preg_match_all(self::FONT_FACE_REGEX, $code, $fontfaces);
502
+        if (isset($fontfaces[0])) {
503 503
             // Check if we need to cdn fonts or not.
504
-            $do_font_cdn = apply_filters( 'autoptimize_filter_css_fonts_cdn', false );
504
+            $do_font_cdn = apply_filters('autoptimize_filter_css_fonts_cdn', false);
505 505
 
506
-            foreach ( $fontfaces[0] as $full_match ) {
506
+            foreach ($fontfaces[0] as $full_match) {
507 507
                 // Keep original match so we can search/replace it.
508 508
                 $match_search = $full_match;
509 509
 
510 510
                 // Do font cdn if needed.
511
-                if ( $do_font_cdn ) {
512
-                    $full_match = $this->replace_urls( $full_match );
511
+                if ($do_font_cdn) {
512
+                    $full_match = $this->replace_urls($full_match);
513 513
                 }
514 514
 
515 515
                 // Replace declaration with its base64 encoded string.
516
-                $replacement = self::build_marker( 'FONTFACE', $full_match );
517
-                $code = str_replace( $match_search, $replacement, $code );
516
+                $replacement = self::build_marker('FONTFACE', $full_match);
517
+                $code = str_replace($match_search, $replacement, $code);
518 518
             }
519 519
         }
520 520
 
@@ -528,16 +528,16 @@  discard block
 block discarded – undo
528 528
      * @param string $code
529 529
      * @return string
530 530
      */
531
-    public function restore_fontface( $code )
531
+    public function restore_fontface($code)
532 532
     {
533
-        return $this->restore_marked_content( 'FONTFACE', $code );
533
+        return $this->restore_marked_content('FONTFACE', $code);
534 534
     }
535 535
 
536 536
     // Re-write (and/or inline) referenced assets.
537
-    public function rewrite_assets( $code )
537
+    public function rewrite_assets($code)
538 538
     {
539 539
         // Handle @font-face rules by hiding and processing them separately.
540
-        $code = $this->hide_fontface_and_maybe_cdn( $code );
540
+        $code = $this->hide_fontface_and_maybe_cdn($code);
541 541
 
542 542
         /**
543 543
          * TODO/FIXME:
@@ -553,30 +553,30 @@  discard block
 block discarded – undo
553 553
         $url_src_matches = array();
554 554
         $imgreplace = array();
555 555
         // Matches and captures anything specified within the literal `url()` and excludes those containing data: URIs.
556
-        preg_match_all( self::ASSETS_REGEX, $code, $url_src_matches );
557
-        if ( is_array( $url_src_matches ) && ! empty( $url_src_matches ) ) {
558
-            foreach ( $url_src_matches[1] as $count => $original_url ) {
556
+        preg_match_all(self::ASSETS_REGEX, $code, $url_src_matches);
557
+        if (is_array($url_src_matches) && !empty($url_src_matches)) {
558
+            foreach ($url_src_matches[1] as $count => $original_url) {
559 559
                 // Removes quotes and other cruft.
560
-                $url = trim( $original_url, " \t\n\r\0\x0B\"'" );
560
+                $url = trim($original_url, " \t\n\r\0\x0B\"'");
561 561
 
562 562
                 // If datauri inlining is turned on, do it.
563 563
                 $inlined = false;
564
-                if ( $this->datauris ) {
564
+                if ($this->datauris) {
565 565
                     $iurl = $url;
566
-                    if ( false !== strpos( $iurl, '?' ) ) {
567
-                        $iurl = strtok( $iurl, '?' );
566
+                    if (false !== strpos($iurl, '?')) {
567
+                        $iurl = strtok($iurl, '?');
568 568
                     }
569 569
 
570
-                    $ipath = $this->getpath( $iurl );
570
+                    $ipath = $this->getpath($iurl);
571 571
 
572
-                    $excluded = $this->check_datauri_exclude_list( $ipath );
573
-                    if ( ! $excluded ) {
574
-                        $is_datauri_candidate = $this->is_datauri_candidate( $ipath );
575
-                        if ( $is_datauri_candidate ) {
576
-                            $datauri     = $this->build_or_get_datauri_image( $ipath );
572
+                    $excluded = $this->check_datauri_exclude_list($ipath);
573
+                    if (!$excluded) {
574
+                        $is_datauri_candidate = $this->is_datauri_candidate($ipath);
575
+                        if ($is_datauri_candidate) {
576
+                            $datauri     = $this->build_or_get_datauri_image($ipath);
577 577
                             $base64data  = $datauri['base64data'];
578 578
                             // Add it to the list for replacement.
579
-                            $imgreplace[ $url_src_matches[1][ $count ] ] = str_replace(
579
+                            $imgreplace[$url_src_matches[1][$count]] = str_replace(
580 580
                                     $original_url,
581 581
                                     $datauri['full'],
582 582
                                     $url_src_matches[1][$count]
@@ -592,20 +592,20 @@  discard block
 block discarded – undo
592 592
                  * inlining isn't turned on, or if a resource is skipped from
593 593
                  * being inlined for whatever reason above.
594 594
                  */
595
-                if ( ! $inlined && ( ! empty( $this->cdn_url ) || has_filter( 'autoptimize_filter_base_replace_cdn' ) ) ) {
595
+                if (!$inlined && (!empty($this->cdn_url) || has_filter('autoptimize_filter_base_replace_cdn'))) {
596 596
                     // Just do the "simple" CDN replacement.
597
-                    $replacement_url = $this->url_replace_cdn( $url );
598
-                    $imgreplace[ $url_src_matches[1][ $count ] ] = str_replace(
597
+                    $replacement_url = $this->url_replace_cdn($url);
598
+                    $imgreplace[$url_src_matches[1][$count]] = str_replace(
599 599
                         $original_url, $replacement_url, $url_src_matches[1][$count]
600 600
                     );
601 601
                 }
602 602
             }
603 603
         }
604 604
 
605
-        $code = self::replace_longest_matches_first( $code, $imgreplace );
605
+        $code = self::replace_longest_matches_first($code, $imgreplace);
606 606
 
607 607
         // Replace back font-face markers with actual font-face declarations.
608
-        $code = $this->restore_fontface( $code );
608
+        $code = $this->restore_fontface($code);
609 609
 
610 610
         return $code;
611 611
     }
@@ -613,29 +613,29 @@  discard block
 block discarded – undo
613 613
     // Joins and optimizes CSS.
614 614
     public function minify()
615 615
     {
616
-        foreach ( $this->css as $group ) {
617
-            list( $media, $css ) = $group;
618
-            if ( preg_match( '#^INLINE;#', $css ) ) {
616
+        foreach ($this->css as $group) {
617
+            list($media, $css) = $group;
618
+            if (preg_match('#^INLINE;#', $css)) {
619 619
                 // <style>.
620
-                $css = preg_replace( '#^INLINE;#', '', $css );
621
-                $css = self::fixurls( ABSPATH . 'index.php', $css ); // ABSPATH already contains a trailing slash.
622
-                $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, '' );
623
-                if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
620
+                $css = preg_replace('#^INLINE;#', '', $css);
621
+                $css = self::fixurls(ABSPATH.'index.php', $css); // ABSPATH already contains a trailing slash.
622
+                $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, '');
623
+                if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
624 624
                     $css = $tmpstyle;
625 625
                     $this->alreadyminified = true;
626 626
                 }
627 627
             } else {
628 628
                 // <link>
629
-                if ( false !== $css && file_exists( $css ) && is_readable( $css ) ) {
629
+                if (false !== $css && file_exists($css) && is_readable($css)) {
630 630
                     $cssPath = $css;
631
-                    $css = self::fixurls( $cssPath, file_get_contents( $cssPath ) );
632
-                    $css = preg_replace( '/\x{EF}\x{BB}\x{BF}/', '', $css );
633
-                    $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, $cssPath );
634
-                    if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
631
+                    $css = self::fixurls($cssPath, file_get_contents($cssPath));
632
+                    $css = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $css);
633
+                    $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, $cssPath);
634
+                    if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
635 635
                         $css = $tmpstyle;
636 636
                         $this->alreadyminified = true;
637
-                    } elseif ( $this->can_inject_late( $cssPath, $css ) ) {
638
-                        $css = self::build_injectlater_marker( $cssPath, md5( $css ) );
637
+                    } elseif ($this->can_inject_late($cssPath, $css)) {
638
+                        $css = self::build_injectlater_marker($cssPath, md5($css));
639 639
                     }
640 640
                 } else {
641 641
                     // Couldn't read CSS. Maybe getpath isn't working?
@@ -643,12 +643,12 @@  discard block
 block discarded – undo
643 643
                 }
644 644
             }
645 645
 
646
-            foreach ( $media as $elem ) {
647
-                if ( ! empty( $css ) ) {
648
-                    if ( ! isset( $this->csscode[$elem] ) ) {
646
+            foreach ($media as $elem) {
647
+                if (!empty($css)) {
648
+                    if (!isset($this->csscode[$elem])) {
649 649
                         $this->csscode[$elem] = '';
650 650
                     }
651
-                    $this->csscode[$elem] .= "\n/*FILESTART*/" . $css;
651
+                    $this->csscode[$elem] .= "\n/*FILESTART*/".$css;
652 652
                 }
653 653
             }
654 654
         }
@@ -656,133 +656,133 @@  discard block
 block discarded – undo
656 656
         // Check for duplicate code.
657 657
         $md5list = array();
658 658
         $tmpcss  = $this->csscode;
659
-        foreach ( $tmpcss as $media => $code ) {
660
-            $md5sum    = md5( $code );
659
+        foreach ($tmpcss as $media => $code) {
660
+            $md5sum    = md5($code);
661 661
             $medianame = $media;
662
-            foreach ( $md5list as $med => $sum ) {
662
+            foreach ($md5list as $med => $sum) {
663 663
                 // If same code.
664
-                if ( $sum === $md5sum ) {
664
+                if ($sum === $md5sum) {
665 665
                     // Add the merged code.
666
-                    $medianame                 = $med . ', ' . $media;
666
+                    $medianame                 = $med.', '.$media;
667 667
                     $this->csscode[$medianame] = $code;
668 668
                     $md5list[$medianame]       = $md5list[$med];
669
-                    unset( $this->csscode[$med], $this->csscode[$media], $md5list[$med] );
669
+                    unset($this->csscode[$med], $this->csscode[$media], $md5list[$med]);
670 670
                 }
671 671
             }
672 672
             $md5list[$medianame] = $md5sum;
673 673
         }
674
-        unset( $tmpcss );
674
+        unset($tmpcss);
675 675
 
676 676
         // Manage @imports, while is for recursive import management.
677
-        foreach ( $this->csscode as &$thiscss ) {
677
+        foreach ($this->csscode as &$thiscss) {
678 678
             // Flag to trigger import reconstitution and var to hold external imports.
679 679
             $fiximports       = false;
680 680
             $external_imports = '';
681 681
 
682 682
             // remove comments to avoid importing commented-out imports.
683
-            $thiscss_nocomments = preg_replace( '#/\*.*\*/#Us', '', $thiscss );
684
-            while ( preg_match_all( '#@import +(?:url)?(?:(?:\((["\']?)(?:[^"\')]+)\1\)|(["\'])(?:[^"\']+)\2)(?:[^,;"\']+(?:,[^,;"\']+)*)?)(?:;)#mi', $thiscss_nocomments, $matches ) ) {
685
-                foreach ( $matches[0] as $import ) {
686
-                    if ( $this->isremovable( $import, $this->cssremovables ) ) {
687
-                        $thiscss = str_replace( $import, '', $thiscss );
683
+            $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
684
+            while (preg_match_all('#@import +(?:url)?(?:(?:\((["\']?)(?:[^"\')]+)\1\)|(["\'])(?:[^"\']+)\2)(?:[^,;"\']+(?:,[^,;"\']+)*)?)(?:;)#mi', $thiscss_nocomments, $matches)) {
685
+                foreach ($matches[0] as $import) {
686
+                    if ($this->isremovable($import, $this->cssremovables)) {
687
+                        $thiscss = str_replace($import, '', $thiscss);
688 688
                         $import_ok = true;
689 689
                     } else {
690
-                        $url = trim( preg_replace( '#^.*((?:https?:|ftp:)?//.*\.css).*$#', '$1', trim( $import ) ), " \t\n\r\0\x0B\"'" );
691
-                        $path = $this->getpath( $url );
690
+                        $url = trim(preg_replace('#^.*((?:https?:|ftp:)?//.*\.css).*$#', '$1', trim($import)), " \t\n\r\0\x0B\"'");
691
+                        $path = $this->getpath($url);
692 692
                         $import_ok = false;
693
-                        if ( file_exists( $path ) && is_readable( $path ) ) {
694
-                            $code = addcslashes( self::fixurls( $path, file_get_contents( $path ) ), "\\" );
695
-                            $code = preg_replace( '/\x{EF}\x{BB}\x{BF}/', '', $code );
696
-                            $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $code, '' );
697
-                            if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
693
+                        if (file_exists($path) && is_readable($path)) {
694
+                            $code = addcslashes(self::fixurls($path, file_get_contents($path)), "\\");
695
+                            $code = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $code);
696
+                            $tmpstyle = apply_filters('autoptimize_css_individual_style', $code, '');
697
+                            if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
698 698
                                 $code = $tmpstyle;
699 699
                                 $this->alreadyminified = true;
700
-                            } elseif ( $this->can_inject_late( $path, $code ) ) {
701
-                                $code = self::build_injectlater_marker( $path, md5( $code ) );
700
+                            } elseif ($this->can_inject_late($path, $code)) {
701
+                                $code = self::build_injectlater_marker($path, md5($code));
702 702
                             }
703 703
 
704
-                            if ( ! empty( $code ) ) {
705
-                                $tmp_thiscss = preg_replace( '#(/\*FILESTART\*/.*)' . preg_quote( $import, '#' ) . '#Us', '/*FILESTART2*/' . $code . '$1', $thiscss );
706
-                                if ( ! empty( $tmp_thiscss ) ) {
704
+                            if (!empty($code)) {
705
+                                $tmp_thiscss = preg_replace('#(/\*FILESTART\*/.*)'.preg_quote($import, '#').'#Us', '/*FILESTART2*/'.$code.'$1', $thiscss);
706
+                                if (!empty($tmp_thiscss)) {
707 707
                                     $thiscss = $tmp_thiscss;
708 708
                                     $import_ok = true;
709
-                                    unset( $tmp_thiscss );
709
+                                    unset($tmp_thiscss);
710 710
                                 }
711 711
                             }
712
-                            unset( $code );
712
+                            unset($code);
713 713
                         }
714 714
                     }
715
-                    if ( ! $import_ok ) {
715
+                    if (!$import_ok) {
716 716
                         // External imports and general fall-back.
717 717
                         $external_imports .= $import;
718 718
 
719
-                        $thiscss    = str_replace( $import, '', $thiscss );
719
+                        $thiscss    = str_replace($import, '', $thiscss);
720 720
                         $fiximports = true;
721 721
                     }
722 722
                 }
723
-                $thiscss = preg_replace( '#/\*FILESTART\*/#', '', $thiscss );
724
-                $thiscss = preg_replace( '#/\*FILESTART2\*/#', '/*FILESTART*/', $thiscss );
723
+                $thiscss = preg_replace('#/\*FILESTART\*/#', '', $thiscss);
724
+                $thiscss = preg_replace('#/\*FILESTART2\*/#', '/*FILESTART*/', $thiscss);
725 725
 
726 726
                 // and update $thiscss_nocomments before going into next iteration in while loop.
727
-                $thiscss_nocomments = preg_replace( '#/\*.*\*/#Us', '', $thiscss );
727
+                $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
728 728
             }
729
-            unset( $thiscss_nocomments );
729
+            unset($thiscss_nocomments);
730 730
 
731 731
             // Add external imports to top of aggregated CSS.
732
-            if ( $fiximports ) {
733
-                $thiscss = $external_imports . $thiscss;
732
+            if ($fiximports) {
733
+                $thiscss = $external_imports.$thiscss;
734 734
             }
735 735
         }
736
-        unset( $thiscss );
736
+        unset($thiscss);
737 737
 
738 738
         // $this->csscode has all the uncompressed code now.
739
-        foreach ( $this->csscode as &$code ) {
739
+        foreach ($this->csscode as &$code) {
740 740
             // Check for already-minified code.
741
-            $hash = md5( $code );
742
-            do_action( 'autoptimize_action_css_hash', $hash );
743
-            $ccheck = new autoptimizeCache( $hash, 'css' );
744
-            if ( $ccheck->check() ) {
741
+            $hash = md5($code);
742
+            do_action('autoptimize_action_css_hash', $hash);
743
+            $ccheck = new autoptimizeCache($hash, 'css');
744
+            if ($ccheck->check()) {
745 745
                 $code = $ccheck->retrieve();
746
-                $this->hashmap[md5( $code )] = $hash;
746
+                $this->hashmap[md5($code)] = $hash;
747 747
                 continue;
748 748
             }
749
-            unset( $ccheck );
749
+            unset($ccheck);
750 750
 
751 751
             // Rewrite and/or inline referenced assets.
752
-            $code = $this->rewrite_assets( $code );
752
+            $code = $this->rewrite_assets($code);
753 753
 
754 754
             // Minify.
755
-            $code = $this->run_minifier_on( $code );
755
+            $code = $this->run_minifier_on($code);
756 756
 
757 757
             // Bring back INJECTLATER stuff.
758
-            $code = $this->inject_minified( $code );
758
+            $code = $this->inject_minified($code);
759 759
 
760 760
             // Filter results.
761
-            $tmp_code = apply_filters( 'autoptimize_css_after_minify', $code );
762
-            if ( ! empty( $tmp_code ) ) {
761
+            $tmp_code = apply_filters('autoptimize_css_after_minify', $code);
762
+            if (!empty($tmp_code)) {
763 763
                 $code = $tmp_code;
764
-                unset( $tmp_code );
764
+                unset($tmp_code);
765 765
             }
766 766
 
767
-            $this->hashmap[md5( $code )] = $hash;
767
+            $this->hashmap[md5($code)] = $hash;
768 768
         }
769 769
 
770
-        unset( $code );
770
+        unset($code);
771 771
         return true;
772 772
     }
773 773
 
774
-    public function run_minifier_on( $code )
774
+    public function run_minifier_on($code)
775 775
     {
776
-        if ( ! $this->alreadyminified ) {
777
-            $do_minify = apply_filters( 'autoptimize_css_do_minify', true );
776
+        if (!$this->alreadyminified) {
777
+            $do_minify = apply_filters('autoptimize_css_do_minify', true);
778 778
 
779
-            if ( $do_minify ) {
779
+            if ($do_minify) {
780 780
                 $cssmin   = new autoptimizeCSSmin();
781
-                $tmp_code = trim( $cssmin->run( $code ) );
781
+                $tmp_code = trim($cssmin->run($code));
782 782
 
783
-                if ( ! empty( $tmp_code ) ) {
783
+                if (!empty($tmp_code)) {
784 784
                     $code = $tmp_code;
785
-                    unset( $tmp_code );
785
+                    unset($tmp_code);
786 786
                 }
787 787
             }
788 788
         }
@@ -794,14 +794,14 @@  discard block
 block discarded – undo
794 794
     public function cache()
795 795
     {
796 796
         // CSS cache.
797
-        foreach ( $this->csscode as $media => $code ) {
798
-            $md5 = $this->hashmap[md5( $code )];
799
-            $cache = new autoptimizeCache( $md5, 'css' );
800
-            if ( ! $cache->check() ) {
797
+        foreach ($this->csscode as $media => $code) {
798
+            $md5 = $this->hashmap[md5($code)];
799
+            $cache = new autoptimizeCache($md5, 'css');
800
+            if (!$cache->check()) {
801 801
                 // Cache our code.
802
-                $cache->cache( $code, 'text/css' );
802
+                $cache->cache($code, 'text/css');
803 803
             }
804
-            $this->url[$media] = AUTOPTIMIZE_CACHE_URL . $cache->getname();
804
+            $this->url[$media] = AUTOPTIMIZE_CACHE_URL.$cache->getname();
805 805
         }
806 806
     }
807 807
 
@@ -809,136 +809,136 @@  discard block
 block discarded – undo
809 809
     public function getcontent()
810 810
     {
811 811
         // Restore the full content (only applies when "autoptimize_filter_css_justhead" filter is true).
812
-        if ( ! empty( $this->restofcontent ) ) {
812
+        if (!empty($this->restofcontent)) {
813 813
             $this->content .= $this->restofcontent;
814 814
             $this->restofcontent = '';
815 815
         }
816 816
 
817 817
         // Inject the new stylesheets.
818
-        $replaceTag = array( '<title', 'before' );
819
-        $replaceTag = apply_filters( 'autoptimize_filter_css_replacetag', $replaceTag, $this->content );
818
+        $replaceTag = array('<title', 'before');
819
+        $replaceTag = apply_filters('autoptimize_filter_css_replacetag', $replaceTag, $this->content);
820 820
 
821
-        if ( $this->inline ) {
822
-            foreach ( $this->csscode as $media => $code ) {
823
-                $this->inject_in_html( '<style type="text/css" media="' . $media . '">' . $code . '</style>', $replaceTag );
821
+        if ($this->inline) {
822
+            foreach ($this->csscode as $media => $code) {
823
+                $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$code.'</style>', $replaceTag);
824 824
             }
825 825
         } else {
826
-            if ( $this->defer ) {
826
+            if ($this->defer) {
827 827
                 $preloadCssBlock = '';
828 828
                 $noScriptCssBlock = "<noscript id=\"aonoscrcss\">";
829 829
 
830 830
                 $defer_inline_code = $this->defer_inline;
831
-                if ( ! empty( $defer_inline_code ) ) {
832
-                    if ( apply_filters( 'autoptimize_filter_css_critcss_minify', true ) ) {
833
-                        $iCssHash = md5( $defer_inline_code );
834
-                        $iCssCache = new autoptimizeCache( $iCssHash, 'css' );
835
-                        if ( $iCssCache->check() ) {
831
+                if (!empty($defer_inline_code)) {
832
+                    if (apply_filters('autoptimize_filter_css_critcss_minify', true)) {
833
+                        $iCssHash = md5($defer_inline_code);
834
+                        $iCssCache = new autoptimizeCache($iCssHash, 'css');
835
+                        if ($iCssCache->check()) {
836 836
                             // we have the optimized inline CSS in cache.
837 837
                             $defer_inline_code = $iCssCache->retrieve();
838 838
                         } else {
839 839
                             $cssmin   = new autoptimizeCSSmin();
840
-                            $tmp_code = trim( $cssmin->run( $defer_inline_code ) );
840
+                            $tmp_code = trim($cssmin->run($defer_inline_code));
841 841
 
842
-                            if ( ! empty( $tmp_code ) ) {
842
+                            if (!empty($tmp_code)) {
843 843
                                 $defer_inline_code = $tmp_code;
844
-                                $iCssCache->cache( $defer_inline_code, 'text/css' );
845
-                                unset( $tmp_code );
844
+                                $iCssCache->cache($defer_inline_code, 'text/css');
845
+                                unset($tmp_code);
846 846
                             }
847 847
                         }
848 848
                     }
849 849
                     // inlined critical css set here, but injected when full CSS is injected
850 850
                     // to avoid CSS containing SVG with <title tag receiving the full CSS link.
851
-                    $inlined_ccss_block = '<style type="text/css" id="aoatfcss" media="all">' . $defer_inline_code . '</style>';
851
+                    $inlined_ccss_block = '<style type="text/css" id="aoatfcss" media="all">'.$defer_inline_code.'</style>';
852 852
                 }
853 853
             }
854 854
 
855
-            foreach ( $this->url as $media => $url ) {
856
-                $url = $this->url_replace_cdn( $url );
855
+            foreach ($this->url as $media => $url) {
856
+                $url = $this->url_replace_cdn($url);
857 857
 
858 858
                 // Add the stylesheet either deferred (import at bottom) or normal links in head.
859
-                if ( $this->defer ) {
859
+                if ($this->defer) {
860 860
                     $preloadOnLoad = autoptimizeConfig::get_ao_css_preload_onload();
861 861
 
862
-                    $preloadCssBlock .= '<link rel="preload" as="style" media="' . $media . '" href="' . $url . '" onload="' . $preloadOnLoad . '" />';
863
-                    $noScriptCssBlock .= '<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />';
862
+                    $preloadCssBlock .= '<link rel="preload" as="style" media="'.$media.'" href="'.$url.'" onload="'.$preloadOnLoad.'" />';
863
+                    $noScriptCssBlock .= '<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />';
864 864
                 } else {
865 865
                     // $this->inject_in_html('<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />', $replaceTag);
866
-                    if ( strlen( $this->csscode[$media] ) > $this->cssinlinesize ) {
867
-                        $this->inject_in_html( '<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />', $replaceTag );
868
-                    } elseif ( strlen( $this->csscode[$media] ) > 0 ) {
869
-                        $this->inject_in_html( '<style type="text/css" media="' . $media . '">' . $this->csscode[$media] . '</style>', $replaceTag );
866
+                    if (strlen($this->csscode[$media]) > $this->cssinlinesize) {
867
+                        $this->inject_in_html('<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />', $replaceTag);
868
+                    } elseif (strlen($this->csscode[$media]) > 0) {
869
+                        $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$this->csscode[$media].'</style>', $replaceTag);
870 870
                     }
871 871
                 }
872 872
             }
873 873
 
874
-            if ( $this->defer ) {
874
+            if ($this->defer) {
875 875
                 $preload_polyfill = autoptimizeConfig::get_ao_css_preload_polyfill();
876 876
                 $noScriptCssBlock .= '</noscript>';
877 877
                 // Inject inline critical CSS, the preloaded full CSS and the noscript-CSS.
878
-                $this->inject_in_html( $inlined_ccss_block . $preloadCssBlock . $noScriptCssBlock, $replaceTag );
878
+                $this->inject_in_html($inlined_ccss_block.$preloadCssBlock.$noScriptCssBlock, $replaceTag);
879 879
 
880 880
                 // Adds preload polyfill at end of body tag.
881 881
                 $this->inject_in_html(
882
-                    apply_filters( 'autoptimize_css_preload_polyfill', $preload_polyfill ),
883
-                    apply_filters( 'autoptimize_css_preload_polyfill_injectat', array( '</body>', 'before' ) )
882
+                    apply_filters('autoptimize_css_preload_polyfill', $preload_polyfill),
883
+                    apply_filters('autoptimize_css_preload_polyfill_injectat', array('</body>', 'before'))
884 884
                 );
885 885
             }
886 886
         }
887 887
 
888 888
         // restore comments.
889
-        $this->content = $this->restore_comments( $this->content );
889
+        $this->content = $this->restore_comments($this->content);
890 890
 
891 891
         // restore IE hacks.
892
-        $this->content = $this->restore_iehacks( $this->content );
892
+        $this->content = $this->restore_iehacks($this->content);
893 893
 
894 894
         // restore (no)script.
895
-        $this->content = $this->restore_marked_content( 'SCRIPT', $this->content );
895
+        $this->content = $this->restore_marked_content('SCRIPT', $this->content);
896 896
 
897 897
         // Restore noptimize.
898
-        $this->content = $this->restore_noptimize( $this->content );
898
+        $this->content = $this->restore_noptimize($this->content);
899 899
 
900 900
         // Return the modified stylesheet.
901 901
         return $this->content;
902 902
     }
903 903
 
904
-    static function fixurls( $file, $code )
904
+    static function fixurls($file, $code)
905 905
     {
906 906
         // Switch all imports to the url() syntax.
907
-        $code = preg_replace( '#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code );
907
+        $code = preg_replace('#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code);
908 908
 
909
-        if ( preg_match_all( self::ASSETS_REGEX, $code, $matches ) ) {
910
-            $file = str_replace( WP_ROOT_DIR, '/', $file );
909
+        if (preg_match_all(self::ASSETS_REGEX, $code, $matches)) {
910
+            $file = str_replace(WP_ROOT_DIR, '/', $file);
911 911
             /**
912 912
              * rollback as per https://github.com/futtta/autoptimize/issues/94
913 913
              * $file = str_replace( AUTOPTIMIZE_WP_CONTENT_NAME, '', $file );
914 914
              */
915
-            $dir = dirname( $file ); // Like /themes/expound/css.
915
+            $dir = dirname($file); // Like /themes/expound/css.
916 916
 
917 917
             /**
918 918
              * $dir should not contain backslashes, since it's used to replace
919 919
              * urls, but it can contain them when running on Windows because
920 920
              * fixurls() is sometimes called with `ABSPATH . 'index.php'`
921 921
              */
922
-            $dir = str_replace( '\\', '/', $dir );
923
-            unset( $file ); // not used below at all.
922
+            $dir = str_replace('\\', '/', $dir);
923
+            unset($file); // not used below at all.
924 924
 
925 925
             $replace = array();
926
-            foreach ( $matches[1] as $k => $url ) {
926
+            foreach ($matches[1] as $k => $url) {
927 927
                 // Remove quotes.
928
-                $url    = trim( $url, " \t\n\r\0\x0B\"'" );
929
-                $noQurl = trim( $url, "\"'" );
930
-                if ( $url !== $noQurl ) {
928
+                $url    = trim($url, " \t\n\r\0\x0B\"'");
929
+                $noQurl = trim($url, "\"'");
930
+                if ($url !== $noQurl) {
931 931
                     $removedQuotes = true;
932 932
                 } else {
933 933
                     $removedQuotes = false;
934 934
                 }
935 935
 
936
-                if ( '' === $noQurl ) {
936
+                if ('' === $noQurl) {
937 937
                     continue;
938 938
                 }
939 939
 
940 940
                 $url = $noQurl;
941
-                if ( '/' === $url{0} || preg_match( '#^(https?://|ftp://|data:)#i', $url ) ) {
941
+                if ('/' === $url{0} || preg_match('#^(https?://|ftp://|data:)#i', $url)) {
942 942
                     // URL is protocol-relative, host-relative or something we don't touch.
943 943
                     continue;
944 944
                 } else {
@@ -947,49 +947,49 @@  discard block
 block discarded – undo
947 947
                      * rollback as per https://github.com/futtta/autoptimize/issues/94
948 948
                      * $newurl = preg_replace( '/https?:/', '', str_replace( ' ', '%20', AUTOPTIMIZE_WP_CONTENT_URL . str_replace( '//', '/', $dir . '/' . $url ) ) );
949 949
                      */
950
-                    $newurl = preg_replace( '/https?:/', '', str_replace( ' ', '%20', AUTOPTIMIZE_WP_ROOT_URL . str_replace( '//', '/', $dir . '/' . $url ) ) );
951
-                    $newurl = apply_filters( 'autoptimize_filter_css_fixurl_newurl', $newurl );
950
+                    $newurl = preg_replace('/https?:/', '', str_replace(' ', '%20', AUTOPTIMIZE_WP_ROOT_URL.str_replace('//', '/', $dir.'/'.$url)));
951
+                    $newurl = apply_filters('autoptimize_filter_css_fixurl_newurl', $newurl);
952 952
 
953 953
                     /**
954 954
                      * Hash the url + whatever was behind potentially for replacement
955 955
                      * We must do this, or different css classes referencing the same bg image (but
956 956
                      * different parts of it, say, in sprites and such) loose their stuff...
957 957
                      */
958
-                    $hash = md5( $url . $matches[2][$k] );
959
-                    $code = str_replace( $matches[0][$k], $hash, $code );
958
+                    $hash = md5($url.$matches[2][$k]);
959
+                    $code = str_replace($matches[0][$k], $hash, $code);
960 960
 
961
-                    if ( $removedQuotes ) {
962
-                        $replace[$hash] = "url('" . $newurl . "')" . $matches[2][$k];
961
+                    if ($removedQuotes) {
962
+                        $replace[$hash] = "url('".$newurl."')".$matches[2][$k];
963 963
                     } else {
964
-                        $replace[$hash] = 'url(' . $newurl . ')' . $matches[2][$k];
964
+                        $replace[$hash] = 'url('.$newurl.')'.$matches[2][$k];
965 965
                     }
966 966
                 }
967 967
             }
968 968
 
969
-            $code = self::replace_longest_matches_first( $code, $replace );
969
+            $code = self::replace_longest_matches_first($code, $replace);
970 970
         }
971 971
 
972 972
         return $code;
973 973
     }
974 974
 
975
-    private function ismovable( $tag )
975
+    private function ismovable($tag)
976 976
     {
977
-        if ( ! $this->aggregate ) {
977
+        if (!$this->aggregate) {
978 978
             return false;
979 979
         }
980 980
 
981
-        if ( ! empty( $this->whitelist ) ) {
982
-            foreach ( $this->whitelist as $match ) {
983
-                if ( false !== strpos( $tag, $match ) ) {
981
+        if (!empty($this->whitelist)) {
982
+            foreach ($this->whitelist as $match) {
983
+                if (false !== strpos($tag, $match)) {
984 984
                     return true;
985 985
                 }
986 986
             }
987 987
             // no match with whitelist.
988 988
             return false;
989 989
         } else {
990
-            if ( is_array( $this->dontmove ) && ! empty( $this->dontmove ) ) {
991
-                foreach ( $this->dontmove as $match ) {
992
-                    if ( false !== strpos( $tag, $match ) ) {
990
+            if (is_array($this->dontmove) && !empty($this->dontmove)) {
991
+                foreach ($this->dontmove as $match) {
992
+                    if (false !== strpos($tag, $match)) {
993 993
                         // Matched something.
994 994
                         return false;
995 995
                     }
@@ -1001,22 +1001,22 @@  discard block
 block discarded – undo
1001 1001
         }
1002 1002
     }
1003 1003
 
1004
-    private function can_inject_late( $cssPath, $css )
1004
+    private function can_inject_late($cssPath, $css)
1005 1005
     {
1006
-        $consider_minified_array = apply_filters( 'autoptimize_filter_css_consider_minified', false, $cssPath );
1007
-        if ( true !== $this->inject_min_late ) {
1006
+        $consider_minified_array = apply_filters('autoptimize_filter_css_consider_minified', false, $cssPath);
1007
+        if (true !== $this->inject_min_late) {
1008 1008
             // late-inject turned off.
1009 1009
             return false;
1010
-        } elseif ( ( false === strpos( $cssPath, 'min.css' ) ) && ( str_replace( $consider_minified_array, '', $cssPath ) === $cssPath ) ) {
1010
+        } elseif ((false === strpos($cssPath, 'min.css')) && (str_replace($consider_minified_array, '', $cssPath) === $cssPath)) {
1011 1011
             // file not minified based on filename & filter.
1012 1012
             return false;
1013
-        } elseif ( false !== strpos( $css, '@import' ) ) {
1013
+        } elseif (false !== strpos($css, '@import')) {
1014 1014
             // can't late-inject files with imports as those need to be aggregated.
1015 1015
             return false;
1016
-        } elseif ( ( false !== strpos( $css, '@font-face' ) ) && ( apply_filters( 'autoptimize_filter_css_fonts_cdn', false ) === true ) && ( ! empty( $this->cdn_url ) ) ) {
1016
+        } elseif ((false !== strpos($css, '@font-face')) && (apply_filters('autoptimize_filter_css_fonts_cdn', false) === true) && (!empty($this->cdn_url))) {
1017 1017
             // don't late-inject CSS with font-src's if fonts are set to be CDN'ed.
1018 1018
             return false;
1019
-        } elseif ( ( ( $this->datauris == true ) || ( ! empty( $this->cdn_url ) ) ) && preg_match( '#background[^;}]*url\(#Ui', $css ) ) {
1019
+        } elseif ((($this->datauris == true) || (!empty($this->cdn_url))) && preg_match('#background[^;}]*url\(#Ui', $css)) {
1020 1020
             // don't late-inject CSS with images if CDN is set OR if image inlining is on.
1021 1021
             return false;
1022 1022
         } else {
@@ -1034,32 +1034,32 @@  discard block
 block discarded – undo
1034 1034
      *
1035 1035
      * @return bool|string Url pointing to the minified css file or false.
1036 1036
      */
1037
-    public function minify_single( $filepath, $cache_miss = false )
1037
+    public function minify_single($filepath, $cache_miss = false)
1038 1038
     {
1039
-        $contents = $this->prepare_minify_single( $filepath );
1039
+        $contents = $this->prepare_minify_single($filepath);
1040 1040
 
1041
-        if ( empty( $contents ) ) {
1041
+        if (empty($contents)) {
1042 1042
             return false;
1043 1043
         }
1044 1044
 
1045 1045
         // Check cache.
1046
-        $hash  = 'single_' . md5( $contents );
1047
-        $cache = new autoptimizeCache( $hash, 'css' );
1046
+        $hash  = 'single_'.md5($contents);
1047
+        $cache = new autoptimizeCache($hash, 'css');
1048 1048
 
1049 1049
         // If not in cache already, minify...
1050
-        if ( ! $cache->check() || $cache_miss ) {
1050
+        if (!$cache->check() || $cache_miss) {
1051 1051
             // Fixurls...
1052
-            $contents = self::fixurls( $filepath, $contents );
1052
+            $contents = self::fixurls($filepath, $contents);
1053 1053
             // CDN-replace any referenced assets if needed...
1054
-            $contents = $this->replace_urls( $contents );
1054
+            $contents = $this->replace_urls($contents);
1055 1055
             // Now minify...
1056 1056
             $cssmin   = new autoptimizeCSSmin();
1057
-            $contents = trim( $cssmin->run( $contents ) );
1057
+            $contents = trim($cssmin->run($contents));
1058 1058
             // Store in cache.
1059
-            $cache->cache( $contents, 'text/css' );
1059
+            $cache->cache($contents, 'text/css');
1060 1060
         }
1061 1061
 
1062
-        $url = $this->build_minify_single_url( $cache );
1062
+        $url = $this->build_minify_single_url($cache);
1063 1063
 
1064 1064
         return $url;
1065 1065
     }
@@ -1079,18 +1079,18 @@  discard block
 block discarded – undo
1079 1079
         return $this->options;
1080 1080
     }
1081 1081
 
1082
-    public function replaceOptions( $options )
1082
+    public function replaceOptions($options)
1083 1083
     {
1084 1084
         $this->options = $options;
1085 1085
     }
1086 1086
 
1087
-    public function setOption( $name, $value )
1087
+    public function setOption($name, $value)
1088 1088
     {
1089 1089
         $this->options[$name] = $value;
1090 1090
         $this->$name = $value;
1091 1091
     }
1092 1092
 
1093
-    public function getOption( $name )
1093
+    public function getOption($name)
1094 1094
     {
1095 1095
         return $this->options[$name];
1096 1096
     }
Please login to merge, or discard this patch.
classes/autoptimizeImages.php 1 patch
Spacing   +285 added lines, -285 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles optimizing images.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -23,17 +23,17 @@  discard block
 block discarded – undo
23 23
      */
24 24
     protected static $instance = null;
25 25
 
26
-    public function __construct( array $options = array() )
26
+    public function __construct(array $options = array())
27 27
     {
28 28
         // If options are not provided, fetch them.
29
-        if ( empty( $options ) ) {
29
+        if (empty($options)) {
30 30
             $options = $this->fetch_options();
31 31
         }
32 32
 
33
-        $this->set_options( $options );
33
+        $this->set_options($options);
34 34
     }
35 35
 
36
-    public function set_options( array $options )
36
+    public function set_options(array $options)
37 37
     {
38 38
         $this->options = $options;
39 39
 
@@ -42,17 +42,17 @@  discard block
 block discarded – undo
42 42
 
43 43
     public static function fetch_options()
44 44
     {
45
-        $value = get_option( 'autoptimize_imgopt_settings' );
46
-        if ( empty( $value ) ) {
45
+        $value = get_option('autoptimize_imgopt_settings');
46
+        if (empty($value)) {
47 47
             // Fallback to returning defaults when no stored option exists yet.
48 48
             $value = autoptimizeConfig::get_ao_imgopt_default_options();
49 49
         }
50 50
 
51 51
         // get service availability and add it to the options-array.
52
-        $value['availabilities'] = get_option( 'autoptimize_service_availablity' );
52
+        $value['availabilities'] = get_option('autoptimize_service_availablity');
53 53
 
54
-        if ( empty( $value['availabilities'] ) ) {
55
-            $value['availabilities'] = autoptimizeUtils::check_service_availability( true );
54
+        if (empty($value['availabilities'])) {
55
+            $value['availabilities'] = autoptimizeUtils::check_service_availability(true);
56 56
         }
57 57
 
58 58
         return $value;
@@ -65,9 +65,9 @@  discard block
 block discarded – undo
65 65
         // and does not use/ request the availablity data (which could slow things down).
66 66
         static $imgopt_active = null;
67 67
 
68
-        if ( null === $imgopt_active ) {
69
-            $opts = get_option( 'autoptimize_imgopt_settings', '' );
70
-            if ( ! empty( $opts ) && is_array( $opts ) && array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $opts ) && ! empty( $opts['autoptimize_imgopt_checkbox_field_1'] ) && '1' === $opts['autoptimize_imgopt_checkbox_field_1'] ) {
68
+        if (null === $imgopt_active) {
69
+            $opts = get_option('autoptimize_imgopt_settings', '');
70
+            if (!empty($opts) && is_array($opts) && array_key_exists('autoptimize_imgopt_checkbox_field_1', $opts) && !empty($opts['autoptimize_imgopt_checkbox_field_1']) && '1' === $opts['autoptimize_imgopt_checkbox_field_1']) {
71 71
                 $imgopt_active = true;
72 72
             } else {
73 73
                 $imgopt_active = false;
@@ -87,7 +87,7 @@  discard block
 block discarded – undo
87 87
      */
88 88
     public static function instance()
89 89
     {
90
-        if ( null === self::$instance ) {
90
+        if (null === self::$instance) {
91 91
             self::$instance = new self();
92 92
         }
93 93
 
@@ -96,26 +96,26 @@  discard block
 block discarded – undo
96 96
 
97 97
     public function run()
98 98
     {
99
-        if ( is_admin() ) {
100
-            add_action( 'admin_menu', array( $this, 'imgopt_admin_menu' ) );
101
-            add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_imgopt_tab' ), 9 );
99
+        if (is_admin()) {
100
+            add_action('admin_menu', array($this, 'imgopt_admin_menu'));
101
+            add_filter('autoptimize_filter_settingsscreen_tabs', array($this, 'add_imgopt_tab'), 9);
102 102
         } else {
103 103
             $this->run_on_frontend();
104 104
         }
105 105
     }
106 106
 
107 107
     public function run_on_frontend() {
108
-        if ( ! $this->should_run() ) {
109
-            if ( $this->should_lazyload() ) {
108
+        if (!$this->should_run()) {
109
+            if ($this->should_lazyload()) {
110 110
                 add_filter(
111 111
                     'autoptimize_html_after_minify',
112
-                    array( $this, 'filter_lazyload_images' ),
112
+                    array($this, 'filter_lazyload_images'),
113 113
                     10,
114 114
                     1
115 115
                 );
116 116
                 add_action(
117 117
                     'wp_footer',
118
-                    array( $this, 'add_lazyload_js_footer' ),
118
+                    array($this, 'add_lazyload_js_footer'),
119 119
                     10,
120 120
                     0
121 121
                 );
@@ -125,39 +125,39 @@  discard block
 block discarded – undo
125 125
 
126 126
         $active = false;
127 127
 
128
-        if ( apply_filters( 'autoptimize_filter_imgopt_do', true ) ) {
128
+        if (apply_filters('autoptimize_filter_imgopt_do', true)) {
129 129
             add_filter(
130 130
                 'autoptimize_html_after_minify',
131
-                array( $this, 'filter_optimize_images' ),
131
+                array($this, 'filter_optimize_images'),
132 132
                 10,
133 133
                 1
134 134
             );
135 135
             $active = true;
136 136
         }
137 137
 
138
-        if ( apply_filters( 'autoptimize_filter_imgopt_do_css', true ) ) {
138
+        if (apply_filters('autoptimize_filter_imgopt_do_css', true)) {
139 139
             add_filter(
140 140
                 'autoptimize_filter_base_replace_cdn',
141
-                array( $this, 'filter_optimize_css_images' ),
141
+                array($this, 'filter_optimize_css_images'),
142 142
                 10,
143 143
                 1
144 144
             );
145 145
             $active = true;
146 146
         }
147 147
 
148
-        if ( $active ) {
148
+        if ($active) {
149 149
             add_filter(
150 150
                 'autoptimize_extra_filter_tobepreconn',
151
-                array( $this, 'filter_preconnect_imgopt_url' ),
151
+                array($this, 'filter_preconnect_imgopt_url'),
152 152
                 10,
153 153
                 1
154 154
             );
155 155
         }
156 156
 
157
-        if ( $this->should_lazyload() ) {
157
+        if ($this->should_lazyload()) {
158 158
             add_action(
159 159
                 'wp_footer',
160
-                array( $this, 'add_lazyload_js_footer' )
160
+                array($this, 'add_lazyload_js_footer')
161 161
             );
162 162
         }
163 163
     }
@@ -170,8 +170,8 @@  discard block
 block discarded – undo
170 170
     protected function should_run()
171 171
     {
172 172
         $opts              = $this->options;
173
-        $service_not_down  = ( 'down' !== $opts['availabilities']['extra_imgopt']['status'] );
174
-        $not_launch_status = ( 'launch' !== $opts['availabilities']['extra_imgopt']['status'] );
173
+        $service_not_down  = ('down' !== $opts['availabilities']['extra_imgopt']['status']);
174
+        $not_launch_status = ('launch' !== $opts['availabilities']['extra_imgopt']['status']);
175 175
 
176 176
         $do_cdn      = true;
177 177
         $_userstatus = $this->get_imgopt_provider_userstatus();
@@ -183,7 +183,7 @@  discard block
 block discarded – undo
183 183
             $this->imgopt_active()
184 184
             && $do_cdn
185 185
             && $service_not_down
186
-            && ( $not_launch_status || $this->launch_ok() )
186
+            && ($not_launch_status || $this->launch_ok())
187 187
         ) {
188 188
             return true;
189 189
         }
@@ -194,11 +194,11 @@  discard block
 block discarded – undo
194 194
     {
195 195
         static $imgopt_host = null;
196 196
 
197
-        if ( null === $imgopt_host ) {
197
+        if (null === $imgopt_host) {
198 198
             $imgopt_host  = 'https://cdn.shortpixel.ai/';
199 199
             $avail_imgopt = $this->options['availabilities']['extra_imgopt'];
200
-            if ( ! empty( $avail_imgopt ) && array_key_exists( 'hosts', $avail_imgopt ) && is_array( $avail_imgopt['hosts'] ) ) {
201
-                $imgopt_host = array_rand( array_flip( $avail_imgopt['hosts'] ) );
200
+            if (!empty($avail_imgopt) && array_key_exists('hosts', $avail_imgopt) && is_array($avail_imgopt['hosts'])) {
201
+                $imgopt_host = array_rand(array_flip($avail_imgopt['hosts']));
202 202
             }
203 203
         }
204 204
 
@@ -214,7 +214,7 @@  discard block
 block discarded – undo
214 214
 
215 215
     public static function get_service_url_suffix()
216 216
     {
217
-        $suffix = '/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
217
+        $suffix = '/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
218 218
 
219 219
         return $suffix;
220 220
     }
@@ -223,12 +223,12 @@  discard block
 block discarded – undo
223 223
     {
224 224
         static $quality = null;
225 225
 
226
-        if ( null === $quality ) {
226
+        if (null === $quality) {
227 227
             $q_array = $this->get_img_quality_array();
228 228
             $setting = $this->get_img_quality_setting();
229 229
             $quality = apply_filters(
230 230
                 'autoptimize_filter_imgopt_quality',
231
-                'q_' . $q_array[ $setting ]
231
+                'q_'.$q_array[$setting]
232 232
             );
233 233
         }
234 234
 
@@ -239,7 +239,7 @@  discard block
 block discarded – undo
239 239
     {
240 240
         static $map = null;
241 241
 
242
-        if ( null === $map ) {
242
+        if (null === $map) {
243 243
             $map = array(
244 244
                 '1' => 'lossy',
245 245
                 '2' => 'glossy',
@@ -258,12 +258,12 @@  discard block
 block discarded – undo
258 258
     {
259 259
         static $q = null;
260 260
 
261
-        if ( null === $q ) {
262
-            if ( is_array( $this->options ) && array_key_exists( 'autoptimize_imgopt_select_field_2', $this->options ) ) {
261
+        if (null === $q) {
262
+            if (is_array($this->options) && array_key_exists('autoptimize_imgopt_select_field_2', $this->options)) {
263 263
                 $setting = $this->options['autoptimize_imgopt_select_field_2'];
264 264
             }
265 265
 
266
-            if ( ! isset( $setting ) || empty( $setting ) || ( '1' !== $setting && '3' !== $setting ) ) {
266
+            if (!isset($setting) || empty($setting) || ('1' !== $setting && '3' !== $setting)) {
267 267
                 // default image opt. value is 2 ("glossy").
268 268
                 $q = '2';
269 269
             } else {
@@ -274,10 +274,10 @@  discard block
 block discarded – undo
274 274
         return $q;
275 275
     }
276 276
 
277
-    public function filter_preconnect_imgopt_url( array $in )
277
+    public function filter_preconnect_imgopt_url(array $in)
278 278
     {
279
-        $url_parts = parse_url( $this->get_imgopt_base_url() );
280
-        $in[]      = $url_parts['scheme'] . '://' . $url_parts['host'];
279
+        $url_parts = parse_url($this->get_imgopt_base_url());
280
+        $in[]      = $url_parts['scheme'].'://'.$url_parts['host'];
281 281
 
282 282
         return $in;
283 283
     }
@@ -290,20 +290,20 @@  discard block
 block discarded – undo
290 290
      *
291 291
      * @return string
292 292
      */
293
-    private function normalize_img_url( $in )
293
+    private function normalize_img_url($in)
294 294
     {
295 295
         // Only parse the site url once.
296 296
         static $parsed_site_url = null;
297
-        if ( null === $parsed_site_url ) {
298
-            $parsed_site_url = parse_url( site_url() );
297
+        if (null === $parsed_site_url) {
298
+            $parsed_site_url = parse_url(site_url());
299 299
         }
300 300
 
301 301
         // get CDN domain once.
302 302
         static $cdn_domain = null;
303
-        if ( is_null( $cdn_domain ) ) {
304
-            $cdn_url = apply_filters( 'autoptimize_filter_base_cdnurl', get_option( 'autoptimize_cdn_url', '' ) );
305
-            if ( ! empty( $cdn_url ) ) {
306
-                $cdn_domain = parse_url( $cdn_url, PHP_URL_HOST );
303
+        if (is_null($cdn_domain)) {
304
+            $cdn_url = apply_filters('autoptimize_filter_base_cdnurl', get_option('autoptimize_cdn_url', ''));
305
+            if (!empty($cdn_url)) {
306
+                $cdn_domain = parse_url($cdn_url, PHP_URL_HOST);
307 307
             } else {
308 308
                 $cdn_domain = '';
309 309
             }
@@ -319,43 +319,43 @@  discard block
 block discarded – undo
319 319
          * identical string operations).
320 320
          */
321 321
         static $cache = null;
322
-        if ( null === $cache ) {
322
+        if (null === $cache) {
323 323
             $cache = array();
324 324
         }
325 325
 
326 326
         // Do the work on cache miss only.
327
-        if ( ! isset( $cache[ $in ] ) ) {
327
+        if (!isset($cache[$in])) {
328 328
             // Default to what was given to us.
329 329
             $result = $in;
330
-            if ( autoptimizeUtils::is_protocol_relative( $in ) ) {
331
-                $result = $parsed_site_url['scheme'] . ':' . $in;
332
-            } elseif ( 0 === strpos( $in, '/' ) ) {
330
+            if (autoptimizeUtils::is_protocol_relative($in)) {
331
+                $result = $parsed_site_url['scheme'].':'.$in;
332
+            } elseif (0 === strpos($in, '/')) {
333 333
                 // Root-relative...
334
-                $result = $parsed_site_url['scheme'] . '://' . $parsed_site_url['host'];
334
+                $result = $parsed_site_url['scheme'].'://'.$parsed_site_url['host'];
335 335
                 // Add the path for subfolder installs.
336
-                if ( isset( $parsed_site_url['path'] ) ) {
336
+                if (isset($parsed_site_url['path'])) {
337 337
                     $result .= $parsed_site_url['path'];
338 338
                 }
339 339
                 $result .= $in;
340
-            } elseif ( ! empty( $cdn_domain ) && strpos( $in, $cdn_domain ) !== 0 ) {
341
-                $result = str_replace( $cdn_domain, $parsed_site_url['host'], $in );
340
+            } elseif (!empty($cdn_domain) && strpos($in, $cdn_domain) !== 0) {
341
+                $result = str_replace($cdn_domain, $parsed_site_url['host'], $in);
342 342
             }
343 343
 
344
-            $result = apply_filters( 'autoptimize_filter_imgopt_normalized_url', $result );
344
+            $result = apply_filters('autoptimize_filter_imgopt_normalized_url', $result);
345 345
 
346 346
             // Store in cache.
347
-            $cache[ $in ] = $result;
347
+            $cache[$in] = $result;
348 348
         }
349 349
 
350
-        return $cache[ $in ];
350
+        return $cache[$in];
351 351
     }
352 352
 
353
-    public function filter_optimize_css_images( $in )
353
+    public function filter_optimize_css_images($in)
354 354
     {
355
-        $in = $this->normalize_img_url( $in );
355
+        $in = $this->normalize_img_url($in);
356 356
 
357
-        if ( $this->can_optimize_image( $in ) ) {
358
-            return $this->build_imgopt_url( $in, '', '' );
357
+        if ($this->can_optimize_image($in)) {
358
+            return $this->build_imgopt_url($in, '', '');
359 359
         } else {
360 360
             return $in;
361 361
         }
@@ -365,50 +365,50 @@  discard block
 block discarded – undo
365 365
     {
366 366
         static $imgopt_base_url = null;
367 367
 
368
-        if ( null === $imgopt_base_url ) {
368
+        if (null === $imgopt_base_url) {
369 369
             $imgopt_host     = $this->get_imgopt_host();
370 370
             $quality         = $this->get_img_quality_string();
371
-            $ret_val         = apply_filters( 'autoptimize_filter_imgopt_wait', 'ret_img' ); // values: ret_wait, ret_img, ret_json, ret_blank.
372
-            $imgopt_base_url = $imgopt_host . 'client/' . $quality . ',' . $ret_val;
373
-            $imgopt_base_url = apply_filters( 'autoptimize_filter_imgopt_base_url', $imgopt_base_url );
371
+            $ret_val         = apply_filters('autoptimize_filter_imgopt_wait', 'ret_img'); // values: ret_wait, ret_img, ret_json, ret_blank.
372
+            $imgopt_base_url = $imgopt_host.'client/'.$quality.','.$ret_val;
373
+            $imgopt_base_url = apply_filters('autoptimize_filter_imgopt_base_url', $imgopt_base_url);
374 374
         }
375 375
 
376 376
         return $imgopt_base_url;
377 377
     }
378 378
 
379
-    private function can_optimize_image( $url )
379
+    private function can_optimize_image($url)
380 380
     {
381 381
         static $cdn_url      = null;
382 382
         static $nopti_images = null;
383 383
 
384
-        if ( null === $cdn_url ) {
384
+        if (null === $cdn_url) {
385 385
             $cdn_url = apply_filters(
386 386
                 'autoptimize_filter_base_cdnurl',
387
-                get_option( 'autoptimize_cdn_url', '' )
387
+                get_option('autoptimize_cdn_url', '')
388 388
             );
389 389
         }
390 390
 
391
-        if ( null === $nopti_images ) {
392
-            $nopti_images = apply_filters( 'autoptimize_filter_imgopt_noptimize', '' );
391
+        if (null === $nopti_images) {
392
+            $nopti_images = apply_filters('autoptimize_filter_imgopt_noptimize', '');
393 393
         }
394 394
 
395 395
         $site_host  = AUTOPTIMIZE_SITE_DOMAIN;
396
-        $url        = $this->normalize_img_url( $url );
397
-        $url_parsed = parse_url( $url );
396
+        $url        = $this->normalize_img_url($url);
397
+        $url_parsed = parse_url($url);
398 398
 
399
-        if ( array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host && empty( $cdn_url ) ) {
399
+        if (array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host && empty($cdn_url)) {
400 400
             return false;
401
-        } elseif ( ! empty( $cdn_url ) && strpos( $url, $cdn_url ) === false && array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host ) {
401
+        } elseif (!empty($cdn_url) && strpos($url, $cdn_url) === false && array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host) {
402 402
             return false;
403
-        } elseif ( strpos( $url, '.php' ) !== false ) {
403
+        } elseif (strpos($url, '.php') !== false) {
404 404
             return false;
405
-        } elseif ( str_ireplace( array( '.png', '.gif', '.jpg', '.jpeg', '.webp' ), '', $url_parsed['path'] ) === $url_parsed['path'] ) {
405
+        } elseif (str_ireplace(array('.png', '.gif', '.jpg', '.jpeg', '.webp'), '', $url_parsed['path']) === $url_parsed['path']) {
406 406
             // fixme: better check against end of string.
407 407
             return false;
408
-        } elseif ( ! empty( $nopti_images ) ) {
409
-            $nopti_images_array = array_filter( array_map( 'trim', explode( ',', $nopti_images ) ) );
410
-            foreach ( $nopti_images_array as $nopti_image ) {
411
-                if ( strpos( $url, $nopti_image ) !== false ) {
408
+        } elseif (!empty($nopti_images)) {
409
+            $nopti_images_array = array_filter(array_map('trim', explode(',', $nopti_images)));
410
+            foreach ($nopti_images_array as $nopti_image) {
411
+                if (strpos($url, $nopti_image) !== false) {
412 412
                     return false;
413 413
                 }
414 414
             }
@@ -416,13 +416,13 @@  discard block
 block discarded – undo
416 416
         return true;
417 417
     }
418 418
 
419
-    private function build_imgopt_url( $orig_url, $width = 0, $height = 0 )
419
+    private function build_imgopt_url($orig_url, $width = 0, $height = 0)
420 420
     {
421 421
         // sanitize width and height.
422
-        if ( strpos( $width, '%' ) !== false ) {
422
+        if (strpos($width, '%') !== false) {
423 423
             $width = 0;
424 424
         }
425
-        if ( strpos( $height, '%' ) !== false ) {
425
+        if (strpos($height, '%') !== false) {
426 426
             $height = 0;
427 427
         }
428 428
         $width  = (int) $width;
@@ -436,42 +436,42 @@  discard block
 block discarded – undo
436 436
         );
437 437
 
438 438
         // If filter modified the url, return that.
439
-        if ( $filtered_url !== $orig_url ) {
439
+        if ($filtered_url !== $orig_url) {
440 440
             return $filtered_url;
441 441
         }
442 442
 
443
-        $orig_url        = $this->normalize_img_url( $orig_url );
443
+        $orig_url        = $this->normalize_img_url($orig_url);
444 444
         $imgopt_base_url = $this->get_imgopt_base_url();
445 445
         $imgopt_size     = '';
446 446
 
447
-        if ( $width && 0 !== $width ) {
448
-            $imgopt_size = ',w_' . $width;
447
+        if ($width && 0 !== $width) {
448
+            $imgopt_size = ',w_'.$width;
449 449
         }
450 450
 
451
-        if ( $height && 0 !== $height ) {
452
-            $imgopt_size .= ',h_' . $height;
451
+        if ($height && 0 !== $height) {
452
+            $imgopt_size .= ',h_'.$height;
453 453
         }
454 454
 
455
-        $url = $imgopt_base_url . $imgopt_size . '/' . $orig_url;
455
+        $url = $imgopt_base_url.$imgopt_size.'/'.$orig_url;
456 456
 
457 457
         return $url;
458 458
     }
459 459
 
460
-    public function replace_data_thumbs( $matches )
460
+    public function replace_data_thumbs($matches)
461 461
     {
462
-        return $this->replace_img_callback( $matches, 150, 150 );
462
+        return $this->replace_img_callback($matches, 150, 150);
463 463
     }
464 464
 
465
-    public function replace_img_callback( $matches, $width = 0, $height = 0 )
465
+    public function replace_img_callback($matches, $width = 0, $height = 0)
466 466
     {
467
-        if ( $this->can_optimize_image( $matches[1] ) ) {
468
-            return str_replace( $matches[1], $this->build_imgopt_url( $matches[1], $width, $height ), $matches[0] );
467
+        if ($this->can_optimize_image($matches[1])) {
468
+            return str_replace($matches[1], $this->build_imgopt_url($matches[1], $width, $height), $matches[0]);
469 469
         } else {
470 470
             return $matches[0];
471 471
         }
472 472
     }
473 473
 
474
-    public function filter_optimize_images( $in )
474
+    public function filter_optimize_images($in)
475 475
     {
476 476
         /*
477 477
          * potential future functional improvements:
@@ -482,7 +482,7 @@  discard block
 block discarded – undo
482 482
         $to_replace = array();
483 483
 
484 484
         // hide noscript tags to avoid nesting noscript tags (as lazyloaded images add noscript).
485
-        if ( $this->should_lazyload() ) {
485
+        if ($this->should_lazyload()) {
486 486
             $in = autoptimizeBase::replace_contents_with_marker_if_exists(
487 487
                 'NOSCRIPT',
488 488
                 '<noscript',
@@ -492,25 +492,25 @@  discard block
 block discarded – undo
492 492
         }
493 493
 
494 494
         // extract img tags.
495
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $in, $matches ) ) {
496
-            foreach ( $matches[0] as $tag ) {
495
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $in, $matches)) {
496
+            foreach ($matches[0] as $tag) {
497 497
                 $orig_tag = $tag;
498 498
                 $imgopt_w = '';
499 499
                 $imgopt_h = '';
500 500
 
501 501
                 // first do (data-)srcsets.
502
-                if ( preg_match_all( '#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER ) ) {
503
-                    foreach ( $allsrcsets as $srcset ) {
502
+                if (preg_match_all('#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER)) {
503
+                    foreach ($allsrcsets as $srcset) {
504 504
                         $srcset  = $srcset[2];
505
-                        $srcsets = explode( ',', $srcset );
506
-                        foreach ( $srcsets as $indiv_srcset ) {
507
-                            $indiv_srcset_parts = explode( ' ', trim( $indiv_srcset ) );
508
-                            if ( isset( $indiv_srcset_parts[1] ) && rtrim( $indiv_srcset_parts[1], 'w' ) !== $indiv_srcset_parts[1] ) {
509
-                                $imgopt_w = rtrim( $indiv_srcset_parts[1], 'w' );
505
+                        $srcsets = explode(',', $srcset);
506
+                        foreach ($srcsets as $indiv_srcset) {
507
+                            $indiv_srcset_parts = explode(' ', trim($indiv_srcset));
508
+                            if (isset($indiv_srcset_parts[1]) && rtrim($indiv_srcset_parts[1], 'w') !== $indiv_srcset_parts[1]) {
509
+                                $imgopt_w = rtrim($indiv_srcset_parts[1], 'w');
510 510
                             }
511
-                            if ( $this->can_optimize_image( $indiv_srcset_parts[0] ) ) {
512
-                                $imgopt_url = $this->build_imgopt_url( $indiv_srcset_parts[0], $imgopt_w, '' );
513
-                                $tag        = str_replace( $indiv_srcset_parts[0], $imgopt_url, $tag );
511
+                            if ($this->can_optimize_image($indiv_srcset_parts[0])) {
512
+                                $imgopt_url = $this->build_imgopt_url($indiv_srcset_parts[0], $imgopt_w, '');
513
+                                $tag        = str_replace($indiv_srcset_parts[0], $imgopt_url, $tag);
514 514
                             }
515 515
                         }
516 516
                     }
@@ -518,87 +518,87 @@  discard block
 block discarded – undo
518 518
 
519 519
                 // proceed with img src.
520 520
                 // get width and height and add to $imgopt_size.
521
-                $_get_size = $this->get_size_from_tag( $tag );
521
+                $_get_size = $this->get_size_from_tag($tag);
522 522
                 $imgopt_w  = $_get_size['width'];
523 523
                 $imgopt_h  = $_get_size['height'];
524 524
 
525 525
                 // then start replacing images src.
526
-                if ( preg_match_all( '#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER ) ) {
527
-                    foreach ( $urls as $url ) {
526
+                if (preg_match_all('#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER)) {
527
+                    foreach ($urls as $url) {
528 528
                         $full_src_orig = $url[0];
529 529
                         $url           = $url[1];
530
-                        if ( $this->can_optimize_image( $url ) ) {
531
-                            $imgopt_url      = $this->build_imgopt_url( $url, $imgopt_w, $imgopt_h );
532
-                            $full_imgopt_src = str_replace( $url, $imgopt_url, $full_src_orig );
533
-                            $tag             = str_replace( $full_src_orig, $full_imgopt_src, $tag );
530
+                        if ($this->can_optimize_image($url)) {
531
+                            $imgopt_url      = $this->build_imgopt_url($url, $imgopt_w, $imgopt_h);
532
+                            $full_imgopt_src = str_replace($url, $imgopt_url, $full_src_orig);
533
+                            $tag             = str_replace($full_src_orig, $full_imgopt_src, $tag);
534 534
                         }
535 535
                     }
536 536
                 }
537 537
 
538 538
                 // do lazyload stuff.
539
-                if ( $this->should_lazyload() && str_ireplace( $this->get_lazyload_exclusions(), '', $tag ) === $tag ) {
540
-                    $noscript_tag = '<noscript>' . $tag . '</noscript>';
541
-                    $tag          = str_replace( 'srcset=', 'data-srcset=', $tag );
539
+                if ($this->should_lazyload() && str_ireplace($this->get_lazyload_exclusions(), '', $tag) === $tag) {
540
+                    $noscript_tag = '<noscript>'.$tag.'</noscript>';
541
+                    $tag          = str_replace('srcset=', 'data-srcset=', $tag);
542 542
 
543 543
                     // add lazyload class.
544
-                    $tag = $this->inject_classes_in_tag( $tag, 'lazyload ' );
544
+                    $tag = $this->inject_classes_in_tag($tag, 'lazyload ');
545 545
 
546 546
                     // set placeholder.
547
-                    if ( strpos( $url, $this->get_imgopt_host() ) === 0 ) {
547
+                    if (strpos($url, $this->get_imgopt_host()) === 0) {
548 548
                         // if all img src have been replaced during srcset, we have to extract the
549 549
                         // origin url from the imgopt one to be able to set a lqip placeholder.
550
-                        $_url = substr( $url, strpos( $url, '/http' ) + 1 );
550
+                        $_url = substr($url, strpos($url, '/http') + 1);
551 551
                     } else {
552 552
                         $_url = $url;
553 553
                     }
554
-                    if ( $this->can_optimize_image( $_url ) && apply_filters( 'autoptimize_filter_imgopt_lazyload_dolqip', true ) ) {
555
-                        $placeholder = $this->get_imgopt_host() . 'client/q_lqip,ret_wait,w_' . $imgopt_w . ',h_' . $imgopt_h . '/' . $_url;
554
+                    if ($this->can_optimize_image($_url) && apply_filters('autoptimize_filter_imgopt_lazyload_dolqip', true)) {
555
+                        $placeholder = $this->get_imgopt_host().'client/q_lqip,ret_wait,w_'.$imgopt_w.',h_'.$imgopt_h.'/'.$_url;
556 556
                     } else {
557
-                        $placeholder = $this->get_default_lazyload_placeholder( $imgopt_w, $imgopt_h );
557
+                        $placeholder = $this->get_default_lazyload_placeholder($imgopt_w, $imgopt_h);
558 558
                     }
559
-                    $placeholder = ' src=\'' . apply_filters( 'autoptimize_filter_imgopt_lazyload_placeholder', $placeholder );
559
+                    $placeholder = ' src=\''.apply_filters('autoptimize_filter_imgopt_lazyload_placeholder', $placeholder);
560 560
 
561 561
                     // add min-heigth off by default as it can deform images, can be enabled with filter.
562 562
                     $min_height = '';
563
-                    if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_addminheight', false ) ) {
564
-                        $min_height = ' style="min-height:' . $imgopt_h . 'px;"';
563
+                    if (apply_filters('autoptimize_filter_imgopt_lazyload_addminheight', false)) {
564
+                        $min_height = ' style="min-height:'.$imgopt_h.'px;"';
565 565
                     }
566 566
 
567 567
                     // add noscript & placeholder.
568
-                    $tag = $noscript_tag . str_replace( ' src=', $min_height . $placeholder . '\' data-src=', $tag );
569
-                    $tag = apply_filters( 'autoptimize_filter_imgopt_lazyloaded_img', $tag );
568
+                    $tag = $noscript_tag.str_replace(' src=', $min_height.$placeholder.'\' data-src=', $tag);
569
+                    $tag = apply_filters('autoptimize_filter_imgopt_lazyloaded_img', $tag);
570 570
                 }
571 571
 
572 572
                 // add tag to array for later replacement.
573
-                if ( $tag !== $orig_tag ) {
574
-                    $to_replace[ $orig_tag ] = $tag;
573
+                if ($tag !== $orig_tag) {
574
+                    $to_replace[$orig_tag] = $tag;
575 575
                 }
576 576
             }
577 577
         }
578 578
 
579 579
         // and replace all.
580
-        $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $in );
580
+        $out = str_replace(array_keys($to_replace), array_values($to_replace), $in);
581 581
 
582 582
         // img thumbnails in e.g. woocommerce.
583
-        if ( strpos( $out, 'data-thumb' ) !== false && apply_filters( 'autoptimize_filter_imgopt_datathumbs', true ) ) {
583
+        if (strpos($out, 'data-thumb') !== false && apply_filters('autoptimize_filter_imgopt_datathumbs', true)) {
584 584
             $out = preg_replace_callback(
585 585
                 '/\<div(?:[^>]?)\sdata-thumb\=(?:\"|\')(.+?)(?:\"|\')(?:[^>]*)?\>/s',
586
-                array( $this, 'replace_data_thumbs' ),
586
+                array($this, 'replace_data_thumbs'),
587 587
                 $out
588 588
             );
589 589
         }
590 590
 
591 591
         // background-image in inline style.
592
-        if ( strpos( $out, 'background-image:' ) !== false && apply_filters( 'autoptimize_filter_imgopt_backgroundimages', true ) ) {
592
+        if (strpos($out, 'background-image:') !== false && apply_filters('autoptimize_filter_imgopt_backgroundimages', true)) {
593 593
             $out = preg_replace_callback(
594 594
                 '/style=(?:"|\').*?background-image:\s?url\((?:"|\')?([^"\')]*)(?:"|\')?\)/',
595
-                array( $this, 'replace_img_callback' ),
595
+                array($this, 'replace_img_callback'),
596 596
                 $out
597 597
             );
598 598
         }
599 599
 
600 600
         // and restore noscript tags if these were hidden for lazyload purposes.
601
-        if ( $this->should_lazyload() ) {
601
+        if ($this->should_lazyload()) {
602 602
             $out = autoptimizeBase::restore_marked_content(
603 603
                 'NOSCRIPT',
604 604
                 $out
@@ -608,34 +608,34 @@  discard block
 block discarded – undo
608 608
         return $out;
609 609
     }
610 610
 
611
-    public function get_size_from_tag( $tag ) {
611
+    public function get_size_from_tag($tag) {
612 612
         // reusable function to extract widht and height from an image tag
613 613
         // enforcing a filterable maximum width and height (default 4999X4999).
614 614
         $width  = '';
615 615
         $height = '';
616 616
 
617
-        if ( preg_match( '#width=("|\')(.*)("|\')#Usmi', $tag, $_width ) ) {
618
-            if ( strpos( $_width[2], '%' ) === false ) {
617
+        if (preg_match('#width=("|\')(.*)("|\')#Usmi', $tag, $_width)) {
618
+            if (strpos($_width[2], '%') === false) {
619 619
                 $width = (int) $_width[2];
620 620
             }
621 621
         }
622
-        if ( preg_match( '#height=("|\')(.*)("|\')#Usmi', $tag, $_height ) ) {
623
-            if ( strpos( $_height[2], '%' ) === false ) {
622
+        if (preg_match('#height=("|\')(.*)("|\')#Usmi', $tag, $_height)) {
623
+            if (strpos($_height[2], '%') === false) {
624 624
                 $height = (int) $_height[2];
625 625
             }
626 626
         }
627 627
 
628 628
         // check for and enforce (filterable) max sizes.
629
-        $_max_width = apply_filters( 'autoptimize_filter_imgopt_max_width', 4999 );
630
-        if ( $width > $_max_width ) {
629
+        $_max_width = apply_filters('autoptimize_filter_imgopt_max_width', 4999);
630
+        if ($width > $_max_width) {
631 631
             $_width = $_max_width;
632
-            $height = $_width / $width * $height;
632
+            $height = $_width/$width*$height;
633 633
             $width  = $_width;
634 634
         }
635
-        $_max_height = apply_filters( 'autoptimize_filter_imgopt_max_height', 4999 );
636
-        if ( $height > $_max_height ) {
635
+        $_max_height = apply_filters('autoptimize_filter_imgopt_max_height', 4999);
636
+        if ($height > $_max_height) {
637 637
             $_height = $_max_height;
638
-            $width   = $_height / $height * $width;
638
+            $width   = $_height/$height*$width;
639 639
             $height  = $_height;
640 640
         }
641 641
 
@@ -649,7 +649,7 @@  discard block
 block discarded – undo
649 649
      * Lazyload functions
650 650
      */
651 651
     public function should_lazyload() {
652
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) ) {
652
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_3'])) {
653 653
             $lazyload_return = true;
654 654
         } else {
655 655
             $lazyload_return = false;
@@ -664,7 +664,7 @@  discard block
 block discarded – undo
664 664
         return $self->should_lazyload();
665 665
     }
666 666
 
667
-    public function filter_lazyload_images( $in )
667
+    public function filter_lazyload_images($in)
668 668
     {
669 669
         // only used is image optimization is NOT active but lazyload is.
670 670
         $to_replace = array();
@@ -678,11 +678,11 @@  discard block
 block discarded – undo
678 678
         );
679 679
 
680 680
         // extract img tags and add lazyload attribs.
681
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $out, $matches ) ) {
682
-            foreach ( $matches[0] as $tag ) {
683
-                $to_replace[ $tag ] = $this->add_lazyload( $tag );
681
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $out, $matches)) {
682
+            foreach ($matches[0] as $tag) {
683
+                $to_replace[$tag] = $this->add_lazyload($tag);
684 684
             }
685
-            $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $out );
685
+            $out = str_replace(array_keys($to_replace), array_values($to_replace), $out);
686 686
         }
687 687
 
688 688
         // restore noscript tags.
@@ -694,35 +694,35 @@  discard block
 block discarded – undo
694 694
         return $out;
695 695
     }
696 696
 
697
-    public function add_lazyload( $tag ) {
697
+    public function add_lazyload($tag) {
698 698
         // adds actual lazyload-attributes to an image node.
699
-        if ( str_ireplace( $this->get_lazyload_exclusions(), '', $tag ) === $tag ) {
699
+        if (str_ireplace($this->get_lazyload_exclusions(), '', $tag) === $tag) {
700 700
             // store original tag for use in noscript version.
701
-            $noscript_tag = '<noscript>' . $tag . '</noscript>';
701
+            $noscript_tag = '<noscript>'.$tag.'</noscript>';
702 702
 
703 703
             // insert lazyload class.
704
-            $tag = $this->inject_classes_in_tag( $tag, 'lazyload ' );
704
+            $tag = $this->inject_classes_in_tag($tag, 'lazyload ');
705 705
 
706 706
             // get image width & heigth for placeholder fun (and to prevent content reflow).
707
-            $_get_size = $this->get_size_from_tag( $tag );
707
+            $_get_size = $this->get_size_from_tag($tag);
708 708
             $width     = $_get_size['width'];
709 709
             $height    = $_get_size['height'];
710
-            if ( false === $width ) {
710
+            if (false === $width) {
711 711
                 $widht = 210; // default width for SVG placeholder.
712 712
             }
713
-            if ( false === $height ) {
714
-                $heigth = $width / 3 * 2; // if no height, base it on width using the 3/2 aspect ratio.
713
+            if (false === $height) {
714
+                $heigth = $width/3*2; // if no height, base it on width using the 3/2 aspect ratio.
715 715
             }
716 716
 
717 717
             // insert the actual lazyload stuff.
718 718
             // see https://css-tricks.com/preventing-content-reflow-from-lazy-loaded-images/ for great read on why we're using empty svg's.
719
-            $placeholder = apply_filters( 'autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder( $width, $height ) );
720
-            $tag         = str_replace( ' src=', ' src=\'' . $placeholder . '\' data-src=', $tag );
721
-            $tag         = str_replace( ' srcset=', ' data-srcset=', $tag );
719
+            $placeholder = apply_filters('autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder($width, $height));
720
+            $tag         = str_replace(' src=', ' src=\''.$placeholder.'\' data-src=', $tag);
721
+            $tag         = str_replace(' srcset=', ' data-srcset=', $tag);
722 722
 
723 723
             // add the noscript-tag from earlier.
724
-            $tag = $noscript_tag . $tag;
725
-            $tag = apply_filters( 'autoptimize_filter_imgopt_lazyloaded_img', $tag );
724
+            $tag = $noscript_tag.$tag;
725
+            $tag = apply_filters('autoptimize_filter_imgopt_lazyloaded_img', $tag);
726 726
         }
727 727
 
728 728
         return $tag;
@@ -731,20 +731,20 @@  discard block
 block discarded – undo
731 731
     public function add_lazyload_js_footer() {
732 732
         // The JS will by default be excluded form autoptimization but this can be changed with a filter.
733 733
         $noptimize_flag = '';
734
-        if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_js_noptimize', true ) ) {
734
+        if (apply_filters('autoptimize_filter_imgopt_lazyload_js_noptimize', true)) {
735 735
             $noptimize_flag = ' data-noptimize="1"';
736 736
         }
737 737
 
738 738
         // Adds lazyload CSS & JS to footer, using echo because wp_enqueue_script seems not to support pushing attributes (async).
739
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_cssoutput', '<style>.lazyload,.lazyloading{opacity:0;}.lazyloaded{opacity:1;transition:opacity 300ms;}</style><noscript><style>.lazyload{display:none;}</style></noscript>' );
740
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_jsconfig', '<script' . $noptimize_flag . '>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>' );
741
-        echo '<script async' . $noptimize_flag . ' src=\'' . plugins_url( 'external/js/lazysizes.min.js', __FILE__ ) . '\'></script>';
739
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_cssoutput', '<style>.lazyload,.lazyloading{opacity:0;}.lazyloaded{opacity:1;transition:opacity 300ms;}</style><noscript><style>.lazyload{display:none;}</style></noscript>');
740
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_jsconfig', '<script'.$noptimize_flag.'>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>');
741
+        echo '<script async'.$noptimize_flag.' src=\''.plugins_url('external/js/lazysizes.min.js', __FILE__).'\'></script>';
742 742
 
743 743
         // And add webp detection and loading JS.
744
-        if ( $this->should_webp() ) {
744
+        if ($this->should_webp()) {
745 745
             $_webp_detect = "function c_webp(A){var n=new Image;n.onload=function(){var e=0<n.width&&0<n.height;A(e)},n.onerror=function(){A(!1)},n.src=''}function s_webp(e){window.supportsWebP=e}c_webp(s_webp);";
746 746
             $_webp_load   = "document.addEventListener('lazybeforeunveil',function({target:c}){supportsWebP&&['data-src','data-srcset'].forEach(function(a){attr=c.getAttribute(a),null!==attr&&c.setAttribute(a,attr.replace(/\/client\//,'/client/to_webp,'))})});";
747
-            echo apply_filters( 'autoptimize_filter_imgopt_webp_js', '<script' . $noptimize_flag . '>' . $_webp_detect . $_webp_load . '</script>' );
747
+            echo apply_filters('autoptimize_filter_imgopt_webp_js', '<script'.$noptimize_flag.'>'.$_webp_detect.$_webp_load.'</script>');
748 748
         }
749 749
     }
750 750
 
@@ -752,47 +752,47 @@  discard block
 block discarded – undo
752 752
         // returns array of strings that if found in an <img tag will stop the img from being lazy-loaded.
753 753
         static $exclude_lazyload_array = null;
754 754
 
755
-        if ( null === $exclude_lazyload_array ) {
755
+        if (null === $exclude_lazyload_array) {
756 756
             $options = $this->options;
757 757
 
758 758
             // set default exclusions.
759
-            $exclude_lazyload_array = array( 'skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset' );
759
+            $exclude_lazyload_array = array('skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset');
760 760
 
761 761
             // add from setting.
762
-            if ( array_key_exists( 'autoptimize_imgopt_text_field_5', $options ) ) {
762
+            if (array_key_exists('autoptimize_imgopt_text_field_5', $options)) {
763 763
                 $exclude_lazyload_option = $options['autoptimize_imgopt_text_field_5'];
764
-                if ( ! empty( $exclude_lazyload_option ) ) {
765
-                    $exclude_lazyload_array = array_merge( $exclude_lazyload_array, array_filter( array_map( 'trim', explode( ',', $options['autoptimize_imgopt_text_field_5'] ) ) ) );
764
+                if (!empty($exclude_lazyload_option)) {
765
+                    $exclude_lazyload_array = array_merge($exclude_lazyload_array, array_filter(array_map('trim', explode(',', $options['autoptimize_imgopt_text_field_5']))));
766 766
                 }
767 767
             }
768 768
 
769 769
             // and filter for developer-initiated changes.
770
-            $exclude_lazyload_array = apply_filters( 'autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array );
770
+            $exclude_lazyload_array = apply_filters('autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array);
771 771
         }
772 772
 
773 773
         return $exclude_lazyload_array;
774 774
     }
775 775
 
776
-    public function inject_classes_in_tag( $tag, $target_class ) {
777
-        if ( strpos( $tag, 'class=' ) !== false ) {
778
-            $tag = preg_replace( '/(\sclass\s?=\s?("|\'))/', '$1' . $target_class, $tag );
776
+    public function inject_classes_in_tag($tag, $target_class) {
777
+        if (strpos($tag, 'class=') !== false) {
778
+            $tag = preg_replace('/(\sclass\s?=\s?("|\'))/', '$1'.$target_class, $tag);
779 779
         } else {
780
-            $tag = str_replace( '<img ', '<img class="' . trim( $target_class ) . '" ', $tag );
780
+            $tag = str_replace('<img ', '<img class="'.trim($target_class).'" ', $tag);
781 781
         }
782 782
 
783 783
         return $tag;
784 784
     }
785 785
 
786
-    public function get_default_lazyload_placeholder( $imgopt_w, $imgopt_h ) {
787
-        return 'data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%20' . $imgopt_w . '%20' . $imgopt_h . '%22%3E%3C/svg%3E';
786
+    public function get_default_lazyload_placeholder($imgopt_w, $imgopt_h) {
787
+        return 'data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%20'.$imgopt_w.'%20'.$imgopt_h.'%22%3E%3C/svg%3E';
788 788
     }
789 789
 
790 790
     public function should_webp() {
791 791
         static $webp_return = null;
792 792
 
793
-        if ( is_null( $webp_return ) ) {
793
+        if (is_null($webp_return)) {
794 794
             // webp only works if imgopt and lazyload are also active.
795
-            if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_4'] ) && ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) && $this->imgopt_active() ) {
795
+            if (!empty($this->options['autoptimize_imgopt_checkbox_field_4']) && !empty($this->options['autoptimize_imgopt_checkbox_field_3']) && $this->imgopt_active()) {
796 796
                 $webp_return = true;
797 797
             } else {
798 798
                 $webp_return = false;
@@ -813,14 +813,14 @@  discard block
 block discarded – undo
813 813
             'autoptimize_imgopt',
814 814
             'manage_options',
815 815
             'autoptimize_imgopt',
816
-            array( $this, 'imgopt_options_page' )
816
+            array($this, 'imgopt_options_page')
817 817
         );
818
-        register_setting( 'autoptimize_imgopt_settings', 'autoptimize_imgopt_settings' );
818
+        register_setting('autoptimize_imgopt_settings', 'autoptimize_imgopt_settings');
819 819
     }
820 820
 
821
-    public function add_imgopt_tab( $in )
821
+    public function add_imgopt_tab($in)
822 822
     {
823
-        $in = array_merge( $in, array( 'autoptimize_imgopt' => __( 'Images', 'autoptimize' ) ) );
823
+        $in = array_merge($in, array('autoptimize_imgopt' => __('Images', 'autoptimize')));
824 824
 
825 825
         return $in;
826 826
     }
@@ -828,7 +828,7 @@  discard block
 block discarded – undo
828 828
     public function imgopt_options_page()
829 829
     {
830 830
         // Check querystring for "refreshCacheChecker" and call cachechecker if so.
831
-        if ( array_key_exists( 'refreshImgProvStats', $_GET ) && 1 == $_GET['refreshImgProvStats'] ) {
831
+        if (array_key_exists('refreshImgProvStats', $_GET) && 1 == $_GET['refreshImgProvStats']) {
832 832
             $this->query_img_provider_stats();
833 833
         }
834 834
 
@@ -841,45 +841,45 @@  discard block
 block discarded – undo
841 841
         #autoptimize_imgopt_descr{font-size: 120%;}
842 842
     </style>
843 843
     <div class="wrap">
844
-    <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
844
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
845 845
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
846
-        <?php if ( 'down' === $options['availabilities']['extra_imgopt']['status'] ) { ?>
846
+        <?php if ('down' === $options['availabilities']['extra_imgopt']['status']) { ?>
847 847
             <div class="notice-warning notice"><p>
848 848
             <?php
849 849
             // translators: "Autoptimize support forum" will appear in a "a href".
850
-            echo sprintf( __( 'The image optimization service is currently down, image optimization will be skipped until further notice. Check the %1$sAutoptimize support forum%2$s for more info.', 'autoptimize' ), '<a href="https://wordpress.org/support/plugin/autoptimize/" target="_blank">', '</a>' );
850
+            echo sprintf(__('The image optimization service is currently down, image optimization will be skipped until further notice. Check the %1$sAutoptimize support forum%2$s for more info.', 'autoptimize'), '<a href="https://wordpress.org/support/plugin/autoptimize/" target="_blank">', '</a>');
851 851
             ?>
852 852
             </p></div>
853 853
         <?php } ?>
854 854
 
855
-        <?php if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] && ! autoptimizeImages::instance()->launch_ok() ) { ?>
855
+        <?php if ('launch' === $options['availabilities']['extra_imgopt']['status'] && !autoptimizeImages::instance()->launch_ok()) { ?>
856 856
             <div class="notice-warning notice"><p>
857
-            <?php _e( 'The image optimization service is launching, but not yet available for this domain, it should become available in the next couple of days.', 'autoptimize' ); ?>
857
+            <?php _e('The image optimization service is launching, but not yet available for this domain, it should become available in the next couple of days.', 'autoptimize'); ?>
858 858
             </p></div>
859 859
         <?php } ?>
860 860
 
861
-        <?php if ( class_exists( 'Jetpack' ) && method_exists( 'Jetpack', 'get_active_modules' ) && in_array( 'photon', Jetpack::get_active_modules() ) ) { ?>
861
+        <?php if (class_exists('Jetpack') && method_exists('Jetpack', 'get_active_modules') && in_array('photon', Jetpack::get_active_modules())) { ?>
862 862
             <div class="notice-warning notice"><p>
863 863
             <?php
864 864
             // translators: "disable  Jetpack's site accelerator for images" will appear in a "a href" linking to the jetpack settings page.
865
-            echo sprintf( __( 'Please %1$sdisable Jetpack\'s site accelerator for images%2$s to be able to use Autoptomize\'s advanced image optimization features below.', 'autoptimize' ), '<a href="admin.php?page=jetpack#/settings">', '</a>' );
865
+            echo sprintf(__('Please %1$sdisable Jetpack\'s site accelerator for images%2$s to be able to use Autoptomize\'s advanced image optimization features below.', 'autoptimize'), '<a href="admin.php?page=jetpack#/settings">', '</a>');
866 866
             ?>
867 867
             </p></div>
868 868
         <?php } ?>
869 869
     <form id='ao_settings_form' action='options.php' method='post'>
870
-        <?php settings_fields( 'autoptimize_imgopt_settings' ); ?>
871
-        <h2><?php _e( 'Image optimization', 'autoptimize' ); ?></h2>
872
-        <span id='autoptimize_imgopt_descr'><?php _e( 'Make your site significantly faster by just ticking a couple of checkboxes to optimize and lazy load your images, WebP support included!', 'autoptimize' ); ?></span>
870
+        <?php settings_fields('autoptimize_imgopt_settings'); ?>
871
+        <h2><?php _e('Image optimization', 'autoptimize'); ?></h2>
872
+        <span id='autoptimize_imgopt_descr'><?php _e('Make your site significantly faster by just ticking a couple of checkboxes to optimize and lazy load your images, WebP support included!', 'autoptimize'); ?></span>
873 873
         <table class="form-table">
874 874
             <tr>
875
-                <th scope="row"><?php _e( 'Optimize Images', 'autoptimize' ); ?></th>
875
+                <th scope="row"><?php _e('Optimize Images', 'autoptimize'); ?></th>
876 876
                 <td>
877
-                    <label><input id='autoptimize_imgopt_checkbox' type='checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_1]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_1'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Optimize images on the fly and serve them from Shortpixel\'s global CDN.', 'autoptimize' ); ?></label>
877
+                    <label><input id='autoptimize_imgopt_checkbox' type='checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_1]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_1']) && '1' === $options['autoptimize_imgopt_checkbox_field_1']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Optimize images on the fly and serve them from Shortpixel\'s global CDN.', 'autoptimize'); ?></label>
878 878
                     <?php
879 879
                     // show shortpixel status.
880 880
                     $_notice = autoptimizeImages::instance()->get_status_notice();
881
-                    if ( $_notice ) {
882
-                        switch ( $_notice['status'] ) {
881
+                    if ($_notice) {
882
+                        switch ($_notice['status']) {
883 883
                             case 2:
884 884
                                 $_notice_color = 'green';
885 885
                                 break;
@@ -895,28 +895,28 @@  discard block
 block discarded – undo
895 895
                             default:
896 896
                                 $_notice_color = 'green';
897 897
                         }
898
-                        echo apply_filters( 'autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:' . $_notice_color . ';">' . __( 'Shortpixel status: ', 'autoptimize' ) . '</span></strong>' . $_notice['notice'] . '</p>' );
898
+                        echo apply_filters('autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:'.$_notice_color.';">'.__('Shortpixel status: ', 'autoptimize').'</span></strong>'.$_notice['notice'].'</p>');
899 899
                     } else {
900 900
                         // translators: link points to shortpixel.
901
-                        $upsell_msg_1 = '<p>' . sprintf( __( 'Get more Google love and improve your website\'s loading speed by having the images optimized on the fly (also in the "next-gen" WebP image format) by %1$sShortPixel%2$s and then cached and served fast from Shortpixel\'s global CDN.', 'autoptimize' ), '<a href="https://shortpixel.com/aospai' . $sp_url_suffix . '" target="_blank">', '</a>' );
902
-                        if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] ) {
903
-                            $upsell_msg_2 = __( 'For a limited time only, this service is offered free for all Autoptimize users, <b>don\'t miss the chance to test it</b> and see how much it could improve your site\'s speed.', 'autoptimize' );
901
+                        $upsell_msg_1 = '<p>'.sprintf(__('Get more Google love and improve your website\'s loading speed by having the images optimized on the fly (also in the "next-gen" WebP image format) by %1$sShortPixel%2$s and then cached and served fast from Shortpixel\'s global CDN.', 'autoptimize'), '<a href="https://shortpixel.com/aospai'.$sp_url_suffix.'" target="_blank">', '</a>');
902
+                        if ('launch' === $options['availabilities']['extra_imgopt']['status']) {
903
+                            $upsell_msg_2 = __('For a limited time only, this service is offered free for all Autoptimize users, <b>don\'t miss the chance to test it</b> and see how much it could improve your site\'s speed.', 'autoptimize');
904 904
                         } else {
905 905
                             // translators: link points to shortpixel.
906
-                            $upsell_msg_2 = sprintf( __( '%1$sSign-up now%2$s to receive a 1 000 bonus + 50&#37; more image optimization credits regardless of the traffic used. More image optimizations can be purchased starting with $4.99.', 'autoptimize' ), '<a href="https://shortpixel.com/aospai' . $sp_url_suffix . '" target="_blank">', '</a>' );
906
+                            $upsell_msg_2 = sprintf(__('%1$sSign-up now%2$s to receive a 1 000 bonus + 50&#37; more image optimization credits regardless of the traffic used. More image optimizations can be purchased starting with $4.99.', 'autoptimize'), '<a href="https://shortpixel.com/aospai'.$sp_url_suffix.'" target="_blank">', '</a>');
907 907
                         }
908
-                        echo apply_filters( 'autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1 . ' ' . $upsell_msg_2 . '</p>' );
908
+                        echo apply_filters('autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1.' '.$upsell_msg_2.'</p>');
909 909
                     }
910 910
                     // translators: link points to shortpixel FAQ.
911
-                    $faqcopy = sprintf( __( '<strong>Questions</strong>? Have a look at the %1$sShortPixel FAQ%2$s!', 'autoptimize' ), '<strong><a href="https://shortpixel.helpscoutdocs.com/category/60-shortpixel-ai-cdn" target="_blank">', '</strong></a>' );
911
+                    $faqcopy = sprintf(__('<strong>Questions</strong>? Have a look at the %1$sShortPixel FAQ%2$s!', 'autoptimize'), '<strong><a href="https://shortpixel.helpscoutdocs.com/category/60-shortpixel-ai-cdn" target="_blank">', '</strong></a>');
912 912
                     // translators: links points to shortpixel TOS & Privacy Policy.
913
-                    $toscopy = sprintf( __( 'Usage of this feature is subject to Shortpixel\'s %1$sTerms of Use%2$s and %3$sPrivacy policy%4$s.', 'autoptimize' ), '<a href="https://shortpixel.com/tos' . $sp_url_suffix . '" target="_blank">', '</a>', '<a href="https://shortpixel.com/pp' . $sp_url_suffix . '" target="_blank">', '</a>' );
914
-                    echo apply_filters( 'autoptimize_imgopt_imgopt_settings_tos', '<p>' . $faqcopy . ' ' . $toscopy . '</p>' );
913
+                    $toscopy = sprintf(__('Usage of this feature is subject to Shortpixel\'s %1$sTerms of Use%2$s and %3$sPrivacy policy%4$s.', 'autoptimize'), '<a href="https://shortpixel.com/tos'.$sp_url_suffix.'" target="_blank">', '</a>', '<a href="https://shortpixel.com/pp'.$sp_url_suffix.'" target="_blank">', '</a>');
914
+                    echo apply_filters('autoptimize_imgopt_imgopt_settings_tos', '<p>'.$faqcopy.' '.$toscopy.'</p>');
915 915
                     ?>
916 916
                 </td>
917 917
             </tr>
918
-            <tr id='autoptimize_imgopt_quality' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'] ) ) { echo 'class="hidden"'; } ?>>
919
-                <th scope="row"><?php _e( 'Image Optimization quality', 'autoptimize' ); ?></th>
918
+            <tr id='autoptimize_imgopt_quality' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_1', $options) || (isset($options['autoptimize_imgopt_checkbox_field_1']) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'])) { echo 'class="hidden"'; } ?>>
919
+                <th scope="row"><?php _e('Image Optimization quality', 'autoptimize'); ?></th>
920 920
                 <td>
921 921
                     <label>
922 922
                     <select name='autoptimize_imgopt_settings[autoptimize_imgopt_select_field_2]'>
@@ -924,12 +924,12 @@  discard block
 block discarded – undo
924 924
                         $_imgopt_array = autoptimizeImages::instance()->get_img_quality_array();
925 925
                         $_imgopt_val   = autoptimizeImages::instance()->get_img_quality_setting();
926 926
 
927
-                        foreach ( $_imgopt_array as $key => $value ) {
928
-                            echo '<option value="' . $key . '"';
929
-                            if ( $_imgopt_val == $key ) {
927
+                        foreach ($_imgopt_array as $key => $value) {
928
+                            echo '<option value="'.$key.'"';
929
+                            if ($_imgopt_val == $key) {
930 930
                                 echo ' selected';
931 931
                             }
932
-                            echo '>' . ucfirst( $value ) . '</option>';
932
+                            echo '>'.ucfirst($value).'</option>';
933 933
                         }
934 934
                         echo "\n";
935 935
                         ?>
@@ -938,31 +938,31 @@  discard block
 block discarded – undo
938 938
                     <p>
939 939
                         <?php
940 940
                             // translators: link points to shortpixel image test page.
941
-                            echo apply_filters( 'autoptimize_imgopt_imgopt_quality_copy', sprintf( __( 'You can %1$stest compression levels here%2$s.', 'autoptimize' ), '<a href="https://shortpixel.com/oic' . $sp_url_suffix . '" target="_blank">', '</a>' ) );
941
+                            echo apply_filters('autoptimize_imgopt_imgopt_quality_copy', sprintf(__('You can %1$stest compression levels here%2$s.', 'autoptimize'), '<a href="https://shortpixel.com/oic'.$sp_url_suffix.'" target="_blank">', '</a>'));
942 942
                         ?>
943 943
                     </p>
944 944
                 </td>
945 945
             </tr>
946
-            <tr id='autoptimize_imgopt_webp' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'] ) ) { echo 'class="hidden"'; } ?>>
947
-                <th scope="row"><?php _e( 'Load WebP in supported browsers?', 'autoptimize' ); ?></th>
946
+            <tr id='autoptimize_imgopt_webp' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_1', $options) || (isset($options['autoptimize_imgopt_checkbox_field_1']) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'])) { echo 'class="hidden"'; } ?>>
947
+                <th scope="row"><?php _e('Load WebP in supported browsers?', 'autoptimize'); ?></th>
948 948
                 <td>
949
-                    <label><input type='checkbox' id='autoptimize_imgopt_webp_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_4]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_4'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_3'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Automatically serve "next-gen" WebP image format to any browser that supports it (requires lazy load to be active).', 'autoptimize' ); ?></label>
949
+                    <label><input type='checkbox' id='autoptimize_imgopt_webp_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_4]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_4']) && '1' === $options['autoptimize_imgopt_checkbox_field_3']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Automatically serve "next-gen" WebP image format to any browser that supports it (requires lazy load to be active).', 'autoptimize'); ?></label>
950 950
                 </td>
951 951
             </tr>
952 952
             <tr>
953
-                <th scope="row"><?php _e( 'Lazy-load images?', 'autoptimize' ); ?></th>
953
+                <th scope="row"><?php _e('Lazy-load images?', 'autoptimize'); ?></th>
954 954
                 <td>
955
-                    <label><input type='checkbox' id='autoptimize_imgopt_lazyload_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_3]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_3'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_3'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Image lazy-loading will delay the loading of non-visible images to allow the browser to optimally load all resources for the "above the fold"-page first.', 'autoptimize' ); ?></label>
955
+                    <label><input type='checkbox' id='autoptimize_imgopt_lazyload_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_3]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_3']) && '1' === $options['autoptimize_imgopt_checkbox_field_3']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Image lazy-loading will delay the loading of non-visible images to allow the browser to optimally load all resources for the "above the fold"-page first.', 'autoptimize'); ?></label>
956 956
                 </td>
957 957
             </tr>
958
-            <tr id='autoptimize_imgopt_lazyload_exclusions' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_3', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_3'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_3'] ) ) { echo 'class="hidden"'; } ?>>
959
-                <th scope="row"><?php _e( 'Lazy-load exclusions', 'autoptimize' ); ?></th>
958
+            <tr id='autoptimize_imgopt_lazyload_exclusions' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_3', $options) || (isset($options['autoptimize_imgopt_checkbox_field_3']) && '1' !== $options['autoptimize_imgopt_checkbox_field_3'])) { echo 'class="hidden"'; } ?>>
959
+                <th scope="row"><?php _e('Lazy-load exclusions', 'autoptimize'); ?></th>
960 960
                 <td>
961
-                    <label><input type='text' style='width:80%' id='autoptimize_imgopt_lazyload_exclusions' name='autoptimize_imgopt_settings[autoptimize_imgopt_text_field_5]' value='<?php if ( ! empty( $options['autoptimize_imgopt_text_field_5'] ) ) { echo esc_attr( $options['autoptimize_imgopt_text_field_5'] ); } ?>'><br /><?php _e( 'Comma-separated list of to be excluded image classes or filenames.', 'autoptimize' ); ?></label>
961
+                    <label><input type='text' style='width:80%' id='autoptimize_imgopt_lazyload_exclusions' name='autoptimize_imgopt_settings[autoptimize_imgopt_text_field_5]' value='<?php if (!empty($options['autoptimize_imgopt_text_field_5'])) { echo esc_attr($options['autoptimize_imgopt_text_field_5']); } ?>'><br /><?php _e('Comma-separated list of to be excluded image classes or filenames.', 'autoptimize'); ?></label>
962 962
                 </td>
963 963
             </tr>
964 964
         </table>
965
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e( 'Save Changes', 'autoptimize' ); ?>" /></p>
965
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize'); ?>" /></p>
966 966
     </form>
967 967
     <script>
968 968
         jQuery(document).ready(function() {
@@ -998,37 +998,37 @@  discard block
 block discarded – undo
998 998
      * Ïmg opt status as used on dashboard.
999 999
      */
1000 1000
     public function get_imgopt_status_notice() {
1001
-        if ( $this->imgopt_active() ) {
1001
+        if ($this->imgopt_active()) {
1002 1002
             $_imgopt_notice = '';
1003
-            $_stat          = get_option( 'autoptimize_imgopt_provider_stat', '' );
1003
+            $_stat          = get_option('autoptimize_imgopt_provider_stat', '');
1004 1004
             $_site_host     = AUTOPTIMIZE_SITE_DOMAIN;
1005
-            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . $_site_host;
1005
+            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.$_site_host;
1006 1006
 
1007
-            if ( is_array( $_stat ) ) {
1008
-                if ( 1 == $_stat['Status'] ) {
1007
+            if (is_array($_stat)) {
1008
+                if (1 == $_stat['Status']) {
1009 1009
                     // translators: "add more credits" will appear in a "a href".
1010
-                    $_imgopt_notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1010
+                    $_imgopt_notice = sprintf(__('Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1011 1011
                 } elseif ( -1 == $_stat['Status'] || -2 == $_stat['Status'] ) {
1012 1012
                     // translators: "add more credits" will appear in a "a href".
1013
-                    $_imgopt_notice            = sprintf( __( 'Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1014
-                    $_imgopt_stats_refresh_url = add_query_arg( array(
1013
+                    $_imgopt_notice            = sprintf(__('Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1014
+                    $_imgopt_stats_refresh_url = add_query_arg(array(
1015 1015
                         'page'                => 'autoptimize_imgopt',
1016 1016
                         'refreshImgProvStats' => '1',
1017
-                    ), admin_url( 'options-general.php' ) );
1018
-                    if ( $_stat && array_key_exists( 'timestamp', $_stat ) && ! empty( $_stat['timestamp'] ) ) {
1019
-                        $_imgopt_stats_last_run = __( 'based on status at ', 'autoptimize' ) . date_i18n( get_option( 'time_format' ), $_stat['timestamp'] );
1017
+                    ), admin_url('options-general.php'));
1018
+                    if ($_stat && array_key_exists('timestamp', $_stat) && !empty($_stat['timestamp'])) {
1019
+                        $_imgopt_stats_last_run = __('based on status at ', 'autoptimize').date_i18n(get_option('time_format'), $_stat['timestamp']);
1020 1020
                     } else {
1021
-                        $_imgopt_stats_last_run = __( 'based on previously fetched data', 'autoptimize' );
1021
+                        $_imgopt_stats_last_run = __('based on previously fetched data', 'autoptimize');
1022 1022
                     }
1023
-                    $_imgopt_notice .= ' (' . $_imgopt_stats_last_run . ', ';
1023
+                    $_imgopt_notice .= ' ('.$_imgopt_stats_last_run.', ';
1024 1024
                     // translators: "here to refresh" links to the Autoptimize Extra page and forces a refresh of the img opt stats.
1025
-                    $_imgopt_notice .= sprintf( __( 'click %1$shere to refresh%2$s', 'autoptimize' ), '<a href="' . $_imgopt_stats_refresh_url . '">', '</a>).' );
1025
+                    $_imgopt_notice .= sprintf(__('click %1$shere to refresh%2$s', 'autoptimize'), '<a href="'.$_imgopt_stats_refresh_url.'">', '</a>).');
1026 1026
                 } else {
1027 1027
                     $_imgopt_upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1028 1028
                     // translators: "log in to check your account" will appear in a "a href".
1029
-                    $_imgopt_notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1029
+                    $_imgopt_notice = sprintf(__('Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1030 1030
                 }
1031
-                $_imgopt_notice = apply_filters( 'autoptimize_filter_imgopt_notice', $_imgopt_notice );
1031
+                $_imgopt_notice = apply_filters('autoptimize_filter_imgopt_notice', $_imgopt_notice);
1032 1032
 
1033 1033
                 return array(
1034 1034
                     'status' => $_stat['Status'],
@@ -1049,14 +1049,14 @@  discard block
 block discarded – undo
1049 1049
      * Get img provider stats (used to display notice).
1050 1050
      */
1051 1051
     public function query_img_provider_stats() {
1052
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_1'] ) ) {
1052
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_1'])) {
1053 1053
             $url      = '';
1054
-            $endpoint = $this->get_imgopt_host() . 'read-domain/';
1054
+            $endpoint = $this->get_imgopt_host().'read-domain/';
1055 1055
             $domain   = AUTOPTIMIZE_SITE_DOMAIN;
1056 1056
 
1057 1057
             // make sure parse_url result makes sense, keeping $url empty if not.
1058
-            if ( $domain && ! empty( $domain ) ) {
1059
-                $url = $endpoint . $domain;
1058
+            if ($domain && !empty($domain)) {
1059
+                $url = $endpoint.$domain;
1060 1060
             }
1061 1061
 
1062 1062
             $url = apply_filters(
@@ -1066,12 +1066,12 @@  discard block
 block discarded – undo
1066 1066
 
1067 1067
             // only do the remote call if $url is not empty to make sure no parse_url
1068 1068
             // weirdness results in useless calls.
1069
-            if ( ! empty( $url ) ) {
1070
-                $response = wp_remote_get( $url );
1071
-                if ( ! is_wp_error( $response ) ) {
1072
-                    if ( '200' == wp_remote_retrieve_response_code( $response ) ) {
1073
-                        $stats = json_decode( wp_remote_retrieve_body( $response ), true );
1074
-                        update_option( 'autoptimize_imgopt_provider_stat', $stats );
1069
+            if (!empty($url)) {
1070
+                $response = wp_remote_get($url);
1071
+                if (!is_wp_error($response)) {
1072
+                    if ('200' == wp_remote_retrieve_response_code($response)) {
1073
+                        $stats = json_decode(wp_remote_retrieve_body($response), true);
1074
+                        update_option('autoptimize_imgopt_provider_stat', $stats);
1075 1075
                     }
1076 1076
                 }
1077 1077
             }
@@ -1094,15 +1094,15 @@  discard block
 block discarded – undo
1094 1094
     {
1095 1095
         static $launch_status = null;
1096 1096
 
1097
-        if ( null === $launch_status ) {
1097
+        if (null === $launch_status) {
1098 1098
             $avail_imgopt  = $this->options['availabilities']['extra_imgopt'];
1099
-            $magic_number  = intval( substr( md5( parse_url( AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST ) ), 0, 3 ), 16 );
1100
-            $has_launched  = get_option( 'autoptimize_imgopt_launched', '' );
1099
+            $magic_number  = intval(substr(md5(parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST)), 0, 3), 16);
1100
+            $has_launched  = get_option('autoptimize_imgopt_launched', '');
1101 1101
             $launch_status = false;
1102
-            if ( $has_launched || ( is_array( $avail_imgopt ) && array_key_exists( 'launch-threshold', $avail_imgopt ) && $magic_number < $avail_imgopt['launch-threshold'] ) ) {
1102
+            if ($has_launched || (is_array($avail_imgopt) && array_key_exists('launch-threshold', $avail_imgopt) && $magic_number < $avail_imgopt['launch-threshold'])) {
1103 1103
                 $launch_status = true;
1104
-                if ( ! $has_launched ) {
1105
-                    update_option( 'autoptimize_imgopt_launched', 'on' );
1104
+                if (!$has_launched) {
1105
+                    update_option('autoptimize_imgopt_launched', 'on');
1106 1106
                 }
1107 1107
             }
1108 1108
         }
@@ -1119,16 +1119,16 @@  discard block
 block discarded – undo
1119 1119
     public function get_imgopt_provider_userstatus() {
1120 1120
         static $_provider_userstatus = null;
1121 1121
 
1122
-        if ( is_null( $_provider_userstatus ) ) {
1123
-            $_stat = get_option( 'autoptimize_imgopt_provider_stat', '' );
1124
-            if ( is_array( $_stat ) ) {
1125
-                if ( array_key_exists( 'Status', $_stat ) ) {
1122
+        if (is_null($_provider_userstatus)) {
1123
+            $_stat = get_option('autoptimize_imgopt_provider_stat', '');
1124
+            if (is_array($_stat)) {
1125
+                if (array_key_exists('Status', $_stat)) {
1126 1126
                     $_provider_userstatus['Status'] = $_stat['Status'];
1127 1127
                 } else {
1128 1128
                     // if no stats then we assume all is well.
1129 1129
                     $_provider_userstatus['Status'] = 2;
1130 1130
                 }
1131
-                if ( array_key_exists( 'timestamp', $_stat ) ) {
1131
+                if (array_key_exists('timestamp', $_stat)) {
1132 1132
                     $_provider_userstatus['timestamp'] = $_stat['timestamp'];
1133 1133
                 } else {
1134 1134
                     // if no timestamp then we return "".
@@ -1141,27 +1141,27 @@  discard block
 block discarded – undo
1141 1141
     }
1142 1142
 
1143 1143
     public function get_status_notice() {
1144
-        if ( $this->imgopt_active() ) {
1144
+        if ($this->imgopt_active()) {
1145 1145
             $notice = '';
1146 1146
             $stat   = $this->get_imgopt_provider_userstatus();
1147
-            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
1147
+            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
1148 1148
             $assoc  = 'https://shortpixel.helpscoutdocs.com/article/94-how-to-associate-a-domain-to-my-account';
1149 1149
 
1150
-            if ( is_array( $stat ) ) {
1151
-                if ( 1 == $stat['Status'] ) {
1150
+            if (is_array($stat)) {
1151
+                if (1 == $stat['Status']) {
1152 1152
                     // translators: "add more credits" will appear in a "a href".
1153
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1153
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1154 1154
                 } elseif ( -1 == $stat['Status'] || -2 == $stat['Status'] ) {
1155 1155
                     // translators: "add more credits" will appear in a "a href".
1156
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1156
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1157 1157
                     // translators: "associate your domain" will appear in a "a href".
1158
-                    $notice = $notice . ' ' . sprintf( __( 'If you already have enough credits then you may need to %1$sassociate your domain%2$s to your Shortpixel account.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $assoc . '" target="_blank">', '</a>' );
1158
+                    $notice = $notice.' '.sprintf(__('If you already have enough credits then you may need to %1$sassociate your domain%2$s to your Shortpixel account.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$assoc.'" target="_blank">', '</a>');
1159 1159
                 } else {
1160 1160
                     $upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1161 1161
                     // translators: "log in to check your account" will appear in a "a href".
1162
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1162
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1163 1163
                 }
1164
-                $notice = apply_filters( 'autoptimize_filter_imgopt_notice', $notice );
1164
+                $notice = apply_filters('autoptimize_filter_imgopt_notice', $notice);
1165 1165
 
1166 1166
                 return array(
1167 1167
                     'status' => $stat['Status'],
Please login to merge, or discard this patch.
classes/autoptimizeCache.php 1 patch
Spacing   +140 added lines, -140 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles disk-cache-related operations.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -38,17 +38,17 @@  discard block
 block discarded – undo
38 38
      * @param string $md5 Hash.
39 39
      * @param string $ext Extension.
40 40
      */
41
-    public function __construct( $md5, $ext = 'php' )
41
+    public function __construct($md5, $ext = 'php')
42 42
     {
43 43
         $this->cachedir = AUTOPTIMIZE_CACHE_DIR;
44 44
         $this->nogzip   = AUTOPTIMIZE_CACHE_NOGZIP;
45
-        if ( ! $this->nogzip ) {
46
-            $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX . $md5 . '.php';
45
+        if (!$this->nogzip) {
46
+            $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.php';
47 47
         } else {
48
-            if ( in_array( $ext, array( 'js', 'css' ) ) ) {
49
-                $this->filename = $ext . '/' . AUTOPTIMIZE_CACHEFILE_PREFIX . $md5 . '.' . $ext;
48
+            if (in_array($ext, array('js', 'css'))) {
49
+                $this->filename = $ext.'/'.AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext;
50 50
             } else {
51
-                $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX . $md5 . '.' . $ext;
51
+                $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext;
52 52
             }
53 53
         }
54 54
     }
@@ -60,7 +60,7 @@  discard block
 block discarded – undo
60 60
      */
61 61
     public function check()
62 62
     {
63
-        return file_exists( $this->cachedir . $this->filename );
63
+        return file_exists($this->cachedir.$this->filename);
64 64
     }
65 65
 
66 66
     /**
@@ -70,11 +70,11 @@  discard block
 block discarded – undo
70 70
      */
71 71
     public function retrieve()
72 72
     {
73
-        if ( $this->check() ) {
74
-            if ( false == $this->nogzip ) {
75
-                return file_get_contents( $this->cachedir . $this->filename . '.none' );
73
+        if ($this->check()) {
74
+            if (false == $this->nogzip) {
75
+                return file_get_contents($this->cachedir.$this->filename.'.none');
76 76
             } else {
77
-                return file_get_contents( $this->cachedir . $this->filename );
77
+                return file_get_contents($this->cachedir.$this->filename);
78 78
             }
79 79
         }
80 80
         return false;
@@ -88,33 +88,33 @@  discard block
 block discarded – undo
88 88
      *
89 89
      * @return void
90 90
      */
91
-    public function cache( $data, $mime )
91
+    public function cache($data, $mime)
92 92
     {
93 93
         // off by default; check if cachedirs exist every time before caching
94 94
         //
95 95
         // to be activated for users that experience these ugly errors;
96 96
         // PHP Warning: file_put_contents failed to open stream: No such file or directory.
97
-        if ( apply_filters( 'autoptimize_filter_cache_checkdirs_on_write', false ) ) {
97
+        if (apply_filters('autoptimize_filter_cache_checkdirs_on_write', false)) {
98 98
             $this->check_and_create_dirs();
99 99
         }
100 100
 
101
-        if ( false === $this->nogzip ) {
101
+        if (false === $this->nogzip) {
102 102
             // We handle gzipping ourselves.
103 103
             $file    = 'default.php';
104
-            $phpcode = file_get_contents( AUTOPTIMIZE_PLUGIN_DIR . 'config/' . $file );
105
-            $phpcode = str_replace( array( '%%CONTENT%%', 'exit;' ), array( $mime, '' ), $phpcode );
104
+            $phpcode = file_get_contents(AUTOPTIMIZE_PLUGIN_DIR.'config/'.$file);
105
+            $phpcode = str_replace(array('%%CONTENT%%', 'exit;'), array($mime, ''), $phpcode);
106 106
 
107
-            file_put_contents( $this->cachedir . $this->filename, $phpcode );
108
-            file_put_contents( $this->cachedir . $this->filename . '.none', $data );
107
+            file_put_contents($this->cachedir.$this->filename, $phpcode);
108
+            file_put_contents($this->cachedir.$this->filename.'.none', $data);
109 109
         } else {
110 110
             // Write code to cache without doing anything else.
111
-            file_put_contents( $this->cachedir . $this->filename, $data );
112
-            if ( apply_filters( 'autoptimize_filter_cache_create_static_gzip', false ) ) {
111
+            file_put_contents($this->cachedir.$this->filename, $data);
112
+            if (apply_filters('autoptimize_filter_cache_create_static_gzip', false)) {
113 113
                 // Create an additional cached gzip file.
114
-                file_put_contents( $this->cachedir . $this->filename . '.gz', gzencode( $data, 9, FORCE_GZIP ) );
114
+                file_put_contents($this->cachedir.$this->filename.'.gz', gzencode($data, 9, FORCE_GZIP));
115 115
                 // If PHP Brotli extension is installed, create an additional cached Brotli file.
116
-                if ( function_exists( 'brotli_compress' ) ) {
117
-                    file_put_contents( $this->cachedir . $this->filename . '.br', brotli_compress( $data, 11, BROTLI_GENERIC ) );
116
+                if (function_exists('brotli_compress')) {
117
+                    file_put_contents($this->cachedir.$this->filename.'.br', brotli_compress($data, 11, BROTLI_GENERIC));
118 118
                 }
119 119
             }
120 120
         }
@@ -132,7 +132,7 @@  discard block
 block discarded – undo
132 132
         // The original idea here was to provide 3rd party code a hook so that
133 133
         // it can "listen" to all the complete autoptimized-urls that the page
134 134
         // will emit... Or something to that effect I think?
135
-        apply_filters( 'autoptimize_filter_cache_getname', AUTOPTIMIZE_CACHE_URL . $this->filename );
135
+        apply_filters('autoptimize_filter_cache_getname', AUTOPTIMIZE_CACHE_URL.$this->filename);
136 136
 
137 137
         return $this->filename;
138 138
     }
@@ -145,11 +145,11 @@  discard block
 block discarded – undo
145 145
      * @param string $file Filename.
146 146
      * @return bool
147 147
      */
148
-    protected static function is_valid_cache_file( $dir, $file )
148
+    protected static function is_valid_cache_file($dir, $file)
149 149
     {
150
-        if ( '.' !== $file && '..' !== $file &&
151
-            false !== strpos( $file, AUTOPTIMIZE_CACHEFILE_PREFIX ) &&
152
-            is_file( $dir . $file ) ) {
150
+        if ('.' !== $file && '..' !== $file &&
151
+            false !== strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) &&
152
+            is_file($dir.$file)) {
153 153
 
154 154
             // It's a valid file!
155 155
             return true;
@@ -167,16 +167,16 @@  discard block
 block discarded – undo
167 167
     protected static function clear_cache_classic()
168 168
     {
169 169
         $contents = self::get_cache_contents();
170
-        foreach ( $contents as $name => $files ) {
171
-            $dir = rtrim( AUTOPTIMIZE_CACHE_DIR . $name, '/' ) . '/';
172
-            foreach ( $files as $file ) {
173
-                if ( self::is_valid_cache_file( $dir, $file ) ) {
174
-                    @unlink( $dir . $file ); // @codingStandardsIgnoreLine
170
+        foreach ($contents as $name => $files) {
171
+            $dir = rtrim(AUTOPTIMIZE_CACHE_DIR.$name, '/').'/';
172
+            foreach ($files as $file) {
173
+                if (self::is_valid_cache_file($dir, $file)) {
174
+                    @unlink($dir.$file); // @codingStandardsIgnoreLine
175 175
                 }
176 176
             }
177 177
         }
178 178
 
179
-        @unlink( AUTOPTIMIZE_CACHE_DIR . '/.htaccess' ); // @codingStandardsIgnoreLine
179
+        @unlink(AUTOPTIMIZE_CACHE_DIR.'/.htaccess'); // @codingStandardsIgnoreLine
180 180
     }
181 181
 
182 182
     /**
@@ -187,19 +187,19 @@  discard block
 block discarded – undo
187 187
      *
188 188
      * @return bool
189 189
      */
190
-    protected static function rmdir( $pathname )
190
+    protected static function rmdir($pathname)
191 191
     {
192
-        $files = self::get_dir_contents( $pathname );
193
-        foreach ( $files as $file ) {
194
-            $path = $pathname . '/' . $file;
195
-            if ( is_dir( $path ) ) {
196
-                self::rmdir( $path );
192
+        $files = self::get_dir_contents($pathname);
193
+        foreach ($files as $file) {
194
+            $path = $pathname.'/'.$file;
195
+            if (is_dir($path)) {
196
+                self::rmdir($path);
197 197
             } else {
198
-                unlink( $path );
198
+                unlink($path);
199 199
             }
200 200
         }
201 201
 
202
-        return rmdir( $pathname );
202
+        return rmdir($pathname);
203 203
     }
204 204
 
205 205
     /**
@@ -216,12 +216,12 @@  discard block
 block discarded – undo
216 216
         $new_name = self::get_unique_name();
217 217
 
218 218
         // Makes sure the new pathname is on the same level...
219
-        $new_pathname = dirname( $dir ) . '/' . $new_name;
220
-        $renamed      = @rename( $dir, $new_pathname ); // @codingStandardsIgnoreLine
219
+        $new_pathname = dirname($dir).'/'.$new_name;
220
+        $renamed      = @rename($dir, $new_pathname); // @codingStandardsIgnoreLine
221 221
 
222 222
         // When renamed, re-create the default cache directory back so it's
223 223
         // available again...
224
-        if ( $renamed ) {
224
+        if ($renamed) {
225 225
             $ok = self::cacheavail();
226 226
         }
227 227
 
@@ -235,7 +235,7 @@  discard block
 block discarded – undo
235 235
      */
236 236
     public static function advanced_cache_clear_enabled()
237 237
     {
238
-        return apply_filters( 'autoptimize_filter_cache_clear_advanced', false );
238
+        return apply_filters('autoptimize_filter_cache_clear_advanced', false);
239 239
     }
240 240
 
241 241
     /**
@@ -246,7 +246,7 @@  discard block
 block discarded – undo
246 246
     protected static function get_unique_name()
247 247
     {
248 248
         $prefix   = self::get_advanced_cache_clear_prefix();
249
-        $new_name = uniqid( $prefix, true );
249
+        $new_name = uniqid($prefix, true);
250 250
 
251 251
         return $new_name;
252 252
     }
@@ -259,8 +259,8 @@  discard block
 block discarded – undo
259 259
     protected static function get_advanced_cache_clear_prefix()
260 260
     {
261 261
         $pathname = self::get_pathname_base();
262
-        $basename = basename( $pathname );
263
-        $prefix   = $basename . '-';
262
+        $basename = basename($pathname);
263
+        $prefix   = $basename.'-';
264 264
 
265 265
         return $prefix;
266 266
     }
@@ -273,9 +273,9 @@  discard block
 block discarded – undo
273 273
      *
274 274
      * @return array
275 275
      */
276
-    protected static function get_dir_contents( $pathname )
276
+    protected static function get_dir_contents($pathname)
277 277
     {
278
-        return array_slice( scandir( $pathname ), 2 );
278
+        return array_slice(scandir($pathname), 2);
279 279
     }
280 280
 
281 281
     /**
@@ -289,18 +289,18 @@  discard block
 block discarded – undo
289 289
     {
290 290
         $dir    = self::get_pathname_base();
291 291
         $prefix = self::get_advanced_cache_clear_prefix();
292
-        $parent = dirname( $dir );
292
+        $parent = dirname($dir);
293 293
         $ok     = false;
294 294
 
295 295
         // Returns the list of files without '.' and '..' elements.
296
-        $files = self::get_dir_contents( $parent );
297
-        if ( is_array( $files ) && ! empty( $files ) ) {
298
-            foreach ( $files as $file ) {
299
-                $path     = $parent . '/' . $file;
300
-                $prefixed = ( false !== strpos( $path, $prefix ) );
296
+        $files = self::get_dir_contents($parent);
297
+        if (is_array($files) && !empty($files)) {
298
+            foreach ($files as $file) {
299
+                $path     = $parent.'/'.$file;
300
+                $prefixed = (false !== strpos($path, $prefix));
301 301
                 // Removing only our own (prefixed) directories...
302
-                if ( is_dir( $path ) && $prefixed ) {
303
-                    $ok = self::rmdir( $path );
302
+                if (is_dir($path) && $prefixed) {
303
+                    $ok = self::rmdir($path);
304 304
                 }
305 305
             }
306 306
         }
@@ -320,9 +320,9 @@  discard block
 block discarded – undo
320 320
     {
321 321
         $pathname = self::get_pathname_base();
322 322
 
323
-        if ( is_multisite() && apply_filters( 'autoptimize_separate_blog_caches', true ) ) {
323
+        if (is_multisite() && apply_filters('autoptimize_separate_blog_caches', true)) {
324 324
             $blog_id   = get_current_blog_id();
325
-            $pathname .= $blog_id . '/';
325
+            $pathname .= $blog_id.'/';
326 326
         }
327 327
 
328 328
         return $pathname;
@@ -335,7 +335,7 @@  discard block
 block discarded – undo
335 335
      */
336 336
     protected static function get_pathname_base()
337 337
     {
338
-        $pathname = WP_CONTENT_DIR . AUTOPTIMIZE_CACHE_CHILD_DIR;
338
+        $pathname = WP_CONTENT_DIR.AUTOPTIMIZE_CACHE_CHILD_DIR;
339 339
 
340 340
         return $pathname;
341 341
     }
@@ -347,39 +347,39 @@  discard block
 block discarded – undo
347 347
      *
348 348
      * @return bool
349 349
      */
350
-    public static function clearall( $propagate = true )
350
+    public static function clearall($propagate = true)
351 351
     {
352
-        if ( ! self::cacheavail() ) {
352
+        if (!self::cacheavail()) {
353 353
             return false;
354 354
         }
355 355
 
356 356
         // TODO/FIXME: If cache is big, switch to advanced/new cache clearing automatically?
357
-        if ( self::advanced_cache_clear_enabled() ) {
357
+        if (self::advanced_cache_clear_enabled()) {
358 358
             self::clear_cache_via_rename();
359 359
         } else {
360 360
             self::clear_cache_classic();
361 361
         }
362 362
 
363 363
         // Remove the transient so it gets regenerated...
364
-        delete_transient( 'autoptimize_stats' );
364
+        delete_transient('autoptimize_stats');
365 365
 
366 366
         // Cache was just purged, clear page cache and allow others to hook into our purging...
367
-        if ( true === $propagate ) {
368
-            if ( ! function_exists( 'autoptimize_do_cachepurged_action' ) ) {
367
+        if (true === $propagate) {
368
+            if (!function_exists('autoptimize_do_cachepurged_action')) {
369 369
                 function autoptimize_do_cachepurged_action() {
370
-                    do_action( 'autoptimize_action_cachepurged' );
370
+                    do_action('autoptimize_action_cachepurged');
371 371
                 }
372 372
             }
373
-            add_action( 'shutdown', 'autoptimize_do_cachepurged_action', 11 );
374
-            add_action( 'autoptimize_action_cachepurged', array( 'autoptimizeCache', 'flushPageCache' ), 10, 0 );
373
+            add_action('shutdown', 'autoptimize_do_cachepurged_action', 11);
374
+            add_action('autoptimize_action_cachepurged', array('autoptimizeCache', 'flushPageCache'), 10, 0);
375 375
         }
376 376
 
377 377
         // Warm cache (part of speedupper)!
378
-        if ( apply_filters( 'autoptimize_filter_speedupper', true ) && false == get_transient( 'autoptimize_cache_warmer_protector' ) ) {
379
-            set_transient( 'autoptimize_cache_warmer_protector', 'I shall not warm cache for another 10 minutes.', 60 * 10 );
380
-            $url   = site_url() . '/?ao_speedup_cachebuster=' . rand( 1, 100000 );
381
-            $cache = @wp_remote_get( $url ); // @codingStandardsIgnoreLine
382
-            unset( $cache );
378
+        if (apply_filters('autoptimize_filter_speedupper', true) && false == get_transient('autoptimize_cache_warmer_protector')) {
379
+            set_transient('autoptimize_cache_warmer_protector', 'I shall not warm cache for another 10 minutes.', 60*10);
380
+            $url   = site_url().'/?ao_speedup_cachebuster='.rand(1, 100000);
381
+            $cache = @wp_remote_get($url); // @codingStandardsIgnoreLine
382
+            unset($cache);
383 383
         }
384 384
 
385 385
         return true;
@@ -394,7 +394,7 @@  discard block
 block discarded – undo
394 394
      */
395 395
     public static function clearall_actionless()
396 396
     {
397
-        return self::clearall( false );
397
+        return self::clearall(false);
398 398
     }
399 399
 
400 400
     /**
@@ -406,8 +406,8 @@  discard block
 block discarded – undo
406 406
     {
407 407
         $contents = array();
408 408
 
409
-        foreach ( array( '', 'js', 'css' ) as $dir ) {
410
-            $contents[ $dir ] = scandir( AUTOPTIMIZE_CACHE_DIR . $dir );
409
+        foreach (array('', 'js', 'css') as $dir) {
410
+            $contents[$dir] = scandir(AUTOPTIMIZE_CACHE_DIR.$dir);
411 411
         }
412 412
 
413 413
         return $contents;
@@ -420,21 +420,21 @@  discard block
 block discarded – undo
420 420
      */
421 421
     public static function stats()
422 422
     {
423
-        $stats = get_transient( 'autoptimize_stats' );
423
+        $stats = get_transient('autoptimize_stats');
424 424
 
425 425
         // If no transient, do the actual scan!
426
-        if ( ! is_array( $stats ) ) {
427
-            if ( ! self::cacheavail() ) {
426
+        if (!is_array($stats)) {
427
+            if (!self::cacheavail()) {
428 428
                 return 0;
429 429
             }
430 430
             $stats = self::stats_scan();
431 431
             $count = $stats[0];
432
-            if ( $count > 100 ) {
432
+            if ($count > 100) {
433 433
                 // Store results in transient.
434 434
                 set_transient(
435 435
                     'autoptimize_stats',
436 436
                     $stats,
437
-                    apply_filters( 'autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS )
437
+                    apply_filters('autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS)
438 438
                 );
439 439
             }
440 440
         }
@@ -457,30 +457,30 @@  discard block
 block discarded – undo
457 457
         $size  = 0;
458 458
 
459 459
         // Scan everything in our cache directories.
460
-        foreach ( self::get_cache_contents() as $name => $files ) {
461
-            $dir = rtrim( AUTOPTIMIZE_CACHE_DIR . $name, '/' ) . '/';
462
-            foreach ( $files as $file ) {
463
-                if ( self::is_valid_cache_file( $dir, $file ) ) {
464
-                    if ( AUTOPTIMIZE_CACHE_NOGZIP &&
460
+        foreach (self::get_cache_contents() as $name => $files) {
461
+            $dir = rtrim(AUTOPTIMIZE_CACHE_DIR.$name, '/').'/';
462
+            foreach ($files as $file) {
463
+                if (self::is_valid_cache_file($dir, $file)) {
464
+                    if (AUTOPTIMIZE_CACHE_NOGZIP &&
465 465
                         (
466
-                            false !== strpos( $file, '.js' ) ||
467
-                            false !== strpos( $file, '.css' ) ||
468
-                            false !== strpos( $file, '.img' ) ||
469
-                            false !== strpos( $file, '.txt' )
466
+                            false !== strpos($file, '.js') ||
467
+                            false !== strpos($file, '.css') ||
468
+                            false !== strpos($file, '.img') ||
469
+                            false !== strpos($file, '.txt')
470 470
                         )
471 471
                     ) {
472 472
                         // Web server is gzipping, we count .js|.css|.img|.txt files.
473 473
                         $count++;
474
-                    } elseif ( ! AUTOPTIMIZE_CACHE_NOGZIP && false !== strpos( $file, '.none' ) ) {
474
+                    } elseif (!AUTOPTIMIZE_CACHE_NOGZIP && false !== strpos($file, '.none')) {
475 475
                         // We are gzipping ourselves via php, counting only .none files.
476 476
                         $count++;
477 477
                     }
478
-                    $size += filesize( $dir . $file );
478
+                    $size += filesize($dir.$file);
479 479
                 }
480 480
             }
481 481
         }
482 482
 
483
-        $stats = array( $count, $size, time() );
483
+        $stats = array($count, $size, time());
484 484
 
485 485
         return $stats;
486 486
     }
@@ -494,22 +494,22 @@  discard block
 block discarded – undo
494 494
      */
495 495
     public static function cacheavail()
496 496
     {
497
-        if ( false === autoptimizeCache::check_and_create_dirs() ) {
497
+        if (false === autoptimizeCache::check_and_create_dirs()) {
498 498
             return false;
499 499
         }
500 500
 
501 501
         // Using .htaccess inside our cache folder to overrule wp-super-cache.
502
-        $htaccess = AUTOPTIMIZE_CACHE_DIR . '/.htaccess';
503
-        if ( ! is_file( $htaccess ) ) {
502
+        $htaccess = AUTOPTIMIZE_CACHE_DIR.'/.htaccess';
503
+        if (!is_file($htaccess)) {
504 504
             /**
505 505
              * Create `wp-content/AO_htaccess_tmpl` file with
506 506
              * whatever htaccess rules you might need
507 507
              * if you want to override default AO htaccess
508 508
              */
509
-            $htaccess_tmpl = WP_CONTENT_DIR . '/AO_htaccess_tmpl';
510
-            if ( is_file( $htaccess_tmpl ) ) {
511
-                $content = file_get_contents( $htaccess_tmpl );
512
-            } elseif ( is_multisite() || ! AUTOPTIMIZE_CACHE_NOGZIP ) {
509
+            $htaccess_tmpl = WP_CONTENT_DIR.'/AO_htaccess_tmpl';
510
+            if (is_file($htaccess_tmpl)) {
511
+                $content = file_get_contents($htaccess_tmpl);
512
+            } elseif (is_multisite() || !AUTOPTIMIZE_CACHE_NOGZIP) {
513 513
                 $content = '<IfModule mod_expires.c>
514 514
         ExpiresActive On
515 515
         ExpiresByType text/css A30672000
@@ -562,7 +562,7 @@  discard block
 block discarded – undo
562 562
     </Files>
563 563
 </IfModule>';
564 564
             }
565
-            @file_put_contents( $htaccess, $content ); // @codingStandardsIgnoreLine
565
+            @file_put_contents($htaccess, $content); // @codingStandardsIgnoreLine
566 566
         }
567 567
 
568 568
         // All OK!
@@ -576,13 +576,13 @@  discard block
 block discarded – undo
576 576
      * @return bool
577 577
      */
578 578
     public static function check_and_create_dirs() {
579
-        if ( ! defined( 'AUTOPTIMIZE_CACHE_DIR' ) ) {
579
+        if (!defined('AUTOPTIMIZE_CACHE_DIR')) {
580 580
             // We didn't set a cache.
581 581
             return false;
582 582
         }
583 583
 
584
-        foreach ( array( '', 'js', 'css' ) as $dir ) {
585
-            if ( ! self::check_cache_dir( AUTOPTIMIZE_CACHE_DIR . $dir ) ) {
584
+        foreach (array('', 'js', 'css') as $dir) {
585
+            if (!self::check_cache_dir(AUTOPTIMIZE_CACHE_DIR.$dir)) {
586 586
                 return false;
587 587
             }
588 588
         }
@@ -597,25 +597,25 @@  discard block
 block discarded – undo
597 597
      *
598 598
      * @return bool
599 599
      */
600
-    protected static function check_cache_dir( $dir )
600
+    protected static function check_cache_dir($dir)
601 601
     {
602 602
         // Try creating the dir if it doesn't exist.
603
-        if ( ! file_exists( $dir ) ) {
604
-            @mkdir( $dir, 0775, true ); // @codingStandardsIgnoreLine
605
-            if ( ! file_exists( $dir ) ) {
603
+        if (!file_exists($dir)) {
604
+            @mkdir($dir, 0775, true); // @codingStandardsIgnoreLine
605
+            if (!file_exists($dir)) {
606 606
                 return false;
607 607
             }
608 608
         }
609 609
 
610 610
         // If we still cannot write, bail.
611
-        if ( ! is_writable( $dir ) ) {
611
+        if (!is_writable($dir)) {
612 612
             return false;
613 613
         }
614 614
 
615 615
         // Create an index.html in there to avoid prying eyes!
616
-        $idx_file = rtrim( $dir, '/\\' ) . '/index.html';
617
-        if ( ! is_file( $idx_file ) ) {
618
-            @file_put_contents( $idx_file, '<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>' ); // @codingStandardsIgnoreLine
616
+        $idx_file = rtrim($dir, '/\\').'/index.html';
617
+        if (!is_file($idx_file)) {
618
+            @file_put_contents($idx_file, '<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>'); // @codingStandardsIgnoreLine
619 619
         }
620 620
 
621 621
         return true;
@@ -629,59 +629,59 @@  discard block
 block discarded – undo
629 629
     // @codingStandardsIgnoreStart
630 630
     public static function flushPageCache()
631 631
     {
632
-        if ( function_exists( 'wp_cache_clear_cache' ) ) {
633
-            if ( is_multisite() ) {
632
+        if (function_exists('wp_cache_clear_cache')) {
633
+            if (is_multisite()) {
634 634
                 $blog_id = get_current_blog_id();
635
-                wp_cache_clear_cache( $blog_id );
635
+                wp_cache_clear_cache($blog_id);
636 636
             } else {
637 637
                 wp_cache_clear_cache();
638 638
             }
639
-        } elseif ( has_action( 'cachify_flush_cache' ) ) {
640
-            do_action( 'cachify_flush_cache' );
641
-        } elseif ( function_exists( 'w3tc_pgcache_flush' ) ) {
639
+        } elseif (has_action('cachify_flush_cache')) {
640
+            do_action('cachify_flush_cache');
641
+        } elseif (function_exists('w3tc_pgcache_flush')) {
642 642
             w3tc_pgcache_flush();
643
-        } elseif ( function_exists( 'wp_fast_cache_bulk_delete_all' ) ) {
643
+        } elseif (function_exists('wp_fast_cache_bulk_delete_all')) {
644 644
             wp_fast_cache_bulk_delete_all();
645
-        } elseif ( class_exists( 'WpFastestCache' ) ) {
645
+        } elseif (class_exists('WpFastestCache')) {
646 646
             $wpfc = new WpFastestCache();
647 647
             $wpfc->deleteCache();
648
-        } elseif ( class_exists( 'c_ws_plugin__qcache_purging_routines' ) ) {
648
+        } elseif (class_exists('c_ws_plugin__qcache_purging_routines')) {
649 649
             c_ws_plugin__qcache_purging_routines::purge_cache_dir(); // quick cache
650
-        } elseif ( class_exists( 'zencache' ) ) {
650
+        } elseif (class_exists('zencache')) {
651 651
             zencache::clear();
652
-        } elseif ( class_exists( 'comet_cache' ) ) {
652
+        } elseif (class_exists('comet_cache')) {
653 653
             comet_cache::clear();
654
-        } elseif ( class_exists( 'WpeCommon' ) ) {
654
+        } elseif (class_exists('WpeCommon')) {
655 655
             // WPEngine cache purge/flush methods to call by default
656 656
             $wpe_methods = array(
657 657
                 'purge_varnish_cache',
658 658
             );
659 659
 
660 660
             // More agressive clear/flush/purge behind a filter
661
-            if ( apply_filters( 'autoptimize_flush_wpengine_aggressive', false ) ) {
662
-                $wpe_methods = array_merge( $wpe_methods, array( 'purge_memcached', 'clear_maxcdn_cache' ) );
661
+            if (apply_filters('autoptimize_flush_wpengine_aggressive', false)) {
662
+                $wpe_methods = array_merge($wpe_methods, array('purge_memcached', 'clear_maxcdn_cache'));
663 663
             }
664 664
 
665 665
             // Filtering the entire list of WpeCommon methods to be called (for advanced usage + easier testing)
666
-            $wpe_methods = apply_filters( 'autoptimize_flush_wpengine_methods', $wpe_methods );
666
+            $wpe_methods = apply_filters('autoptimize_flush_wpengine_methods', $wpe_methods);
667 667
 
668
-            foreach ( $wpe_methods as $wpe_method ) {
669
-                if ( method_exists( 'WpeCommon', $wpe_method ) ) {
668
+            foreach ($wpe_methods as $wpe_method) {
669
+                if (method_exists('WpeCommon', $wpe_method)) {
670 670
                     WpeCommon::$wpe_method();
671 671
                 }
672 672
             }
673
-        } elseif ( function_exists( 'sg_cachepress_purge_cache' ) ) {
673
+        } elseif (function_exists('sg_cachepress_purge_cache')) {
674 674
             sg_cachepress_purge_cache();
675
-        } elseif ( file_exists( WP_CONTENT_DIR . '/wp-cache-config.php' ) && function_exists( 'prune_super_cache' ) ) {
675
+        } elseif (file_exists(WP_CONTENT_DIR.'/wp-cache-config.php') && function_exists('prune_super_cache')) {
676 676
             // fallback for WP-Super-Cache
677 677
             global $cache_path;
678
-            if ( is_multisite() ) {
678
+            if (is_multisite()) {
679 679
                 $blog_id = get_current_blog_id();
680
-                prune_super_cache( get_supercache_dir( $blog_id ), true );
681
-                prune_super_cache( $cache_path . 'blogs/', true );
680
+                prune_super_cache(get_supercache_dir($blog_id), true);
681
+                prune_super_cache($cache_path.'blogs/', true);
682 682
             } else {
683
-                prune_super_cache( $cache_path . 'supercache/', true );
684
-                prune_super_cache( $cache_path, true );
683
+                prune_super_cache($cache_path.'supercache/', true);
684
+                prune_super_cache($cache_path, true);
685 685
             }
686 686
         }
687 687
     }
Please login to merge, or discard this patch.