Completed
Push — master ( 4bd316...e57bb0 )
by frank
01:51
created
classes/autoptimizeVersionUpdatesHandler.php 1 patch
Spacing   +62 added lines, -62 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,33 +220,33 @@  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 ) && ! empty( $extra_settings ) ) {
239
+        $extra_settings  = get_option('autoptimize_extra_settings', '');
240
+        $imgopt_settings = get_option('autoptimize_imgopt_settings', '');
241
+        if (empty($imgopt_settings) && !empty($extra_settings)) {
242 242
             $imgopt_settings = autoptimizeConfig::get_ao_imgopt_default_options();
243
-            if ( array_key_exists( 'autoptimize_extra_checkbox_field_5', $extra_settings ) ) {
243
+            if (array_key_exists('autoptimize_extra_checkbox_field_5', $extra_settings)) {
244 244
                 $imgopt_settings['autoptimize_imgopt_checkbox_field_1'] = $extra_settings['autoptimize_extra_checkbox_field_5'];
245 245
             }
246
-            if ( array_key_exists( 'autoptimize_extra_select_field_6', $extra_settings ) ) {
246
+            if (array_key_exists('autoptimize_extra_select_field_6', $extra_settings)) {
247 247
                 $imgopt_settings['autoptimize_imgopt_select_field_2'] = $extra_settings['autoptimize_extra_select_field_6'];
248 248
             }
249
-            update_option( 'autoptimize_imgopt_settings', $imgopt_settings );
249
+            update_option('autoptimize_imgopt_settings', $imgopt_settings);
250 250
         }
251 251
     }
252 252
 }
Please login to merge, or discard this patch.
tests/test-ao.php 1 patch
Spacing   +425 added lines, -425 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,17 +28,17 @@  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' ),
41
-            'minify_excluded' => $conf->get( 'autoptimize_minify_excluded' ),
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
+            'minify_excluded' => $conf->get('autoptimize_minify_excluded'),
42 42
         ];
43 43
     }
44 44
 
@@ -47,14 +47,14 @@  discard block
 block discarded – undo
47 47
         $conf = autoptimizeConfig::instance();
48 48
 
49 49
         return [
50
-            'aggregate'       => $conf->get( 'autoptimize_js_aggregate' ),
51
-            'justhead'        => $conf->get( 'autoptimize_js_justhead' ),
52
-            'forcehead'       => $conf->get( 'autoptimize_js_forcehead' ),
53
-            'trycatch'        => $conf->get( 'autoptimize_js_trycatch' ),
54
-            'js_exclude'      => $conf->get( 'autoptimize_js_exclude' ),
55
-            'cdn_url'         => $conf->get( 'autoptimize_cdn_url' ),
56
-            'include_inline'  => $conf->get( 'autoptimize_js_include_inline' ),
57
-            'minify_excluded' => $conf->get( 'autoptimize_minify_excluded' ),
50
+            'aggregate'       => $conf->get('autoptimize_js_aggregate'),
51
+            'justhead'        => $conf->get('autoptimize_js_justhead'),
52
+            'forcehead'       => $conf->get('autoptimize_js_forcehead'),
53
+            'trycatch'        => $conf->get('autoptimize_js_trycatch'),
54
+            'js_exclude'      => $conf->get('autoptimize_js_exclude'),
55
+            'cdn_url'         => $conf->get('autoptimize_cdn_url'),
56
+            'include_inline'  => $conf->get('autoptimize_js_include_inline'),
57
+            'minify_excluded' => $conf->get('autoptimize_minify_excluded'),
58 58
         ];
59 59
     }
60 60
 
@@ -64,35 +64,35 @@  discard block
 block discarded – undo
64 64
     protected function get_urls()
65 65
     {
66 66
         static $site_url = null;
67
-        if ( null === $site_url ) {
67
+        if (null === $site_url) {
68 68
             $site_url = site_url();
69 69
         }
70 70
 
71 71
         static $cdn_url = null;
72
-        if ( null === $cdn_url ) {
73
-            $cdn_url = get_option( 'autoptimize_cdn_url' );
72
+        if (null === $cdn_url) {
73
+            $cdn_url = get_option('autoptimize_cdn_url');
74 74
         }
75 75
 
76 76
         static $imgopt_host = null;
77
-        if ( null === $imgopt_host ) {
77
+        if (null === $imgopt_host) {
78 78
             $optimizer   = new autoptimizeImages();
79
-            $imgopt_host = rtrim( $optimizer->get_imgopt_host(), '/' );
79
+            $imgopt_host = rtrim($optimizer->get_imgopt_host(), '/');
80 80
         }
81 81
 
82 82
         static $urls = [];
83 83
 
84
-        if ( empty( $urls ) ) {
84
+        if (empty($urls)) {
85 85
             $parts = autoptimizeUtils::get_ao_wp_site_url_parts();
86 86
             $urls  = [
87 87
                 'siteurl'    => $site_url,
88
-                'prsiteurl'  => '//' . str_replace( array( 'http://', 'https://' ), '', $site_url ),
89
-                'wwwsiteurl' => $parts['scheme'] . '://www.' . str_replace( 'www.', '', $parts['host'] ),
88
+                'prsiteurl'  => '//'.str_replace(array('http://', 'https://'), '', $site_url),
89
+                'wwwsiteurl' => $parts['scheme'].'://www.'.str_replace('www.', '', $parts['host']),
90 90
                 'cdnurl'     => $cdn_url,
91 91
                 'imgopthost' => $imgopt_host,
92 92
                 'subfolder'  => '',
93 93
             ];
94 94
 
95
-            if ( AO_TEST_SUBFOLDER_INSTALL ) {
95
+            if (AO_TEST_SUBFOLDER_INSTALL) {
96 96
                 $urls['subfolder'] = 'wordpress/';
97 97
             }
98 98
         }
@@ -105,7 +105,7 @@  discard block
 block discarded – undo
105 105
      */
106 106
     public function setUp()
107 107
     {
108
-        $this->ao = new autoptimizeMain( AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE );
108
+        $this->ao = new autoptimizeMain(AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE);
109 109
 
110 110
         parent::setUp();
111 111
     }
@@ -124,8 +124,8 @@  discard block
 block discarded – undo
124 124
             'autoptimize_filter_css_inlinesize',
125 125
             'autoptimize_filter_css_fonts_cdn',
126 126
         );
127
-        foreach ( $filter_tags as $filter_tag ) {
128
-            remove_all_filters( $filter_tag );
127
+        foreach ($filter_tags as $filter_tag) {
128
+            remove_all_filters($filter_tag);
129 129
         }
130 130
 
131 131
         parent::tearDown();
@@ -249,15 +249,15 @@  discard block
 block discarded – undo
249 249
     protected function get_test_markup_output()
250 250
     {
251 251
         $key = 'default';
252
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
252
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
253 253
             $key = 'custom';
254 254
         }
255 255
 
256
-        $csspart = self::$flexible_url_parts_css[ $key ];
257
-        $jspart  = self::$flexible_url_parts_js[ $key ];
256
+        $csspart = self::$flexible_url_parts_css[$key];
257
+        $jspart  = self::$flexible_url_parts_js[$key];
258 258
 
259 259
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
260
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
260
+        if (AO_TEST_SUBFOLDER_INSTALL) {
261 261
             $csshash = '56398de576d59887e88e3011715250e0';
262 262
         }
263 263
 
@@ -316,15 +316,15 @@  discard block
 block discarded – undo
316 316
     protected function get_test_markup_output_ms()
317 317
     {
318 318
         $key = 'multisite';
319
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
319
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
320 320
             $key = 'multisite_custom';
321 321
         }
322 322
 
323
-        $csspart = self::$flexible_url_parts_css[ $key ];
324
-        $jspart  = self::$flexible_url_parts_js[ $key ];
323
+        $csspart = self::$flexible_url_parts_css[$key];
324
+        $jspart  = self::$flexible_url_parts_js[$key];
325 325
 
326 326
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
327
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
327
+        if (AO_TEST_SUBFOLDER_INSTALL) {
328 328
             $csshash = '56398de576d59887e88e3011715250e0';
329 329
         }
330 330
 
@@ -383,15 +383,15 @@  discard block
 block discarded – undo
383 383
     protected function get_test_markup_output_inline_defer()
384 384
     {
385 385
         $key = 'default';
386
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
386
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
387 387
             $key = 'custom';
388 388
         }
389 389
 
390
-        $csspart = self::$flexible_url_parts_css[ $key ];
391
-        $jspart  = self::$flexible_url_parts_js[ $key ];
390
+        $csspart = self::$flexible_url_parts_css[$key];
391
+        $jspart  = self::$flexible_url_parts_js[$key];
392 392
 
393 393
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
394
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
394
+        if (AO_TEST_SUBFOLDER_INSTALL) {
395 395
             $csshash = '56398de576d59887e88e3011715250e0';
396 396
         }
397 397
 
@@ -450,15 +450,15 @@  discard block
 block discarded – undo
450 450
     protected function get_test_markup_output_inline_defer_ms()
451 451
     {
452 452
         $key = 'multisite';
453
-        if ( defined( 'CUSTOM_CONSTANTS_USED' ) && CUSTOM_CONSTANTS_USED ) {
453
+        if (defined('CUSTOM_CONSTANTS_USED') && CUSTOM_CONSTANTS_USED) {
454 454
             $key = 'multisite_custom';
455 455
         }
456 456
 
457
-        $csspart = self::$flexible_url_parts_css[ $key ];
458
-        $jspart  = self::$flexible_url_parts_js[ $key ];
457
+        $csspart = self::$flexible_url_parts_css[$key];
458
+        $jspart  = self::$flexible_url_parts_js[$key];
459 459
 
460 460
         $csshash = '863f587e89f100b0223ddccc0dabc57a';
461
-        if ( AO_TEST_SUBFOLDER_INSTALL ) {
461
+        if (AO_TEST_SUBFOLDER_INSTALL) {
462 462
             $csshash = '56398de576d59887e88e3011715250e0';
463 463
         }
464 464
 
@@ -517,11 +517,11 @@  discard block
 block discarded – undo
517 517
     /**
518 518
      * @dataProvider provider_test_rewrite_markup_with_cdn
519 519
      */
520
-    function test_rewrite_markup_with_cdn( $input, $expected )
520
+    function test_rewrite_markup_with_cdn($input, $expected)
521 521
     {
522
-        $actual = $this->ao->end_buffering( $input );
522
+        $actual = $this->ao->end_buffering($input);
523 523
 
524
-        $this->assertEquals( $expected, $actual );
524
+        $this->assertEquals($expected, $actual);
525 525
     }
526 526
 
527 527
     public function provider_test_rewrite_markup_with_cdn()
@@ -533,7 +533,7 @@  discard block
 block discarded – undo
533 533
                 $this->get_test_markup(),
534 534
                 // Expected output.
535 535
                 // TODO/FIXME: This seemed like the fastest way to get MS crude test to pass...
536
-                ( is_multisite() ? $this->get_test_markup_output_ms() : $this->get_test_markup_output() ),
536
+                (is_multisite() ? $this->get_test_markup_output_ms() : $this->get_test_markup_output()),
537 537
             ),
538 538
 
539 539
         );
@@ -593,12 +593,12 @@  discard block
 block discarded – undo
593 593
 }
594 594
 CSS;
595 595
 
596
-        $instance = new autoptimizeStyles( $css_in );
597
-        $instance->setOption( 'cdn_url', $cdnurl );
596
+        $instance = new autoptimizeStyles($css_in);
597
+        $instance->setOption('cdn_url', $cdnurl);
598 598
 
599
-        $css_actual = $instance->rewrite_assets( $css_in );
599
+        $css_actual = $instance->rewrite_assets($css_in);
600 600
 
601
-        $this->assertEquals( $css_expected, $css_actual );
601
+        $this->assertEquals($css_expected, $css_actual);
602 602
     }
603 603
 
604 604
     public function test_default_cssmin_minifier()
@@ -632,21 +632,21 @@  discard block
 block discarded – undo
632 632
 .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')}
633 633
 CSS;
634 634
 
635
-        $instance = new autoptimizeStyles( $css );
636
-        $minified = $instance->run_minifier_on( $css );
635
+        $instance = new autoptimizeStyles($css);
636
+        $minified = $instance->run_minifier_on($css);
637 637
 
638
-        $this->assertEquals( $expected, $minified );
638
+        $this->assertEquals($expected, $minified);
639 639
     }
640 640
 
641 641
     /**
642 642
      * @dataProvider provider_test_should_aggregate_script_types
643 643
      */
644
-    public function test_should_aggregate_script_types( $input, $expected )
644
+    public function test_should_aggregate_script_types($input, $expected)
645 645
     {
646
-        $instance = new autoptimizeScripts( '' );
647
-        $actual   = $instance->should_aggregate( $input );
646
+        $instance = new autoptimizeScripts('');
647
+        $actual   = $instance->should_aggregate($input);
648 648
 
649
-        $this->assertEquals( $expected, $actual );
649
+        $this->assertEquals($expected, $actual);
650 650
     }
651 651
 
652 652
     public function provider_test_should_aggregate_script_types()
@@ -708,11 +708,11 @@  discard block
 block discarded – undo
708 708
     /**
709 709
      * @dataProvider provider_is_valid_buffer
710 710
      */
711
-    public function test_valid_buffers( $input, $expected )
711
+    public function test_valid_buffers($input, $expected)
712 712
     {
713
-        $actual = $this->ao->is_valid_buffer( $input );
713
+        $actual = $this->ao->is_valid_buffer($input);
714 714
 
715
-        $this->assertEquals( $expected, $actual );
715
+        $this->assertEquals($expected, $actual);
716 716
     }
717 717
 
718 718
     public function provider_is_valid_buffer()
@@ -774,11 +774,11 @@  discard block
 block discarded – undo
774 774
     /**
775 775
      * @dataProvider provider_is_amp_markup
776 776
      */
777
-    public function test_autoptimize_is_amp_markup( $input, $expected )
777
+    public function test_autoptimize_is_amp_markup($input, $expected)
778 778
     {
779
-        $actual = autoptimizeMain::is_amp_markup( $input );
779
+        $actual = autoptimizeMain::is_amp_markup($input);
780 780
 
781
-        $this->assertEquals( $expected, $actual );
781
+        $this->assertEquals($expected, $actual);
782 782
     }
783 783
 
784 784
     public function provider_is_amp_markup()
@@ -809,31 +809,31 @@  discard block
 block discarded – undo
809 809
     public function test_skips_buffering_when_ao_noptimize_filter_is_true()
810 810
     {
811 811
         // True => disable autoptimize.
812
-        add_filter( 'autoptimize_filter_noptimize', '__return_true' );
812
+        add_filter('autoptimize_filter_noptimize', '__return_true');
813 813
 
814 814
         // Buffering should not run due to the above filter.
815 815
         $expected = false;
816
-        $actual   = $this->ao->should_buffer( $doing_tests = true );
816
+        $actual   = $this->ao->should_buffer($doing_tests = true);
817 817
 
818
-        $this->assertEquals( $expected, $actual );
818
+        $this->assertEquals($expected, $actual);
819 819
     }
820 820
 
821 821
     public function test_does_buffering_when_ao_noptimize_filter_is_false()
822 822
     {
823 823
         // False => disable noptimize, aka, run normally (weird, yes...).
824
-        add_filter( 'autoptimize_filter_noptimize', '__return_false' );
824
+        add_filter('autoptimize_filter_noptimize', '__return_false');
825 825
 
826 826
         // Buffering should run because of above.
827 827
         $expected = true;
828
-        $actual   = $this->ao->should_buffer( $doing_tests = true );
828
+        $actual   = $this->ao->should_buffer($doing_tests = true);
829 829
 
830
-        $this->assertEquals( $expected, $actual );
830
+        $this->assertEquals($expected, $actual);
831 831
     }
832 832
 
833 833
     public function test_ignores_ao_noptimize_qs_when_instructed()
834 834
     {
835 835
         // Should skip checking for the qs completely due to filter.
836
-        add_filter( 'autoptimize_filter_honor_qs_noptimize', '__return_false' );
836
+        add_filter('autoptimize_filter_honor_qs_noptimize', '__return_false');
837 837
 
838 838
         /**
839 839
          * The above should then result in the "current" value being `false`
@@ -844,23 +844,23 @@  discard block
 block discarded – undo
844 844
          */
845 845
 
846 846
         $that = $this; // Makes it work on php 5.3!
847
-        add_filter( 'autoptimize_filter_noptimize', function ( $current_value ) use ( $that ) {
847
+        add_filter('autoptimize_filter_noptimize', function($current_value) use ($that) {
848 848
             $expected = false;
849
-            if ( defined( 'DONOTMINIFY' ) && DONOTMINIFY ) {
849
+            if (defined('DONOTMINIFY') && DONOTMINIFY) {
850 850
                 $expected = true;
851 851
             }
852 852
 
853
-            $that->assertEquals( $expected, $current_value );
853
+            $that->assertEquals($expected, $current_value);
854 854
         });
855 855
 
856
-        $this->ao->should_buffer( $doing_tests = true );
856
+        $this->ao->should_buffer($doing_tests = true);
857 857
     }
858 858
 
859 859
     public function test_wpengine_cache_flush()
860 860
     {
861 861
         // Creating a mock so that we can get past class_exists() and method_exists() checks present
862 862
         // in `autoptimizeCache::flushPageCache()`...
863
-        $stub = $this->getMockBuilder( 'WpeCommon' )->disableAutoload()
863
+        $stub = $this->getMockBuilder('WpeCommon')->disableAutoload()
864 864
                 ->disableOriginalConstructor()->setMethods(
865 865
                     array(
866 866
                         'purge_varnish_cache',
@@ -869,9 +869,9 @@  discard block
 block discarded – undo
869 869
                 ->getMock();
870 870
 
871 871
         $that = $this;
872
-        add_filter( 'autoptimize_flush_wpengine_methods', function( $methods ) use ( $that ) {
873
-            $expected_methods = array( 'purge_varnish_cache' );
874
-            $that->assertEquals( $methods, $expected_methods );
872
+        add_filter('autoptimize_flush_wpengine_methods', function($methods) use ($that) {
873
+            $expected_methods = array('purge_varnish_cache');
874
+            $that->assertEquals($methods, $expected_methods);
875 875
 
876 876
             return $methods;
877 877
         });
@@ -885,7 +885,7 @@  discard block
 block discarded – undo
885 885
     public function test_wpengine_cache_flush_agressive()
886 886
     {
887 887
         // Creating a mock so that we can get past class_exists() and method_exists() checks `autoptimize_flush_pagecache()`...
888
-        $stub = $this->getMockBuilder( 'WpeCommon' )->disableAutoload()
888
+        $stub = $this->getMockBuilder('WpeCommon')->disableAutoload()
889 889
                 ->disableOriginalConstructor()->setMethods(
890 890
                     array(
891 891
                         'purge_varnish_cache',
@@ -895,19 +895,19 @@  discard block
 block discarded – undo
895 895
                 )
896 896
                 ->getMock();
897 897
 
898
-        add_filter( 'autoptimize_flush_wpengine_aggressive', function() {
898
+        add_filter('autoptimize_flush_wpengine_aggressive', function() {
899 899
             return true;
900 900
         });
901 901
 
902 902
         $that = $this;
903
-        add_filter( 'autoptimize_flush_wpengine_methods', function( $methods ) use ( $that ) {
903
+        add_filter('autoptimize_flush_wpengine_methods', function($methods) use ($that) {
904 904
             $expected_methods = array(
905 905
                 'purge_varnish_cache',
906 906
                 'purge_memcached',
907 907
                 'clear_maxcdn_cache',
908 908
             );
909 909
 
910
-            $that->assertEquals( $methods, $expected_methods );
910
+            $that->assertEquals($methods, $expected_methods);
911 911
 
912 912
             return $methods;
913 913
         });
@@ -918,15 +918,15 @@  discard block
 block discarded – undo
918 918
     /**
919 919
      * @dataProvider provider_test_url_replace_cdn
920 920
      */
921
-    public function test_url_replace_cdn( $cdn_url, $input, $expected )
921
+    public function test_url_replace_cdn($cdn_url, $input, $expected)
922 922
     {
923
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )
923
+        $mock = $this->getMockBuilder('autoptimizeBase')
924 924
                 ->disableOriginalConstructor()
925 925
                 ->getMockForAbstractClass();
926 926
 
927 927
         $mock->cdn_url = $cdn_url;
928
-        $actual        = $mock->url_replace_cdn( $input );
929
-        $this->assertEquals( $expected, $actual );
928
+        $actual        = $mock->url_replace_cdn($input);
929
+        $this->assertEquals($expected, $actual);
930 930
     }
931 931
 
932 932
     public function provider_test_url_replace_cdn()
@@ -943,13 +943,13 @@  discard block
 block discarded – undo
943 943
                 // CDN base url, url, expected result...
944 944
                 'http://cdn-test.example.org',
945 945
                 '/a.jpg',
946
-                'http://cdn-test.example.org/' . $subfolder . 'a.jpg',
946
+                'http://cdn-test.example.org/'.$subfolder.'a.jpg',
947 947
             ),
948 948
             // Full link with a matching AUTOPTIMIZE_WP_SITE_URL gets properly replaced...
949 949
             array(
950 950
                 'http://cdn-test.example.org',
951
-                $siteurl . '/wp-content/themes/something/example.svg',
952
-                'http://cdn-test.example.org/' . $subfolder . 'wp-content/themes/something/example.svg',
951
+                $siteurl.'/wp-content/themes/something/example.svg',
952
+                'http://cdn-test.example.org/'.$subfolder.'wp-content/themes/something/example.svg',
953 953
             ),
954 954
             // Protocol-relative url with a "local" hostname that doesn't match example.org (AUTOPTIMIZE_WP_SITE_URL)...
955 955
             array(
@@ -960,59 +960,59 @@  discard block
 block discarded – undo
960 960
             // www.example.org does not match example.org (AUTOPTIMIZE_WP_SITE_URL) so it's left alone...
961 961
             array(
962 962
                 'http://cdn-test.example.org',
963
-                $wwwsiteurl . '/wp-content/themes/something/example.svg',
964
-                $wwwsiteurl . '/wp-content/themes/something/example.svg',
963
+                $wwwsiteurl.'/wp-content/themes/something/example.svg',
964
+                $wwwsiteurl.'/wp-content/themes/something/example.svg',
965 965
             ),
966 966
             // SSL cdn url + host-relative link...
967 967
             array(
968 968
                 'https://cdn.example.org',
969 969
                 '/a.jpg',
970
-                'https://cdn.example.org/' . $subfolder . 'a.jpg',
970
+                'https://cdn.example.org/'.$subfolder.'a.jpg',
971 971
             ),
972 972
             // SSL cdn url + http site url that matches AUTOPTIMIZE_WP_SITE_URL is properly replaced...
973 973
             array(
974 974
                 'https://cdn.example.org',
975
-                $siteurl . '/wp-content/themes/something/example.svg',
976
-                'https://cdn.example.org/' . $subfolder . 'wp-content/themes/something/example.svg',
975
+                $siteurl.'/wp-content/themes/something/example.svg',
976
+                'https://cdn.example.org/'.$subfolder.'wp-content/themes/something/example.svg',
977 977
             ),
978 978
             // Protocol-relative cdn url given with protocol relative link that matches AUTOPTIMIZE_WP_SITE_URL host...
979 979
             array(
980 980
                 '//cdn.example.org',
981
-                $protorelativesiteurl . '/something.jpg',
982
-                '//cdn.example.org/' . $subfolder . 'something.jpg',
981
+                $protorelativesiteurl.'/something.jpg',
982
+                '//cdn.example.org/'.$subfolder.'something.jpg',
983 983
             ),
984 984
             // Protocol-relative cdn url given a http link that matches AUTOPTIMIZE_WP_SITE_URL host...
985 985
             array(
986 986
                 '//cdn.example.org',
987
-                $siteurl . '/something.png',
988
-                '//cdn.example.org/' . $subfolder . 'something.png',
987
+                $siteurl.'/something.png',
988
+                '//cdn.example.org/'.$subfolder.'something.png',
989 989
             ),
990 990
             // Protocol-relative cdn url with a host-relative link...
991 991
             array(
992 992
                 '//cdn.example.org',
993 993
                 '/a.jpg',
994
-                '//cdn.example.org/' . $subfolder . 'a.jpg',
994
+                '//cdn.example.org/'.$subfolder.'a.jpg',
995 995
             ),
996 996
             // Testing cdn urls with an explicit port number...
997 997
             array(
998 998
                 'http://cdn.com:8080',
999 999
                 '/a.jpg',
1000
-                'http://cdn.com:8080/' . $subfolder . 'a.jpg',
1000
+                'http://cdn.com:8080/'.$subfolder.'a.jpg',
1001 1001
             ),
1002 1002
             array(
1003 1003
                 '//cdn.com:4433',
1004 1004
                 '/a.jpg',
1005
-                '//cdn.com:4433/' . $subfolder . 'a.jpg',
1005
+                '//cdn.com:4433/'.$subfolder.'a.jpg',
1006 1006
             ),
1007 1007
             array(
1008 1008
                 '//cdn.com:4433',
1009
-                $siteurl . '/something.jpg',
1010
-                '//cdn.com:4433/' . $subfolder . 'something.jpg',
1009
+                $siteurl.'/something.jpg',
1010
+                '//cdn.com:4433/'.$subfolder.'something.jpg',
1011 1011
             ),
1012 1012
             array(
1013 1013
                 '//cdn.com:1234',
1014
-                $protorelativesiteurl . '/something.jpg',
1015
-                '//cdn.com:1234/' . $subfolder . 'something.jpg',
1014
+                $protorelativesiteurl.'/something.jpg',
1015
+                '//cdn.com:1234/'.$subfolder.'something.jpg',
1016 1016
             ),
1017 1017
             // Relative links should not be touched by url_replace_cdn()...
1018 1018
             array(
@@ -1037,8 +1037,8 @@  discard block
 block discarded – undo
1037 1037
             // even though they are really strange...
1038 1038
             array(
1039 1039
                 $siteurl, // example.org or http://localhost or http://localhost/wordpress
1040
-                $siteurl . '/something.jpg',
1041
-                $siteurl . '/something.jpg',
1040
+                $siteurl.'/something.jpg',
1041
+                $siteurl.'/something.jpg',
1042 1042
             ),
1043 1043
             // These shouldn't really be changed, or even if replacements do
1044 1044
             // happen, they shouldn't be destructive...
@@ -1077,31 +1077,31 @@  discard block
 block discarded – undo
1077 1077
         $test_link = '/a.jpg';
1078 1078
         $cdn_url   = '//cdn.example.org';
1079 1079
 
1080
-        $with_ssl = function( $cdn ) {
1080
+        $with_ssl = function($cdn) {
1081 1081
             return '';
1082 1082
         };
1083 1083
         $expected_with_ssl = '/a.jpg';
1084 1084
 
1085
-        $without_ssl = function( $cdn ) {
1085
+        $without_ssl = function($cdn) {
1086 1086
             return $cdn;
1087 1087
         };
1088
-        $expected_without_ssl = '//cdn.example.org/' . $sub . 'a.jpg';
1088
+        $expected_without_ssl = '//cdn.example.org/'.$sub.'a.jpg';
1089 1089
 
1090 1090
         // With a filter that returns something considered "empty", cdn replacement shouldn't occur...
1091
-        add_filter( 'autoptimize_filter_base_cdnurl', $with_ssl );
1092
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )
1091
+        add_filter('autoptimize_filter_base_cdnurl', $with_ssl);
1092
+        $mock = $this->getMockBuilder('autoptimizeBase')
1093 1093
                 ->disableOriginalConstructor()
1094 1094
                 ->getMockForAbstractClass();
1095 1095
 
1096 1096
         $mock->cdn_url   = $cdn_url;
1097
-        $actual_with_ssl = $mock->url_replace_cdn( $test_link );
1098
-        $this->assertEquals( $expected_with_ssl, $actual_with_ssl );
1099
-        remove_filter( 'autoptimize_filter_base_cdnurl', $with_ssl );
1097
+        $actual_with_ssl = $mock->url_replace_cdn($test_link);
1098
+        $this->assertEquals($expected_with_ssl, $actual_with_ssl);
1099
+        remove_filter('autoptimize_filter_base_cdnurl', $with_ssl);
1100 1100
 
1101 1101
         // With a filter that returns an actual cdn url, cdn replacement should occur.
1102
-        add_filter( 'autoptimize_filter_base_cdnurl', $without_ssl );
1103
-        $actual_without_ssl = $mock->url_replace_cdn( $test_link );
1104
-        $this->assertEquals( $expected_without_ssl, $actual_without_ssl );
1102
+        add_filter('autoptimize_filter_base_cdnurl', $without_ssl);
1103
+        $actual_without_ssl = $mock->url_replace_cdn($test_link);
1104
+        $this->assertEquals($expected_without_ssl, $actual_without_ssl);
1105 1105
     }
1106 1106
 
1107 1107
     public function provider_cssmin_issues()
@@ -1140,11 +1140,11 @@  discard block
 block discarded – undo
1140 1140
     /**
1141 1141
      * @dataProvider provider_cssmin_issues
1142 1142
      */
1143
-    public function test_cssmin_issues( $input, $expected )
1143
+    public function test_cssmin_issues($input, $expected)
1144 1144
     {
1145
-        $minifier = new autoptimizeCSSmin( false ); // No need to raise limits for now.
1146
-        $actual   = $minifier->run( $input );
1147
-        $this->assertEquals( $expected, $actual );
1145
+        $minifier = new autoptimizeCSSmin(false); // No need to raise limits for now.
1146
+        $actual   = $minifier->run($input);
1147
+        $this->assertEquals($expected, $actual);
1148 1148
     }
1149 1149
 
1150 1150
     public function provider_getpath()
@@ -1169,7 +1169,7 @@  discard block
 block discarded – undo
1169 1169
             // This file comes with core, so should exist...
1170 1170
             array(
1171 1171
                 '/wp-includes/js/jquery/jquery.js',
1172
-                WP_ROOT_DIR . '/wp-includes/js/jquery/jquery.js',
1172
+                WP_ROOT_DIR.'/wp-includes/js/jquery/jquery.js',
1173 1173
             ),
1174 1174
             // Empty $url should return false.
1175 1175
             array(
@@ -1194,12 +1194,12 @@  discard block
 block discarded – undo
1194 1194
     /**
1195 1195
      * @dataProvider provider_getpath
1196 1196
      */
1197
-    public function test_getpath( $input, $expected )
1197
+    public function test_getpath($input, $expected)
1198 1198
     {
1199
-        $mock = $this->getMockBuilder( 'autoptimizeBase' )->disableOriginalConstructor()->getMockForAbstractClass();
1199
+        $mock = $this->getMockBuilder('autoptimizeBase')->disableOriginalConstructor()->getMockForAbstractClass();
1200 1200
 
1201
-        $actual = $mock->getpath( $input );
1202
-        $this->assertEquals( $expected, $actual );
1201
+        $actual = $mock->getpath($input);
1202
+        $this->assertEquals($expected, $actual);
1203 1203
     }
1204 1204
 
1205 1205
     /**
@@ -1213,7 +1213,7 @@  discard block
 block discarded – undo
1213 1213
 
1214 1214
         $protorelativesiteurl = $urls['prsiteurl'];
1215 1215
 
1216
-        $css_orig     = <<<CSS
1216
+        $css_orig = <<<CSS
1217 1217
 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")}
1218 1218
 section.clipped.clippedTop {clip-path:url("#clipPolygonTop")}
1219 1219
 section.clipped.clippedBottom {clip-path:url("#clipPolygonBottom")}
@@ -1226,13 +1226,13 @@  discard block
 block discarded – undo
1226 1226
 .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);}
1227 1227
 CSS;
1228 1228
 
1229
-        $fixurls_result = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $css_orig );
1230
-        $this->assertEquals( $css_expected, $fixurls_result );
1229
+        $fixurls_result = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $css_orig);
1230
+        $this->assertEquals($css_expected, $fixurls_result);
1231 1231
     }
1232 1232
 
1233 1233
     public function test_background_datauri_sprites_with_fixurls()
1234 1234
     {
1235
-        $css_orig     = <<<CSS
1235
+        $css_orig = <<<CSS
1236 1236
 .shadow { background:url(img/1x1.png) top center; }
1237 1237
 .shadow1 { background-image:url(img/1x1.png) 0 -767px repeat-x; }
1238 1238
 .shadow2 {background:url(img/1x1.png) top center}
@@ -1284,27 +1284,27 @@  discard block
 block discarded – undo
1284 1284
 CSS;
1285 1285
 
1286 1286
         // For test purposes, ALL images in the css are being inline with a 1x1 trans png string/datauri.
1287
-        add_filter( 'autoptimize_filter_css_is_datauri_candidate', function( $is_candidate, $path ) {
1287
+        add_filter('autoptimize_filter_css_is_datauri_candidate', function($is_candidate, $path) {
1288 1288
             return true;
1289
-        }, 10, 2 );
1289
+        }, 10, 2);
1290 1290
 
1291 1291
         // For test purposes, ALL images in the css are being inline with a 1x1 trans png string/datauri.
1292
-        add_filter( 'autoptimize_filter_css_datauri_image', function( $base64array, $path ) {
1292
+        add_filter('autoptimize_filter_css_datauri_image', function($base64array, $path) {
1293 1293
             $head = 'data:image/png;base64,';
1294 1294
             $data = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=';
1295 1295
 
1296
-            $result['full']       = $head . $data;
1296
+            $result['full']       = $head.$data;
1297 1297
             $result['base64data'] = $data;
1298 1298
             return $result;
1299
-        }, 10, 2 );
1299
+        }, 10, 2);
1300 1300
 
1301
-        $instance = new autoptimizeStyles( $css_orig );
1302
-        $instance->setOption( 'datauris', true );
1301
+        $instance = new autoptimizeStyles($css_orig);
1302
+        $instance->setOption('datauris', true);
1303 1303
 
1304
-        $fixurls_result = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $css_orig );
1305
-        $css_actual     = $instance->rewrite_assets( $fixurls_result );
1304
+        $fixurls_result = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $css_orig);
1305
+        $css_actual     = $instance->rewrite_assets($fixurls_result);
1306 1306
 
1307
-        $this->assertEquals( $css_expected, $css_actual );
1307
+        $this->assertEquals($css_expected, $css_actual);
1308 1308
     }
1309 1309
 
1310 1310
     /**
@@ -1324,7 +1324,7 @@  discard block
 block discarded – undo
1324 1324
      */
1325 1325
     public function test_background_datauri_sprites_without_fixurls()
1326 1326
     {
1327
-        $css_orig     = <<<CSS
1327
+        $css_orig = <<<CSS
1328 1328
 .shadow { background:url(img/1x1.png) top center; }
1329 1329
 .shadow1 { background-image:url(img/1x1.png) 0 -767px repeat-x; }
1330 1330
 .shadow2 {background:url(img/1x1.png) top center}
@@ -1368,24 +1368,24 @@  discard block
 block discarded – undo
1368 1368
 CSS;
1369 1369
 
1370 1370
         // For test purposes, ALL images in the css are being inlined with a 1x1 trans png string/datauri.
1371
-        add_filter( 'autoptimize_filter_css_is_datauri_candidate', function( $is_candidate, $path ) {
1371
+        add_filter('autoptimize_filter_css_is_datauri_candidate', function($is_candidate, $path) {
1372 1372
             return true;
1373
-        }, 10, 2 );
1373
+        }, 10, 2);
1374 1374
 
1375 1375
         // For test purposes, ALL images in the css are being inlined with a 1x1 trans png string/datauri.
1376
-        add_filter( 'autoptimize_filter_css_datauri_image', function( $base64array, $path ) {
1376
+        add_filter('autoptimize_filter_css_datauri_image', function($base64array, $path) {
1377 1377
             $head = 'data:image/png;base64,';
1378 1378
             $data = 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=';
1379 1379
 
1380
-            $result['full']       = $head . $data;
1380
+            $result['full']       = $head.$data;
1381 1381
             $result['base64data'] = $data;
1382 1382
             return $result;
1383
-        }, 10, 2 );
1383
+        }, 10, 2);
1384 1384
 
1385
-        $instance = new autoptimizeStyles( $css_orig );
1386
-        $instance->setOption( 'datauris', true );
1387
-        $css_actual = $instance->rewrite_assets( $css_orig );
1388
-        $this->assertEquals( $css_expected, $css_actual );
1385
+        $instance = new autoptimizeStyles($css_orig);
1386
+        $instance->setOption('datauris', true);
1387
+        $css_actual = $instance->rewrite_assets($css_orig);
1388
+        $this->assertEquals($css_expected, $css_actual);
1389 1389
     }
1390 1390
 
1391 1391
     /**
@@ -1505,12 +1505,12 @@  discard block
 block discarded – undo
1505 1505
 CSS;
1506 1506
 
1507 1507
         // Test with fonts pointed to the CDN + cdn option is set.
1508
-        add_filter( 'autoptimize_filter_css_fonts_cdn', '__return_true' );
1509
-        $instance = new autoptimizeStyles( $css_in );
1510
-        $instance->setOption( 'cdn_url', $cdnurl );
1511
-        $css_actual_fonts_cdn = $instance->rewrite_assets( $css_in );
1508
+        add_filter('autoptimize_filter_css_fonts_cdn', '__return_true');
1509
+        $instance = new autoptimizeStyles($css_in);
1510
+        $instance->setOption('cdn_url', $cdnurl);
1511
+        $css_actual_fonts_cdn = $instance->rewrite_assets($css_in);
1512 1512
 
1513
-        $this->assertEquals( $css_expected_fonts_cdn, $css_actual_fonts_cdn );
1513
+        $this->assertEquals($css_expected_fonts_cdn, $css_actual_fonts_cdn);
1514 1514
     }
1515 1515
 
1516 1516
     /**
@@ -1626,10 +1626,10 @@  discard block
 block discarded – undo
1626 1626
 }
1627 1627
 CSS;
1628 1628
         // Test without moving fonts to CDN, but cdn option is set.
1629
-        $instance = new autoptimizeStyles( $css_in );
1630
-        $instance->setOption( 'cdn_url', $urls['cdnurl'] );
1631
-        $css_actual = $instance->rewrite_assets( $css_in );
1632
-        $this->assertEquals( $css_expected, $css_actual );
1629
+        $instance = new autoptimizeStyles($css_in);
1630
+        $instance->setOption('cdn_url', $urls['cdnurl']);
1631
+        $css_actual = $instance->rewrite_assets($css_in);
1632
+        $this->assertEquals($css_expected, $css_actual);
1633 1633
     }
1634 1634
 
1635 1635
     public function test_assets_regex_replaces_multi_bg_images()
@@ -1650,16 +1650,16 @@  discard block
 block discarded – undo
1650 1650
 }
1651 1651
 CSS;
1652 1652
 
1653
-        $instance = new autoptimizeStyles( $in );
1654
-        $instance->setOption( 'cdn_url', $cdnurl );
1655
-        $actual = $instance->rewrite_assets( $in );
1653
+        $instance = new autoptimizeStyles($in);
1654
+        $instance->setOption('cdn_url', $cdnurl);
1655
+        $actual = $instance->rewrite_assets($in);
1656 1656
 
1657
-        $this->assertEquals( $expected, $actual );
1657
+        $this->assertEquals($expected, $actual);
1658 1658
     }
1659 1659
 
1660 1660
     public function test_at_supports_spacing_issue_110()
1661 1661
     {
1662
-        $in       = <<<CSS
1662
+        $in = <<<CSS
1663 1663
 @supports (-webkit-filter: blur(3px)) or (filter: blur(3px)) {
1664 1664
     .blur {
1665 1665
         filter:blur(3px);
@@ -1673,10 +1673,10 @@  discard block
 block discarded – undo
1673 1673
 @supports (-webkit-filter:blur(3px)) or (filter:blur(3px)){.blur{filter:blur(3px)}}@supports((position:-webkit-sticky) or (position:sticky)){.sticky{position:sticky}}
1674 1674
 CSS;
1675 1675
 
1676
-        $instance = new autoptimizeStyles( $in );
1677
-        $actual   = $instance->run_minifier_on( $in );
1676
+        $instance = new autoptimizeStyles($in);
1677
+        $actual   = $instance->run_minifier_on($in);
1678 1678
 
1679
-        $this->assertEquals( $expected, $actual );
1679
+        $this->assertEquals($expected, $actual);
1680 1680
     }
1681 1681
 
1682 1682
     public function test_css_import_semicolon_url_issue_122()
@@ -1692,18 +1692,18 @@  discard block
 block discarded – undo
1692 1692
 </style>
1693 1693
 HTML;
1694 1694
 
1695
-        $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-->';
1695
+        $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-->';
1696 1696
 
1697 1697
         $options = [
1698 1698
             'autoptimizeStyles' => $this->getAoStylesDefaultOptions(),
1699 1699
         ];
1700 1700
 
1701
-        $instance = new autoptimizeStyles( $in );
1702
-        $instance->read( $options['autoptimizeStyles'] );
1701
+        $instance = new autoptimizeStyles($in);
1702
+        $instance->read($options['autoptimizeStyles']);
1703 1703
         $instance->minify();
1704 1704
         $instance->cache();
1705 1705
         $actual = $instance->getcontent();
1706
-        $this->assertEquals( $expected, $actual );
1706
+        $this->assertEquals($expected, $actual);
1707 1707
     }
1708 1708
 
1709 1709
     public function test_fixurls_with_at_imports_and_media_queries()
@@ -1713,10 +1713,10 @@  discard block
 block discarded – undo
1713 1713
         $subfolder = $urls['subfolder'];
1714 1714
 
1715 1715
         $in  = '@import "foo.css"; @import "bar.css" (orientation:landscape);';
1716
-        $exp = '@import url(' . $prsiteurl . '/wp-content/themes/my-theme/foo.css); @import url(' . $prsiteurl . '/wp-content/themes/my-theme/bar.css) (orientation:landscape);';
1716
+        $exp = '@import url('.$prsiteurl.'/wp-content/themes/my-theme/foo.css); @import url('.$prsiteurl.'/wp-content/themes/my-theme/bar.css) (orientation:landscape);';
1717 1717
 
1718
-        $actual = autoptimizeStyles::fixurls( ABSPATH . 'wp-content/themes/my-theme/style.css', $in );
1719
-        $this->assertEquals( $exp, $actual );
1718
+        $actual = autoptimizeStyles::fixurls(ABSPATH.'wp-content/themes/my-theme/style.css', $in);
1719
+        $this->assertEquals($exp, $actual);
1720 1720
     }
1721 1721
 
1722 1722
     public function test_aostyles_at_imports_with_media_queries()
@@ -1731,43 +1731,43 @@  discard block
 block discarded – undo
1731 1731
 </style>
1732 1732
 HTML;
1733 1733
 
1734
-        $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-->';
1734
+        $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-->';
1735 1735
 
1736 1736
         $options = [
1737 1737
             'autoptimizeStyles' => $this->getAoStylesDefaultOptions(),
1738 1738
         ];
1739 1739
 
1740
-        $instance = new autoptimizeStyles( $in );
1741
-        $instance->read( $options['autoptimizeStyles'] );
1740
+        $instance = new autoptimizeStyles($in);
1741
+        $instance->read($options['autoptimizeStyles']);
1742 1742
         $instance->minify();
1743 1743
         $instance->cache();
1744 1744
 
1745 1745
         $actual = $instance->getcontent();
1746
-        $this->assertEquals( $expected, $actual );
1746
+        $this->assertEquals($expected, $actual);
1747 1747
     }
1748 1748
 
1749 1749
     public function test_cache_size_checker_hooked_by_default()
1750 1750
     {
1751
-        $this->assertNotEmpty( autoptimizeCacheChecker::SCHEDULE_HOOK );
1751
+        $this->assertNotEmpty(autoptimizeCacheChecker::SCHEDULE_HOOK);
1752 1752
 
1753 1753
         // No schedule, because it's only added when is_admin() is true.
1754
-        $this->assertEquals( false, wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1754
+        $this->assertEquals(false, wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1755 1755
 
1756 1756
         // Proving that setup() sets the schedule as needed.
1757 1757
         $checker = new autoptimizeCacheChecker();
1758 1758
         $checker->setup();
1759
-        $this->assertEquals( 'twicedaily', wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1759
+        $this->assertEquals('twicedaily', wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1760 1760
     }
1761 1761
 
1762 1762
     public function test_cache_size_checker_disabled_with_filter()
1763 1763
     {
1764
-        add_filter( 'autoptimize_filter_cachecheck_do', '__return_false' );
1764
+        add_filter('autoptimize_filter_cachecheck_do', '__return_false');
1765 1765
 
1766 1766
         $checker = new autoptimizeCacheChecker();
1767 1767
         $checker->setup();
1768
-        $this->assertEquals( false, wp_get_schedule( autoptimizeCacheChecker::SCHEDULE_HOOK ) );
1768
+        $this->assertEquals(false, wp_get_schedule(autoptimizeCacheChecker::SCHEDULE_HOOK));
1769 1769
 
1770
-        remove_all_filters( 'autoptimize_filter_cachecheck_do' );
1770
+        remove_all_filters('autoptimize_filter_cachecheck_do');
1771 1771
     }
1772 1772
 
1773 1773
     public function test_is_start_buffering_hooked_properly()
@@ -1780,12 +1780,12 @@  discard block
 block discarded – undo
1780 1780
          * https://www.theaveragedev.com/mocking-constants-in-tests/.
1781 1781
          */
1782 1782
 
1783
-        if ( defined( 'AUTOPTIMIZE_INIT_EARLIER' ) ) {
1783
+        if (defined('AUTOPTIMIZE_INIT_EARLIER')) {
1784 1784
             $this->assertEquals(
1785 1785
                 autoptimizeMain::INIT_EARLIER_PRIORITY,
1786
-                has_action( 'init', array( $instance, 'start_buffering' ) )
1786
+                has_action('init', array($instance, 'start_buffering'))
1787 1787
             );
1788
-            $this->assertTrue( ! defined( 'AUTOPTIMIZE_HOOK_INTO' ) );
1788
+            $this->assertTrue(!defined('AUTOPTIMIZE_HOOK_INTO'));
1789 1789
         }
1790 1790
 
1791 1791
         /*
@@ -1802,18 +1802,18 @@  discard block
 block discarded – undo
1802 1802
 
1803 1803
     public function test_inline_and_defer_markup()
1804 1804
     {
1805
-        add_filter( 'autoptimize_filter_css_defer', '__return_true' );
1806
-        add_filter( 'autoptimize_filter_css_defer_inline', '__return_true' );
1805
+        add_filter('autoptimize_filter_css_defer', '__return_true');
1806
+        add_filter('autoptimize_filter_css_defer_inline', '__return_true');
1807 1807
 
1808
-        $actual = $this->ao->end_buffering( $this->get_test_markup() );
1809
-        if ( is_multisite() ) {
1810
-            $this->assertEquals( $this->get_test_markup_output_inline_defer_ms(), $actual );
1808
+        $actual = $this->ao->end_buffering($this->get_test_markup());
1809
+        if (is_multisite()) {
1810
+            $this->assertEquals($this->get_test_markup_output_inline_defer_ms(), $actual);
1811 1811
         } else {
1812
-            $this->assertEquals( $this->get_test_markup_output_inline_defer(), $actual );
1812
+            $this->assertEquals($this->get_test_markup_output_inline_defer(), $actual);
1813 1813
         }
1814 1814
 
1815
-        remove_all_filters( 'autoptimize_filter_css_defer' );
1816
-        remove_all_filters( 'autoptimize_filter_css_defer_inline' );
1815
+        remove_all_filters('autoptimize_filter_css_defer');
1816
+        remove_all_filters('autoptimize_filter_css_defer_inline');
1817 1817
     }
1818 1818
 
1819 1819
     public function test_js_aggregation_decision_and_dontaggregate_filter()
@@ -1821,47 +1821,47 @@  discard block
 block discarded – undo
1821 1821
         $opts = $this->getAoScriptsDefaultOptions();
1822 1822
 
1823 1823
         // Aggregating: true by default.
1824
-        $scripts = new autoptimizeScripts( '' );
1825
-        $scripts->read( $opts );
1826
-        $this->assertTrue( $scripts->aggregating() );
1824
+        $scripts = new autoptimizeScripts('');
1825
+        $scripts->read($opts);
1826
+        $this->assertTrue($scripts->aggregating());
1827 1827
 
1828 1828
         // Aggregating: option=true (dontaggregate=false by default).
1829 1829
         $opts['aggregate'] = true;
1830
-        $scripts           = new autoptimizeScripts( '' );
1831
-        $scripts->read( $opts );
1832
-        $this->assertTrue( $scripts->aggregating() );
1830
+        $scripts           = new autoptimizeScripts('');
1831
+        $scripts->read($opts);
1832
+        $this->assertTrue($scripts->aggregating());
1833 1833
 
1834 1834
         // Aggregating: option=true, dontaggregate=false explicit.
1835 1835
         $opts['aggregate'] = true;
1836
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_false' );
1837
-        $scripts = new autoptimizeScripts( '' );
1838
-        $scripts->read( $opts );
1839
-        $this->assertTrue( $scripts->aggregating() );
1840
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1836
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_false');
1837
+        $scripts = new autoptimizeScripts('');
1838
+        $scripts->read($opts);
1839
+        $this->assertTrue($scripts->aggregating());
1840
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1841 1841
 
1842 1842
         // Not aggregating: option=true, dontaggregate=true.
1843 1843
         $opts['aggregate'] = true;
1844
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_true' );
1845
-        $scripts = new autoptimizeScripts( '' );
1846
-        $scripts->read( $opts );
1847
-        $this->assertFalse( $scripts->aggregating() );
1848
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1844
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_true');
1845
+        $scripts = new autoptimizeScripts('');
1846
+        $scripts->read($opts);
1847
+        $this->assertFalse($scripts->aggregating());
1848
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1849 1849
 
1850 1850
         // Not aggregating: option=false, dontaggregate=false.
1851 1851
         $opts['aggregate'] = false;
1852
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_false' );
1853
-        $scripts = new autoptimizeScripts( '' );
1854
-        $scripts->read( $opts );
1855
-        $this->assertFalse( $scripts->aggregating() );
1856
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1852
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_false');
1853
+        $scripts = new autoptimizeScripts('');
1854
+        $scripts->read($opts);
1855
+        $this->assertFalse($scripts->aggregating());
1856
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1857 1857
 
1858 1858
         // Not aggregating: option=false, dontaggregate=true.
1859 1859
         $opts['aggregate'] = false;
1860
-        add_filter( 'autoptimize_filter_js_dontaggregate', '__return_true' );
1861
-        $scripts = new autoptimizeScripts( '' );
1862
-        $scripts->read( $opts );
1863
-        $this->assertFalse( $scripts->aggregating() );
1864
-        remove_all_filters( 'autoptimize_filter_js_dontaggregate' );
1860
+        add_filter('autoptimize_filter_js_dontaggregate', '__return_true');
1861
+        $scripts = new autoptimizeScripts('');
1862
+        $scripts->read($opts);
1863
+        $this->assertFalse($scripts->aggregating());
1864
+        remove_all_filters('autoptimize_filter_js_dontaggregate');
1865 1865
     }
1866 1866
 
1867 1867
     public function test_css_aggregation_decision_and_dontaggregate_filter()
@@ -1869,78 +1869,78 @@  discard block
 block discarded – undo
1869 1869
         $opts = $this->getAoStylesDefaultOptions();
1870 1870
 
1871 1871
         // Aggregating: true by default.
1872
-        $styles = new autoptimizeStyles( '' );
1873
-        $this->assertTrue( $styles->aggregating() );
1872
+        $styles = new autoptimizeStyles('');
1873
+        $this->assertTrue($styles->aggregating());
1874 1874
 
1875 1875
         // Aggregating: option=true (dontaggregate=false by default).
1876 1876
         $opts['aggregate'] = true;
1877
-        $styles            = new autoptimizeStyles( '' );
1878
-        $styles->read( $opts );
1879
-        $this->assertTrue( $styles->aggregating() );
1877
+        $styles            = new autoptimizeStyles('');
1878
+        $styles->read($opts);
1879
+        $this->assertTrue($styles->aggregating());
1880 1880
 
1881 1881
         // Aggregating: option=true, dontaggregate=false explicit.
1882 1882
         $opts['aggregate'] = true;
1883
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_false' );
1884
-        $styles = new autoptimizeStyles( '' );
1885
-        $styles->read( $opts );
1886
-        $this->assertTrue( $styles->aggregating() );
1887
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1883
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_false');
1884
+        $styles = new autoptimizeStyles('');
1885
+        $styles->read($opts);
1886
+        $this->assertTrue($styles->aggregating());
1887
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1888 1888
 
1889 1889
         // Not aggregating: option=true, dontaggregate=true.
1890 1890
         $opts['aggregate'] = true;
1891
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_true' );
1892
-        $styles = new autoptimizeStyles( '' );
1893
-        $styles->read( $opts );
1894
-        $this->assertFalse( $styles->aggregating() );
1895
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1891
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_true');
1892
+        $styles = new autoptimizeStyles('');
1893
+        $styles->read($opts);
1894
+        $this->assertFalse($styles->aggregating());
1895
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1896 1896
 
1897 1897
         // Not aggregating: option=false, dontaggregate=false.
1898 1898
         $opts['aggregate'] = false;
1899
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_false' );
1900
-        $styles = new autoptimizeStyles( '' );
1901
-        $styles->read( $opts );
1902
-        $this->assertFalse( $styles->aggregating() );
1903
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1899
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_false');
1900
+        $styles = new autoptimizeStyles('');
1901
+        $styles->read($opts);
1902
+        $this->assertFalse($styles->aggregating());
1903
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1904 1904
 
1905 1905
         // Not aggregating: option=false, dontaggregate=true.
1906 1906
         $opts['aggregate'] = false;
1907
-        add_filter( 'autoptimize_filter_css_dontaggregate', '__return_true' );
1908
-        $styles = new autoptimizeStyles( '' );
1909
-        $styles->read( $opts );
1910
-        $this->assertFalse( $styles->aggregating() );
1911
-        remove_all_filters( 'autoptimize_filter_css_dontaggregate' );
1907
+        add_filter('autoptimize_filter_css_dontaggregate', '__return_true');
1908
+        $styles = new autoptimizeStyles('');
1909
+        $styles->read($opts);
1910
+        $this->assertFalse($styles->aggregating());
1911
+        remove_all_filters('autoptimize_filter_css_dontaggregate');
1912 1912
     }
1913 1913
 
1914 1914
     public function test_css_minify_single_with_cdning()
1915 1915
     {
1916
-        $pathname = dirname( __FILE__ ) . '/fixtures/minify-single.css';
1916
+        $pathname = dirname(__FILE__).'/fixtures/minify-single.css';
1917 1917
         $opts     = $this->getAoStylesDefaultOptions();
1918
-        $styles   = new autoptimizeStyles( '' );
1919
-        $styles->read( $opts );
1918
+        $styles   = new autoptimizeStyles('');
1919
+        $styles->read($opts);
1920 1920
 
1921
-        $url = $styles->minify_single( $pathname, $cache_miss = true );
1921
+        $url = $styles->minify_single($pathname, $cache_miss = true);
1922 1922
 
1923 1923
         // Minified url filename + its pointed to cdn.
1924
-        $this->assertContains( AUTOPTIMIZE_CACHE_CHILD_DIR, $url );
1925
-        $this->assertContains( '/autoptimize_single_', $url );
1926
-        $this->assertContains( $styles->cdn_url, $url );
1924
+        $this->assertContains(AUTOPTIMIZE_CACHE_CHILD_DIR, $url);
1925
+        $this->assertContains('/autoptimize_single_', $url);
1926
+        $this->assertContains($styles->cdn_url, $url);
1927 1927
 
1928 1928
         // Actual minified css contents are minified and cdn-ed.
1929
-        $path     = $styles->getpath( $url );
1930
-        $contents = file_get_contents( $path );
1931
-        $this->assertContains( $styles->cdn_url, $contents );
1932
-        $this->assertContains( '.bg{background:url(' . $styles->cdn_url, $contents );
1929
+        $path     = $styles->getpath($url);
1930
+        $contents = file_get_contents($path);
1931
+        $this->assertContains($styles->cdn_url, $contents);
1932
+        $this->assertContains('.bg{background:url('.$styles->cdn_url, $contents);
1933 1933
     }
1934 1934
 
1935 1935
     public function test_ao_partners_instantiation_without_explicit_include()
1936 1936
     {
1937 1937
         $partners = new autoptimizePartners();
1938
-        $this->assertTrue( $partners instanceof autoptimizePartners );
1938
+        $this->assertTrue($partners instanceof autoptimizePartners);
1939 1939
     }
1940 1940
 
1941 1941
     public function test_html_minify_keep_html_comments_inside_script_blocks()
1942 1942
     {
1943
-        $markup   = <<<MARKUP
1943
+        $markup = <<<MARKUP
1944 1944
 <script>
1945 1945
 <!-- End Support AJAX add to cart -->
1946 1946
 var a = "b";
@@ -1970,23 +1970,23 @@  discard block
 block discarded – undo
1970 1970
             ],
1971 1971
         ];
1972 1972
 
1973
-        $instance = new autoptimizeHTML( $markup );
1974
-        $instance->read( $options['autoptimizeHTML'] );
1973
+        $instance = new autoptimizeHTML($markup);
1974
+        $instance->read($options['autoptimizeHTML']);
1975 1975
         $instance->minify();
1976 1976
         $actual = $instance->getcontent();
1977
-        $this->assertEquals( $expected, $actual );
1977
+        $this->assertEquals($expected, $actual);
1978 1978
 
1979
-        $instance = new autoptimizeHTML( $markup2 );
1980
-        $instance->read( $options['autoptimizeHTML'] );
1979
+        $instance = new autoptimizeHTML($markup2);
1980
+        $instance->read($options['autoptimizeHTML']);
1981 1981
         $instance->minify();
1982 1982
         $actual2 = $instance->getcontent();
1983
-        $this->assertEquals( $expected2, $actual2 );
1983
+        $this->assertEquals($expected2, $actual2);
1984 1984
     }
1985 1985
 
1986 1986
     public function test_html_minify_remove_html_comments_inside_script_blocks()
1987 1987
     {
1988 1988
         // Default case, html comments removed (keepcomments = false).
1989
-        $markup1   = <<<MARKUP
1989
+        $markup1 = <<<MARKUP
1990 1990
 <script>
1991 1991
 var a = "b";
1992 1992
 <!-- End Support AJAX add to cart -->
@@ -1997,7 +1997,7 @@  discard block
 block discarded – undo
1997 1997
 <!-- End Support AJAX add to cart</script>
1998 1998
 MARKUP;
1999 1999
 
2000
-        $markup2   = <<<MARKUP
2000
+        $markup2 = <<<MARKUP
2001 2001
 <script>
2002 2002
 <!-- End Support AJAX add to cart -->
2003 2003
 var a = "b";
@@ -2014,17 +2014,17 @@  discard block
 block discarded – undo
2014 2014
             ],
2015 2015
         ];
2016 2016
 
2017
-        $instance = new autoptimizeHTML( $markup1 );
2018
-        $instance->read( $options['autoptimizeHTML'] );
2017
+        $instance = new autoptimizeHTML($markup1);
2018
+        $instance->read($options['autoptimizeHTML']);
2019 2019
         $instance->minify();
2020 2020
         $actual = $instance->getcontent();
2021
-        $this->assertEquals( $expected1, $actual );
2021
+        $this->assertEquals($expected1, $actual);
2022 2022
 
2023
-        $instance = new autoptimizeHTML( $markup2 );
2024
-        $instance->read( $options['autoptimizeHTML'] );
2023
+        $instance = new autoptimizeHTML($markup2);
2024
+        $instance->read($options['autoptimizeHTML']);
2025 2025
         $instance->minify();
2026 2026
         $actual2 = $instance->getcontent();
2027
-        $this->assertEquals( $expected2, $actual2 );
2027
+        $this->assertEquals($expected2, $actual2);
2028 2028
     }
2029 2029
 
2030 2030
     public function test_html_minify_html_comments_inside_script_blocks_old_school_pattern()
@@ -2048,11 +2048,11 @@  discard block
 block discarded – undo
2048 2048
             ],
2049 2049
         ];
2050 2050
 
2051
-        $instance = new autoptimizeHTML( $markup );
2052
-        $instance->read( $options['autoptimizeHTML'] );
2051
+        $instance = new autoptimizeHTML($markup);
2052
+        $instance->read($options['autoptimizeHTML']);
2053 2053
         $instance->minify();
2054 2054
         $actual = $instance->getcontent();
2055
-        $this->assertEquals( $expected, $actual );
2055
+        $this->assertEquals($expected, $actual);
2056 2056
     }
2057 2057
 
2058 2058
     public function test_html_minify_html_comments_inside_script_blocks_old_school_pattern_untouched()
@@ -2077,49 +2077,49 @@  discard block
 block discarded – undo
2077 2077
             ],
2078 2078
         ];
2079 2079
 
2080
-        $instance = new autoptimizeHTML( $markup );
2081
-        $instance->read( $options['autoptimizeHTML'] );
2080
+        $instance = new autoptimizeHTML($markup);
2081
+        $instance->read($options['autoptimizeHTML']);
2082 2082
         $instance->minify();
2083 2083
         $actual = $instance->getcontent();
2084
-        $this->assertEquals( $expected, $actual );
2084
+        $this->assertEquals($expected, $actual);
2085 2085
     }
2086 2086
 
2087 2087
     public function test_utils_mbstring_availabilty_overriding()
2088 2088
     {
2089 2089
         $orig     = autoptimizeUtils::mbstring_available();
2090
-        $opposite = ! $orig;
2090
+        $opposite = !$orig;
2091 2091
 
2092
-        $this->assertSame( $orig, autoptimizeUtils::mbstring_available() );
2092
+        $this->assertSame($orig, autoptimizeUtils::mbstring_available());
2093 2093
         // Override works...
2094
-        $this->assertSame( $opposite, autoptimizeUtils::mbstring_available( $opposite ) );
2094
+        $this->assertSame($opposite, autoptimizeUtils::mbstring_available($opposite));
2095 2095
         // And override remains cached as the last version.
2096
-        $this->assertSame( $opposite, autoptimizeUtils::mbstring_available() );
2096
+        $this->assertSame($opposite, autoptimizeUtils::mbstring_available());
2097 2097
     }
2098 2098
 
2099 2099
     public function test_utils_mbstring_basics()
2100 2100
     {
2101 2101
         // Turn on mbstring usage.
2102
-        autoptimizeUtils::mbstring_available( true );
2102
+        autoptimizeUtils::mbstring_available(true);
2103 2103
 
2104
-        $this->assertSame( 2, autoptimizeUtils::strlen( "\x00\xFF", 'ASCII' ) );
2105
-        $this->assertSame( 2, autoptimizeUtils::strlen( "\x00\xFF", 'CP850' ) );
2106
-        $this->assertSame( 3, autoptimizeUtils::strlen( '한국어' ) );
2104
+        $this->assertSame(2, autoptimizeUtils::strlen("\x00\xFF", 'ASCII'));
2105
+        $this->assertSame(2, autoptimizeUtils::strlen("\x00\xFF", 'CP850'));
2106
+        $this->assertSame(3, autoptimizeUtils::strlen('한국어'));
2107 2107
 
2108
-        $this->assertFalse( @autoptimizeUtils::strpos( 'abc', '' ) );
2109
-        $this->assertFalse( @autoptimizeUtils::strpos( 'abc', 'a', -1 ) );
2110
-        $this->assertFalse( autoptimizeUtils::strpos( 'abc', 'd' ) );
2111
-        $this->assertFalse( autoptimizeUtils::strpos( 'abc', 'a', 3 ) );
2112
-        $this->assertSame( 1, autoptimizeUtils::strpos( '한국어', '국' ) );
2108
+        $this->assertFalse(@autoptimizeUtils::strpos('abc', ''));
2109
+        $this->assertFalse(@autoptimizeUtils::strpos('abc', 'a', -1));
2110
+        $this->assertFalse(autoptimizeUtils::strpos('abc', 'd'));
2111
+        $this->assertFalse(autoptimizeUtils::strpos('abc', 'a', 3));
2112
+        $this->assertSame(1, autoptimizeUtils::strpos('한국어', '국'));
2113 2113
     }
2114 2114
 
2115 2115
     /**
2116 2116
      * @dataProvider provider_utils_substr_replace
2117 2117
      */
2118
-    function test_utils_substr_replace_basics_mbstring( $s, $repl, $start, $len, $expected )
2118
+    function test_utils_substr_replace_basics_mbstring($s, $repl, $start, $len, $expected)
2119 2119
     {
2120 2120
         // Force mbstring code path...
2121
-        autoptimizeUtils::mbstring_available( true );
2122
-        $this->assertEquals( $expected, autoptimizeUtils::substr_replace( $s, $repl, $start, $len ) );
2121
+        autoptimizeUtils::mbstring_available(true);
2122
+        $this->assertEquals($expected, autoptimizeUtils::substr_replace($s, $repl, $start, $len));
2123 2123
     }
2124 2124
 
2125 2125
     public function provider_utils_substr_replace()
@@ -2161,48 +2161,48 @@  discard block
 block discarded – undo
2161 2161
 
2162 2162
     function test_mb_substr_replace_with_ascii_input_string()
2163 2163
     {
2164
-        autoptimizeUtils::mbstring_available( false );
2164
+        autoptimizeUtils::mbstring_available(false);
2165 2165
 
2166 2166
         $str = 'Ascii';
2167 2167
 
2168
-        $this->assertSame( 'Añ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) );
2169
-        $this->assertSame( 'ñcii', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2170
-        $this->assertSame( 'Asñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2171
-        $this->assertSame( 'Asz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) );
2172
-        $this->assertSame( 'Añii', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2168
+        $this->assertSame('Añ', autoptimizeUtils::substr_replace($str, 'ñ', 1));
2169
+        $this->assertSame('ñcii', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2170
+        $this->assertSame('Asñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2171
+        $this->assertSame('Asz', autoptimizeUtils::substr_replace($str, 'z', 2, 10));
2172
+        $this->assertSame('Añii', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2173 2173
     }
2174 2174
 
2175 2175
     function test_mb_substr_replace_with_utf8_input_string()
2176 2176
     {
2177
-        autoptimizeUtils::mbstring_available( true );
2177
+        autoptimizeUtils::mbstring_available(true);
2178 2178
 
2179 2179
         $str = 'âønæë';
2180 2180
 
2181
-        $this->assertSame( 'âñ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) ); // No length.
2182
-        $this->assertSame( 'ñnæë', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2183
-        $this->assertSame( 'âøñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2184
-        $this->assertSame( 'âøz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) ); // Length larger than possible...
2185
-        $this->assertSame( 'âñæë', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2181
+        $this->assertSame('âñ', autoptimizeUtils::substr_replace($str, 'ñ', 1)); // No length.
2182
+        $this->assertSame('ñnæë', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2183
+        $this->assertSame('âøñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2184
+        $this->assertSame('âøz', autoptimizeUtils::substr_replace($str, 'z', 2, 10)); // Length larger than possible...
2185
+        $this->assertSame('âñæë', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2186 2186
     }
2187 2187
 
2188 2188
     function test_default_substr_replace_with_ascii_input_string()
2189 2189
     {
2190 2190
         // Disable mbstring which should fall ack to substr_replace...
2191
-        autoptimizeUtils::mbstring_available( false );
2191
+        autoptimizeUtils::mbstring_available(false);
2192 2192
 
2193 2193
         $str = 'Ascii';
2194 2194
 
2195
-        $this->assertSame( 'Añ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) );
2196
-        $this->assertSame( 'ñcii', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2197
-        $this->assertSame( 'Asñx', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2198
-        $this->assertSame( 'Asz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) );
2199
-        $this->assertSame( 'Añii', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2195
+        $this->assertSame('Añ', autoptimizeUtils::substr_replace($str, 'ñ', 1));
2196
+        $this->assertSame('ñcii', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2197
+        $this->assertSame('Asñx', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2198
+        $this->assertSame('Asz', autoptimizeUtils::substr_replace($str, 'z', 2, 10));
2199
+        $this->assertSame('Añii', autoptimizeUtils::substr_replace($str, 'ñ', 1, 2));
2200 2200
     }
2201 2201
 
2202 2202
     function test_default_substr_replace_with_utf8_input_string()
2203 2203
     {
2204 2204
         // Disabling mbstring, falling back to substr_replace...
2205
-        autoptimizeUtils::mbstring_available( false );
2205
+        autoptimizeUtils::mbstring_available(false);
2206 2206
 
2207 2207
         // This is really impossible to make work properly, since
2208 2208
         // any start/len parameters we give are working with bytes instead
@@ -2211,55 +2211,55 @@  discard block
 block discarded – undo
2211 2211
 
2212 2212
         // $this->assertSame( '�ñ', autoptimizeUtils::substr_replace( $str, 'ñ', 1 ) ); // No length.
2213 2213
         // $this->assertSame( 'ñ�næë', autoptimizeUtils::substr_replace( $str, 'ñ', 1, 2 ) );
2214
-        $this->assertSame( 'ñønæë', autoptimizeUtils::substr_replace( $str, 'ñ', 0, 2 ) );
2215
-        $this->assertSame( 'âñxæë', autoptimizeUtils::substr_replace( $str, 'ñx', 2, 3 ) );
2216
-        $this->assertSame( 'âz', autoptimizeUtils::substr_replace( $str, 'z', 2, 10 ) ); // Length larger than possible...
2214
+        $this->assertSame('ñønæë', autoptimizeUtils::substr_replace($str, 'ñ', 0, 2));
2215
+        $this->assertSame('âñxæë', autoptimizeUtils::substr_replace($str, 'ñx', 2, 3));
2216
+        $this->assertSame('âz', autoptimizeUtils::substr_replace($str, 'z', 2, 10)); // Length larger than possible...
2217 2217
     }
2218 2218
 
2219 2219
     public function test_cache_fast_delete()
2220 2220
     {
2221
-        add_filter( 'autoptimize_filter_cache_clear_advanced', '__return_true' );
2221
+        add_filter('autoptimize_filter_cache_clear_advanced', '__return_true');
2222 2222
 
2223 2223
         autoptimizeCache::clearall_actionless();
2224 2224
 
2225
-        remove_all_filters( 'autoptimize_filter_cache_clear_advanced' );
2225
+        remove_all_filters('autoptimize_filter_cache_clear_advanced');
2226 2226
     }
2227 2227
 
2228 2228
     public function test_delete_advanced_cache_clear_artifacts()
2229 2229
     {
2230
-        $this->assertTrue( autoptimizeCache::delete_advanced_cache_clear_artifacts() );
2230
+        $this->assertTrue(autoptimizeCache::delete_advanced_cache_clear_artifacts());
2231 2231
     }
2232 2232
 
2233 2233
     public function provider_canonicalization()
2234 2234
     {
2235 2235
         return array(
2236
-            array( '../common', 'common' ),
2237
-            array( '../what-does-this-mean/really?/', 'what-does-this-mean/really?/' ),
2238
-            array( '../../what/where/how', 'what/where/how' ),
2239
-            array( '/../more.dots.please/', '/more.dots.please/' ),
2240
-            array( '/../../what/where/how', '/what/where/how' ),
2241
-            array( '/a/b/c/../../../d/e/file.txt', '/d/e/file.txt' ),
2242
-            array( 'a/b/../c', 'a/c' ),
2243
-            array( './../../etc/passwd', './etc/passwd' ),
2244
-            array( '/var/.////./user/./././..//.//../////../././.././test/////', '/test/' ),
2245
-            array( '/var/user/./././.././../.././././test/', '/test/' ),
2246
-            array( '/hello/0//how/../are/../you', '/hello/0/you' ),
2247
-            array( '', '' ),
2248
-            array( '.', '.' ),
2249
-            array( '..', '..' ),
2250
-            array( './..', './..' ),
2251
-            array( '../.', '.' ),
2236
+            array('../common', 'common'),
2237
+            array('../what-does-this-mean/really?/', 'what-does-this-mean/really?/'),
2238
+            array('../../what/where/how', 'what/where/how'),
2239
+            array('/../more.dots.please/', '/more.dots.please/'),
2240
+            array('/../../what/where/how', '/what/where/how'),
2241
+            array('/a/b/c/../../../d/e/file.txt', '/d/e/file.txt'),
2242
+            array('a/b/../c', 'a/c'),
2243
+            array('./../../etc/passwd', './etc/passwd'),
2244
+            array('/var/.////./user/./././..//.//../////../././.././test/////', '/test/'),
2245
+            array('/var/user/./././.././../.././././test/', '/test/'),
2246
+            array('/hello/0//how/../are/../you', '/hello/0/you'),
2247
+            array('', ''),
2248
+            array('.', '.'),
2249
+            array('..', '..'),
2250
+            array('./..', './..'),
2251
+            array('../.', '.'),
2252 2252
             // This might be debatable...
2253
-            array( '../..', '..' ),
2253
+            array('../..', '..'),
2254 2254
         );
2255 2255
     }
2256 2256
 
2257 2257
     /**
2258 2258
      * @dataProvider provider_canonicalization
2259 2259
      */
2260
-    public function test_path_canonicalize( $path, $canonicalized )
2260
+    public function test_path_canonicalize($path, $canonicalized)
2261 2261
     {
2262
-        $this->assertSame( $canonicalized, autoptimizeUtils::path_canonicalize( $path ) );
2262
+        $this->assertSame($canonicalized, autoptimizeUtils::path_canonicalize($path));
2263 2263
     }
2264 2264
 
2265 2265
     /**
@@ -2273,16 +2273,16 @@  discard block
 block discarded – undo
2273 2273
     public function test_autoptimize_filter_cdn_magic_path_check()
2274 2274
     {
2275 2275
         $cdnurl = 'http://cdn.example.org';
2276
-        add_filter( 'autoptimize_filter_cdn_magic_path_check', '__return_false', 10, 2 );
2276
+        add_filter('autoptimize_filter_cdn_magic_path_check', '__return_false', 10, 2);
2277 2277
 
2278 2278
         // Even when site is in a subfolder, the resulting cdn-rewritten url
2279 2279
         // should not magically include it, due to the above filter.
2280 2280
         // The second parameter is here to force a cache miss and re-run
2281 2281
         // the filter since we're using the same cdn url all over the place,
2282 2282
         // but want to prove different things with it.
2283
-        $this->assertSame( $cdnurl, autoptimizeUtils::tweak_cdn_url_if_needed( $cdnurl, true ) );
2283
+        $this->assertSame($cdnurl, autoptimizeUtils::tweak_cdn_url_if_needed($cdnurl, true));
2284 2284
 
2285
-        remove_all_filters( 'autoptimize_filter_cdn_magic_path_check' );
2285
+        remove_all_filters('autoptimize_filter_cdn_magic_path_check');
2286 2286
     }
2287 2287
 
2288 2288
     /**
@@ -2307,9 +2307,9 @@  discard block
 block discarded – undo
2307 2307
 <img src='$imgopthost/client/q_glossy,ret_img,w_400,h_200/$siteurl/wp-content/image.jpg' width='400' height='200' srcset="$imgopthost/client/q_glossy,ret_img,w_300/$siteurl/wp-content/image-300X150.jpg 300w, $imgopthost/client/q_glossy,ret_img,w_600/$siteurl/wp-content/image-600X300.jpg 600w" sizes="(max-width: 300px) 100vw, 300px" />
2308 2308
 MARKUP;
2309 2309
         $instance = autoptimizeImages::instance();
2310
-        $instance->set_options( $opts );
2311
-        $actual = $instance->filter_optimize_images( $markup );
2312
-        $this->assertEquals( $expected, $actual );
2310
+        $instance->set_options($opts);
2311
+        $actual = $instance->filter_optimize_images($markup);
2312
+        $this->assertEquals($expected, $actual);
2313 2313
     }
2314 2314
 
2315 2315
     /**
@@ -2334,9 +2334,9 @@  discard block
 block discarded – undo
2334 2334
 <picture><source srcset="$imgopthost/client/q_glossy,ret_img/$siteurl/wp-content/image.jpg" media="(min-width: 800px)"><img src="$imgopthost/client/q_glossy,ret_img/$siteurl/wp-content/image.jpg"/></picture>
2335 2335
 MARKUP;
2336 2336
         $instance = autoptimizeImages::instance();
2337
-        $instance->set_options( $opts );
2338
-        $actual = $instance->filter_optimize_images( $markup );
2339
-        $this->assertEquals( $expected, $actual );
2337
+        $instance->set_options($opts);
2338
+        $actual = $instance->filter_optimize_images($markup);
2339
+        $this->assertEquals($expected, $actual);
2340 2340
     }
2341 2341
 
2342 2342
     /**
@@ -2361,9 +2361,9 @@  discard block
 block discarded – undo
2361 2361
 <picture><source data-srcset="$imgopthost/client/q_glossy,ret_img/$siteurl/wp-content/image.jpg" media="(min-width: 800px)"><noscript><img src="$imgopthost/client/q_glossy,ret_img/$siteurl/wp-content/image.jpg"/></noscript><img class="lazyload" src='$imgopthost/client/q_lqip,ret_wait/$siteurl/wp-content/image.jpg' data-src="https://cdn.shortpixel.ai/client/q_glossy,ret_img/$siteurl/wp-content/image.jpg"/></picture>
2362 2362
 MARKUP;
2363 2363
         $instance = autoptimizeImages::instance();
2364
-        $instance->set_options( $opts );
2365
-        $actual = $instance->filter_optimize_images( $markup );
2366
-        $this->assertEquals( $expected, $actual );
2364
+        $instance->set_options($opts);
2365
+        $actual = $instance->filter_optimize_images($markup);
2366
+        $this->assertEquals($expected, $actual);
2367 2367
     }
2368 2368
 
2369 2369
     /**
@@ -2389,9 +2389,9 @@  discard block
 block discarded – undo
2389 2389
 MARKUP;
2390 2390
 
2391 2391
         $instance = autoptimizeImages::instance();
2392
-        $instance->set_options( $opts );
2393
-        $actual = $instance->filter_optimize_images( $markup );
2394
-        $this->assertEquals( $expected, $actual );
2392
+        $instance->set_options($opts);
2393
+        $actual = $instance->filter_optimize_images($markup);
2394
+        $this->assertEquals($expected, $actual);
2395 2395
     }
2396 2396
 
2397 2397
     /**
@@ -2417,9 +2417,9 @@  discard block
 block discarded – undo
2417 2417
 MARKUP;
2418 2418
 
2419 2419
         $instance = autoptimizeImages::instance();
2420
-        $instance->set_options( $opts );
2421
-        $actual = $instance->filter_optimize_images( $markup );
2422
-        $this->assertEquals( $expected, $actual );
2420
+        $instance->set_options($opts);
2421
+        $actual = $instance->filter_optimize_images($markup);
2422
+        $this->assertEquals($expected, $actual);
2423 2423
     }
2424 2424
 
2425 2425
     /**
@@ -2444,9 +2444,9 @@  discard block
 block discarded – undo
2444 2444
 MARKUP;
2445 2445
 
2446 2446
         $instance = autoptimizeImages::instance();
2447
-        $instance->set_options( $opts );
2448
-        $actual = $instance->filter_lazyload_images( $markup );
2449
-        $this->assertEquals( $expected, $actual );
2447
+        $instance->set_options($opts);
2448
+        $actual = $instance->filter_lazyload_images($markup);
2449
+        $this->assertEquals($expected, $actual);
2450 2450
     }
2451 2451
 
2452 2452
     /**
@@ -2471,9 +2471,9 @@  discard block
 block discarded – undo
2471 2471
 MARKUP;
2472 2472
 
2473 2473
         $instance = autoptimizeImages::instance();
2474
-        $instance->set_options( $opts );
2475
-        $actual = $instance->filter_lazyload_images( $markup );
2476
-        $this->assertEquals( $expected, $actual );
2474
+        $instance->set_options($opts);
2475
+        $actual = $instance->filter_lazyload_images($markup);
2476
+        $this->assertEquals($expected, $actual);
2477 2477
     }
2478 2478
 
2479 2479
     /**
@@ -2492,11 +2492,11 @@  discard block
 block discarded – undo
2492 2492
 MARKUP;
2493 2493
 
2494 2494
         $instance = autoptimizeImages::instance();
2495
-        $instance->set_options( $opts );
2496
-        $actual = $instance->filter_optimize_images( $markup );
2495
+        $instance->set_options($opts);
2496
+        $actual = $instance->filter_optimize_images($markup);
2497 2497
 
2498 2498
         // Expecting $markup since replacement should not happen.
2499
-        $this->assertEquals( $markup, $actual );
2499
+        $this->assertEquals($markup, $actual);
2500 2500
     }
2501 2501
 
2502 2502
     /**
@@ -2522,10 +2522,10 @@  discard block
 block discarded – undo
2522 2522
 MARKUP;
2523 2523
 
2524 2524
         $instance = autoptimizeImages::instance();
2525
-        $instance->set_options( $opts );
2526
-        $actual = $instance->filter_optimize_images( $markup );
2525
+        $instance->set_options($opts);
2526
+        $actual = $instance->filter_optimize_images($markup);
2527 2527
 
2528
-        $this->assertEquals( $expected, $actual );
2528
+        $this->assertEquals($expected, $actual);
2529 2529
     }
2530 2530
 
2531 2531
     /**
@@ -2535,8 +2535,8 @@  discard block
 block discarded – undo
2535 2535
     {
2536 2536
         $urls                                        = $this->get_urls();
2537 2537
         $siteurl                                     = $urls['siteurl'];
2538
-        $siteurlparsed                               = parse_url( $siteurl );
2539
-        $sitedomain                                  = $siteurlparsed['scheme'] . '://' . $siteurlparsed['host'];
2538
+        $siteurlparsed                               = parse_url($siteurl);
2539
+        $sitedomain                                  = $siteurlparsed['scheme'].'://'.$siteurlparsed['host'];
2540 2540
         $imgopthost                                  = $urls['imgopthost'];
2541 2541
         $opts                                        = autoptimizeImages::fetch_options();
2542 2542
         $opts['autoptimize_imgopt_checkbox_field_1'] = '1';
@@ -2551,10 +2551,10 @@  discard block
 block discarded – undo
2551 2551
 MARKUP;
2552 2552
 
2553 2553
         $instance = autoptimizeImages::instance();
2554
-        $instance->set_options( $opts );
2555
-        $actual = $instance->filter_optimize_images( $markup );
2554
+        $instance->set_options($opts);
2555
+        $actual = $instance->filter_optimize_images($markup);
2556 2556
 
2557
-        $this->assertEquals( $expected, $actual );
2557
+        $this->assertEquals($expected, $actual);
2558 2558
     }
2559 2559
 
2560 2560
     /**
@@ -2579,53 +2579,53 @@  discard block
 block discarded – undo
2579 2579
 MARKUP;
2580 2580
 
2581 2581
         $instance = autoptimizeImages::instance();
2582
-        $instance->set_options( $opts );
2583
-        $actual = $instance->filter_optimize_images( $markup );
2582
+        $instance->set_options($opts);
2583
+        $actual = $instance->filter_optimize_images($markup);
2584 2584
 
2585
-        $this->assertEquals( $expected, $actual );
2585
+        $this->assertEquals($expected, $actual);
2586 2586
     }
2587 2587
 
2588 2588
     /**
2589 2589
      * @dataProvider provider_str_is_valid_regex
2590 2590
      */
2591
-    public function test_str_is_valid_regex( $str, $expected )
2591
+    public function test_str_is_valid_regex($str, $expected)
2592 2592
     {
2593
-        $actual = autoptimizeUtils::str_is_valid_regex( $str );
2593
+        $actual = autoptimizeUtils::str_is_valid_regex($str);
2594 2594
 
2595
-        $this->assertEquals( $expected, $actual );
2595
+        $this->assertEquals($expected, $actual);
2596 2596
     }
2597 2597
 
2598 2598
     public function provider_str_is_valid_regex()
2599 2599
     {
2600 2600
         return [
2601
-            [ '<!--[if', false ],
2602
-            [ '&lt;--[if', false ],
2603
-            [ '/booya/i', true ],
2604
-            [ '~Valid(Regular)Expression~', true ],
2601
+            ['<!--[if', false],
2602
+            ['&lt;--[if', false],
2603
+            ['/booya/i', true],
2604
+            ['~Valid(Regular)Expression~', true],
2605 2605
         ];
2606 2606
     }
2607 2607
 
2608 2608
     /**
2609 2609
      * @dataProvider provider_protocol_relative_tests
2610 2610
      */
2611
-    public function test_is_protocol_relative( $str, $expected )
2611
+    public function test_is_protocol_relative($str, $expected)
2612 2612
     {
2613
-        $actual = autoptimizeUtils::is_protocol_relative( $str );
2613
+        $actual = autoptimizeUtils::is_protocol_relative($str);
2614 2614
 
2615
-        $this->assertEquals( $expected, $actual );
2615
+        $this->assertEquals($expected, $actual);
2616 2616
     }
2617 2617
 
2618 2618
     public function provider_protocol_relative_tests()
2619 2619
     {
2620 2620
         return [
2621
-            [ '//something-that-might-be-an-url-but-isnt-really', true ],
2622
-            [ '', false ],
2623
-            [ null, false ],
2624
-            [ 'booya/i', false ],
2625
-            [ '/root-relative', false ],
2626
-            [ 'http://what.ever/', false ],
2627
-            [ 'https://booya.kasha', false ],
2628
-            [ '1/', false ],
2621
+            ['//something-that-might-be-an-url-but-isnt-really', true],
2622
+            ['', false],
2623
+            [null, false],
2624
+            ['booya/i', false],
2625
+            ['/root-relative', false],
2626
+            ['http://what.ever/', false],
2627
+            ['https://booya.kasha', false],
2628
+            ['1/', false],
2629 2629
         ];
2630 2630
     }
2631 2631
 
@@ -2640,38 +2640,38 @@  discard block
 block discarded – undo
2640 2640
 
2641 2641
         $expected = 'img.centered,.aligncenter{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}';
2642 2642
 
2643
-        $instance = new autoptimizeStyles( $css );
2644
-        $minified = $instance->run_minifier_on( $css );
2643
+        $instance = new autoptimizeStyles($css);
2644
+        $minified = $instance->run_minifier_on($css);
2645 2645
 
2646
-        $this->assertEquals( $expected, $minified );
2646
+        $this->assertEquals($expected, $minified);
2647 2647
     }
2648 2648
 
2649 2649
     public function test_css_font_names_mangling()
2650 2650
     {
2651 2651
         // Properly quoted font names dont get mangled.
2652 2652
         $css      = 'h2{font-family:"Archivo Black"}';
2653
-        $instance = new autoptimizeStyles( $css );
2654
-        $actual   = $instance->run_minifier_on( $css );
2655
-        $this->assertEquals( $css, $actual );
2653
+        $instance = new autoptimizeStyles($css);
2654
+        $actual   = $instance->run_minifier_on($css);
2655
+        $this->assertEquals($css, $actual);
2656 2656
 
2657 2657
         // When not quoted, 'Black' used to become '#000', but not anymore... :)
2658 2658
         $css_unquoted = 'h2{font-family:Archivo Black;}';
2659 2659
         $expected     = 'h2{font-family:Archivo Black}';
2660
-        $instance     = new autoptimizeStyles( $css_unquoted );
2661
-        $actual       = $instance->run_minifier_on( $css_unquoted );
2662
-        $this->assertEquals( $expected, $actual );
2660
+        $instance     = new autoptimizeStyles($css_unquoted);
2661
+        $actual       = $instance->run_minifier_on($css_unquoted);
2662
+        $this->assertEquals($expected, $actual);
2663 2663
 
2664 2664
         $css_unquoted = 'h1{font:italic 1.2em Fira White,serif}';
2665
-        $instance     = new autoptimizeStyles( $css_unquoted );
2666
-        $actual       = $instance->run_minifier_on( $css_unquoted );
2667
-        $this->assertEquals( $css_unquoted, $actual );
2665
+        $instance     = new autoptimizeStyles($css_unquoted);
2666
+        $actual       = $instance->run_minifier_on($css_unquoted);
2667
+        $this->assertEquals($css_unquoted, $actual);
2668 2668
     }
2669 2669
 
2670 2670
     public function test_is_plugin_active_utils_wrapper()
2671 2671
     {
2672 2672
         // Our plugin is loaded via "muplugins_loaded" filter in tests/bootstrap.php
2673
-        $this->assertFalse( autoptimizeUtils::is_plugin_active( 'autoptimize/autoptimize.php' ) );
2674
-        $this->assertFalse( autoptimizeUtils::is_plugin_active( 'async-javascript/async-javascript.php' ) );
2673
+        $this->assertFalse(autoptimizeUtils::is_plugin_active('autoptimize/autoptimize.php'));
2674
+        $this->assertFalse(autoptimizeUtils::is_plugin_active('async-javascript/async-javascript.php'));
2675 2675
     }
2676 2676
 
2677 2677
     public function test_jsminphp_string_literal_minification()
@@ -2685,7 +2685,7 @@  discard block
 block discarded – undo
2685 2685
         $expected = '`line
2686 2686
 break`+`he  llo`;foo`hel( \'\');lo`;`he\nl\`lo`;(`he${one + two}`)';
2687 2687
 
2688
-        $actual = JSMin::minify( $js );
2689
-        $this->assertEquals( $expected, $actual );
2688
+        $actual = JSMin::minify($js);
2689
+        $this->assertEquals($expected, $actual);
2690 2690
     }
2691 2691
 }
Please login to merge, or discard this patch.
classes/autoptimizeStyles.php 1 patch
Spacing   +314 added lines, -314 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
 
@@ -51,53 +51,53 @@  discard block
 block discarded – undo
51 51
     // public $cdn_url; // Used all over the place implicitly, so will have to be either public or protected :/ .
52 52
 
53 53
     // Reads the page and collects style tags.
54
-    public function read( $options )
54
+    public function read($options)
55 55
     {
56
-        $noptimizeCSS = apply_filters( 'autoptimize_filter_css_noptimize', false, $this->content );
57
-        if ( $noptimizeCSS ) {
56
+        $noptimizeCSS = apply_filters('autoptimize_filter_css_noptimize', false, $this->content);
57
+        if ($noptimizeCSS) {
58 58
             return false;
59 59
         }
60 60
 
61
-        $whitelistCSS = apply_filters( 'autoptimize_filter_css_whitelist', '', $this->content );
62
-        if ( ! empty( $whitelistCSS ) ) {
63
-            $this->whitelist = array_filter( array_map( 'trim', explode( ',', $whitelistCSS ) ) );
61
+        $whitelistCSS = apply_filters('autoptimize_filter_css_whitelist', '', $this->content);
62
+        if (!empty($whitelistCSS)) {
63
+            $this->whitelist = array_filter(array_map('trim', explode(',', $whitelistCSS)));
64 64
         }
65 65
 
66
-        $removableCSS = apply_filters( 'autoptimize_filter_css_removables', '' );
67
-        if ( ! empty( $removableCSS ) ) {
68
-            $this->cssremovables = array_filter( array_map( 'trim', explode( ',', $removableCSS ) ) );
66
+        $removableCSS = apply_filters('autoptimize_filter_css_removables', '');
67
+        if (!empty($removableCSS)) {
68
+            $this->cssremovables = array_filter(array_map('trim', explode(',', $removableCSS)));
69 69
         }
70 70
 
71
-        $this->cssinlinesize = apply_filters( 'autoptimize_filter_css_inlinesize', 256 );
71
+        $this->cssinlinesize = apply_filters('autoptimize_filter_css_inlinesize', 256);
72 72
 
73 73
         // filter to "late inject minified CSS", default to true for now (it is faster).
74
-        $this->inject_min_late = apply_filters( 'autoptimize_filter_css_inject_min_late', true );
74
+        $this->inject_min_late = apply_filters('autoptimize_filter_css_inject_min_late', true);
75 75
 
76 76
         // Remove everything that's not the header.
77
-        if ( apply_filters( 'autoptimize_filter_css_justhead', $options['justhead'] ) ) {
78
-            $content             = explode( '</head>', $this->content, 2 );
79
-            $this->content       = $content[0] . '</head>';
77
+        if (apply_filters('autoptimize_filter_css_justhead', $options['justhead'])) {
78
+            $content             = explode('</head>', $this->content, 2);
79
+            $this->content       = $content[0].'</head>';
80 80
             $this->restofcontent = $content[1];
81 81
         }
82 82
 
83 83
         // Determine whether we're doing CSS-files aggregation or not.
84
-        if ( isset( $options['aggregate'] ) && ! $options['aggregate'] ) {
84
+        if (isset($options['aggregate']) && !$options['aggregate']) {
85 85
             $this->aggregate = false;
86 86
         }
87 87
         // Returning true for "dontaggregate" turns off aggregation.
88
-        if ( $this->aggregate && apply_filters( 'autoptimize_filter_css_dontaggregate', false ) ) {
88
+        if ($this->aggregate && apply_filters('autoptimize_filter_css_dontaggregate', false)) {
89 89
             $this->aggregate = false;
90 90
         }
91 91
 
92 92
         // include inline?
93
-        if ( apply_filters( 'autoptimize_css_include_inline', $options['include_inline'] ) ) {
93
+        if (apply_filters('autoptimize_css_include_inline', $options['include_inline'])) {
94 94
             $this->include_inline = true;
95 95
         }
96 96
 
97 97
         // List of CSS strings which are excluded from autoptimization.
98
-        $excludeCSS = apply_filters( 'autoptimize_filter_css_exclude', $options['css_exclude'], $this->content );
99
-        if ( '' !== $excludeCSS ) {
100
-            $this->dontmove = array_filter( array_map( 'trim', explode( ',', $excludeCSS ) ) );
98
+        $excludeCSS = apply_filters('autoptimize_filter_css_exclude', $options['css_exclude'], $this->content);
99
+        if ('' !== $excludeCSS) {
100
+            $this->dontmove = array_filter(array_map('trim', explode(',', $excludeCSS)));
101 101
         } else {
102 102
             $this->dontmove = array();
103 103
         }
@@ -108,16 +108,16 @@  discard block
 block discarded – undo
108 108
         // Should we defer css?
109 109
         // value: true / false.
110 110
         $this->defer = $options['defer'];
111
-        $this->defer = apply_filters( 'autoptimize_filter_css_defer', $this->defer, $this->content );
111
+        $this->defer = apply_filters('autoptimize_filter_css_defer', $this->defer, $this->content);
112 112
 
113 113
         // Should we inline while deferring?
114 114
         // value: inlined CSS.
115
-        $this->defer_inline = apply_filters( 'autoptimize_filter_css_defer_inline', $options['defer_inline'], $this->content );
115
+        $this->defer_inline = apply_filters('autoptimize_filter_css_defer_inline', $options['defer_inline'], $this->content);
116 116
 
117 117
         // Should we inline?
118 118
         // value: true / false.
119 119
         $this->inline = $options['inline'];
120
-        $this->inline = apply_filters( 'autoptimize_filter_css_inline', $this->inline, $this->content );
120
+        $this->inline = apply_filters('autoptimize_filter_css_inline', $this->inline, $this->content);
121 121
 
122 122
         // Store cdn url.
123 123
         $this->cdn_url = $options['cdn_url'];
@@ -126,12 +126,12 @@  discard block
 block discarded – undo
126 126
         $this->datauris = $options['datauris'];
127 127
 
128 128
         // Determine whether excluded files should be minified if not yet so.
129
-        if ( ! $options['minify_excluded'] && $options['aggregate'] ) {
129
+        if (!$options['minify_excluded'] && $options['aggregate']) {
130 130
             $this->minify_excluded = false;
131 131
         }
132 132
 
133 133
         // noptimize me.
134
-        $this->content = $this->hide_noptimize( $this->content );
134
+        $this->content = $this->hide_noptimize($this->content);
135 135
 
136 136
         // Exclude (no)script, as those may contain CSS which should be left as is.
137 137
         $this->content = $this->replace_contents_with_marker_if_exists(
@@ -142,26 +142,26 @@  discard block
 block discarded – undo
142 142
         );
143 143
 
144 144
         // Save IE hacks.
145
-        $this->content = $this->hide_iehacks( $this->content );
145
+        $this->content = $this->hide_iehacks($this->content);
146 146
 
147 147
         // Hide HTML comments.
148
-        $this->content = $this->hide_comments( $this->content );
148
+        $this->content = $this->hide_comments($this->content);
149 149
 
150 150
         // Get <style> and <link>.
151
-        if ( preg_match_all( '#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi', $this->content, $matches ) ) {
151
+        if (preg_match_all('#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi', $this->content, $matches)) {
152 152
 
153
-            foreach ( $matches[0] as $tag ) {
154
-                if ( $this->isremovable( $tag, $this->cssremovables ) ) {
155
-                    $this->content = str_replace( $tag, '', $this->content );
156
-                } elseif ( $this->ismovable( $tag ) ) {
153
+            foreach ($matches[0] as $tag) {
154
+                if ($this->isremovable($tag, $this->cssremovables)) {
155
+                    $this->content = str_replace($tag, '', $this->content);
156
+                } elseif ($this->ismovable($tag)) {
157 157
                     // Get the media.
158
-                    if ( false !== strpos( $tag, 'media=' ) ) {
159
-                        preg_match( '#media=(?:"|\')([^>]*)(?:"|\')#Ui', $tag, $medias );
160
-                        $medias = explode( ',', $medias[1] );
158
+                    if (false !== strpos($tag, 'media=')) {
159
+                        preg_match('#media=(?:"|\')([^>]*)(?:"|\')#Ui', $tag, $medias);
160
+                        $medias = explode(',', $medias[1]);
161 161
                         $media = array();
162
-                        foreach ( $medias as $elem ) {
162
+                        foreach ($medias as $elem) {
163 163
                             /* $media[] = current(explode(' ',trim($elem),2)); */
164
-                            if ( empty( $elem ) ) {
164
+                            if (empty($elem)) {
165 165
                                 $elem = 'all';
166 166
                             }
167 167
 
@@ -169,72 +169,72 @@  discard block
 block discarded – undo
169 169
                         }
170 170
                     } else {
171 171
                         // No media specified - applies to all.
172
-                        $media = array( 'all' );
172
+                        $media = array('all');
173 173
                     }
174 174
 
175
-                    $media = apply_filters( 'autoptimize_filter_css_tagmedia', $media, $tag );
175
+                    $media = apply_filters('autoptimize_filter_css_tagmedia', $media, $tag);
176 176
 
177
-                    if ( preg_match( '#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source ) ) {
177
+                    if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
178 178
                         // <link>.
179
-                        $url  = current( explode( '?', $source[2], 2 ) );
180
-                        $path = $this->getpath( $url );
179
+                        $url  = current(explode('?', $source[2], 2));
180
+                        $path = $this->getpath($url);
181 181
 
182
-                        if ( false !== $path && preg_match( '#\.css$#', $path ) ) {
182
+                        if (false !== $path && preg_match('#\.css$#', $path)) {
183 183
                             // Good link.
184
-                            $this->css[] = array( $media, $path );
184
+                            $this->css[] = array($media, $path);
185 185
                         } else {
186 186
                             // Link is dynamic (.php etc).
187
-                            $new_tag = $this->optionally_defer_excluded( $tag, 'none' );
188
-                            if ( $new_tag !== '' && $new_tag !== $tag ) {
189
-                                $this->content = str_replace( $tag, $new_tag, $this->content );
187
+                            $new_tag = $this->optionally_defer_excluded($tag, 'none');
188
+                            if ($new_tag !== '' && $new_tag !== $tag) {
189
+                                $this->content = str_replace($tag, $new_tag, $this->content);
190 190
                             }
191 191
                             $tag = '';
192 192
                         }
193 193
                     } else {
194 194
                         // Inline css in style tags can be wrapped in comment tags, so restore comments.
195
-                        $tag = $this->restore_comments( $tag );
196
-                        preg_match( '#<style.*>(.*)</style>#Usmi', $tag, $code );
195
+                        $tag = $this->restore_comments($tag);
196
+                        preg_match('#<style.*>(.*)</style>#Usmi', $tag, $code);
197 197
 
198 198
                         // And re-hide them to be able to to the removal based on tag.
199
-                        $tag = $this->hide_comments( $tag );
199
+                        $tag = $this->hide_comments($tag);
200 200
 
201
-                        if ( $this->include_inline ) {
202
-                            $code = preg_replace( '#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm', '$1', $code[1] );
203
-                            $this->css[] = array( $media, 'INLINE;' . $code );
201
+                        if ($this->include_inline) {
202
+                            $code = preg_replace('#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm', '$1', $code[1]);
203
+                            $this->css[] = array($media, 'INLINE;'.$code);
204 204
                         } else {
205 205
                             $tag = '';
206 206
                         }
207 207
                     }
208 208
 
209 209
                     // Remove the original style tag.
210
-                    $this->content = str_replace( $tag, '', $this->content );
210
+                    $this->content = str_replace($tag, '', $this->content);
211 211
                 } else {
212
-                    if ( preg_match( '#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source ) ) {
213
-                        $exploded_url = explode( '?', $source[2], 2 );
212
+                    if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
213
+                        $exploded_url = explode('?', $source[2], 2);
214 214
                         $url          = $exploded_url[0];
215
-                        $path         = $this->getpath( $url );
215
+                        $path         = $this->getpath($url);
216 216
                         $new_tag      = $tag;
217 217
 
218 218
                         // Excluded CSS, minify that file:
219 219
                         // -> if aggregate is on and exclude minify is on
220 220
                         // -> if aggregate is off and the file is not in dontmove.
221
-                        if ( $path && ( $this->minify_excluded || apply_filters( 'autoptimize_filter_css_minify_excluded', false, $url ) ) ) {
222
-                            $consider_minified_array = apply_filters( 'autoptimize_filter_css_consider_minified', false );
223
-                            if ( ( false === $this->aggregate && str_replace( $this->dontmove, '', $path ) === $path ) || ( true === $this->aggregate && ( false === $consider_minified_array || str_replace( $consider_minified_array, '', $path ) === $path ) ) ) {
224
-                                $minified_url = $this->minify_single( $path );
225
-                                if ( ! empty( $minified_url ) ) {
221
+                        if ($path && ($this->minify_excluded || apply_filters('autoptimize_filter_css_minify_excluded', false, $url))) {
222
+                            $consider_minified_array = apply_filters('autoptimize_filter_css_consider_minified', false);
223
+                            if ((false === $this->aggregate && str_replace($this->dontmove, '', $path) === $path) || (true === $this->aggregate && (false === $consider_minified_array || str_replace($consider_minified_array, '', $path) === $path))) {
224
+                                $minified_url = $this->minify_single($path);
225
+                                if (!empty($minified_url)) {
226 226
                                     // Replace orig URL with cached minified URL.
227
-                                    $new_tag = str_replace( $url, $minified_url, $tag );
227
+                                    $new_tag = str_replace($url, $minified_url, $tag);
228 228
                                 }
229 229
                             }
230 230
                         }
231 231
 
232 232
                         // Optionally defer (preload) non-aggregated CSS.
233
-                        $new_tag = $this->optionally_defer_excluded( $new_tag, $url );
233
+                        $new_tag = $this->optionally_defer_excluded($new_tag, $url);
234 234
 
235 235
                         // And replace!
236
-                        if ( $new_tag !== '' && $new_tag !== $tag ) {
237
-                            $this->content = str_replace( $tag, $new_tag, $this->content );
236
+                        if ($new_tag !== '' && $new_tag !== $tag) {
237
+                            $this->content = str_replace($tag, $new_tag, $this->content);
238 238
                         }
239 239
                     }
240 240
                 }
@@ -255,10 +255,10 @@  discard block
 block discarded – undo
255 255
      *
256 256
      * @return string $new_tag
257 257
      */
258
-    private function optionally_defer_excluded( $tag, $url = '' )
258
+    private function optionally_defer_excluded($tag, $url = '')
259 259
     {
260 260
         // Defer single CSS if "inline & defer" is ON and there is inline CSS.
261
-        if ( $this->defer && ! empty( $this->defer_inline ) ) {
261
+        if ($this->defer && !empty($this->defer_inline)) {
262 262
             // Get/ set (via filter) the JS to be triggers onload of the preloaded CSS.
263 263
             $_preload_onload = apply_filters(
264 264
                 'autoptimize_filter_css_preload_onload',
@@ -266,12 +266,12 @@  discard block
 block discarded – undo
266 266
                 $url
267 267
             );
268 268
             // Adapt original <link> element for CSS to be preloaded and add <noscript>-version for fallback.
269
-            $new_tag = '<noscript>' . $tag . '</noscript>' . str_replace(
269
+            $new_tag = '<noscript>'.$tag.'</noscript>'.str_replace(
270 270
                 array(
271 271
                     "rel='stylesheet'",
272 272
                     'rel="stylesheet"',
273 273
                 ),
274
-                "rel='preload' as='style' onload=\"" . $_preload_onload . "\"",
274
+                "rel='preload' as='style' onload=\"".$_preload_onload."\"",
275 275
                 $tag
276 276
             );
277 277
         } else {
@@ -288,22 +288,22 @@  discard block
 block discarded – undo
288 288
      * @param string $path
289 289
      * @return boolean
290 290
      */
291
-    private function is_datauri_candidate( $path )
291
+    private function is_datauri_candidate($path)
292 292
     {
293 293
         // Call only once since it's called from a loop.
294 294
         static $max_size = null;
295
-        if ( null === $max_size ) {
295
+        if (null === $max_size) {
296 296
             $max_size = $this->get_datauri_maxsize();
297 297
         }
298 298
 
299
-        if ( $path && preg_match( '#\.(jpe?g|png|gif|webp|bmp)$#i', $path ) &&
300
-            file_exists( $path ) && is_readable( $path ) && filesize( $path ) <= $max_size ) {
299
+        if ($path && preg_match('#\.(jpe?g|png|gif|webp|bmp)$#i', $path) &&
300
+            file_exists($path) && is_readable($path) && filesize($path) <= $max_size) {
301 301
 
302 302
             // Seems we have a candidate.
303 303
             $is_candidate = true;
304 304
         } else {
305 305
             // Filter allows overriding default decision (which checks for local file existence).
306
-            $is_candidate = apply_filters( 'autoptimize_filter_css_is_datauri_candidate', false, $path );
306
+            $is_candidate = apply_filters('autoptimize_filter_css_is_datauri_candidate', false, $path);
307 307
         }
308 308
 
309 309
         return $is_candidate;
@@ -328,29 +328,29 @@  discard block
 block discarded – undo
328 328
          * of thing you're probably better of building assets completely
329 329
          * outside of WordPress anyway.
330 330
          */
331
-        if ( null === $max_size ) {
332
-            $max_size = (int) apply_filters( 'autoptimize_filter_css_datauri_maxsize', 4096 );
331
+        if (null === $max_size) {
332
+            $max_size = (int) apply_filters('autoptimize_filter_css_datauri_maxsize', 4096);
333 333
         }
334 334
 
335 335
         return $max_size;
336 336
     }
337 337
 
338
-    private function check_datauri_exclude_list( $url )
338
+    private function check_datauri_exclude_list($url)
339 339
     {
340 340
         static $exclude_list = null;
341 341
         $no_datauris         = array();
342 342
 
343 343
         // Again, skip doing certain stuff repeatedly when loop-called.
344
-        if ( null === $exclude_list ) {
345
-            $exclude_list = apply_filters( 'autoptimize_filter_css_datauri_exclude', '' );
346
-            $no_datauris = array_filter( array_map( 'trim', explode( ',', $exclude_list ) ) );
344
+        if (null === $exclude_list) {
345
+            $exclude_list = apply_filters('autoptimize_filter_css_datauri_exclude', '');
346
+            $no_datauris = array_filter(array_map('trim', explode(',', $exclude_list)));
347 347
         }
348 348
 
349 349
         $matched = false;
350 350
 
351
-        if ( ! empty( $exclude_list ) ) {
352
-            foreach ( $no_datauris as $no_datauri ) {
353
-                if ( false !== strpos( $url, $no_datauri ) ) {
351
+        if (!empty($exclude_list)) {
352
+            foreach ($no_datauris as $no_datauri) {
353
+                if (false !== strpos($url, $no_datauri)) {
354 354
                     $matched = true;
355 355
                     break;
356 356
                 }
@@ -360,7 +360,7 @@  discard block
 block discarded – undo
360 360
         return $matched;
361 361
     }
362 362
 
363
-    private function build_or_get_datauri_image( $path )
363
+    private function build_or_get_datauri_image($path)
364 364
     {
365 365
         /**
366 366
          * TODO/FIXME: document the required return array format, or better yet,
@@ -369,27 +369,27 @@  discard block
 block discarded – undo
369 369
          */
370 370
 
371 371
         // Allows short-circuiting datauri generation for an image.
372
-        $result = apply_filters( 'autoptimize_filter_css_datauri_image', array(), $path );
373
-        if ( ! empty( $result ) ) {
374
-            if ( is_array( $result ) && isset( $result['full'] ) && isset( $result['base64data'] ) ) {
372
+        $result = apply_filters('autoptimize_filter_css_datauri_image', array(), $path);
373
+        if (!empty($result)) {
374
+            if (is_array($result) && isset($result['full']) && isset($result['base64data'])) {
375 375
                 return $result;
376 376
             }
377 377
         }
378 378
 
379
-        $hash = md5( $path );
380
-        $check = new autoptimizeCache( $hash, 'img' );
381
-        if ( $check->check() ) {
379
+        $hash = md5($path);
380
+        $check = new autoptimizeCache($hash, 'img');
381
+        if ($check->check()) {
382 382
             // we have the base64 image in cache.
383 383
             $headAndData = $check->retrieve();
384
-            $_base64data = explode( ';base64,', $headAndData );
384
+            $_base64data = explode(';base64,', $headAndData);
385 385
             $base64data  = $_base64data[1];
386
-            unset( $_base64data );
386
+            unset($_base64data);
387 387
         } else {
388 388
             // It's an image and we don't have it in cache, get the type by extension.
389
-            $exploded_path = explode( '.', $path );
390
-            $type = end( $exploded_path );
389
+            $exploded_path = explode('.', $path);
390
+            $type = end($exploded_path);
391 391
 
392
-            switch ( $type ) {
392
+            switch ($type) {
393 393
                 case 'jpg':
394 394
                 case 'jpeg':
395 395
                     $dataurihead = 'data:image/jpeg;base64,';
@@ -411,15 +411,15 @@  discard block
 block discarded – undo
411 411
             }
412 412
 
413 413
             // Encode the data.
414
-            $base64data  = base64_encode( file_get_contents( $path ) );
415
-            $headAndData = $dataurihead . $base64data;
414
+            $base64data  = base64_encode(file_get_contents($path));
415
+            $headAndData = $dataurihead.$base64data;
416 416
 
417 417
             // Save in cache.
418
-            $check->cache( $headAndData, 'text/plain' );
418
+            $check->cache($headAndData, 'text/plain');
419 419
         }
420
-        unset( $check );
420
+        unset($check);
421 421
 
422
-        return array( 'full' => $headAndData, 'base64data' => $base64data );
422
+        return array('full' => $headAndData, 'base64data' => $base64data);
423 423
     }
424 424
 
425 425
     /**
@@ -431,13 +431,13 @@  discard block
 block discarded – undo
431 431
      *
432 432
      * @return string
433 433
      */
434
-    protected static function replace_longest_matches_first( $string, $replacements = array() )
434
+    protected static function replace_longest_matches_first($string, $replacements = array())
435 435
     {
436
-        if ( ! empty( $replacements ) ) {
436
+        if (!empty($replacements)) {
437 437
             // Sort the replacements array by key length in desc order (so that the longest strings are replaced first).
438
-            $keys = array_map( 'strlen', array_keys( $replacements ) );
439
-            array_multisort( $keys, SORT_DESC, $replacements );
440
-            $string = str_replace( array_keys( $replacements ), array_values( $replacements ), $string );
438
+            $keys = array_map('strlen', array_keys($replacements));
439
+            array_multisort($keys, SORT_DESC, $replacements);
440
+            $string = str_replace(array_keys($replacements), array_values($replacements), $string);
441 441
         }
442 442
 
443 443
         return $string;
@@ -453,15 +453,15 @@  discard block
 block discarded – undo
453 453
      *
454 454
      * @return string
455 455
      */
456
-    public function replace_urls( $code = '' )
456
+    public function replace_urls($code = '')
457 457
     {
458 458
         $replacements = array();
459 459
 
460
-        preg_match_all( self::ASSETS_REGEX, $code, $url_src_matches );
461
-        if ( is_array( $url_src_matches ) && ! empty( $url_src_matches ) ) {
462
-            foreach ( $url_src_matches[1] as $count => $original_url ) {
460
+        preg_match_all(self::ASSETS_REGEX, $code, $url_src_matches);
461
+        if (is_array($url_src_matches) && !empty($url_src_matches)) {
462
+            foreach ($url_src_matches[1] as $count => $original_url) {
463 463
                 // Removes quotes and other cruft.
464
-                $url = trim( $original_url, " \t\n\r\0\x0B\"'" );
464
+                $url = trim($original_url, " \t\n\r\0\x0B\"'");
465 465
 
466 466
                 /**
467 467
                  * TODO/FIXME: Add a way for other code / callable to be called here
@@ -479,17 +479,17 @@  discard block
 block discarded – undo
479 479
                  */
480 480
 
481 481
                 // Do CDN replacement if needed.
482
-                if ( ! empty( $this->cdn_url ) ) {
483
-                    $replacement_url = $this->url_replace_cdn( $url );
482
+                if (!empty($this->cdn_url)) {
483
+                    $replacement_url = $this->url_replace_cdn($url);
484 484
                     // Prepare replacements array.
485
-                    $replacements[ $url_src_matches[1][ $count ] ] = str_replace(
485
+                    $replacements[$url_src_matches[1][$count]] = str_replace(
486 486
                         $original_url, $replacement_url, $url_src_matches[1][$count]
487 487
                     );
488 488
                 }
489 489
             }
490 490
         }
491 491
 
492
-        $code = self::replace_longest_matches_first( $code, $replacements );
492
+        $code = self::replace_longest_matches_first($code, $replacements);
493 493
 
494 494
         return $code;
495 495
     }
@@ -502,26 +502,26 @@  discard block
 block discarded – undo
502 502
      * @param string $code
503 503
      * @return string
504 504
      */
505
-    public function hide_fontface_and_maybe_cdn( $code )
505
+    public function hide_fontface_and_maybe_cdn($code)
506 506
     {
507 507
         // Proceed only if @font-face declarations exist within $code.
508
-        preg_match_all( self::FONT_FACE_REGEX, $code, $fontfaces );
509
-        if ( isset( $fontfaces[0] ) ) {
508
+        preg_match_all(self::FONT_FACE_REGEX, $code, $fontfaces);
509
+        if (isset($fontfaces[0])) {
510 510
             // Check if we need to cdn fonts or not.
511
-            $do_font_cdn = apply_filters( 'autoptimize_filter_css_fonts_cdn', false );
511
+            $do_font_cdn = apply_filters('autoptimize_filter_css_fonts_cdn', false);
512 512
 
513
-            foreach ( $fontfaces[0] as $full_match ) {
513
+            foreach ($fontfaces[0] as $full_match) {
514 514
                 // Keep original match so we can search/replace it.
515 515
                 $match_search = $full_match;
516 516
 
517 517
                 // Do font cdn if needed.
518
-                if ( $do_font_cdn ) {
519
-                    $full_match = $this->replace_urls( $full_match );
518
+                if ($do_font_cdn) {
519
+                    $full_match = $this->replace_urls($full_match);
520 520
                 }
521 521
 
522 522
                 // Replace declaration with its base64 encoded string.
523
-                $replacement = self::build_marker( 'FONTFACE', $full_match );
524
-                $code = str_replace( $match_search, $replacement, $code );
523
+                $replacement = self::build_marker('FONTFACE', $full_match);
524
+                $code = str_replace($match_search, $replacement, $code);
525 525
             }
526 526
         }
527 527
 
@@ -535,16 +535,16 @@  discard block
 block discarded – undo
535 535
      * @param string $code
536 536
      * @return string
537 537
      */
538
-    public function restore_fontface( $code )
538
+    public function restore_fontface($code)
539 539
     {
540
-        return $this->restore_marked_content( 'FONTFACE', $code );
540
+        return $this->restore_marked_content('FONTFACE', $code);
541 541
     }
542 542
 
543 543
     // Re-write (and/or inline) referenced assets.
544
-    public function rewrite_assets( $code )
544
+    public function rewrite_assets($code)
545 545
     {
546 546
         // Handle @font-face rules by hiding and processing them separately.
547
-        $code = $this->hide_fontface_and_maybe_cdn( $code );
547
+        $code = $this->hide_fontface_and_maybe_cdn($code);
548 548
 
549 549
         /**
550 550
          * TODO/FIXME:
@@ -560,30 +560,30 @@  discard block
 block discarded – undo
560 560
         $url_src_matches = array();
561 561
         $imgreplace = array();
562 562
         // Matches and captures anything specified within the literal `url()` and excludes those containing data: URIs.
563
-        preg_match_all( self::ASSETS_REGEX, $code, $url_src_matches );
564
-        if ( is_array( $url_src_matches ) && ! empty( $url_src_matches ) ) {
565
-            foreach ( $url_src_matches[1] as $count => $original_url ) {
563
+        preg_match_all(self::ASSETS_REGEX, $code, $url_src_matches);
564
+        if (is_array($url_src_matches) && !empty($url_src_matches)) {
565
+            foreach ($url_src_matches[1] as $count => $original_url) {
566 566
                 // Removes quotes and other cruft.
567
-                $url = trim( $original_url, " \t\n\r\0\x0B\"'" );
567
+                $url = trim($original_url, " \t\n\r\0\x0B\"'");
568 568
 
569 569
                 // If datauri inlining is turned on, do it.
570 570
                 $inlined = false;
571
-                if ( $this->datauris ) {
571
+                if ($this->datauris) {
572 572
                     $iurl = $url;
573
-                    if ( false !== strpos( $iurl, '?' ) ) {
574
-                        $iurl = strtok( $iurl, '?' );
573
+                    if (false !== strpos($iurl, '?')) {
574
+                        $iurl = strtok($iurl, '?');
575 575
                     }
576 576
 
577
-                    $ipath = $this->getpath( $iurl );
577
+                    $ipath = $this->getpath($iurl);
578 578
 
579
-                    $excluded = $this->check_datauri_exclude_list( $ipath );
580
-                    if ( ! $excluded ) {
581
-                        $is_datauri_candidate = $this->is_datauri_candidate( $ipath );
582
-                        if ( $is_datauri_candidate ) {
583
-                            $datauri     = $this->build_or_get_datauri_image( $ipath );
579
+                    $excluded = $this->check_datauri_exclude_list($ipath);
580
+                    if (!$excluded) {
581
+                        $is_datauri_candidate = $this->is_datauri_candidate($ipath);
582
+                        if ($is_datauri_candidate) {
583
+                            $datauri     = $this->build_or_get_datauri_image($ipath);
584 584
                             $base64data  = $datauri['base64data'];
585 585
                             // Add it to the list for replacement.
586
-                            $imgreplace[ $url_src_matches[1][ $count ] ] = str_replace(
586
+                            $imgreplace[$url_src_matches[1][$count]] = str_replace(
587 587
                                     $original_url,
588 588
                                     $datauri['full'],
589 589
                                     $url_src_matches[1][$count]
@@ -599,20 +599,20 @@  discard block
 block discarded – undo
599 599
                  * inlining isn't turned on, or if a resource is skipped from
600 600
                  * being inlined for whatever reason above.
601 601
                  */
602
-                if ( ! $inlined && ( ! empty( $this->cdn_url ) || has_filter( 'autoptimize_filter_base_replace_cdn' ) ) ) {
602
+                if (!$inlined && (!empty($this->cdn_url) || has_filter('autoptimize_filter_base_replace_cdn'))) {
603 603
                     // Just do the "simple" CDN replacement.
604
-                    $replacement_url = $this->url_replace_cdn( $url );
605
-                    $imgreplace[ $url_src_matches[1][ $count ] ] = str_replace(
604
+                    $replacement_url = $this->url_replace_cdn($url);
605
+                    $imgreplace[$url_src_matches[1][$count]] = str_replace(
606 606
                         $original_url, $replacement_url, $url_src_matches[1][$count]
607 607
                     );
608 608
                 }
609 609
             }
610 610
         }
611 611
 
612
-        $code = self::replace_longest_matches_first( $code, $imgreplace );
612
+        $code = self::replace_longest_matches_first($code, $imgreplace);
613 613
 
614 614
         // Replace back font-face markers with actual font-face declarations.
615
-        $code = $this->restore_fontface( $code );
615
+        $code = $this->restore_fontface($code);
616 616
 
617 617
         return $code;
618 618
     }
@@ -620,29 +620,29 @@  discard block
 block discarded – undo
620 620
     // Joins and optimizes CSS.
621 621
     public function minify()
622 622
     {
623
-        foreach ( $this->css as $group ) {
624
-            list( $media, $css ) = $group;
625
-            if ( preg_match( '#^INLINE;#', $css ) ) {
623
+        foreach ($this->css as $group) {
624
+            list($media, $css) = $group;
625
+            if (preg_match('#^INLINE;#', $css)) {
626 626
                 // <style>.
627
-                $css = preg_replace( '#^INLINE;#', '', $css );
628
-                $css = self::fixurls( ABSPATH . 'index.php', $css ); // ABSPATH already contains a trailing slash.
629
-                $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, '' );
630
-                if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
627
+                $css = preg_replace('#^INLINE;#', '', $css);
628
+                $css = self::fixurls(ABSPATH.'index.php', $css); // ABSPATH already contains a trailing slash.
629
+                $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, '');
630
+                if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
631 631
                     $css = $tmpstyle;
632 632
                     $this->alreadyminified = true;
633 633
                 }
634 634
             } else {
635 635
                 // <link>
636
-                if ( false !== $css && file_exists( $css ) && is_readable( $css ) ) {
636
+                if (false !== $css && file_exists($css) && is_readable($css)) {
637 637
                     $cssPath = $css;
638
-                    $css = self::fixurls( $cssPath, file_get_contents( $cssPath ) );
639
-                    $css = preg_replace( '/\x{EF}\x{BB}\x{BF}/', '', $css );
640
-                    $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, $cssPath );
641
-                    if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
638
+                    $css = self::fixurls($cssPath, file_get_contents($cssPath));
639
+                    $css = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $css);
640
+                    $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, $cssPath);
641
+                    if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
642 642
                         $css = $tmpstyle;
643 643
                         $this->alreadyminified = true;
644
-                    } elseif ( $this->can_inject_late( $cssPath, $css ) ) {
645
-                        $css = self::build_injectlater_marker( $cssPath, md5( $css ) );
644
+                    } elseif ($this->can_inject_late($cssPath, $css)) {
645
+                        $css = self::build_injectlater_marker($cssPath, md5($css));
646 646
                     }
647 647
                 } else {
648 648
                     // Couldn't read CSS. Maybe getpath isn't working?
@@ -650,12 +650,12 @@  discard block
 block discarded – undo
650 650
                 }
651 651
             }
652 652
 
653
-            foreach ( $media as $elem ) {
654
-                if ( ! empty( $css ) ) {
655
-                    if ( ! isset( $this->csscode[$elem] ) ) {
653
+            foreach ($media as $elem) {
654
+                if (!empty($css)) {
655
+                    if (!isset($this->csscode[$elem])) {
656 656
                         $this->csscode[$elem] = '';
657 657
                     }
658
-                    $this->csscode[$elem] .= "\n/*FILESTART*/" . $css;
658
+                    $this->csscode[$elem] .= "\n/*FILESTART*/".$css;
659 659
                 }
660 660
             }
661 661
         }
@@ -663,133 +663,133 @@  discard block
 block discarded – undo
663 663
         // Check for duplicate code.
664 664
         $md5list = array();
665 665
         $tmpcss  = $this->csscode;
666
-        foreach ( $tmpcss as $media => $code ) {
667
-            $md5sum    = md5( $code );
666
+        foreach ($tmpcss as $media => $code) {
667
+            $md5sum    = md5($code);
668 668
             $medianame = $media;
669
-            foreach ( $md5list as $med => $sum ) {
669
+            foreach ($md5list as $med => $sum) {
670 670
                 // If same code.
671
-                if ( $sum === $md5sum ) {
671
+                if ($sum === $md5sum) {
672 672
                     // Add the merged code.
673
-                    $medianame                 = $med . ', ' . $media;
673
+                    $medianame                 = $med.', '.$media;
674 674
                     $this->csscode[$medianame] = $code;
675 675
                     $md5list[$medianame]       = $md5list[$med];
676
-                    unset( $this->csscode[$med], $this->csscode[$media], $md5list[$med] );
676
+                    unset($this->csscode[$med], $this->csscode[$media], $md5list[$med]);
677 677
                 }
678 678
             }
679 679
             $md5list[$medianame] = $md5sum;
680 680
         }
681
-        unset( $tmpcss );
681
+        unset($tmpcss);
682 682
 
683 683
         // Manage @imports, while is for recursive import management.
684
-        foreach ( $this->csscode as &$thiscss ) {
684
+        foreach ($this->csscode as &$thiscss) {
685 685
             // Flag to trigger import reconstitution and var to hold external imports.
686 686
             $fiximports       = false;
687 687
             $external_imports = '';
688 688
 
689 689
             // remove comments to avoid importing commented-out imports.
690
-            $thiscss_nocomments = preg_replace( '#/\*.*\*/#Us', '', $thiscss );
691
-            while ( preg_match_all( '#@import +(?:url)?(?:(?:\((["\']?)(?:[^"\')]+)\1\)|(["\'])(?:[^"\']+)\2)(?:[^,;"\']+(?:,[^,;"\']+)*)?)(?:;)#mi', $thiscss_nocomments, $matches ) ) {
692
-                foreach ( $matches[0] as $import ) {
693
-                    if ( $this->isremovable( $import, $this->cssremovables ) ) {
694
-                        $thiscss = str_replace( $import, '', $thiscss );
690
+            $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
691
+            while (preg_match_all('#@import +(?:url)?(?:(?:\((["\']?)(?:[^"\')]+)\1\)|(["\'])(?:[^"\']+)\2)(?:[^,;"\']+(?:,[^,;"\']+)*)?)(?:;)#mi', $thiscss_nocomments, $matches)) {
692
+                foreach ($matches[0] as $import) {
693
+                    if ($this->isremovable($import, $this->cssremovables)) {
694
+                        $thiscss = str_replace($import, '', $thiscss);
695 695
                         $import_ok = true;
696 696
                     } else {
697
-                        $url = trim( preg_replace( '#^.*((?:https?:|ftp:)?//.*\.css).*$#', '$1', trim( $import ) ), " \t\n\r\0\x0B\"'" );
698
-                        $path = $this->getpath( $url );
697
+                        $url = trim(preg_replace('#^.*((?:https?:|ftp:)?//.*\.css).*$#', '$1', trim($import)), " \t\n\r\0\x0B\"'");
698
+                        $path = $this->getpath($url);
699 699
                         $import_ok = false;
700
-                        if ( file_exists( $path ) && is_readable( $path ) ) {
701
-                            $code = addcslashes( self::fixurls( $path, file_get_contents( $path ) ), "\\" );
702
-                            $code = preg_replace( '/\x{EF}\x{BB}\x{BF}/', '', $code );
703
-                            $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $code, '' );
704
-                            if ( has_filter( 'autoptimize_css_individual_style' ) && ! empty( $tmpstyle ) ) {
700
+                        if (file_exists($path) && is_readable($path)) {
701
+                            $code = addcslashes(self::fixurls($path, file_get_contents($path)), "\\");
702
+                            $code = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $code);
703
+                            $tmpstyle = apply_filters('autoptimize_css_individual_style', $code, '');
704
+                            if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
705 705
                                 $code = $tmpstyle;
706 706
                                 $this->alreadyminified = true;
707
-                            } elseif ( $this->can_inject_late( $path, $code ) ) {
708
-                                $code = self::build_injectlater_marker( $path, md5( $code ) );
707
+                            } elseif ($this->can_inject_late($path, $code)) {
708
+                                $code = self::build_injectlater_marker($path, md5($code));
709 709
                             }
710 710
 
711
-                            if ( ! empty( $code ) ) {
712
-                                $tmp_thiscss = preg_replace( '#(/\*FILESTART\*/.*)' . preg_quote( $import, '#' ) . '#Us', '/*FILESTART2*/' . $code . '$1', $thiscss );
713
-                                if ( ! empty( $tmp_thiscss ) ) {
711
+                            if (!empty($code)) {
712
+                                $tmp_thiscss = preg_replace('#(/\*FILESTART\*/.*)'.preg_quote($import, '#').'#Us', '/*FILESTART2*/'.$code.'$1', $thiscss);
713
+                                if (!empty($tmp_thiscss)) {
714 714
                                     $thiscss = $tmp_thiscss;
715 715
                                     $import_ok = true;
716
-                                    unset( $tmp_thiscss );
716
+                                    unset($tmp_thiscss);
717 717
                                 }
718 718
                             }
719
-                            unset( $code );
719
+                            unset($code);
720 720
                         }
721 721
                     }
722
-                    if ( ! $import_ok ) {
722
+                    if (!$import_ok) {
723 723
                         // External imports and general fall-back.
724 724
                         $external_imports .= $import;
725 725
 
726
-                        $thiscss    = str_replace( $import, '', $thiscss );
726
+                        $thiscss    = str_replace($import, '', $thiscss);
727 727
                         $fiximports = true;
728 728
                     }
729 729
                 }
730
-                $thiscss = preg_replace( '#/\*FILESTART\*/#', '', $thiscss );
731
-                $thiscss = preg_replace( '#/\*FILESTART2\*/#', '/*FILESTART*/', $thiscss );
730
+                $thiscss = preg_replace('#/\*FILESTART\*/#', '', $thiscss);
731
+                $thiscss = preg_replace('#/\*FILESTART2\*/#', '/*FILESTART*/', $thiscss);
732 732
 
733 733
                 // and update $thiscss_nocomments before going into next iteration in while loop.
734
-                $thiscss_nocomments = preg_replace( '#/\*.*\*/#Us', '', $thiscss );
734
+                $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
735 735
             }
736
-            unset( $thiscss_nocomments );
736
+            unset($thiscss_nocomments);
737 737
 
738 738
             // Add external imports to top of aggregated CSS.
739
-            if ( $fiximports ) {
740
-                $thiscss = $external_imports . $thiscss;
739
+            if ($fiximports) {
740
+                $thiscss = $external_imports.$thiscss;
741 741
             }
742 742
         }
743
-        unset( $thiscss );
743
+        unset($thiscss);
744 744
 
745 745
         // $this->csscode has all the uncompressed code now.
746
-        foreach ( $this->csscode as &$code ) {
746
+        foreach ($this->csscode as &$code) {
747 747
             // Check for already-minified code.
748
-            $hash = md5( $code );
749
-            do_action( 'autoptimize_action_css_hash', $hash );
750
-            $ccheck = new autoptimizeCache( $hash, 'css' );
751
-            if ( $ccheck->check() ) {
748
+            $hash = md5($code);
749
+            do_action('autoptimize_action_css_hash', $hash);
750
+            $ccheck = new autoptimizeCache($hash, 'css');
751
+            if ($ccheck->check()) {
752 752
                 $code = $ccheck->retrieve();
753
-                $this->hashmap[md5( $code )] = $hash;
753
+                $this->hashmap[md5($code)] = $hash;
754 754
                 continue;
755 755
             }
756
-            unset( $ccheck );
756
+            unset($ccheck);
757 757
 
758 758
             // Rewrite and/or inline referenced assets.
759
-            $code = $this->rewrite_assets( $code );
759
+            $code = $this->rewrite_assets($code);
760 760
 
761 761
             // Minify.
762
-            $code = $this->run_minifier_on( $code );
762
+            $code = $this->run_minifier_on($code);
763 763
 
764 764
             // Bring back INJECTLATER stuff.
765
-            $code = $this->inject_minified( $code );
765
+            $code = $this->inject_minified($code);
766 766
 
767 767
             // Filter results.
768
-            $tmp_code = apply_filters( 'autoptimize_css_after_minify', $code );
769
-            if ( ! empty( $tmp_code ) ) {
768
+            $tmp_code = apply_filters('autoptimize_css_after_minify', $code);
769
+            if (!empty($tmp_code)) {
770 770
                 $code = $tmp_code;
771
-                unset( $tmp_code );
771
+                unset($tmp_code);
772 772
             }
773 773
 
774
-            $this->hashmap[md5( $code )] = $hash;
774
+            $this->hashmap[md5($code)] = $hash;
775 775
         }
776 776
 
777
-        unset( $code );
777
+        unset($code);
778 778
         return true;
779 779
     }
780 780
 
781
-    public function run_minifier_on( $code )
781
+    public function run_minifier_on($code)
782 782
     {
783
-        if ( ! $this->alreadyminified ) {
784
-            $do_minify = apply_filters( 'autoptimize_css_do_minify', true );
783
+        if (!$this->alreadyminified) {
784
+            $do_minify = apply_filters('autoptimize_css_do_minify', true);
785 785
 
786
-            if ( $do_minify ) {
786
+            if ($do_minify) {
787 787
                 $cssmin   = new autoptimizeCSSmin();
788
-                $tmp_code = trim( $cssmin->run( $code ) );
788
+                $tmp_code = trim($cssmin->run($code));
789 789
 
790
-                if ( ! empty( $tmp_code ) ) {
790
+                if (!empty($tmp_code)) {
791 791
                     $code = $tmp_code;
792
-                    unset( $tmp_code );
792
+                    unset($tmp_code);
793 793
                 }
794 794
             }
795 795
         }
@@ -801,14 +801,14 @@  discard block
 block discarded – undo
801 801
     public function cache()
802 802
     {
803 803
         // CSS cache.
804
-        foreach ( $this->csscode as $media => $code ) {
805
-            $md5 = $this->hashmap[md5( $code )];
806
-            $cache = new autoptimizeCache( $md5, 'css' );
807
-            if ( ! $cache->check() ) {
804
+        foreach ($this->csscode as $media => $code) {
805
+            $md5 = $this->hashmap[md5($code)];
806
+            $cache = new autoptimizeCache($md5, 'css');
807
+            if (!$cache->check()) {
808 808
                 // Cache our code.
809
-                $cache->cache( $code, 'text/css' );
809
+                $cache->cache($code, 'text/css');
810 810
             }
811
-            $this->url[$media] = AUTOPTIMIZE_CACHE_URL . $cache->getname();
811
+            $this->url[$media] = AUTOPTIMIZE_CACHE_URL.$cache->getname();
812 812
         }
813 813
     }
814 814
 
@@ -816,136 +816,136 @@  discard block
 block discarded – undo
816 816
     public function getcontent()
817 817
     {
818 818
         // Restore the full content (only applies when "autoptimize_filter_css_justhead" filter is true).
819
-        if ( ! empty( $this->restofcontent ) ) {
819
+        if (!empty($this->restofcontent)) {
820 820
             $this->content .= $this->restofcontent;
821 821
             $this->restofcontent = '';
822 822
         }
823 823
 
824 824
         // Inject the new stylesheets.
825
-        $replaceTag = array( '<title', 'before' );
826
-        $replaceTag = apply_filters( 'autoptimize_filter_css_replacetag', $replaceTag, $this->content );
825
+        $replaceTag = array('<title', 'before');
826
+        $replaceTag = apply_filters('autoptimize_filter_css_replacetag', $replaceTag, $this->content);
827 827
 
828
-        if ( $this->inline ) {
829
-            foreach ( $this->csscode as $media => $code ) {
830
-                $this->inject_in_html( '<style type="text/css" media="' . $media . '">' . $code . '</style>', $replaceTag );
828
+        if ($this->inline) {
829
+            foreach ($this->csscode as $media => $code) {
830
+                $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$code.'</style>', $replaceTag);
831 831
             }
832 832
         } else {
833
-            if ( $this->defer ) {
833
+            if ($this->defer) {
834 834
                 $preloadCssBlock = '';
835 835
                 $noScriptCssBlock = "<noscript id=\"aonoscrcss\">";
836 836
 
837 837
                 $defer_inline_code = $this->defer_inline;
838
-                if ( ! empty( $defer_inline_code ) ) {
839
-                    if ( apply_filters( 'autoptimize_filter_css_critcss_minify', true ) ) {
840
-                        $iCssHash = md5( $defer_inline_code );
841
-                        $iCssCache = new autoptimizeCache( $iCssHash, 'css' );
842
-                        if ( $iCssCache->check() ) {
838
+                if (!empty($defer_inline_code)) {
839
+                    if (apply_filters('autoptimize_filter_css_critcss_minify', true)) {
840
+                        $iCssHash = md5($defer_inline_code);
841
+                        $iCssCache = new autoptimizeCache($iCssHash, 'css');
842
+                        if ($iCssCache->check()) {
843 843
                             // we have the optimized inline CSS in cache.
844 844
                             $defer_inline_code = $iCssCache->retrieve();
845 845
                         } else {
846 846
                             $cssmin   = new autoptimizeCSSmin();
847
-                            $tmp_code = trim( $cssmin->run( $defer_inline_code ) );
847
+                            $tmp_code = trim($cssmin->run($defer_inline_code));
848 848
 
849
-                            if ( ! empty( $tmp_code ) ) {
849
+                            if (!empty($tmp_code)) {
850 850
                                 $defer_inline_code = $tmp_code;
851
-                                $iCssCache->cache( $defer_inline_code, 'text/css' );
852
-                                unset( $tmp_code );
851
+                                $iCssCache->cache($defer_inline_code, 'text/css');
852
+                                unset($tmp_code);
853 853
                             }
854 854
                         }
855 855
                     }
856 856
                     // inlined critical css set here, but injected when full CSS is injected
857 857
                     // to avoid CSS containing SVG with <title tag receiving the full CSS link.
858
-                    $inlined_ccss_block = '<style type="text/css" id="aoatfcss" media="all">' . $defer_inline_code . '</style>';
858
+                    $inlined_ccss_block = '<style type="text/css" id="aoatfcss" media="all">'.$defer_inline_code.'</style>';
859 859
                 }
860 860
             }
861 861
 
862
-            foreach ( $this->url as $media => $url ) {
863
-                $url = $this->url_replace_cdn( $url );
862
+            foreach ($this->url as $media => $url) {
863
+                $url = $this->url_replace_cdn($url);
864 864
 
865 865
                 // Add the stylesheet either deferred (import at bottom) or normal links in head.
866
-                if ( $this->defer ) {
866
+                if ($this->defer) {
867 867
                     $preloadOnLoad = autoptimizeConfig::get_ao_css_preload_onload();
868 868
 
869
-                    $preloadCssBlock .= '<link rel="preload" as="style" media="' . $media . '" href="' . $url . '" onload="' . $preloadOnLoad . '" />';
870
-                    $noScriptCssBlock .= '<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />';
869
+                    $preloadCssBlock .= '<link rel="preload" as="style" media="'.$media.'" href="'.$url.'" onload="'.$preloadOnLoad.'" />';
870
+                    $noScriptCssBlock .= '<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />';
871 871
                 } else {
872 872
                     // $this->inject_in_html('<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />', $replaceTag);
873
-                    if ( strlen( $this->csscode[$media] ) > $this->cssinlinesize ) {
874
-                        $this->inject_in_html( '<link type="text/css" media="' . $media . '" href="' . $url . '" rel="stylesheet" />', $replaceTag );
875
-                    } elseif ( strlen( $this->csscode[$media] ) > 0 ) {
876
-                        $this->inject_in_html( '<style type="text/css" media="' . $media . '">' . $this->csscode[$media] . '</style>', $replaceTag );
873
+                    if (strlen($this->csscode[$media]) > $this->cssinlinesize) {
874
+                        $this->inject_in_html('<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />', $replaceTag);
875
+                    } elseif (strlen($this->csscode[$media]) > 0) {
876
+                        $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$this->csscode[$media].'</style>', $replaceTag);
877 877
                     }
878 878
                 }
879 879
             }
880 880
 
881
-            if ( $this->defer ) {
881
+            if ($this->defer) {
882 882
                 $preload_polyfill = autoptimizeConfig::get_ao_css_preload_polyfill();
883 883
                 $noScriptCssBlock .= '</noscript>';
884 884
                 // Inject inline critical CSS, the preloaded full CSS and the noscript-CSS.
885
-                $this->inject_in_html( $inlined_ccss_block . $preloadCssBlock . $noScriptCssBlock, $replaceTag );
885
+                $this->inject_in_html($inlined_ccss_block.$preloadCssBlock.$noScriptCssBlock, $replaceTag);
886 886
 
887 887
                 // Adds preload polyfill at end of body tag.
888 888
                 $this->inject_in_html(
889
-                    apply_filters( 'autoptimize_css_preload_polyfill', $preload_polyfill ),
890
-                    apply_filters( 'autoptimize_css_preload_polyfill_injectat', array( '</body>', 'before' ) )
889
+                    apply_filters('autoptimize_css_preload_polyfill', $preload_polyfill),
890
+                    apply_filters('autoptimize_css_preload_polyfill_injectat', array('</body>', 'before'))
891 891
                 );
892 892
             }
893 893
         }
894 894
 
895 895
         // restore comments.
896
-        $this->content = $this->restore_comments( $this->content );
896
+        $this->content = $this->restore_comments($this->content);
897 897
 
898 898
         // restore IE hacks.
899
-        $this->content = $this->restore_iehacks( $this->content );
899
+        $this->content = $this->restore_iehacks($this->content);
900 900
 
901 901
         // restore (no)script.
902
-        $this->content = $this->restore_marked_content( 'SCRIPT', $this->content );
902
+        $this->content = $this->restore_marked_content('SCRIPT', $this->content);
903 903
 
904 904
         // Restore noptimize.
905
-        $this->content = $this->restore_noptimize( $this->content );
905
+        $this->content = $this->restore_noptimize($this->content);
906 906
 
907 907
         // Return the modified stylesheet.
908 908
         return $this->content;
909 909
     }
910 910
 
911
-    static function fixurls( $file, $code )
911
+    static function fixurls($file, $code)
912 912
     {
913 913
         // Switch all imports to the url() syntax.
914
-        $code = preg_replace( '#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code );
914
+        $code = preg_replace('#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code);
915 915
 
916
-        if ( preg_match_all( self::ASSETS_REGEX, $code, $matches ) ) {
917
-            $file = str_replace( WP_ROOT_DIR, '/', $file );
916
+        if (preg_match_all(self::ASSETS_REGEX, $code, $matches)) {
917
+            $file = str_replace(WP_ROOT_DIR, '/', $file);
918 918
             /**
919 919
              * rollback as per https://github.com/futtta/autoptimize/issues/94
920 920
              * $file = str_replace( AUTOPTIMIZE_WP_CONTENT_NAME, '', $file );
921 921
              */
922
-            $dir = dirname( $file ); // Like /themes/expound/css.
922
+            $dir = dirname($file); // Like /themes/expound/css.
923 923
 
924 924
             /**
925 925
              * $dir should not contain backslashes, since it's used to replace
926 926
              * urls, but it can contain them when running on Windows because
927 927
              * fixurls() is sometimes called with `ABSPATH . 'index.php'`
928 928
              */
929
-            $dir = str_replace( '\\', '/', $dir );
930
-            unset( $file ); // not used below at all.
929
+            $dir = str_replace('\\', '/', $dir);
930
+            unset($file); // not used below at all.
931 931
 
932 932
             $replace = array();
933
-            foreach ( $matches[1] as $k => $url ) {
933
+            foreach ($matches[1] as $k => $url) {
934 934
                 // Remove quotes.
935
-                $url    = trim( $url, " \t\n\r\0\x0B\"'" );
936
-                $noQurl = trim( $url, "\"'" );
937
-                if ( $url !== $noQurl ) {
935
+                $url    = trim($url, " \t\n\r\0\x0B\"'");
936
+                $noQurl = trim($url, "\"'");
937
+                if ($url !== $noQurl) {
938 938
                     $removedQuotes = true;
939 939
                 } else {
940 940
                     $removedQuotes = false;
941 941
                 }
942 942
 
943
-                if ( '' === $noQurl ) {
943
+                if ('' === $noQurl) {
944 944
                     continue;
945 945
                 }
946 946
 
947 947
                 $url = $noQurl;
948
-                if ( '/' === $url{0} || preg_match( '#^(https?://|ftp://|data:)#i', $url ) ) {
948
+                if ('/' === $url{0} || preg_match('#^(https?://|ftp://|data:)#i', $url)) {
949 949
                     // URL is protocol-relative, host-relative or something we don't touch.
950 950
                     continue;
951 951
                 } else {
@@ -954,49 +954,49 @@  discard block
 block discarded – undo
954 954
                      * rollback as per https://github.com/futtta/autoptimize/issues/94
955 955
                      * $newurl = preg_replace( '/https?:/', '', str_replace( ' ', '%20', AUTOPTIMIZE_WP_CONTENT_URL . str_replace( '//', '/', $dir . '/' . $url ) ) );
956 956
                      */
957
-                    $newurl = preg_replace( '/https?:/', '', str_replace( ' ', '%20', AUTOPTIMIZE_WP_ROOT_URL . str_replace( '//', '/', $dir . '/' . $url ) ) );
958
-                    $newurl = apply_filters( 'autoptimize_filter_css_fixurl_newurl', $newurl );
957
+                    $newurl = preg_replace('/https?:/', '', str_replace(' ', '%20', AUTOPTIMIZE_WP_ROOT_URL.str_replace('//', '/', $dir.'/'.$url)));
958
+                    $newurl = apply_filters('autoptimize_filter_css_fixurl_newurl', $newurl);
959 959
 
960 960
                     /**
961 961
                      * Hash the url + whatever was behind potentially for replacement
962 962
                      * We must do this, or different css classes referencing the same bg image (but
963 963
                      * different parts of it, say, in sprites and such) loose their stuff...
964 964
                      */
965
-                    $hash = md5( $url . $matches[2][$k] );
966
-                    $code = str_replace( $matches[0][$k], $hash, $code );
965
+                    $hash = md5($url.$matches[2][$k]);
966
+                    $code = str_replace($matches[0][$k], $hash, $code);
967 967
 
968
-                    if ( $removedQuotes ) {
969
-                        $replace[$hash] = "url('" . $newurl . "')" . $matches[2][$k];
968
+                    if ($removedQuotes) {
969
+                        $replace[$hash] = "url('".$newurl."')".$matches[2][$k];
970 970
                     } else {
971
-                        $replace[$hash] = 'url(' . $newurl . ')' . $matches[2][$k];
971
+                        $replace[$hash] = 'url('.$newurl.')'.$matches[2][$k];
972 972
                     }
973 973
                 }
974 974
             }
975 975
 
976
-            $code = self::replace_longest_matches_first( $code, $replace );
976
+            $code = self::replace_longest_matches_first($code, $replace);
977 977
         }
978 978
 
979 979
         return $code;
980 980
     }
981 981
 
982
-    private function ismovable( $tag )
982
+    private function ismovable($tag)
983 983
     {
984
-        if ( ! $this->aggregate ) {
984
+        if (!$this->aggregate) {
985 985
             return false;
986 986
         }
987 987
 
988
-        if ( ! empty( $this->whitelist ) ) {
989
-            foreach ( $this->whitelist as $match ) {
990
-                if ( false !== strpos( $tag, $match ) ) {
988
+        if (!empty($this->whitelist)) {
989
+            foreach ($this->whitelist as $match) {
990
+                if (false !== strpos($tag, $match)) {
991 991
                     return true;
992 992
                 }
993 993
             }
994 994
             // no match with whitelist.
995 995
             return false;
996 996
         } else {
997
-            if ( is_array( $this->dontmove ) && ! empty( $this->dontmove ) ) {
998
-                foreach ( $this->dontmove as $match ) {
999
-                    if ( false !== strpos( $tag, $match ) ) {
997
+            if (is_array($this->dontmove) && !empty($this->dontmove)) {
998
+                foreach ($this->dontmove as $match) {
999
+                    if (false !== strpos($tag, $match)) {
1000 1000
                         // Matched something.
1001 1001
                         return false;
1002 1002
                     }
@@ -1008,22 +1008,22 @@  discard block
 block discarded – undo
1008 1008
         }
1009 1009
     }
1010 1010
 
1011
-    private function can_inject_late( $cssPath, $css )
1011
+    private function can_inject_late($cssPath, $css)
1012 1012
     {
1013
-        $consider_minified_array = apply_filters( 'autoptimize_filter_css_consider_minified', false, $cssPath );
1014
-        if ( true !== $this->inject_min_late ) {
1013
+        $consider_minified_array = apply_filters('autoptimize_filter_css_consider_minified', false, $cssPath);
1014
+        if (true !== $this->inject_min_late) {
1015 1015
             // late-inject turned off.
1016 1016
             return false;
1017
-        } elseif ( ( false === strpos( $cssPath, 'min.css' ) ) && ( str_replace( $consider_minified_array, '', $cssPath ) === $cssPath ) ) {
1017
+        } elseif ((false === strpos($cssPath, 'min.css')) && (str_replace($consider_minified_array, '', $cssPath) === $cssPath)) {
1018 1018
             // file not minified based on filename & filter.
1019 1019
             return false;
1020
-        } elseif ( false !== strpos( $css, '@import' ) ) {
1020
+        } elseif (false !== strpos($css, '@import')) {
1021 1021
             // can't late-inject files with imports as those need to be aggregated.
1022 1022
             return false;
1023
-        } elseif ( ( false !== strpos( $css, '@font-face' ) ) && ( apply_filters( 'autoptimize_filter_css_fonts_cdn', false ) === true ) && ( ! empty( $this->cdn_url ) ) ) {
1023
+        } elseif ((false !== strpos($css, '@font-face')) && (apply_filters('autoptimize_filter_css_fonts_cdn', false) === true) && (!empty($this->cdn_url))) {
1024 1024
             // don't late-inject CSS with font-src's if fonts are set to be CDN'ed.
1025 1025
             return false;
1026
-        } elseif ( ( ( $this->datauris == true ) || ( ! empty( $this->cdn_url ) ) ) && preg_match( '#background[^;}]*url\(#Ui', $css ) ) {
1026
+        } elseif ((($this->datauris == true) || (!empty($this->cdn_url))) && preg_match('#background[^;}]*url\(#Ui', $css)) {
1027 1027
             // don't late-inject CSS with images if CDN is set OR if image inlining is on.
1028 1028
             return false;
1029 1029
         } else {
@@ -1041,32 +1041,32 @@  discard block
 block discarded – undo
1041 1041
      *
1042 1042
      * @return bool|string Url pointing to the minified css file or false.
1043 1043
      */
1044
-    public function minify_single( $filepath, $cache_miss = false )
1044
+    public function minify_single($filepath, $cache_miss = false)
1045 1045
     {
1046
-        $contents = $this->prepare_minify_single( $filepath );
1046
+        $contents = $this->prepare_minify_single($filepath);
1047 1047
 
1048
-        if ( empty( $contents ) ) {
1048
+        if (empty($contents)) {
1049 1049
             return false;
1050 1050
         }
1051 1051
 
1052 1052
         // Check cache.
1053
-        $hash  = 'single_' . md5( $contents );
1054
-        $cache = new autoptimizeCache( $hash, 'css' );
1053
+        $hash  = 'single_'.md5($contents);
1054
+        $cache = new autoptimizeCache($hash, 'css');
1055 1055
 
1056 1056
         // If not in cache already, minify...
1057
-        if ( ! $cache->check() || $cache_miss ) {
1057
+        if (!$cache->check() || $cache_miss) {
1058 1058
             // Fixurls...
1059
-            $contents = self::fixurls( $filepath, $contents );
1059
+            $contents = self::fixurls($filepath, $contents);
1060 1060
             // CDN-replace any referenced assets if needed...
1061
-            $contents = $this->replace_urls( $contents );
1061
+            $contents = $this->replace_urls($contents);
1062 1062
             // Now minify...
1063 1063
             $cssmin   = new autoptimizeCSSmin();
1064
-            $contents = trim( $cssmin->run( $contents ) );
1064
+            $contents = trim($cssmin->run($contents));
1065 1065
             // Store in cache.
1066
-            $cache->cache( $contents, 'text/css' );
1066
+            $cache->cache($contents, 'text/css');
1067 1067
         }
1068 1068
 
1069
-        $url = $this->build_minify_single_url( $cache );
1069
+        $url = $this->build_minify_single_url($cache);
1070 1070
 
1071 1071
         return $url;
1072 1072
     }
@@ -1086,18 +1086,18 @@  discard block
 block discarded – undo
1086 1086
         return $this->options;
1087 1087
     }
1088 1088
 
1089
-    public function replaceOptions( $options )
1089
+    public function replaceOptions($options)
1090 1090
     {
1091 1091
         $this->options = $options;
1092 1092
     }
1093 1093
 
1094
-    public function setOption( $name, $value )
1094
+    public function setOption($name, $value)
1095 1095
     {
1096 1096
         $this->options[$name] = $value;
1097 1097
         $this->$name = $value;
1098 1098
     }
1099 1099
 
1100
-    public function getOption( $name )
1100
+    public function getOption($name)
1101 1101
     {
1102 1102
         return $this->options[$name];
1103 1103
     }
Please login to merge, or discard this patch.
classes/autoptimizeExtra.php 1 patch
Spacing   +159 added lines, -159 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles autoptimizeExtra frontend features + admin options page
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -21,9 +21,9 @@  discard block
 block discarded – undo
21 21
      *
22 22
      * @param array $options Optional. Allows overriding options without having to specify them via admin options page.
23 23
      */
24
-    public function __construct( $options = array() )
24
+    public function __construct($options = array())
25 25
     {
26
-        if ( empty( $options ) ) {
26
+        if (empty($options)) {
27 27
             $options = self::fetch_options();
28 28
         }
29 29
 
@@ -32,9 +32,9 @@  discard block
 block discarded – undo
32 32
 
33 33
     public function run()
34 34
     {
35
-        if ( is_admin() ) {
36
-            add_action( 'admin_menu', array( $this, 'admin_menu' ) );
37
-            add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_extra_tab' ) );
35
+        if (is_admin()) {
36
+            add_action('admin_menu', array($this, 'admin_menu'));
37
+            add_filter('autoptimize_filter_settingsscreen_tabs', array($this, 'add_extra_tab'));
38 38
         } else {
39 39
             $this->run_on_frontend();
40 40
         }
@@ -42,8 +42,8 @@  discard block
 block discarded – undo
42 42
 
43 43
     public static function fetch_options()
44 44
     {
45
-        $value = get_option( 'autoptimize_extra_settings' );
46
-        if ( empty( $value ) ) {
45
+        $value = get_option('autoptimize_extra_settings');
46
+        if (empty($value)) {
47 47
             // Fallback to returning defaults when no stored option exists yet.
48 48
             $value = autoptimizeConfig::get_ao_extra_default_options();
49 49
         }
@@ -54,55 +54,55 @@  discard block
 block discarded – undo
54 54
     public function disable_emojis()
55 55
     {
56 56
         // Removing all actions related to emojis!
57
-        remove_action( 'admin_print_styles', 'print_emoji_styles' );
58
-        remove_action( 'wp_head', 'print_emoji_detection_script', 7 );
59
-        remove_action( 'admin_print_scripts', 'print_emoji_detection_script' );
60
-        remove_action( 'wp_print_styles', 'print_emoji_styles' );
61
-        remove_filter( 'wp_mail', 'wp_staticize_emoji_for_email' );
62
-        remove_filter( 'the_content_feed', 'wp_staticize_emoji' );
63
-        remove_filter( 'comment_text_rss', 'wp_staticize_emoji' );
57
+        remove_action('admin_print_styles', 'print_emoji_styles');
58
+        remove_action('wp_head', 'print_emoji_detection_script', 7);
59
+        remove_action('admin_print_scripts', 'print_emoji_detection_script');
60
+        remove_action('wp_print_styles', 'print_emoji_styles');
61
+        remove_filter('wp_mail', 'wp_staticize_emoji_for_email');
62
+        remove_filter('the_content_feed', 'wp_staticize_emoji');
63
+        remove_filter('comment_text_rss', 'wp_staticize_emoji');
64 64
 
65 65
         // Removes TinyMCE emojis.
66
-        add_filter( 'tiny_mce_plugins', array( $this, 'filter_disable_emojis_tinymce' ) );
66
+        add_filter('tiny_mce_plugins', array($this, 'filter_disable_emojis_tinymce'));
67 67
 
68 68
         // Removes emoji dns-preftech.
69
-        add_filter( 'wp_resource_hints', array( $this, 'filter_remove_emoji_dns_prefetch' ), 10, 2 );
69
+        add_filter('wp_resource_hints', array($this, 'filter_remove_emoji_dns_prefetch'), 10, 2);
70 70
     }
71 71
 
72
-    public function filter_disable_emojis_tinymce( $plugins )
72
+    public function filter_disable_emojis_tinymce($plugins)
73 73
     {
74
-        if ( is_array( $plugins ) ) {
75
-            return array_diff( $plugins, array( 'wpemoji' ) );
74
+        if (is_array($plugins)) {
75
+            return array_diff($plugins, array('wpemoji'));
76 76
         } else {
77 77
             return array();
78 78
         }
79 79
     }
80 80
 
81
-    public function filter_remove_qs( $src )
81
+    public function filter_remove_qs($src)
82 82
     {
83
-        if ( strpos( $src, '?ver=' ) ) {
84
-            $src = remove_query_arg( 'ver', $src );
83
+        if (strpos($src, '?ver=')) {
84
+            $src = remove_query_arg('ver', $src);
85 85
         }
86 86
 
87 87
         return $src;
88 88
     }
89 89
 
90
-    public function extra_async_js( $in )
90
+    public function extra_async_js($in)
91 91
     {
92 92
         $exclusions = array();
93
-        if ( ! empty( $in ) ) {
94
-            $exclusions = array_fill_keys( array_filter( array_map( 'trim', explode( ',', $in ) ) ), '' );
93
+        if (!empty($in)) {
94
+            $exclusions = array_fill_keys(array_filter(array_map('trim', explode(',', $in))), '');
95 95
         }
96 96
 
97 97
         $settings = $this->options['autoptimize_extra_text_field_3'];
98
-        $async    = array_fill_keys( array_filter( array_map( 'trim', explode( ',', $settings ) ) ), '' );
99
-        $attr     = apply_filters( 'autoptimize_filter_extra_async', 'async' );
100
-        foreach ( $async as $k => $v ) {
101
-            $async[ $k ] = $attr;
98
+        $async    = array_fill_keys(array_filter(array_map('trim', explode(',', $settings))), '');
99
+        $attr     = apply_filters('autoptimize_filter_extra_async', 'async');
100
+        foreach ($async as $k => $v) {
101
+            $async[$k] = $attr;
102 102
         }
103 103
 
104 104
         // Merge exclusions & asyncs in one array and return to AO API.
105
-        $merged = array_merge( $exclusions, $async );
105
+        $merged = array_merge($exclusions, $async);
106 106
 
107 107
         return $merged;
108 108
     }
@@ -112,56 +112,56 @@  discard block
 block discarded – undo
112 112
         $options = $this->options;
113 113
 
114 114
         // Disable emojis if specified.
115
-        if ( ! empty( $options['autoptimize_extra_checkbox_field_1'] ) ) {
115
+        if (!empty($options['autoptimize_extra_checkbox_field_1'])) {
116 116
             $this->disable_emojis();
117 117
         }
118 118
 
119 119
         // Remove version query parameters.
120
-        if ( ! empty( $options['autoptimize_extra_checkbox_field_0'] ) ) {
121
-            add_filter( 'script_loader_src', array( $this, 'filter_remove_qs' ), 15, 1 );
122
-            add_filter( 'style_loader_src', array( $this, 'filter_remove_qs' ), 15, 1 );
120
+        if (!empty($options['autoptimize_extra_checkbox_field_0'])) {
121
+            add_filter('script_loader_src', array($this, 'filter_remove_qs'), 15, 1);
122
+            add_filter('style_loader_src', array($this, 'filter_remove_qs'), 15, 1);
123 123
         }
124 124
 
125 125
         // Avoiding conflicts of interest when async-javascript plugin is active!
126
-        $async_js_plugin_active = autoptimizeUtils::is_plugin_active( 'async-javascript/async-javascript.php' );
127
-        if ( ! empty( $options['autoptimize_extra_text_field_3'] ) && ! $async_js_plugin_active ) {
128
-            add_filter( 'autoptimize_filter_js_exclude', array( $this, 'extra_async_js' ), 10, 1 );
126
+        $async_js_plugin_active = autoptimizeUtils::is_plugin_active('async-javascript/async-javascript.php');
127
+        if (!empty($options['autoptimize_extra_text_field_3']) && !$async_js_plugin_active) {
128
+            add_filter('autoptimize_filter_js_exclude', array($this, 'extra_async_js'), 10, 1);
129 129
         }
130 130
 
131 131
         // Optimize google fonts!
132
-        if ( ! empty( $options['autoptimize_extra_radio_field_4'] ) && ( '1' !== $options['autoptimize_extra_radio_field_4'] ) ) {
133
-            add_filter( 'wp_resource_hints', array( $this, 'filter_remove_gfonts_dnsprefetch' ), 10, 2 );
134
-            add_filter( 'autoptimize_html_after_minify', array( $this, 'filter_optimize_google_fonts' ), 10, 1 );
135
-            add_filter( 'autoptimize_extra_filter_tobepreconn', array( $this, 'filter_preconnect_google_fonts' ), 10, 1 );
132
+        if (!empty($options['autoptimize_extra_radio_field_4']) && ('1' !== $options['autoptimize_extra_radio_field_4'])) {
133
+            add_filter('wp_resource_hints', array($this, 'filter_remove_gfonts_dnsprefetch'), 10, 2);
134
+            add_filter('autoptimize_html_after_minify', array($this, 'filter_optimize_google_fonts'), 10, 1);
135
+            add_filter('autoptimize_extra_filter_tobepreconn', array($this, 'filter_preconnect_google_fonts'), 10, 1);
136 136
         }
137 137
 
138 138
         // Preconnect!
139
-        if ( ! empty( $options['autoptimize_extra_text_field_2'] ) || has_filter( 'autoptimize_extra_filter_tobepreconn' ) ) {
140
-            add_filter( 'wp_resource_hints', array( $this, 'filter_preconnect' ), 10, 2 );
139
+        if (!empty($options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn')) {
140
+            add_filter('wp_resource_hints', array($this, 'filter_preconnect'), 10, 2);
141 141
         }
142 142
     }
143 143
 
144
-    public function filter_remove_emoji_dns_prefetch( $urls, $relation_type )
144
+    public function filter_remove_emoji_dns_prefetch($urls, $relation_type)
145 145
     {
146
-        $emoji_svg_url = apply_filters( 'emoji_svg_url', 'https://s.w.org/images/core/emoji/' );
146
+        $emoji_svg_url = apply_filters('emoji_svg_url', 'https://s.w.org/images/core/emoji/');
147 147
 
148
-        return $this->filter_remove_dns_prefetch( $urls, $relation_type, $emoji_svg_url );
148
+        return $this->filter_remove_dns_prefetch($urls, $relation_type, $emoji_svg_url);
149 149
     }
150 150
 
151
-    public function filter_remove_gfonts_dnsprefetch( $urls, $relation_type )
151
+    public function filter_remove_gfonts_dnsprefetch($urls, $relation_type)
152 152
     {
153
-        return $this->filter_remove_dns_prefetch( $urls, $relation_type, 'fonts.googleapis.com' );
153
+        return $this->filter_remove_dns_prefetch($urls, $relation_type, 'fonts.googleapis.com');
154 154
     }
155 155
 
156
-    public function filter_remove_dns_prefetch( $urls, $relation_type, $url_to_remove )
156
+    public function filter_remove_dns_prefetch($urls, $relation_type, $url_to_remove)
157 157
     {
158 158
         $url_to_remove = (string) $url_to_remove;
159 159
 
160
-        if ( ! empty( $url_to_remove ) && 'dns-prefetch' === $relation_type ) {
160
+        if (!empty($url_to_remove) && 'dns-prefetch' === $relation_type) {
161 161
             $cnt = 0;
162
-            foreach ( $urls as $url ) {
163
-                if ( false !== strpos( $url, $url_to_remove ) ) {
164
-                    unset( $urls[ $cnt ] );
162
+            foreach ($urls as $url) {
163
+                if (false !== strpos($url, $url_to_remove)) {
164
+                    unset($urls[$cnt]);
165 165
                 }
166 166
                 $cnt++;
167 167
             }
@@ -170,131 +170,131 @@  discard block
 block discarded – undo
170 170
         return $urls;
171 171
     }
172 172
 
173
-    public function filter_optimize_google_fonts( $in )
173
+    public function filter_optimize_google_fonts($in)
174 174
     {
175 175
         // Extract fonts, partly based on wp rocket's extraction code.
176
-        $markup = preg_replace( '/<!--(.*)-->/Uis', '', $in );
177
-        preg_match_all( '#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $markup, $matches );
176
+        $markup = preg_replace('/<!--(.*)-->/Uis', '', $in);
177
+        preg_match_all('#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $markup, $matches);
178 178
 
179 179
         $fonts_collection = array();
180
-        if ( ! $matches[2] ) {
180
+        if (!$matches[2]) {
181 181
             return $in;
182 182
         }
183 183
 
184 184
         // Store them in $fonts array.
185 185
         $i = 0;
186
-        foreach ( $matches[2] as $font ) {
187
-            if ( ! preg_match( '/rel=["\']dns-prefetch["\']/', $matches[0][ $i ] ) ) {
186
+        foreach ($matches[2] as $font) {
187
+            if (!preg_match('/rel=["\']dns-prefetch["\']/', $matches[0][$i])) {
188 188
                 // Get fonts name.
189
-                $font = str_replace( array( '%7C', '%7c' ), '|', $font );
190
-                $font = explode( 'family=', $font );
191
-                $font = ( isset( $font[1] ) ) ? explode( '&', $font[1] ) : array();
189
+                $font = str_replace(array('%7C', '%7c'), '|', $font);
190
+                $font = explode('family=', $font);
191
+                $font = (isset($font[1])) ? explode('&', $font[1]) : array();
192 192
                 // Add font to $fonts[$i] but make sure not to pollute with an empty family!
193
-                $_thisfont = array_values( array_filter( explode( '|', reset( $font ) ) ) );
194
-                if ( ! empty( $_thisfont ) ) {
195
-                    $fonts_collection[ $i ]['fonts'] = $_thisfont;
193
+                $_thisfont = array_values(array_filter(explode('|', reset($font))));
194
+                if (!empty($_thisfont)) {
195
+                    $fonts_collection[$i]['fonts'] = $_thisfont;
196 196
                     // And add subset if any!
197
-                    $subset = ( is_array( $font ) ) ? end( $font ) : '';
198
-                    if ( false !== strpos( $subset, 'subset=' ) ) {
199
-                        $subset                            = str_replace( array( '%2C', '%2c' ), ',', $subset );
200
-                        $subset                            = explode( 'subset=', $subset );
201
-                        $fonts_collection[ $i ]['subsets'] = explode( ',', $subset[1] );
197
+                    $subset = (is_array($font)) ? end($font) : '';
198
+                    if (false !== strpos($subset, 'subset=')) {
199
+                        $subset                            = str_replace(array('%2C', '%2c'), ',', $subset);
200
+                        $subset                            = explode('subset=', $subset);
201
+                        $fonts_collection[$i]['subsets'] = explode(',', $subset[1]);
202 202
                     }
203 203
                 }
204 204
                 // And remove Google Fonts.
205
-                $in = str_replace( $matches[0][ $i ], '', $in );
205
+                $in = str_replace($matches[0][$i], '', $in);
206 206
             }
207 207
             $i++;
208 208
         }
209 209
 
210 210
         $options      = $this->options;
211 211
         $fonts_markup = '';
212
-        if ( '2' === $options['autoptimize_extra_radio_field_4'] ) {
212
+        if ('2' === $options['autoptimize_extra_radio_field_4']) {
213 213
             // Remove Google Fonts.
214
-            unset( $fonts_collection );
214
+            unset($fonts_collection);
215 215
             return $in;
216
-        } elseif ( '3' === $options['autoptimize_extra_radio_field_4'] || '5' === $options['autoptimize_extra_radio_field_4'] ) {
216
+        } elseif ('3' === $options['autoptimize_extra_radio_field_4'] || '5' === $options['autoptimize_extra_radio_field_4']) {
217 217
             // Aggregate & link!
218 218
             $fonts_string  = '';
219 219
             $subset_string = '';
220
-            foreach ( $fonts_collection as $font ) {
221
-                $fonts_string .= '|' . trim( implode( '|', $font['fonts'] ), '|' );
222
-                if ( ! empty( $font['subsets'] ) ) {
223
-                    $subset_string .= ',' . trim( implode( ',', $font['subsets'] ), ',' );
220
+            foreach ($fonts_collection as $font) {
221
+                $fonts_string .= '|'.trim(implode('|', $font['fonts']), '|');
222
+                if (!empty($font['subsets'])) {
223
+                    $subset_string .= ','.trim(implode(',', $font['subsets']), ',');
224 224
                 }
225 225
             }
226 226
 
227
-            if ( ! empty( $subset_string ) ) {
228
-                $subset_string = str_replace( ',', '%2C', ltrim( $subset_string, ',' ) );
229
-                $fonts_string  = $fonts_string . '&#038;subset=' . $subset_string;
227
+            if (!empty($subset_string)) {
228
+                $subset_string = str_replace(',', '%2C', ltrim($subset_string, ','));
229
+                $fonts_string  = $fonts_string.'&#038;subset='.$subset_string;
230 230
             }
231 231
 
232
-            $fonts_string = apply_filters( 'autoptimize_filter_extra_gfont_fontstring', str_replace( '|', '%7C', ltrim( $fonts_string, '|' ) ) );
232
+            $fonts_string = apply_filters('autoptimize_filter_extra_gfont_fontstring', str_replace('|', '%7C', ltrim($fonts_string, '|')));
233 233
 
234
-            if ( ! empty( $fonts_string ) ) {
235
-                if ( '5' === $options['autoptimize_extra_radio_field_4'] ) {
236
-                    $rel_string = 'rel="preload" as="style" onload="' . autoptimizeConfig::get_ao_css_preload_onload() . '"';
234
+            if (!empty($fonts_string)) {
235
+                if ('5' === $options['autoptimize_extra_radio_field_4']) {
236
+                    $rel_string = 'rel="preload" as="style" onload="'.autoptimizeConfig::get_ao_css_preload_onload().'"';
237 237
                 } else {
238 238
                     $rel_string = 'rel="stylesheet"';
239 239
                 }
240
-                $fonts_markup = '<link ' . $rel_string . ' id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family=' . $fonts_string . '" />';
240
+                $fonts_markup = '<link '.$rel_string.' id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family='.$fonts_string.'" />';
241 241
             }
242
-        } elseif ( '4' === $options['autoptimize_extra_radio_field_4'] ) {
242
+        } elseif ('4' === $options['autoptimize_extra_radio_field_4']) {
243 243
             // Aggregate & load async (webfont.js impl.)!
244 244
             $fonts_array = array();
245
-            foreach ( $fonts_collection as $_fonts ) {
246
-                if ( ! empty( $_fonts['subsets'] ) ) {
247
-                    $_subset = implode( ',', $_fonts['subsets'] );
248
-                    foreach ( $_fonts['fonts'] as $key => $_one_font ) {
249
-                        $_one_font               = $_one_font . ':' . $_subset;
250
-                        $_fonts['fonts'][ $key ] = $_one_font;
245
+            foreach ($fonts_collection as $_fonts) {
246
+                if (!empty($_fonts['subsets'])) {
247
+                    $_subset = implode(',', $_fonts['subsets']);
248
+                    foreach ($_fonts['fonts'] as $key => $_one_font) {
249
+                        $_one_font               = $_one_font.':'.$_subset;
250
+                        $_fonts['fonts'][$key] = $_one_font;
251 251
                     }
252 252
                 }
253
-                $fonts_array = array_merge( $fonts_array, $_fonts['fonts'] );
253
+                $fonts_array = array_merge($fonts_array, $_fonts['fonts']);
254 254
             }
255 255
 
256
-            $fonts_array          = array_map( 'urldecode', $fonts_array );
257
-            $fonts_markup         = '<script data-cfasync="false" id="ao_optimized_gfonts_config" type="text/javascript">WebFontConfig={google:{families:' . wp_json_encode( $fonts_array ) . ' },classes:false, events:false, timeout:1500};</script>';
256
+            $fonts_array          = array_map('urldecode', $fonts_array);
257
+            $fonts_markup         = '<script data-cfasync="false" id="ao_optimized_gfonts_config" type="text/javascript">WebFontConfig={google:{families:'.wp_json_encode($fonts_array).' },classes:false, events:false, timeout:1500};</script>';
258 258
             $fonts_library_markup = '<script data-cfasync="false" id="ao_optimized_gfonts_webfontloader" type="text/javascript">(function() {var wf = document.createElement(\'script\');wf.src=\'https://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js\';wf.type=\'text/javascript\';wf.async=\'true\';var s=document.getElementsByTagName(\'script\')[0];s.parentNode.insertBefore(wf, s);})();</script>';
259
-            $in                   = substr_replace( $in, $fonts_library_markup . '</head>', strpos( $in, '</head>' ), strlen( '</head>' ) );
259
+            $in                   = substr_replace($in, $fonts_library_markup.'</head>', strpos($in, '</head>'), strlen('</head>'));
260 260
         }
261 261
 
262 262
         // Replace back in markup.
263
-        $inject_point = apply_filters( 'autoptimize_filter_extra_gfont_injectpoint', '<link' );
264
-        $out          = substr_replace( $in, $fonts_markup . $inject_point, strpos( $in, $inject_point ), strlen( $inject_point ) );
265
-        unset( $fonts_collection );
263
+        $inject_point = apply_filters('autoptimize_filter_extra_gfont_injectpoint', '<link');
264
+        $out          = substr_replace($in, $fonts_markup.$inject_point, strpos($in, $inject_point), strlen($inject_point));
265
+        unset($fonts_collection);
266 266
 
267 267
         // and insert preload polyfill if "link preload" and if the polyfill isn't there yet (courtesy of inline&defer).
268 268
         $preload_polyfill = autoptimizeConfig::get_ao_css_preload_polyfill();
269
-        if ( '5' === $options['autoptimize_extra_radio_field_4'] && strpos( $out, $preload_polyfill ) === false ) {
270
-            $out = str_replace( '</body>', $preload_polyfill . '</body>', $out );
269
+        if ('5' === $options['autoptimize_extra_radio_field_4'] && strpos($out, $preload_polyfill) === false) {
270
+            $out = str_replace('</body>', $preload_polyfill.'</body>', $out);
271 271
         }
272 272
         return $out;
273 273
     }
274 274
 
275
-    public function filter_preconnect( $hints, $relation_type )
275
+    public function filter_preconnect($hints, $relation_type)
276 276
     {
277 277
         $options = $this->options;
278 278
 
279 279
         // Get settings and store in array.
280
-        $preconns = array_filter( array_map( 'trim', explode( ',', $options['autoptimize_extra_text_field_2'] ) ) );
281
-        $preconns = apply_filters( 'autoptimize_extra_filter_tobepreconn', $preconns );
280
+        $preconns = array_filter(array_map('trim', explode(',', $options['autoptimize_extra_text_field_2'])));
281
+        $preconns = apply_filters('autoptimize_extra_filter_tobepreconn', $preconns);
282 282
 
283 283
         // Walk array, extract domain and add to new array with crossorigin attribute.
284
-        foreach ( $preconns as $preconn ) {
285
-            $parsed = parse_url( $preconn );
286
-            if ( is_array( $parsed ) && empty( $parsed['scheme'] ) ) {
287
-                $domain = '//' . $parsed['host'];
288
-            } elseif ( is_array( $parsed ) ) {
289
-                $domain = $parsed['scheme'] . '://' . $parsed['host'];
284
+        foreach ($preconns as $preconn) {
285
+            $parsed = parse_url($preconn);
286
+            if (is_array($parsed) && empty($parsed['scheme'])) {
287
+                $domain = '//'.$parsed['host'];
288
+            } elseif (is_array($parsed)) {
289
+                $domain = $parsed['scheme'].'://'.$parsed['host'];
290 290
             }
291 291
 
292
-            if ( ! empty( $domain ) ) {
293
-                $hint = array( 'href' => $domain );
292
+            if (!empty($domain)) {
293
+                $hint = array('href' => $domain);
294 294
                 // Fonts don't get preconnected unless crossorigin flag is set, non-fonts don't get preconnected if origin flag is set
295 295
                 // so hardcode fonts.gstatic.com to come with crossorigin and have filter to add other domains if needed.
296
-                $crossorigins = apply_filters( 'autoptimize_extra_filter_preconn_crossorigin', array( 'https://fonts.gstatic.com' ) );
297
-                if ( in_array( $domain, $crossorigins ) ) {
296
+                $crossorigins = apply_filters('autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com'));
297
+                if (in_array($domain, $crossorigins)) {
298 298
                     $hint['crossorigin'] = 'anonymous';
299 299
                 }
300 300
                 $new_hints[] = $hint;
@@ -302,21 +302,21 @@  discard block
 block discarded – undo
302 302
         }
303 303
 
304 304
         // Merge in WP's preconnect hints.
305
-        if ( 'preconnect' === $relation_type && ! empty( $new_hints ) ) {
306
-            $hints = array_merge( $hints, $new_hints );
305
+        if ('preconnect' === $relation_type && !empty($new_hints)) {
306
+            $hints = array_merge($hints, $new_hints);
307 307
         }
308 308
 
309 309
         return $hints;
310 310
     }
311 311
 
312
-    public function filter_preconnect_google_fonts( $in )
312
+    public function filter_preconnect_google_fonts($in)
313 313
     {
314
-        if ( '2' !== $this->options['autoptimize_extra_radio_field_4'] ) {
314
+        if ('2' !== $this->options['autoptimize_extra_radio_field_4']) {
315 315
             // Preconnect to fonts.gstatic.com unless we remove gfonts.
316 316
             $in[] = 'https://fonts.gstatic.com';
317 317
         }
318 318
 
319
-        if ( '4' === $this->options['autoptimize_extra_radio_field_4'] ) {
319
+        if ('4' === $this->options['autoptimize_extra_radio_field_4']) {
320 320
             // Preconnect even more hosts for webfont.js!
321 321
             $in[] = 'https://ajax.googleapis.com';
322 322
             $in[] = 'https://fonts.googleapis.com';
@@ -333,14 +333,14 @@  discard block
 block discarded – undo
333 333
             'autoptimize_extra',
334 334
             'manage_options',
335 335
             'autoptimize_extra',
336
-            array( $this, 'options_page' )
336
+            array($this, 'options_page')
337 337
         );
338
-        register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
338
+        register_setting('autoptimize_extra_settings', 'autoptimize_extra_settings');
339 339
     }
340 340
 
341
-    public function add_extra_tab( $in )
341
+    public function add_extra_tab($in)
342 342
     {
343
-        $in = array_merge( $in, array( 'autoptimize_extra' => __( 'Extra', 'autoptimize' ) ) );
343
+        $in = array_merge($in, array('autoptimize_extra' => __('Extra', 'autoptimize')));
344 344
 
345 345
         return $in;
346 346
     }
@@ -360,87 +360,87 @@  discard block
 block discarded – undo
360 360
         #autoptimize_extra_descr{font-size: 120%;}
361 361
     </style>
362 362
     <div class="wrap">
363
-    <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
363
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
364 364
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
365
-        <?php if ( 'on' !== get_option( 'autoptimize_js' ) && 'on' !== get_option( 'autoptimize_css' ) && 'on' !== get_option( 'autoptimize_html' ) && ! autoptimizeImages::imgopt_active() ) { ?>
365
+        <?php if ('on' !== get_option('autoptimize_js') && 'on' !== get_option('autoptimize_css') && 'on' !== get_option('autoptimize_html') && !autoptimizeImages::imgopt_active()) { ?>
366 366
             <div class="notice-warning notice"><p>
367
-            <?php _e( 'Most of below Extra optimizations require at least one of HTML, JS, CSS or Image autoptimizations being active.', 'autoptimize' ); ?>
367
+            <?php _e('Most of below Extra optimizations require at least one of HTML, JS, CSS or Image autoptimizations being active.', 'autoptimize'); ?>
368 368
             </p></div>
369 369
         <?php } ?>
370 370
 
371 371
     <form id='ao_settings_form' action='options.php' method='post'>
372
-        <?php settings_fields( 'autoptimize_extra_settings' ); ?>
373
-        <h2><?php _e( 'Extra Auto-Optimizations', 'autoptimize' ); ?></h2>
374
-        <span id='autoptimize_extra_descr'><?php _e( 'The following settings can improve your site\'s performance even more.', 'autoptimize' ); ?></span>
372
+        <?php settings_fields('autoptimize_extra_settings'); ?>
373
+        <h2><?php _e('Extra Auto-Optimizations', 'autoptimize'); ?></h2>
374
+        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.', 'autoptimize'); ?></span>
375 375
         <table class="form-table">
376 376
             <tr>
377
-                <th scope="row"><?php _e( 'Google Fonts', 'autoptimize' ); ?></th>
377
+                <th scope="row"><?php _e('Google Fonts', 'autoptimize'); ?></th>
378 378
                 <td>
379
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if ( ! in_array( $gfonts, array( 2, 3, 4, 5 ) ) ) { echo 'checked'; } ?> ><?php _e( 'Leave as is', 'autoptimize' ); ?><br/>
380
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked( 2, $gfonts, true ); ?> ><?php _e( 'Remove Google Fonts', 'autoptimize' ); ?><br/>
381
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked( 3, $gfonts, true ); ?> ><?php _e( 'Combine and link in head (fonts load fast but are render-blocking)', 'autoptimize' ); ?><br/>
382
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="5" <?php checked( 5, $gfonts, true ); ?> ><?php _e( 'Combine and preload in head (fonts load late, but are not render-blocking)', 'autoptimize' ); ?><br/>
383
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked( 4, $gfonts, true ); ?> ><?php _e( 'Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize' ); ?><br/>
379
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($gfonts, array(2, 3, 4, 5))) { echo 'checked'; } ?> ><?php _e('Leave as is', 'autoptimize'); ?><br/>
380
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $gfonts, true); ?> ><?php _e('Remove Google Fonts', 'autoptimize'); ?><br/>
381
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $gfonts, true); ?> ><?php _e('Combine and link in head (fonts load fast but are render-blocking)', 'autoptimize'); ?><br/>
382
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="5" <?php checked(5, $gfonts, true); ?> ><?php _e('Combine and preload in head (fonts load late, but are not render-blocking)', 'autoptimize'); ?><br/>
383
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $gfonts, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize'); ?><br/>
384 384
                 </td>
385 385
             </tr>
386 386
             <tr>
387
-                <th scope="row"><?php _e( 'Remove emojis', 'autoptimize' ); ?></th>
387
+                <th scope="row"><?php _e('Remove emojis', 'autoptimize'); ?></th>
388 388
                 <td>
389
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if ( ! empty( $options['autoptimize_extra_checkbox_field_1'] ) && '1' === $options['autoptimize_extra_checkbox_field_1'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Removes WordPress\' core emojis\' inline CSS, inline JavaScript, and an otherwise un-autoptimized JavaScript file.', 'autoptimize' ); ?></label>
389
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($options['autoptimize_extra_checkbox_field_1']) && '1' === $options['autoptimize_extra_checkbox_field_1']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Removes WordPress\' core emojis\' inline CSS, inline JavaScript, and an otherwise un-autoptimized JavaScript file.', 'autoptimize'); ?></label>
390 390
                 </td>
391 391
             </tr>
392 392
             <tr>
393
-                <th scope="row"><?php _e( 'Remove query strings from static resources', 'autoptimize' ); ?></th>
393
+                <th scope="row"><?php _e('Remove query strings from static resources', 'autoptimize'); ?></th>
394 394
                 <td>
395
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if ( ! empty( $options['autoptimize_extra_checkbox_field_0'] ) && '1' === $options['autoptimize_extra_checkbox_field_0'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Removing query strings (or more specifically the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize' ); ?></label>
395
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty($options['autoptimize_extra_checkbox_field_0']) && '1' === $options['autoptimize_extra_checkbox_field_0']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Removing query strings (or more specifically the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize'); ?></label>
396 396
                 </td>
397 397
             </tr>
398 398
             <tr>
399
-                <th scope="row"><?php _e( 'Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize' ); ?></th>
399
+                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize'); ?></th>
400 400
                 <td>
401
-                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php if ( array_key_exists( 'autoptimize_extra_text_field_2', $options ) ) { echo esc_attr( $options['autoptimize_extra_text_field_2'] ); } ?>'><br /><?php _e( 'Add 3rd party domains you want the browser to <a href="https://www.keycdn.com/support/preconnect/#primary" target="_blank">preconnect</a> to, separated by comma\'s. Make sure to include the correct protocol (HTTP or HTTPS).', 'autoptimize' ); ?></label>
401
+                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php if (array_key_exists('autoptimize_extra_text_field_2', $options)) { echo esc_attr($options['autoptimize_extra_text_field_2']); } ?>'><br /><?php _e('Add 3rd party domains you want the browser to <a href="https://www.keycdn.com/support/preconnect/#primary" target="_blank">preconnect</a> to, separated by comma\'s. Make sure to include the correct protocol (HTTP or HTTPS).', 'autoptimize'); ?></label>
402 402
                 </td>
403 403
             </tr>
404 404
             <tr>
405
-                <th scope="row"><?php _e( 'Async Javascript-files <em>(advanced users)</em>', 'autoptimize' ); ?></th>
405
+                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>', 'autoptimize'); ?></th>
406 406
                 <td>
407 407
                     <?php
408
-                    if ( autoptimizeUtils::is_plugin_active( 'async-javascript/async-javascript.php' ) ) {
408
+                    if (autoptimizeUtils::is_plugin_active('async-javascript/async-javascript.php')) {
409 409
                         // translators: link points Async Javascript settings page.
410
-                        printf( __( 'You have "Async JavaScript" installed, %1$sconfiguration of async javascript is best done there%2$s.', 'autoptimize' ), '<a href="' . 'options-general.php?page=async-javascript' . '">', '</a>' );
410
+                        printf(__('You have "Async JavaScript" installed, %1$sconfiguration of async javascript is best done there%2$s.', 'autoptimize'), '<a href="'.'options-general.php?page=async-javascript'.'">', '</a>');
411 411
                     } else {
412 412
                     ?>
413
-                        <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php if ( array_key_exists( 'autoptimize_extra_text_field_3', $options ) ) { echo esc_attr( $options['autoptimize_extra_text_field_3'] ); } ?>'>
413
+                        <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php if (array_key_exists('autoptimize_extra_text_field_3', $options)) { echo esc_attr($options['autoptimize_extra_text_field_3']); } ?>'>
414 414
                         <br />
415 415
                         <?php
416
-                            _e( 'Comma-separated list of local or 3rd party JS-files that should loaded with the <code>async</code> flag. JS-files from your own site will be automatically excluded if added here. ', 'autoptimize' );
416
+                            _e('Comma-separated list of local or 3rd party JS-files that should loaded with the <code>async</code> flag. JS-files from your own site will be automatically excluded if added here. ', 'autoptimize');
417 417
                             // translators: %s will be replaced by a link to the "async javascript" plugin.
418
-                            echo sprintf( __( 'Configuration of async javascript is easier and more flexible using the %s plugin.', 'autoptimize' ), '"<a href="https://wordpress.org/plugins/async-javascript" target="_blank">Async Javascript</a>"' );
419
-                            $asj_install_url = network_admin_url() . 'plugin-install.php?s=async+javascript&tab=search&type=term';
420
-                            echo sprintf( ' <a href="' . $asj_install_url . '">%s</a>', __( 'Click here to install and activate it.', 'autoptimize' ) );
418
+                            echo sprintf(__('Configuration of async javascript is easier and more flexible using the %s plugin.', 'autoptimize'), '"<a href="https://wordpress.org/plugins/async-javascript" target="_blank">Async Javascript</a>"');
419
+                            $asj_install_url = network_admin_url().'plugin-install.php?s=async+javascript&tab=search&type=term';
420
+                            echo sprintf(' <a href="'.$asj_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
421 421
                     }
422 422
                     ?>
423 423
                 </td>
424 424
             </tr>
425 425
             <tr>
426
-                <th scope="row"><?php _e( 'Optimize YouTube videos', 'autoptimize' ); ?></th>
426
+                <th scope="row"><?php _e('Optimize YouTube videos', 'autoptimize'); ?></th>
427 427
                 <td>
428 428
                     <?php
429
-                    if ( autoptimizeUtils::is_plugin_active( 'wp-youtube-lyte/wp-youtube-lyte.php' ) ) {
430
-                        _e( 'Great, you have WP YouTube Lyte installed.', 'autoptimize' );
429
+                    if (autoptimizeUtils::is_plugin_active('wp-youtube-lyte/wp-youtube-lyte.php')) {
430
+                        _e('Great, you have WP YouTube Lyte installed.', 'autoptimize');
431 431
                         $lyte_config_url = 'options-general.php?page=lyte_settings_page';
432
-                        echo sprintf( ' <a href="' . $lyte_config_url . '">%s</a>', __( 'Click here to configure it.', 'autoptimize' ) );
432
+                        echo sprintf(' <a href="'.$lyte_config_url.'">%s</a>', __('Click here to configure it.', 'autoptimize'));
433 433
                     } else {
434 434
                         // translators: %s will be replaced by a link to "wp youtube lyte" plugin.
435
-                        echo sprintf( __( '%s allows you to “lazy load” your videos, by inserting responsive “Lite YouTube Embeds". ', 'autoptimize' ), '<a href="https://wordpress.org/plugins/wp-youtube-lyte" target="_blank">WP YouTube Lyte</a>' );
436
-                        $lyte_install_url = network_admin_url() . 'plugin-install.php?s=lyte&tab=search&type=term';
437
-                        echo sprintf( ' <a href="' . $lyte_install_url . '">%s</a>', __( 'Click here to install and activate it.', 'autoptimize' ) );
435
+                        echo sprintf(__('%s allows you to “lazy load” your videos, by inserting responsive “Lite YouTube Embeds". ', 'autoptimize'), '<a href="https://wordpress.org/plugins/wp-youtube-lyte" target="_blank">WP YouTube Lyte</a>');
436
+                        $lyte_install_url = network_admin_url().'plugin-install.php?s=lyte&tab=search&type=term';
437
+                        echo sprintf(' <a href="'.$lyte_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
438 438
                     }
439 439
                     ?>
440 440
                 </td>
441 441
             </tr>
442 442
         </table>
443
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e( 'Save Changes', 'autoptimize' ); ?>" /></p>
443
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize'); ?>" /></p>
444 444
     </form>
445 445
         <?php
446 446
     }
Please login to merge, or discard this patch.
autoptimize.php 1 patch
Spacing   +33 added lines, -33 removed lines patch added patch discarded remove patch
@@ -16,66 +16,66 @@  discard block
 block discarded – undo
16 16
  */
17 17
 
18 18
 
19
-if ( ! defined( 'ABSPATH' ) ) {
19
+if (!defined('ABSPATH')) {
20 20
     exit;
21 21
 }
22 22
 
23
-define( 'AUTOPTIMIZE_PLUGIN_VERSION', '2.5.1' );
23
+define('AUTOPTIMIZE_PLUGIN_VERSION', '2.5.1');
24 24
 
25 25
 // plugin_dir_path() returns the trailing slash!
26
-define( 'AUTOPTIMIZE_PLUGIN_DIR', plugin_dir_path( __FILE__ ) );
27
-define( 'AUTOPTIMIZE_PLUGIN_FILE', __FILE__ );
26
+define('AUTOPTIMIZE_PLUGIN_DIR', plugin_dir_path(__FILE__));
27
+define('AUTOPTIMIZE_PLUGIN_FILE', __FILE__);
28 28
 
29 29
 // Bail early if attempting to run on non-supported php versions.
30
-if ( version_compare( PHP_VERSION, '5.3', '<' ) ) {
30
+if (version_compare(PHP_VERSION, '5.3', '<')) {
31 31
     function autoptimize_incompatible_admin_notice() {
32
-        echo '<div class="error"><p>' . __( 'Autoptimize requires PHP 5.3 (or higher) to function properly. Please upgrade PHP. The Plugin has been auto-deactivated.', 'autoptimize' ) . '</p></div>';
33
-        if ( isset( $_GET['activate'] ) ) {
34
-            unset( $_GET['activate'] );
32
+        echo '<div class="error"><p>'.__('Autoptimize requires PHP 5.3 (or higher) to function properly. Please upgrade PHP. The Plugin has been auto-deactivated.', 'autoptimize').'</p></div>';
33
+        if (isset($_GET['activate'])) {
34
+            unset($_GET['activate']);
35 35
         }
36 36
     }
37 37
     function autoptimize_deactivate_self() {
38
-        deactivate_plugins( plugin_basename( AUTOPTIMIZE_PLUGIN_FILE ) );
38
+        deactivate_plugins(plugin_basename(AUTOPTIMIZE_PLUGIN_FILE));
39 39
     }
40
-    add_action( 'admin_notices', 'autoptimize_incompatible_admin_notice' );
41
-    add_action( 'admin_init', 'autoptimize_deactivate_self' );
40
+    add_action('admin_notices', 'autoptimize_incompatible_admin_notice');
41
+    add_action('admin_init', 'autoptimize_deactivate_self');
42 42
     return;
43 43
 }
44 44
 
45
-function autoptimize_autoload( $class_name ) {
46
-    if ( in_array( $class_name, array( 'Minify_HTML', 'JSMin' ) ) ) {
47
-        $file     = strtolower( $class_name );
48
-        $file     = str_replace( '_', '-', $file );
49
-        $path     = dirname( __FILE__ ) . '/classes/external/php/';
50
-        $filepath = $path . $file . '.php';
51
-    } elseif ( false !== strpos( $class_name, 'Autoptimize\\tubalmartin\\CssMin' ) ) {
52
-        $file     = str_replace( 'Autoptimize\\tubalmartin\\CssMin\\', '', $class_name );
53
-        $path     = dirname( __FILE__ ) . '/classes/external/php/yui-php-cssmin-bundled/';
54
-        $filepath = $path . $file . '.php';
55
-    } elseif ( 'autoptimize' === substr( $class_name, 0, 11 ) ) {
45
+function autoptimize_autoload($class_name) {
46
+    if (in_array($class_name, array('Minify_HTML', 'JSMin'))) {
47
+        $file     = strtolower($class_name);
48
+        $file     = str_replace('_', '-', $file);
49
+        $path     = dirname(__FILE__).'/classes/external/php/';
50
+        $filepath = $path.$file.'.php';
51
+    } elseif (false !== strpos($class_name, 'Autoptimize\\tubalmartin\\CssMin')) {
52
+        $file     = str_replace('Autoptimize\\tubalmartin\\CssMin\\', '', $class_name);
53
+        $path     = dirname(__FILE__).'/classes/external/php/yui-php-cssmin-bundled/';
54
+        $filepath = $path.$file.'.php';
55
+    } elseif ('autoptimize' === substr($class_name, 0, 11)) {
56 56
         // One of our "old" classes.
57 57
         $file     = $class_name;
58
-        $path     = dirname( __FILE__ ) . '/classes/';
59
-        $filepath = $path . $file . '.php';
60
-    } elseif ( 'PAnD' === $class_name ) {
58
+        $path     = dirname(__FILE__).'/classes/';
59
+        $filepath = $path.$file.'.php';
60
+    } elseif ('PAnD' === $class_name) {
61 61
         $file     = 'persist-admin-notices-dismissal';
62
-        $path     = dirname( __FILE__ ) . '/classes/external/php/persist-admin-notices-dismissal/';
63
-        $filepath = $path . $file . '.php';
62
+        $path     = dirname(__FILE__).'/classes/external/php/persist-admin-notices-dismissal/';
63
+        $filepath = $path.$file.'.php';
64 64
     }
65 65
 
66 66
     // If we didn't match one of our rules, bail!
67
-    if ( ! isset( $filepath ) ) {
67
+    if (!isset($filepath)) {
68 68
         return;
69 69
     }
70 70
 
71 71
     require $filepath;
72 72
 }
73 73
 
74
-spl_autoload_register( 'autoptimize_autoload' );
74
+spl_autoload_register('autoptimize_autoload');
75 75
 
76 76
 // Load WP CLI command(s) on demand.
77
-if ( defined( 'WP_CLI' ) && WP_CLI ) {
78
-    require AUTOPTIMIZE_PLUGIN_DIR . 'classes/autoptimizeCLI.php';
77
+if (defined('WP_CLI') && WP_CLI) {
78
+    require AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeCLI.php';
79 79
 }
80 80
 
81 81
 /**
@@ -86,8 +86,8 @@  discard block
 block discarded – undo
86 86
 function autoptimize() {
87 87
     static $plugin = null;
88 88
 
89
-    if ( null === $plugin ) {
90
-        $plugin = new autoptimizeMain( AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE );
89
+    if (null === $plugin) {
90
+        $plugin = new autoptimizeMain(AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE);
91 91
     }
92 92
 
93 93
     return $plugin;
Please login to merge, or discard this patch.
classes/autoptimizeImages.php 1 patch
Spacing   +310 added lines, -310 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,13 +194,13 @@  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
-            $imgopt_host = apply_filters( 'autoptimize_filter_imgopt_host', $imgopt_host );
203
+            $imgopt_host = apply_filters('autoptimize_filter_imgopt_host', $imgopt_host);
204 204
         }
205 205
 
206 206
         return $imgopt_host;
@@ -215,7 +215,7 @@  discard block
 block discarded – undo
215 215
 
216 216
     public static function get_service_url_suffix()
217 217
     {
218
-        $suffix = '/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
218
+        $suffix = '/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
219 219
 
220 220
         return $suffix;
221 221
     }
@@ -224,12 +224,12 @@  discard block
 block discarded – undo
224 224
     {
225 225
         static $quality = null;
226 226
 
227
-        if ( null === $quality ) {
227
+        if (null === $quality) {
228 228
             $q_array = $this->get_img_quality_array();
229 229
             $setting = $this->get_img_quality_setting();
230 230
             $quality = apply_filters(
231 231
                 'autoptimize_filter_imgopt_quality',
232
-                'q_' . $q_array[ $setting ]
232
+                'q_'.$q_array[$setting]
233 233
             );
234 234
         }
235 235
 
@@ -240,7 +240,7 @@  discard block
 block discarded – undo
240 240
     {
241 241
         static $map = null;
242 242
 
243
-        if ( null === $map ) {
243
+        if (null === $map) {
244 244
             $map = array(
245 245
                 '1' => 'lossy',
246 246
                 '2' => 'glossy',
@@ -259,12 +259,12 @@  discard block
 block discarded – undo
259 259
     {
260 260
         static $q = null;
261 261
 
262
-        if ( null === $q ) {
263
-            if ( is_array( $this->options ) && array_key_exists( 'autoptimize_imgopt_select_field_2', $this->options ) ) {
262
+        if (null === $q) {
263
+            if (is_array($this->options) && array_key_exists('autoptimize_imgopt_select_field_2', $this->options)) {
264 264
                 $setting = $this->options['autoptimize_imgopt_select_field_2'];
265 265
             }
266 266
 
267
-            if ( ! isset( $setting ) || empty( $setting ) || ( '1' !== $setting && '3' !== $setting ) ) {
267
+            if (!isset($setting) || empty($setting) || ('1' !== $setting && '3' !== $setting)) {
268 268
                 // default image opt. value is 2 ("glossy").
269 269
                 $q = '2';
270 270
             } else {
@@ -275,10 +275,10 @@  discard block
 block discarded – undo
275 275
         return $q;
276 276
     }
277 277
 
278
-    public function filter_preconnect_imgopt_url( array $in )
278
+    public function filter_preconnect_imgopt_url(array $in)
279 279
     {
280
-        $url_parts = parse_url( $this->get_imgopt_base_url() );
281
-        $in[]      = $url_parts['scheme'] . '://' . $url_parts['host'];
280
+        $url_parts = parse_url($this->get_imgopt_base_url());
281
+        $in[]      = $url_parts['scheme'].'://'.$url_parts['host'];
282 282
 
283 283
         return $in;
284 284
     }
@@ -291,20 +291,20 @@  discard block
 block discarded – undo
291 291
      *
292 292
      * @return string
293 293
      */
294
-    private function normalize_img_url( $in )
294
+    private function normalize_img_url($in)
295 295
     {
296 296
         // Only parse the site url once.
297 297
         static $parsed_site_url = null;
298
-        if ( null === $parsed_site_url ) {
299
-            $parsed_site_url = parse_url( site_url() );
298
+        if (null === $parsed_site_url) {
299
+            $parsed_site_url = parse_url(site_url());
300 300
         }
301 301
 
302 302
         // get CDN domain once.
303 303
         static $cdn_domain = null;
304
-        if ( is_null( $cdn_domain ) ) {
305
-            $cdn_url = apply_filters( 'autoptimize_filter_base_cdnurl', get_option( 'autoptimize_cdn_url', '' ) );
306
-            if ( ! empty( $cdn_url ) ) {
307
-                $cdn_domain = parse_url( $cdn_url, PHP_URL_HOST );
304
+        if (is_null($cdn_domain)) {
305
+            $cdn_url = apply_filters('autoptimize_filter_base_cdnurl', get_option('autoptimize_cdn_url', ''));
306
+            if (!empty($cdn_url)) {
307
+                $cdn_domain = parse_url($cdn_url, PHP_URL_HOST);
308 308
             } else {
309 309
                 $cdn_domain = '';
310 310
             }
@@ -320,39 +320,39 @@  discard block
 block discarded – undo
320 320
          * identical string operations).
321 321
          */
322 322
         static $cache = null;
323
-        if ( null === $cache ) {
323
+        if (null === $cache) {
324 324
             $cache = array();
325 325
         }
326 326
 
327 327
         // Do the work on cache miss only.
328
-        if ( ! isset( $cache[ $in ] ) ) {
328
+        if (!isset($cache[$in])) {
329 329
             // Default to what was given to us.
330
-            $result = trim( $in );
331
-            if ( autoptimizeUtils::is_protocol_relative( $in ) ) {
332
-                $result = $parsed_site_url['scheme'] . ':' . $in;
333
-            } elseif ( 0 === strpos( $in, '/' ) ) {
330
+            $result = trim($in);
331
+            if (autoptimizeUtils::is_protocol_relative($in)) {
332
+                $result = $parsed_site_url['scheme'].':'.$in;
333
+            } elseif (0 === strpos($in, '/')) {
334 334
                 // Root-relative...
335
-                $result  = $parsed_site_url['scheme'] . '://' . $parsed_site_url['host'];
335
+                $result  = $parsed_site_url['scheme'].'://'.$parsed_site_url['host'];
336 336
                 $result .= $in;
337
-            } elseif ( ! empty( $cdn_domain ) && strpos( $in, $cdn_domain ) !== 0 ) {
338
-                $result = str_replace( $cdn_domain, $parsed_site_url['host'], $in );
337
+            } elseif (!empty($cdn_domain) && strpos($in, $cdn_domain) !== 0) {
338
+                $result = str_replace($cdn_domain, $parsed_site_url['host'], $in);
339 339
             }
340 340
 
341
-            $result = apply_filters( 'autoptimize_filter_imgopt_normalized_url', $result );
341
+            $result = apply_filters('autoptimize_filter_imgopt_normalized_url', $result);
342 342
 
343 343
             // Store in cache.
344
-            $cache[ $in ] = $result;
344
+            $cache[$in] = $result;
345 345
         }
346 346
 
347
-        return $cache[ $in ];
347
+        return $cache[$in];
348 348
     }
349 349
 
350
-    public function filter_optimize_css_images( $in )
350
+    public function filter_optimize_css_images($in)
351 351
     {
352
-        $in = $this->normalize_img_url( $in );
352
+        $in = $this->normalize_img_url($in);
353 353
 
354
-        if ( $this->can_optimize_image( $in ) ) {
355
-            return $this->build_imgopt_url( $in, '', '' );
354
+        if ($this->can_optimize_image($in)) {
355
+            return $this->build_imgopt_url($in, '', '');
356 356
         } else {
357 357
             return $in;
358 358
         }
@@ -362,50 +362,50 @@  discard block
 block discarded – undo
362 362
     {
363 363
         static $imgopt_base_url = null;
364 364
 
365
-        if ( null === $imgopt_base_url ) {
365
+        if (null === $imgopt_base_url) {
366 366
             $imgopt_host     = $this->get_imgopt_host();
367 367
             $quality         = $this->get_img_quality_string();
368
-            $ret_val         = apply_filters( 'autoptimize_filter_imgopt_wait', 'ret_img' ); // values: ret_wait, ret_img, ret_json, ret_blank.
369
-            $imgopt_base_url = $imgopt_host . 'client/' . $quality . ',' . $ret_val;
370
-            $imgopt_base_url = apply_filters( 'autoptimize_filter_imgopt_base_url', $imgopt_base_url );
368
+            $ret_val         = apply_filters('autoptimize_filter_imgopt_wait', 'ret_img'); // values: ret_wait, ret_img, ret_json, ret_blank.
369
+            $imgopt_base_url = $imgopt_host.'client/'.$quality.','.$ret_val;
370
+            $imgopt_base_url = apply_filters('autoptimize_filter_imgopt_base_url', $imgopt_base_url);
371 371
         }
372 372
 
373 373
         return $imgopt_base_url;
374 374
     }
375 375
 
376
-    private function can_optimize_image( $url )
376
+    private function can_optimize_image($url)
377 377
     {
378 378
         static $cdn_url      = null;
379 379
         static $nopti_images = null;
380 380
 
381
-        if ( null === $cdn_url ) {
381
+        if (null === $cdn_url) {
382 382
             $cdn_url = apply_filters(
383 383
                 'autoptimize_filter_base_cdnurl',
384
-                get_option( 'autoptimize_cdn_url', '' )
384
+                get_option('autoptimize_cdn_url', '')
385 385
             );
386 386
         }
387 387
 
388
-        if ( null === $nopti_images ) {
389
-            $nopti_images = apply_filters( 'autoptimize_filter_imgopt_noptimize', '' );
388
+        if (null === $nopti_images) {
389
+            $nopti_images = apply_filters('autoptimize_filter_imgopt_noptimize', '');
390 390
         }
391 391
 
392 392
         $site_host  = AUTOPTIMIZE_SITE_DOMAIN;
393
-        $url        = $this->normalize_img_url( $url );
394
-        $url_parsed = parse_url( $url );
393
+        $url        = $this->normalize_img_url($url);
394
+        $url_parsed = parse_url($url);
395 395
 
396
-        if ( array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host && empty( $cdn_url ) ) {
396
+        if (array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host && empty($cdn_url)) {
397 397
             return false;
398
-        } elseif ( ! empty( $cdn_url ) && strpos( $url, $cdn_url ) === false && array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host ) {
398
+        } elseif (!empty($cdn_url) && strpos($url, $cdn_url) === false && array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host) {
399 399
             return false;
400
-        } elseif ( strpos( $url, '.php' ) !== false ) {
400
+        } elseif (strpos($url, '.php') !== false) {
401 401
             return false;
402
-        } elseif ( str_ireplace( array( '.png', '.gif', '.jpg', '.jpeg', '.webp' ), '', $url_parsed['path'] ) === $url_parsed['path'] ) {
402
+        } elseif (str_ireplace(array('.png', '.gif', '.jpg', '.jpeg', '.webp'), '', $url_parsed['path']) === $url_parsed['path']) {
403 403
             // fixme: better check against end of string.
404 404
             return false;
405
-        } elseif ( ! empty( $nopti_images ) ) {
406
-            $nopti_images_array = array_filter( array_map( 'trim', explode( ',', $nopti_images ) ) );
407
-            foreach ( $nopti_images_array as $nopti_image ) {
408
-                if ( strpos( $url, $nopti_image ) !== false ) {
405
+        } elseif (!empty($nopti_images)) {
406
+            $nopti_images_array = array_filter(array_map('trim', explode(',', $nopti_images)));
407
+            foreach ($nopti_images_array as $nopti_image) {
408
+                if (strpos($url, $nopti_image) !== false) {
409 409
                     return false;
410 410
                 }
411 411
             }
@@ -413,13 +413,13 @@  discard block
 block discarded – undo
413 413
         return true;
414 414
     }
415 415
 
416
-    private function build_imgopt_url( $orig_url, $width = 0, $height = 0 )
416
+    private function build_imgopt_url($orig_url, $width = 0, $height = 0)
417 417
     {
418 418
         // sanitize width and height.
419
-        if ( strpos( $width, '%' ) !== false ) {
419
+        if (strpos($width, '%') !== false) {
420 420
             $width = 0;
421 421
         }
422
-        if ( strpos( $height, '%' ) !== false ) {
422
+        if (strpos($height, '%') !== false) {
423 423
             $height = 0;
424 424
         }
425 425
         $width  = (int) $width;
@@ -433,43 +433,43 @@  discard block
 block discarded – undo
433 433
         );
434 434
 
435 435
         // If filter modified the url, return that.
436
-        if ( $filtered_url !== $orig_url ) {
436
+        if ($filtered_url !== $orig_url) {
437 437
             return $filtered_url;
438 438
         }
439 439
 
440
-        $orig_url        = $this->normalize_img_url( $orig_url );
440
+        $orig_url        = $this->normalize_img_url($orig_url);
441 441
         $imgopt_base_url = $this->get_imgopt_base_url();
442 442
         $imgopt_size     = '';
443 443
 
444
-        if ( $width && 0 !== $width ) {
445
-            $imgopt_size = ',w_' . $width;
444
+        if ($width && 0 !== $width) {
445
+            $imgopt_size = ',w_'.$width;
446 446
         }
447 447
 
448
-        if ( $height && 0 !== $height ) {
449
-            $imgopt_size .= ',h_' . $height;
448
+        if ($height && 0 !== $height) {
449
+            $imgopt_size .= ',h_'.$height;
450 450
         }
451 451
 
452
-        $url = $imgopt_base_url . $imgopt_size . '/' . $orig_url;
452
+        $url = $imgopt_base_url.$imgopt_size.'/'.$orig_url;
453 453
 
454 454
         return $url;
455 455
     }
456 456
 
457
-    public function replace_data_thumbs( $matches )
457
+    public function replace_data_thumbs($matches)
458 458
     {
459
-        return $this->replace_img_callback( $matches, 150, 150 );
459
+        return $this->replace_img_callback($matches, 150, 150);
460 460
     }
461 461
 
462
-    public function replace_img_callback( $matches, $width = 0, $height = 0 )
462
+    public function replace_img_callback($matches, $width = 0, $height = 0)
463 463
     {
464
-        $_normalized_img_url = $this->normalize_img_url( $matches[1] );
465
-        if ( $this->can_optimize_image( $matches[1] ) ) {
466
-            return str_replace( $matches[1], $this->build_imgopt_url( $_normalized_img_url, $width, $height ), $matches[0] );
464
+        $_normalized_img_url = $this->normalize_img_url($matches[1]);
465
+        if ($this->can_optimize_image($matches[1])) {
466
+            return str_replace($matches[1], $this->build_imgopt_url($_normalized_img_url, $width, $height), $matches[0]);
467 467
         } else {
468 468
             return $matches[0];
469 469
         }
470 470
     }
471 471
 
472
-    public function filter_optimize_images( $in )
472
+    public function filter_optimize_images($in)
473 473
     {
474 474
         /*
475 475
          * potential future functional improvements:
@@ -479,7 +479,7 @@  discard block
 block discarded – undo
479 479
         $to_replace = array();
480 480
 
481 481
         // hide noscript tags to avoid nesting noscript tags (as lazyloaded images add noscript).
482
-        if ( $this->should_lazyload() ) {
482
+        if ($this->should_lazyload()) {
483 483
             $in = autoptimizeBase::replace_contents_with_marker_if_exists(
484 484
                 'SCRIPT',
485 485
                 '<script',
@@ -489,25 +489,25 @@  discard block
 block discarded – undo
489 489
         }
490 490
 
491 491
         // extract img tags.
492
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $in, $matches ) ) {
493
-            foreach ( $matches[0] as $tag ) {
492
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $in, $matches)) {
493
+            foreach ($matches[0] as $tag) {
494 494
                 $orig_tag = $tag;
495 495
                 $imgopt_w = '';
496 496
                 $imgopt_h = '';
497 497
 
498 498
                 // first do (data-)srcsets.
499
-                if ( preg_match_all( '#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER ) ) {
500
-                    foreach ( $allsrcsets as $srcset ) {
499
+                if (preg_match_all('#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER)) {
500
+                    foreach ($allsrcsets as $srcset) {
501 501
                         $srcset  = $srcset[2];
502
-                        $srcsets = explode( ',', $srcset );
503
-                        foreach ( $srcsets as $indiv_srcset ) {
504
-                            $indiv_srcset_parts = explode( ' ', trim( $indiv_srcset ) );
505
-                            if ( isset( $indiv_srcset_parts[1] ) && rtrim( $indiv_srcset_parts[1], 'w' ) !== $indiv_srcset_parts[1] ) {
506
-                                $imgopt_w = rtrim( $indiv_srcset_parts[1], 'w' );
502
+                        $srcsets = explode(',', $srcset);
503
+                        foreach ($srcsets as $indiv_srcset) {
504
+                            $indiv_srcset_parts = explode(' ', trim($indiv_srcset));
505
+                            if (isset($indiv_srcset_parts[1]) && rtrim($indiv_srcset_parts[1], 'w') !== $indiv_srcset_parts[1]) {
506
+                                $imgopt_w = rtrim($indiv_srcset_parts[1], 'w');
507 507
                             }
508
-                            if ( $this->can_optimize_image( $indiv_srcset_parts[0] ) ) {
509
-                                $imgopt_url = $this->build_imgopt_url( $indiv_srcset_parts[0], $imgopt_w, '' );
510
-                                $tag        = str_replace( $indiv_srcset_parts[0], $imgopt_url, $tag );
508
+                            if ($this->can_optimize_image($indiv_srcset_parts[0])) {
509
+                                $imgopt_url = $this->build_imgopt_url($indiv_srcset_parts[0], $imgopt_w, '');
510
+                                $tag        = str_replace($indiv_srcset_parts[0], $imgopt_url, $tag);
511 511
                             }
512 512
                         }
513 513
                     }
@@ -515,120 +515,120 @@  discard block
 block discarded – undo
515 515
 
516 516
                 // proceed with img src.
517 517
                 // get width and height and add to $imgopt_size.
518
-                $_get_size = $this->get_size_from_tag( $tag );
518
+                $_get_size = $this->get_size_from_tag($tag);
519 519
                 $imgopt_w  = $_get_size['width'];
520 520
                 $imgopt_h  = $_get_size['height'];
521 521
 
522 522
                 // then start replacing images src.
523
-                if ( preg_match_all( '#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER ) ) {
524
-                    foreach ( $urls as $url ) {
523
+                if (preg_match_all('#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER)) {
524
+                    foreach ($urls as $url) {
525 525
                         $full_src_orig = $url[0];
526 526
                         $url           = $url[1];
527
-                        if ( $this->can_optimize_image( $url ) ) {
528
-                            $imgopt_url      = $this->build_imgopt_url( $url, $imgopt_w, $imgopt_h );
529
-                            $full_imgopt_src = str_replace( $url, $imgopt_url, $full_src_orig );
530
-                            $tag             = str_replace( $full_src_orig, $full_imgopt_src, $tag );
527
+                        if ($this->can_optimize_image($url)) {
528
+                            $imgopt_url      = $this->build_imgopt_url($url, $imgopt_w, $imgopt_h);
529
+                            $full_imgopt_src = str_replace($url, $imgopt_url, $full_src_orig);
530
+                            $tag             = str_replace($full_src_orig, $full_imgopt_src, $tag);
531 531
                         }
532 532
                     }
533 533
                 }
534 534
 
535 535
                 // do lazyload stuff.
536
-                if ( $this->should_lazyload( $in ) ) {
536
+                if ($this->should_lazyload($in)) {
537 537
                     // first do lpiq placeholder logic.
538
-                    if ( strpos( $url, $this->get_imgopt_host() ) === 0 ) {
538
+                    if (strpos($url, $this->get_imgopt_host()) === 0) {
539 539
                         // if all img src have been replaced during srcset, we have to extract the
540 540
                         // origin url from the imgopt one to be able to set a lqip placeholder.
541
-                        $_url = substr( $url, strpos( $url, '/http' ) + 1 );
541
+                        $_url = substr($url, strpos($url, '/http') + 1);
542 542
                     } else {
543 543
                         $_url = $url;
544 544
                     }
545 545
 
546
-                    if ( $this->can_optimize_image( $_url ) && apply_filters( 'autoptimize_filter_imgopt_lazyload_dolqip', true ) ) {
546
+                    if ($this->can_optimize_image($_url) && apply_filters('autoptimize_filter_imgopt_lazyload_dolqip', true)) {
547 547
                         $lqip_w = '';
548 548
                         $lqip_h = '';
549
-                        if ( isset( $imgopt_w ) && ! empty( $imgopt_w ) ) {
550
-                            $lqip_w = ',w_' . $imgopt_w;
549
+                        if (isset($imgopt_w) && !empty($imgopt_w)) {
550
+                            $lqip_w = ',w_'.$imgopt_w;
551 551
                         }
552
-                        if ( isset( $imgopt_h ) && ! empty( $imgopt_h ) ) {
553
-                            $lqip_h = ',h_' . $imgopt_h;
552
+                        if (isset($imgopt_h) && !empty($imgopt_h)) {
553
+                            $lqip_h = ',h_'.$imgopt_h;
554 554
                         }
555
-                        $placeholder = $this->get_imgopt_host() . 'client/q_lqip,ret_wait' . $lqip_w . $lqip_h . '/' . $_url;
555
+                        $placeholder = $this->get_imgopt_host().'client/q_lqip,ret_wait'.$lqip_w.$lqip_h.'/'.$_url;
556 556
                     }
557 557
                     // then call add_lazyload-function with lpiq placeholder if set.
558
-                    $tag = $this->add_lazyload( $tag, $placeholder );
558
+                    $tag = $this->add_lazyload($tag, $placeholder);
559 559
                 }
560 560
 
561 561
                 // and add tag to array for later replacement.
562
-                if ( $tag !== $orig_tag ) {
563
-                    $to_replace[ $orig_tag ] = $tag;
562
+                if ($tag !== $orig_tag) {
563
+                    $to_replace[$orig_tag] = $tag;
564 564
                 }
565 565
             }
566 566
         }
567 567
 
568 568
         // and replace all.
569
-        $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $in );
569
+        $out = str_replace(array_keys($to_replace), array_values($to_replace), $in);
570 570
 
571 571
         // img thumbnails in e.g. woocommerce.
572
-        if ( strpos( $out, 'data-thumb' ) !== false && apply_filters( 'autoptimize_filter_imgopt_datathumbs', true ) ) {
572
+        if (strpos($out, 'data-thumb') !== false && apply_filters('autoptimize_filter_imgopt_datathumbs', true)) {
573 573
             $out = preg_replace_callback(
574 574
                 '/\<div(?:[^>]?)\sdata-thumb\=(?:\"|\')(.+?)(?:\"|\')(?:[^>]*)?\>/s',
575
-                array( $this, 'replace_data_thumbs' ),
575
+                array($this, 'replace_data_thumbs'),
576 576
                 $out
577 577
             );
578 578
         }
579 579
 
580 580
         // background-image in inline style.
581
-        if ( strpos( $out, 'background-image:' ) !== false && apply_filters( 'autoptimize_filter_imgopt_backgroundimages', true ) ) {
581
+        if (strpos($out, 'background-image:') !== false && apply_filters('autoptimize_filter_imgopt_backgroundimages', true)) {
582 582
             $out = preg_replace_callback(
583 583
                 '/style=(?:"|\').*?background-image:\s?url\((?:"|\')?([^"\')]*)(?:"|\')?\)/',
584
-                array( $this, 'replace_img_callback' ),
584
+                array($this, 'replace_img_callback'),
585 585
                 $out
586 586
             );
587 587
         }
588 588
 
589 589
         // lazyload: restore noscript tags + lazyload picture source tags.
590
-        if ( $this->should_lazyload() ) {
590
+        if ($this->should_lazyload()) {
591 591
             $out = autoptimizeBase::restore_marked_content(
592 592
                 'SCRIPT',
593 593
                 $out
594 594
             );
595 595
 
596
-            $out = $this->process_picture_tag( $out, true, true );
596
+            $out = $this->process_picture_tag($out, true, true);
597 597
         } else {
598
-            $out = $this->process_picture_tag( $out, true, false );
598
+            $out = $this->process_picture_tag($out, true, false);
599 599
         }
600 600
 
601 601
         return $out;
602 602
     }
603 603
 
604
-    public function get_size_from_tag( $tag ) {
604
+    public function get_size_from_tag($tag) {
605 605
         // reusable function to extract widht and height from an image tag
606 606
         // enforcing a filterable maximum width and height (default 4999X4999).
607 607
         $width  = '';
608 608
         $height = '';
609 609
 
610
-        if ( preg_match( '#width=("|\')(.*)("|\')#Usmi', $tag, $_width ) ) {
611
-            if ( strpos( $_width[2], '%' ) === false ) {
610
+        if (preg_match('#width=("|\')(.*)("|\')#Usmi', $tag, $_width)) {
611
+            if (strpos($_width[2], '%') === false) {
612 612
                 $width = (int) $_width[2];
613 613
             }
614 614
         }
615
-        if ( preg_match( '#height=("|\')(.*)("|\')#Usmi', $tag, $_height ) ) {
616
-            if ( strpos( $_height[2], '%' ) === false ) {
615
+        if (preg_match('#height=("|\')(.*)("|\')#Usmi', $tag, $_height)) {
616
+            if (strpos($_height[2], '%') === false) {
617 617
                 $height = (int) $_height[2];
618 618
             }
619 619
         }
620 620
 
621 621
         // check for and enforce (filterable) max sizes.
622
-        $_max_width = apply_filters( 'autoptimize_filter_imgopt_max_width', 4999 );
623
-        if ( $width > $_max_width ) {
622
+        $_max_width = apply_filters('autoptimize_filter_imgopt_max_width', 4999);
623
+        if ($width > $_max_width) {
624 624
             $_width = $_max_width;
625
-            $height = $_width / $width * $height;
625
+            $height = $_width/$width*$height;
626 626
             $width  = $_width;
627 627
         }
628
-        $_max_height = apply_filters( 'autoptimize_filter_imgopt_max_height', 4999 );
629
-        if ( $height > $_max_height ) {
628
+        $_max_height = apply_filters('autoptimize_filter_imgopt_max_height', 4999);
629
+        if ($height > $_max_height) {
630 630
             $_height = $_max_height;
631
-            $width   = $_height / $height * $width;
631
+            $width   = $_height/$height*$width;
632 632
             $height  = $_height;
633 633
         }
634 634
 
@@ -647,18 +647,18 @@  discard block
 block discarded – undo
647 647
         return $self->should_lazyload();
648 648
     }
649 649
 
650
-    public function should_lazyload( $context = '' ) {
651
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) ) {
650
+    public function should_lazyload($context = '') {
651
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_3'])) {
652 652
             $lazyload_return = true;
653 653
         } else {
654 654
             $lazyload_return = false;
655 655
         }
656
-        $lazyload_return = apply_filters( 'autoptimize_filter_imgopt_should_lazyload', $lazyload_return, $context );
656
+        $lazyload_return = apply_filters('autoptimize_filter_imgopt_should_lazyload', $lazyload_return, $context);
657 657
 
658 658
         return $lazyload_return;
659 659
     }
660 660
 
661
-    public function filter_lazyload_images( $in )
661
+    public function filter_lazyload_images($in)
662 662
     {
663 663
         // only used is image optimization is NOT active but lazyload is.
664 664
         $to_replace = array();
@@ -672,17 +672,17 @@  discard block
 block discarded – undo
672 672
         );
673 673
 
674 674
         // extract img tags and add lazyload attribs.
675
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $out, $matches ) ) {
676
-            foreach ( $matches[0] as $tag ) {
677
-                if ( $this->should_lazyload( $out ) ) {
678
-                    $to_replace[ $tag ] = $this->add_lazyload( $tag );
675
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $out, $matches)) {
676
+            foreach ($matches[0] as $tag) {
677
+                if ($this->should_lazyload($out)) {
678
+                    $to_replace[$tag] = $this->add_lazyload($tag);
679 679
                 }
680 680
             }
681
-            $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $out );
681
+            $out = str_replace(array_keys($to_replace), array_values($to_replace), $out);
682 682
         }
683 683
 
684 684
         // and also lazyload picture tag.
685
-        $out = $this->process_picture_tag( $out, false, true );
685
+        $out = $this->process_picture_tag($out, false, true);
686 686
 
687 687
         // restore noscript tags.
688 688
         $out = autoptimizeBase::restore_marked_content(
@@ -693,46 +693,46 @@  discard block
 block discarded – undo
693 693
         return $out;
694 694
     }
695 695
 
696
-    public function add_lazyload( $tag, $placeholder = '' ) {
696
+    public function add_lazyload($tag, $placeholder = '') {
697 697
         // adds actual lazyload-attributes to an image node.
698
-        if ( str_ireplace( $this->get_lazyload_exclusions(), '', $tag ) === $tag ) {
699
-            $tag = $this->maybe_fix_missing_quotes( $tag );
698
+        if (str_ireplace($this->get_lazyload_exclusions(), '', $tag) === $tag) {
699
+            $tag = $this->maybe_fix_missing_quotes($tag);
700 700
 
701 701
             // store original tag for use in noscript version.
702
-            $noscript_tag = '<noscript>' . $tag . '</noscript>';
702
+            $noscript_tag = '<noscript>'.$tag.'</noscript>';
703 703
 
704
-            $lazyload_class = apply_filters( 'autoptimize_filter_imgopt_lazyload_class', 'lazyload' );
704
+            $lazyload_class = apply_filters('autoptimize_filter_imgopt_lazyload_class', 'lazyload');
705 705
 
706 706
             // insert lazyload class.
707
-            $tag = $this->inject_classes_in_tag( $tag, "$lazyload_class " );
707
+            $tag = $this->inject_classes_in_tag($tag, "$lazyload_class ");
708 708
 
709
-            if ( ! $placeholder || empty( $placeholder ) ) {
709
+            if (!$placeholder || empty($placeholder)) {
710 710
                 // get image width & heigth for placeholder fun (and to prevent content reflow).
711
-                $_get_size = $this->get_size_from_tag( $tag );
711
+                $_get_size = $this->get_size_from_tag($tag);
712 712
                 $width     = $_get_size['width'];
713 713
                 $height    = $_get_size['height'];
714
-                if ( false === $width ) {
714
+                if (false === $width) {
715 715
                     $widht = 210; // default width for SVG placeholder.
716 716
                 }
717
-                if ( false === $height ) {
718
-                    $heigth = $width / 3 * 2; // if no height, base it on width using the 3/2 aspect ratio.
717
+                if (false === $height) {
718
+                    $heigth = $width/3*2; // if no height, base it on width using the 3/2 aspect ratio.
719 719
                 }
720 720
 
721 721
                 // insert the actual lazyload stuff.
722 722
                 // see https://css-tricks.com/preventing-content-reflow-from-lazy-loaded-images/ for great read on why we're using empty svg's.
723
-                $placeholder = apply_filters( 'autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder( $width, $height ) );
723
+                $placeholder = apply_filters('autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder($width, $height));
724 724
             }
725
-            $tag = str_replace( ' src=', ' src=\'' . $placeholder . '\' data-src=', $tag );
726
-            $tag = str_replace( ' srcset=', ' data-srcset=', $tag );
725
+            $tag = str_replace(' src=', ' src=\''.$placeholder.'\' data-src=', $tag);
726
+            $tag = str_replace(' srcset=', ' data-srcset=', $tag);
727 727
 
728 728
             // move sizes to data-sizes unless filter says no.
729
-            if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_move_sizes', true ) ) {
730
-                $tag = str_replace( 'sizes=', 'data-sizes=', $tag );
729
+            if (apply_filters('autoptimize_filter_imgopt_lazyload_move_sizes', true)) {
730
+                $tag = str_replace('sizes=', 'data-sizes=', $tag);
731 731
             }
732 732
 
733 733
             // add the noscript-tag from earlier.
734
-            $tag = $noscript_tag . $tag;
735
-            $tag = apply_filters( 'autoptimize_filter_imgopt_lazyloaded_img', $tag );
734
+            $tag = $noscript_tag.$tag;
735
+            $tag = apply_filters('autoptimize_filter_imgopt_lazyloaded_img', $tag);
736 736
         }
737 737
 
738 738
         return $tag;
@@ -741,20 +741,20 @@  discard block
 block discarded – undo
741 741
     public function add_lazyload_js_footer() {
742 742
         // The JS will by default be excluded form autoptimization but this can be changed with a filter.
743 743
         $noptimize_flag = '';
744
-        if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_js_noptimize', true ) ) {
744
+        if (apply_filters('autoptimize_filter_imgopt_lazyload_js_noptimize', true)) {
745 745
             $noptimize_flag = ' data-noptimize="1"';
746 746
         }
747 747
 
748 748
         // Adds lazyload CSS & JS to footer, using echo because wp_enqueue_script seems not to support pushing attributes (async).
749
-        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>' );
750
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_jsconfig', '<script' . $noptimize_flag . '>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>' );
751
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_js', '<script async' . $noptimize_flag . ' src=\'' . plugins_url( 'external/js/lazysizes.min.js', __FILE__ ) . '\'></script>' );
749
+        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>');
750
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_jsconfig', '<script'.$noptimize_flag.'>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>');
751
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_js', '<script async'.$noptimize_flag.' src=\''.plugins_url('external/js/lazysizes.min.js', __FILE__).'\'></script>');
752 752
 
753 753
         // And add webp detection and loading JS.
754
-        if ( $this->should_webp() ) {
754
+        if ($this->should_webp()) {
755 755
             $_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='data:image/webp;base64,UklGRhoAAABXRUJQVlA4TA0AAAAvAAAAEAcQERGIiP4HAA=='}function s_webp(e){window.supportsWebP=e}c_webp(s_webp);";
756 756
             $_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,'))})});";
757
-            echo apply_filters( 'autoptimize_filter_imgopt_webp_js', '<script' . $noptimize_flag . '>' . $_webp_detect . $_webp_load . '</script>' );
757
+            echo apply_filters('autoptimize_filter_imgopt_webp_js', '<script'.$noptimize_flag.'>'.$_webp_detect.$_webp_load.'</script>');
758 758
         }
759 759
     }
760 760
 
@@ -762,47 +762,47 @@  discard block
 block discarded – undo
762 762
         // returns array of strings that if found in an <img tag will stop the img from being lazy-loaded.
763 763
         static $exclude_lazyload_array = null;
764 764
 
765
-        if ( null === $exclude_lazyload_array ) {
765
+        if (null === $exclude_lazyload_array) {
766 766
             $options = $this->options;
767 767
 
768 768
             // set default exclusions.
769
-            $exclude_lazyload_array = array( 'skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset', 'data:image/', 'data-lazyload', 'rev-slidebg' );
769
+            $exclude_lazyload_array = array('skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset', 'data:image/', 'data-lazyload', 'rev-slidebg');
770 770
 
771 771
             // add from setting.
772
-            if ( array_key_exists( 'autoptimize_imgopt_text_field_5', $options ) ) {
772
+            if (array_key_exists('autoptimize_imgopt_text_field_5', $options)) {
773 773
                 $exclude_lazyload_option = $options['autoptimize_imgopt_text_field_5'];
774
-                if ( ! empty( $exclude_lazyload_option ) ) {
775
-                    $exclude_lazyload_array = array_merge( $exclude_lazyload_array, array_filter( array_map( 'trim', explode( ',', $options['autoptimize_imgopt_text_field_5'] ) ) ) );
774
+                if (!empty($exclude_lazyload_option)) {
775
+                    $exclude_lazyload_array = array_merge($exclude_lazyload_array, array_filter(array_map('trim', explode(',', $options['autoptimize_imgopt_text_field_5']))));
776 776
                 }
777 777
             }
778 778
 
779 779
             // and filter for developer-initiated changes.
780
-            $exclude_lazyload_array = apply_filters( 'autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array );
780
+            $exclude_lazyload_array = apply_filters('autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array);
781 781
         }
782 782
 
783 783
         return $exclude_lazyload_array;
784 784
     }
785 785
 
786
-    public function inject_classes_in_tag( $tag, $target_class ) {
787
-        if ( strpos( $tag, 'class=' ) !== false ) {
788
-            $tag = preg_replace( '/(\sclass\s?=\s?("|\'))/', '$1' . $target_class, $tag );
786
+    public function inject_classes_in_tag($tag, $target_class) {
787
+        if (strpos($tag, 'class=') !== false) {
788
+            $tag = preg_replace('/(\sclass\s?=\s?("|\'))/', '$1'.$target_class, $tag);
789 789
         } else {
790
-            $tag = str_replace( '<img ', '<img class="' . trim( $target_class ) . '" ', $tag );
790
+            $tag = str_replace('<img ', '<img class="'.trim($target_class).'" ', $tag);
791 791
         }
792 792
 
793 793
         return $tag;
794 794
     }
795 795
 
796
-    public function get_default_lazyload_placeholder( $imgopt_w, $imgopt_h ) {
797
-        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';
796
+    public function get_default_lazyload_placeholder($imgopt_w, $imgopt_h) {
797
+        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';
798 798
     }
799 799
 
800 800
     public function should_webp() {
801 801
         static $webp_return = null;
802 802
 
803
-        if ( is_null( $webp_return ) ) {
803
+        if (is_null($webp_return)) {
804 804
             // webp only works if imgopt and lazyload are also active.
805
-            if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_4'] ) && ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) && $this->imgopt_active() ) {
805
+            if (!empty($this->options['autoptimize_imgopt_checkbox_field_4']) && !empty($this->options['autoptimize_imgopt_checkbox_field_3']) && $this->imgopt_active()) {
806 806
                 $webp_return = true;
807 807
             } else {
808 808
                 $webp_return = false;
@@ -812,9 +812,9 @@  discard block
 block discarded – undo
812 812
         return $webp_return;
813 813
     }
814 814
 
815
-    public function process_picture_tag( $in, $imgopt = false, $lazy = false ) {
815
+    public function process_picture_tag($in, $imgopt = false, $lazy = false) {
816 816
         // check if "<picture" is present and if filter allows us to process <picture>.
817
-        if ( strpos( $in, '<picture' ) === false || apply_filters( 'autoptimize_filter_imgopt_dopicture', true ) === false ) {
817
+        if (strpos($in, '<picture') === false || apply_filters('autoptimize_filter_imgopt_dopicture', true) === false) {
818 818
             return $in;
819 819
         }
820 820
 
@@ -822,36 +822,36 @@  discard block
 block discarded – undo
822 822
         $to_replace_pict = array();
823 823
 
824 824
         // extract and process each picture-node.
825
-        preg_match_all( '#<picture.*</picture>#Usmi', $in, $_pictures, PREG_SET_ORDER );
826
-        foreach ( $_pictures as $_picture ) {
827
-            $_picture = $this->maybe_fix_missing_quotes( $_picture );
828
-            if ( strpos( $_picture[0], '<source ' ) !== false && preg_match_all( '#<source .*srcset=(?:"|\')(?!data)(.*)(?:"|\').*>#Usmi', $_picture[0], $_sources, PREG_SET_ORDER ) !== false ) {
829
-                foreach ( $_sources as $_source ) {
825
+        preg_match_all('#<picture.*</picture>#Usmi', $in, $_pictures, PREG_SET_ORDER);
826
+        foreach ($_pictures as $_picture) {
827
+            $_picture = $this->maybe_fix_missing_quotes($_picture);
828
+            if (strpos($_picture[0], '<source ') !== false && preg_match_all('#<source .*srcset=(?:"|\')(?!data)(.*)(?:"|\').*>#Usmi', $_picture[0], $_sources, PREG_SET_ORDER) !== false) {
829
+                foreach ($_sources as $_source) {
830 830
                     $_picture_replacement = $_source[0];
831 831
 
832 832
                     // should we optimize the image?
833
-                    if ( $imgopt && $this->can_optimize_image( $_source[1] ) ) {
834
-                        $_picture_replacement = str_replace( $_source[1], $this->build_imgopt_url( $_source[1] ), $_picture_replacement );
833
+                    if ($imgopt && $this->can_optimize_image($_source[1])) {
834
+                        $_picture_replacement = str_replace($_source[1], $this->build_imgopt_url($_source[1]), $_picture_replacement);
835 835
                     }
836 836
                     // should we lazy-load?
837
-                    if ( $lazy && str_ireplace( $_exclusions, '', $_picture_replacement ) === $_picture_replacement ) {
838
-                        $_picture_replacement = str_replace( ' srcset=', ' data-srcset=', $_picture_replacement );
837
+                    if ($lazy && str_ireplace($_exclusions, '', $_picture_replacement) === $_picture_replacement) {
838
+                        $_picture_replacement = str_replace(' srcset=', ' data-srcset=', $_picture_replacement);
839 839
                     }
840
-                    $to_replace_pict[ $_source[0] ] = $_picture_replacement;
840
+                    $to_replace_pict[$_source[0]] = $_picture_replacement;
841 841
                 }
842 842
             }
843 843
         }
844 844
 
845 845
         // and return the fully procesed $in.
846
-        $out = str_replace( array_keys( $to_replace_pict ), array_values( $to_replace_pict ), $in );
846
+        $out = str_replace(array_keys($to_replace_pict), array_values($to_replace_pict), $in);
847 847
 
848 848
         return $out;
849 849
     }
850 850
 
851
-    public function maybe_fix_missing_quotes( $tag_in ) {
851
+    public function maybe_fix_missing_quotes($tag_in) {
852 852
         // W3TC's Minify_HTML class removes quotes around attribute value, this re-adds them.
853
-        if ( file_exists( WP_PLUGIN_DIR . '/w3-total-cache/w3-total-cache.php' ) && class_exists( 'Minify_HTML' ) && apply_filters( 'autoptimize_filter_imgopt_fixquotes', true ) ) {
854
-            return preg_replace( '/=([^("|\')]*)(\s|>)/U', '=\'$1\'$2', $tag_in );
853
+        if (file_exists(WP_PLUGIN_DIR.'/w3-total-cache/w3-total-cache.php') && class_exists('Minify_HTML') && apply_filters('autoptimize_filter_imgopt_fixquotes', true)) {
854
+            return preg_replace('/=([^("|\')]*)(\s|>)/U', '=\'$1\'$2', $tag_in);
855 855
         } else {
856 856
             return $tag_in;
857 857
         }
@@ -868,14 +868,14 @@  discard block
 block discarded – undo
868 868
             'autoptimize_imgopt',
869 869
             'manage_options',
870 870
             'autoptimize_imgopt',
871
-            array( $this, 'imgopt_options_page' )
871
+            array($this, 'imgopt_options_page')
872 872
         );
873
-        register_setting( 'autoptimize_imgopt_settings', 'autoptimize_imgopt_settings' );
873
+        register_setting('autoptimize_imgopt_settings', 'autoptimize_imgopt_settings');
874 874
     }
875 875
 
876
-    public function add_imgopt_tab( $in )
876
+    public function add_imgopt_tab($in)
877 877
     {
878
-        $in = array_merge( $in, array( 'autoptimize_imgopt' => __( 'Images', 'autoptimize' ) ) );
878
+        $in = array_merge($in, array('autoptimize_imgopt' => __('Images', 'autoptimize')));
879 879
 
880 880
         return $in;
881 881
     }
@@ -883,7 +883,7 @@  discard block
 block discarded – undo
883 883
     public function imgopt_options_page()
884 884
     {
885 885
         // Check querystring for "refreshCacheChecker" and call cachechecker if so.
886
-        if ( array_key_exists( 'refreshImgProvStats', $_GET ) && 1 == $_GET['refreshImgProvStats'] ) {
886
+        if (array_key_exists('refreshImgProvStats', $_GET) && 1 == $_GET['refreshImgProvStats']) {
887 887
             $this->query_img_provider_stats();
888 888
         }
889 889
 
@@ -896,45 +896,45 @@  discard block
 block discarded – undo
896 896
         #autoptimize_imgopt_descr{font-size: 120%;}
897 897
     </style>
898 898
     <div class="wrap">
899
-    <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
899
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
900 900
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
901
-        <?php if ( 'down' === $options['availabilities']['extra_imgopt']['status'] ) { ?>
901
+        <?php if ('down' === $options['availabilities']['extra_imgopt']['status']) { ?>
902 902
             <div class="notice-warning notice"><p>
903 903
             <?php
904 904
             // translators: "Autoptimize support forum" will appear in a "a href".
905
-            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>' );
905
+            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>');
906 906
             ?>
907 907
             </p></div>
908 908
         <?php } ?>
909 909
 
910
-        <?php if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] && ! autoptimizeImages::instance()->launch_ok() ) { ?>
910
+        <?php if ('launch' === $options['availabilities']['extra_imgopt']['status'] && !autoptimizeImages::instance()->launch_ok()) { ?>
911 911
             <div class="notice-warning notice"><p>
912
-            <?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' ); ?>
912
+            <?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'); ?>
913 913
             </p></div>
914 914
         <?php } ?>
915 915
 
916
-        <?php if ( class_exists( 'Jetpack' ) && method_exists( 'Jetpack', 'get_active_modules' ) && in_array( 'photon', Jetpack::get_active_modules() ) ) { ?>
916
+        <?php if (class_exists('Jetpack') && method_exists('Jetpack', 'get_active_modules') && in_array('photon', Jetpack::get_active_modules())) { ?>
917 917
             <div class="notice-warning notice"><p>
918 918
             <?php
919 919
             // translators: "disable  Jetpack's site accelerator for images" will appear in a "a href" linking to the jetpack settings page.
920
-            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>' );
920
+            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>');
921 921
             ?>
922 922
             </p></div>
923 923
         <?php } ?>
924 924
     <form id='ao_settings_form' action='options.php' method='post'>
925
-        <?php settings_fields( 'autoptimize_imgopt_settings' ); ?>
926
-        <h2><?php _e( 'Image optimization', 'autoptimize' ); ?></h2>
927
-        <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>
925
+        <?php settings_fields('autoptimize_imgopt_settings'); ?>
926
+        <h2><?php _e('Image optimization', 'autoptimize'); ?></h2>
927
+        <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>
928 928
         <table class="form-table">
929 929
             <tr>
930
-                <th scope="row"><?php _e( 'Optimize Images', 'autoptimize' ); ?></th>
930
+                <th scope="row"><?php _e('Optimize Images', 'autoptimize'); ?></th>
931 931
                 <td>
932
-                    <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>
932
+                    <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>
933 933
                     <?php
934 934
                     // show shortpixel status.
935 935
                     $_notice = autoptimizeImages::instance()->get_status_notice();
936
-                    if ( $_notice ) {
937
-                        switch ( $_notice['status'] ) {
936
+                    if ($_notice) {
937
+                        switch ($_notice['status']) {
938 938
                             case 2:
939 939
                                 $_notice_color = 'green';
940 940
                                 break;
@@ -950,28 +950,28 @@  discard block
 block discarded – undo
950 950
                             default:
951 951
                                 $_notice_color = 'green';
952 952
                         }
953
-                        echo apply_filters( 'autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:' . $_notice_color . ';">' . __( 'Shortpixel status: ', 'autoptimize' ) . '</span></strong>' . $_notice['notice'] . '</p>' );
953
+                        echo apply_filters('autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:'.$_notice_color.';">'.__('Shortpixel status: ', 'autoptimize').'</span></strong>'.$_notice['notice'].'</p>');
954 954
                     } else {
955 955
                         // translators: link points to shortpixel.
956
-                        $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>' );
957
-                        if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] ) {
958
-                            $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' );
956
+                        $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>');
957
+                        if ('launch' === $options['availabilities']['extra_imgopt']['status']) {
958
+                            $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');
959 959
                         } else {
960 960
                             // translators: link points to shortpixel.
961
-                            $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>' );
961
+                            $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>');
962 962
                         }
963
-                        echo apply_filters( 'autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1 . ' ' . $upsell_msg_2 . '</p>' );
963
+                        echo apply_filters('autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1.' '.$upsell_msg_2.'</p>');
964 964
                     }
965 965
                     // translators: link points to shortpixel FAQ.
966
-                    $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>' );
966
+                    $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>');
967 967
                     // translators: links points to shortpixel TOS & Privacy Policy.
968
-                    $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>' );
969
-                    echo apply_filters( 'autoptimize_imgopt_imgopt_settings_tos', '<p>' . $faqcopy . ' ' . $toscopy . '</p>' );
968
+                    $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>');
969
+                    echo apply_filters('autoptimize_imgopt_imgopt_settings_tos', '<p>'.$faqcopy.' '.$toscopy.'</p>');
970 970
                     ?>
971 971
                 </td>
972 972
             </tr>
973
-            <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"'; } ?>>
974
-                <th scope="row"><?php _e( 'Image Optimization quality', 'autoptimize' ); ?></th>
973
+            <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"'; } ?>>
974
+                <th scope="row"><?php _e('Image Optimization quality', 'autoptimize'); ?></th>
975 975
                 <td>
976 976
                     <label>
977 977
                     <select name='autoptimize_imgopt_settings[autoptimize_imgopt_select_field_2]'>
@@ -979,12 +979,12 @@  discard block
 block discarded – undo
979 979
                         $_imgopt_array = autoptimizeImages::instance()->get_img_quality_array();
980 980
                         $_imgopt_val   = autoptimizeImages::instance()->get_img_quality_setting();
981 981
 
982
-                        foreach ( $_imgopt_array as $key => $value ) {
983
-                            echo '<option value="' . $key . '"';
984
-                            if ( $_imgopt_val == $key ) {
982
+                        foreach ($_imgopt_array as $key => $value) {
983
+                            echo '<option value="'.$key.'"';
984
+                            if ($_imgopt_val == $key) {
985 985
                                 echo ' selected';
986 986
                             }
987
-                            echo '>' . ucfirst( $value ) . '</option>';
987
+                            echo '>'.ucfirst($value).'</option>';
988 988
                         }
989 989
                         echo "\n";
990 990
                         ?>
@@ -993,31 +993,31 @@  discard block
 block discarded – undo
993 993
                     <p>
994 994
                         <?php
995 995
                             // translators: link points to shortpixel image test page.
996
-                            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>' ) );
996
+                            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>'));
997 997
                         ?>
998 998
                     </p>
999 999
                 </td>
1000 1000
             </tr>
1001
-            <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"'; } ?>>
1002
-                <th scope="row"><?php _e( 'Load WebP in supported browsers?', 'autoptimize' ); ?></th>
1001
+            <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"'; } ?>>
1002
+                <th scope="row"><?php _e('Load WebP in supported browsers?', 'autoptimize'); ?></th>
1003 1003
                 <td>
1004
-                    <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>
1004
+                    <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>
1005 1005
                 </td>
1006 1006
             </tr>
1007 1007
             <tr>
1008
-                <th scope="row"><?php _e( 'Lazy-load images?', 'autoptimize' ); ?></th>
1008
+                <th scope="row"><?php _e('Lazy-load images?', 'autoptimize'); ?></th>
1009 1009
                 <td>
1010
-                    <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>
1010
+                    <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>
1011 1011
                 </td>
1012 1012
             </tr>
1013
-            <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"'; } ?>>
1014
-                <th scope="row"><?php _e( 'Lazy-load exclusions', 'autoptimize' ); ?></th>
1013
+            <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"'; } ?>>
1014
+                <th scope="row"><?php _e('Lazy-load exclusions', 'autoptimize'); ?></th>
1015 1015
                 <td>
1016
-                    <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>
1016
+                    <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>
1017 1017
                 </td>
1018 1018
             </tr>
1019 1019
         </table>
1020
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e( 'Save Changes', 'autoptimize' ); ?>" /></p>
1020
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize'); ?>" /></p>
1021 1021
     </form>
1022 1022
     <script>
1023 1023
         jQuery(document).ready(function() {
@@ -1053,37 +1053,37 @@  discard block
 block discarded – undo
1053 1053
      * Ïmg opt status as used on dashboard.
1054 1054
      */
1055 1055
     public function get_imgopt_status_notice() {
1056
-        if ( $this->imgopt_active() ) {
1056
+        if ($this->imgopt_active()) {
1057 1057
             $_imgopt_notice = '';
1058
-            $_stat          = get_option( 'autoptimize_imgopt_provider_stat', '' );
1058
+            $_stat          = get_option('autoptimize_imgopt_provider_stat', '');
1059 1059
             $_site_host     = AUTOPTIMIZE_SITE_DOMAIN;
1060
-            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . $_site_host;
1060
+            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.$_site_host;
1061 1061
 
1062
-            if ( is_array( $_stat ) ) {
1063
-                if ( 1 == $_stat['Status'] ) {
1062
+            if (is_array($_stat)) {
1063
+                if (1 == $_stat['Status']) {
1064 1064
                     // translators: "add more credits" will appear in a "a href".
1065
-                    $_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>' );
1065
+                    $_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>');
1066 1066
                 } elseif ( -1 == $_stat['Status'] || -2 == $_stat['Status'] ) {
1067 1067
                     // translators: "add more credits" will appear in a "a href".
1068
-                    $_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>' );
1069
-                    $_imgopt_stats_refresh_url = add_query_arg( array(
1068
+                    $_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>');
1069
+                    $_imgopt_stats_refresh_url = add_query_arg(array(
1070 1070
                         'page'                => 'autoptimize_imgopt',
1071 1071
                         'refreshImgProvStats' => '1',
1072
-                    ), admin_url( 'options-general.php' ) );
1073
-                    if ( $_stat && array_key_exists( 'timestamp', $_stat ) && ! empty( $_stat['timestamp'] ) ) {
1074
-                        $_imgopt_stats_last_run = __( 'based on status at ', 'autoptimize' ) . date_i18n( get_option( 'time_format' ), $_stat['timestamp'] );
1072
+                    ), admin_url('options-general.php'));
1073
+                    if ($_stat && array_key_exists('timestamp', $_stat) && !empty($_stat['timestamp'])) {
1074
+                        $_imgopt_stats_last_run = __('based on status at ', 'autoptimize').date_i18n(get_option('time_format'), $_stat['timestamp']);
1075 1075
                     } else {
1076
-                        $_imgopt_stats_last_run = __( 'based on previously fetched data', 'autoptimize' );
1076
+                        $_imgopt_stats_last_run = __('based on previously fetched data', 'autoptimize');
1077 1077
                     }
1078
-                    $_imgopt_notice .= ' (' . $_imgopt_stats_last_run . ', ';
1078
+                    $_imgopt_notice .= ' ('.$_imgopt_stats_last_run.', ';
1079 1079
                     // translators: "here to refresh" links to the Autoptimize Extra page and forces a refresh of the img opt stats.
1080
-                    $_imgopt_notice .= sprintf( __( 'click %1$shere to refresh%2$s', 'autoptimize' ), '<a href="' . $_imgopt_stats_refresh_url . '">', '</a>).' );
1080
+                    $_imgopt_notice .= sprintf(__('click %1$shere to refresh%2$s', 'autoptimize'), '<a href="'.$_imgopt_stats_refresh_url.'">', '</a>).');
1081 1081
                 } else {
1082 1082
                     $_imgopt_upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1083 1083
                     // translators: "log in to check your account" will appear in a "a href".
1084
-                    $_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>' );
1084
+                    $_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>');
1085 1085
                 }
1086
-                $_imgopt_notice = apply_filters( 'autoptimize_filter_imgopt_notice', $_imgopt_notice );
1086
+                $_imgopt_notice = apply_filters('autoptimize_filter_imgopt_notice', $_imgopt_notice);
1087 1087
 
1088 1088
                 return array(
1089 1089
                     'status' => $_stat['Status'],
@@ -1104,14 +1104,14 @@  discard block
 block discarded – undo
1104 1104
      * Get img provider stats (used to display notice).
1105 1105
      */
1106 1106
     public function query_img_provider_stats() {
1107
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_1'] ) ) {
1107
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_1'])) {
1108 1108
             $url      = '';
1109
-            $endpoint = $this->get_imgopt_host() . 'read-domain/';
1109
+            $endpoint = $this->get_imgopt_host().'read-domain/';
1110 1110
             $domain   = AUTOPTIMIZE_SITE_DOMAIN;
1111 1111
 
1112 1112
             // make sure parse_url result makes sense, keeping $url empty if not.
1113
-            if ( $domain && ! empty( $domain ) ) {
1114
-                $url = $endpoint . $domain;
1113
+            if ($domain && !empty($domain)) {
1114
+                $url = $endpoint.$domain;
1115 1115
             }
1116 1116
 
1117 1117
             $url = apply_filters(
@@ -1121,12 +1121,12 @@  discard block
 block discarded – undo
1121 1121
 
1122 1122
             // only do the remote call if $url is not empty to make sure no parse_url
1123 1123
             // weirdness results in useless calls.
1124
-            if ( ! empty( $url ) ) {
1125
-                $response = wp_remote_get( $url );
1126
-                if ( ! is_wp_error( $response ) ) {
1127
-                    if ( '200' == wp_remote_retrieve_response_code( $response ) ) {
1128
-                        $stats = json_decode( wp_remote_retrieve_body( $response ), true );
1129
-                        update_option( 'autoptimize_imgopt_provider_stat', $stats );
1124
+            if (!empty($url)) {
1125
+                $response = wp_remote_get($url);
1126
+                if (!is_wp_error($response)) {
1127
+                    if ('200' == wp_remote_retrieve_response_code($response)) {
1128
+                        $stats = json_decode(wp_remote_retrieve_body($response), true);
1129
+                        update_option('autoptimize_imgopt_provider_stat', $stats);
1130 1130
                     }
1131 1131
                 }
1132 1132
             }
@@ -1149,15 +1149,15 @@  discard block
 block discarded – undo
1149 1149
     {
1150 1150
         static $launch_status = null;
1151 1151
 
1152
-        if ( null === $launch_status ) {
1152
+        if (null === $launch_status) {
1153 1153
             $avail_imgopt  = $this->options['availabilities']['extra_imgopt'];
1154
-            $magic_number  = intval( substr( md5( parse_url( AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST ) ), 0, 3 ), 16 );
1155
-            $has_launched  = get_option( 'autoptimize_imgopt_launched', '' );
1154
+            $magic_number  = intval(substr(md5(parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST)), 0, 3), 16);
1155
+            $has_launched  = get_option('autoptimize_imgopt_launched', '');
1156 1156
             $launch_status = false;
1157
-            if ( $has_launched || ( is_array( $avail_imgopt ) && array_key_exists( 'launch-threshold', $avail_imgopt ) && $magic_number < $avail_imgopt['launch-threshold'] ) ) {
1157
+            if ($has_launched || (is_array($avail_imgopt) && array_key_exists('launch-threshold', $avail_imgopt) && $magic_number < $avail_imgopt['launch-threshold'])) {
1158 1158
                 $launch_status = true;
1159
-                if ( ! $has_launched ) {
1160
-                    update_option( 'autoptimize_imgopt_launched', 'on' );
1159
+                if (!$has_launched) {
1160
+                    update_option('autoptimize_imgopt_launched', 'on');
1161 1161
                 }
1162 1162
             }
1163 1163
         }
@@ -1174,16 +1174,16 @@  discard block
 block discarded – undo
1174 1174
     public function get_imgopt_provider_userstatus() {
1175 1175
         static $_provider_userstatus = null;
1176 1176
 
1177
-        if ( is_null( $_provider_userstatus ) ) {
1178
-            $_stat = get_option( 'autoptimize_imgopt_provider_stat', '' );
1179
-            if ( is_array( $_stat ) ) {
1180
-                if ( array_key_exists( 'Status', $_stat ) ) {
1177
+        if (is_null($_provider_userstatus)) {
1178
+            $_stat = get_option('autoptimize_imgopt_provider_stat', '');
1179
+            if (is_array($_stat)) {
1180
+                if (array_key_exists('Status', $_stat)) {
1181 1181
                     $_provider_userstatus['Status'] = $_stat['Status'];
1182 1182
                 } else {
1183 1183
                     // if no stats then we assume all is well.
1184 1184
                     $_provider_userstatus['Status'] = 2;
1185 1185
                 }
1186
-                if ( array_key_exists( 'timestamp', $_stat ) ) {
1186
+                if (array_key_exists('timestamp', $_stat)) {
1187 1187
                     $_provider_userstatus['timestamp'] = $_stat['timestamp'];
1188 1188
                 } else {
1189 1189
                     // if no timestamp then we return "".
@@ -1196,27 +1196,27 @@  discard block
 block discarded – undo
1196 1196
     }
1197 1197
 
1198 1198
     public function get_status_notice() {
1199
-        if ( $this->imgopt_active() ) {
1199
+        if ($this->imgopt_active()) {
1200 1200
             $notice = '';
1201 1201
             $stat   = $this->get_imgopt_provider_userstatus();
1202
-            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
1202
+            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
1203 1203
             $assoc  = 'https://shortpixel.helpscoutdocs.com/article/94-how-to-associate-a-domain-to-my-account';
1204 1204
 
1205
-            if ( is_array( $stat ) ) {
1206
-                if ( 1 == $stat['Status'] ) {
1205
+            if (is_array($stat)) {
1206
+                if (1 == $stat['Status']) {
1207 1207
                     // translators: "add more credits" will appear in a "a href".
1208
-                    $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>' );
1208
+                    $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>');
1209 1209
                 } elseif ( -1 == $stat['Status'] || -2 == $stat['Status'] ) {
1210 1210
                     // translators: "add more credits" will appear in a "a href".
1211
-                    $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>' );
1211
+                    $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>');
1212 1212
                     // translators: "associate your domain" will appear in a "a href".
1213
-                    $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>' );
1213
+                    $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>');
1214 1214
                 } else {
1215 1215
                     $upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1216 1216
                     // translators: "log in to check your account" will appear in a "a href".
1217
-                    $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>' );
1217
+                    $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>');
1218 1218
                 }
1219
-                $notice = apply_filters( 'autoptimize_filter_imgopt_notice', $notice );
1219
+                $notice = apply_filters('autoptimize_filter_imgopt_notice', $notice);
1220 1220
 
1221 1221
                 return array(
1222 1222
                     'status' => $stat['Status'],
Please login to merge, or discard this patch.