Completed
Push — master ( 4a80b9...a1e7b8 )
by frank
06:58
created
autoptimize.php 1 patch
Spacing   +78 added lines, -78 removed lines patch added patch discarded remove patch
@@ -12,15 +12,15 @@  discard block
 block discarded – undo
12 12
 http://www.gnu.org/licenses/gpl.txt
13 13
 */
14 14
 
15
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
15
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
16 16
 
17
-define('AUTOPTIMIZE_PLUGIN_DIR',plugin_dir_path(__FILE__));
17
+define('AUTOPTIMIZE_PLUGIN_DIR', plugin_dir_path(__FILE__));
18 18
 
19 19
 // Load config class
20 20
 include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeConfig.php');
21 21
 
22 22
 // Load toolbar class
23
-include( AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeToolbar.php' );
23
+include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeToolbar.php');
24 24
 
25 25
 // Load partners tab if admin
26 26
 if (is_admin()) {
@@ -28,29 +28,29 @@  discard block
 block discarded – undo
28 28
 }
29 29
 
30 30
 // Do we gzip when caching (needed early to load autoptimizeCache.php)
31
-define('AUTOPTIMIZE_CACHE_NOGZIP',(bool) get_option('autoptimize_cache_nogzip'));
31
+define('AUTOPTIMIZE_CACHE_NOGZIP', (bool) get_option('autoptimize_cache_nogzip'));
32 32
 
33 33
 // Load cache class
34 34
 include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeCache.php');
35 35
 
36 36
 // wp-content dir name (automagically set, should not be needed), dirname of AO cache dir and AO-prefix can be overridden in wp-config.php
37
-if (!defined('AUTOPTIMIZE_WP_CONTENT_NAME')) { define('AUTOPTIMIZE_WP_CONTENT_NAME','/'.wp_basename( WP_CONTENT_DIR )); }
38
-if (!defined('AUTOPTIMIZE_CACHE_CHILD_DIR')) { define('AUTOPTIMIZE_CACHE_CHILD_DIR','/cache/autoptimize/'); }
37
+if (!defined('AUTOPTIMIZE_WP_CONTENT_NAME')) { define('AUTOPTIMIZE_WP_CONTENT_NAME', '/'.wp_basename(WP_CONTENT_DIR)); }
38
+if (!defined('AUTOPTIMIZE_CACHE_CHILD_DIR')) { define('AUTOPTIMIZE_CACHE_CHILD_DIR', '/cache/autoptimize/'); }
39 39
 if (!defined('AUTOPTIMIZE_CACHEFILE_PREFIX')) { define('AUTOPTIMIZE_CACHEFILE_PREFIX', 'autoptimize_'); }
40 40
 
41 41
 // Plugin dir constants (plugin url's defined later to accomodate domain mapped sites)
42
-if (is_multisite() && apply_filters( 'autoptimize_separate_blog_caches' , true )) {
42
+if (is_multisite() && apply_filters('autoptimize_separate_blog_caches', true)) {
43 43
     $blog_id = get_current_blog_id();
44
-    define('AUTOPTIMIZE_CACHE_DIR', WP_CONTENT_DIR.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/' );
44
+    define('AUTOPTIMIZE_CACHE_DIR', WP_CONTENT_DIR.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/');
45 45
 } else {
46 46
     define('AUTOPTIMIZE_CACHE_DIR', WP_CONTENT_DIR.AUTOPTIMIZE_CACHE_CHILD_DIR);
47 47
 }
48
-define('AUTOPTIMIZE_CACHE_DELAY',true);
49
-define('WP_ROOT_DIR',substr(WP_CONTENT_DIR, 0, strlen(WP_CONTENT_DIR)-strlen(AUTOPTIMIZE_WP_CONTENT_NAME)));
48
+define('AUTOPTIMIZE_CACHE_DELAY', true);
49
+define('WP_ROOT_DIR', substr(WP_CONTENT_DIR, 0, strlen(WP_CONTENT_DIR) - strlen(AUTOPTIMIZE_WP_CONTENT_NAME)));
50 50
 
51 51
 // WP CLI
52
-if ( defined( 'WP_CLI' ) && WP_CLI ) {
53
-	require_once AUTOPTIMIZE_PLUGIN_DIR . 'classes/autoptimizeCLI.php';
52
+if (defined('WP_CLI') && WP_CLI) {
53
+	require_once AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeCLI.php';
54 54
 }
55 55
 
56 56
 // Initialize the cache at least once
@@ -59,65 +59,65 @@  discard block
 block discarded – undo
59 59
 /* Check if we're updating, in which case we might need to do stuff and flush the cache
60 60
 to avoid old versions of aggregated files lingering around */
61 61
 
62
-$autoptimize_version="2.3.0";
63
-$autoptimize_db_version=get_option('autoptimize_version','none');
62
+$autoptimize_version = "2.3.0";
63
+$autoptimize_db_version = get_option('autoptimize_version', 'none');
64 64
 
65 65
 if ($autoptimize_db_version !== $autoptimize_version) {
66
-    if ($autoptimize_db_version==="none") {
66
+    if ($autoptimize_db_version === "none") {
67 67
         add_action('admin_notices', 'autoptimize_install_config_notice');
68 68
     } else {
69 69
         // updating, include the update-code
70 70
         include(AUTOPTIMIZE_PLUGIN_DIR.'classlesses/autoptimizeUpdateCode.php');
71 71
     }
72 72
 
73
-    update_option('autoptimize_version',$autoptimize_version);
74
-    $autoptimize_db_version=$autoptimize_version;
73
+    update_option('autoptimize_version', $autoptimize_version);
74
+    $autoptimize_db_version = $autoptimize_version;
75 75
 }
76 76
 
77 77
 // Load translations
78 78
 function autoptimize_load_plugin_textdomain() {
79
-    load_plugin_textdomain('autoptimize',false,plugin_basename(dirname( __FILE__ )).'/localization');
79
+    load_plugin_textdomain('autoptimize', false, plugin_basename(dirname(__FILE__)).'/localization');
80 80
 }
81
-add_action( 'init', 'autoptimize_load_plugin_textdomain' );
81
+add_action('init', 'autoptimize_load_plugin_textdomain');
82 82
 
83
-function autoptimize_uninstall(){
83
+function autoptimize_uninstall() {
84 84
     autoptimizeCache::clearall();
85 85
 
86
-    $delete_options=array("autoptimize_cache_clean", "autoptimize_cache_nogzip", "autoptimize_css", "autoptimize_css_datauris", "autoptimize_css_justhead", "autoptimize_css_defer", "autoptimize_css_defer_inline", "autoptimize_css_inline", "autoptimize_css_exclude", "autoptimize_html", "autoptimize_html_keepcomments", "autoptimize_js", "autoptimize_js_exclude", "autoptimize_js_forcehead", "autoptimize_js_justhead", "autoptimize_js_trycatch", "autoptimize_version", "autoptimize_show_adv", "autoptimize_cdn_url", "autoptimize_cachesize_notice","autoptimize_css_include_inline","autoptimize_js_include_inline","autoptimize_optimize_logged","autoptimize_optimize_checkout","autoptimize_extra_settings");
86
+    $delete_options = array("autoptimize_cache_clean", "autoptimize_cache_nogzip", "autoptimize_css", "autoptimize_css_datauris", "autoptimize_css_justhead", "autoptimize_css_defer", "autoptimize_css_defer_inline", "autoptimize_css_inline", "autoptimize_css_exclude", "autoptimize_html", "autoptimize_html_keepcomments", "autoptimize_js", "autoptimize_js_exclude", "autoptimize_js_forcehead", "autoptimize_js_justhead", "autoptimize_js_trycatch", "autoptimize_version", "autoptimize_show_adv", "autoptimize_cdn_url", "autoptimize_cachesize_notice", "autoptimize_css_include_inline", "autoptimize_js_include_inline", "autoptimize_optimize_logged", "autoptimize_optimize_checkout", "autoptimize_extra_settings");
87 87
 
88
-    if ( !is_multisite() ) {
89
-        foreach ($delete_options as $del_opt) { delete_option( $del_opt ); }
88
+    if (!is_multisite()) {
89
+        foreach ($delete_options as $del_opt) { delete_option($del_opt); }
90 90
     } else {
91 91
         global $wpdb;
92
-        $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
92
+        $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
93 93
         $original_blog_id = get_current_blog_id();
94
-        foreach ( $blog_ids as $blog_id ) {
95
-            switch_to_blog( $blog_id );
96
-            foreach ($delete_options as $del_opt) { delete_option( $del_opt ); }
94
+        foreach ($blog_ids as $blog_id) {
95
+            switch_to_blog($blog_id);
96
+            foreach ($delete_options as $del_opt) { delete_option($del_opt); }
97 97
         }
98
-        switch_to_blog( $original_blog_id );
98
+        switch_to_blog($original_blog_id);
99 99
     }
100 100
 
101
-    if ( wp_get_schedule( 'ao_cachechecker' ) ) {
102
-        wp_clear_scheduled_hook( 'ao_cachechecker' );
101
+    if (wp_get_schedule('ao_cachechecker')) {
102
+        wp_clear_scheduled_hook('ao_cachechecker');
103 103
     }
104 104
 }
105 105
 
106 106
 function autoptimize_install_config_notice() {
107 107
     echo '<div class="updated"><p>';
108
-    _e('Thank you for installing and activating Autoptimize. Please configure it under "Settings" -> "Autoptimize" to start improving your site\'s performance.', 'autoptimize' );
108
+    _e('Thank you for installing and activating Autoptimize. Please configure it under "Settings" -> "Autoptimize" to start improving your site\'s performance.', 'autoptimize');
109 109
     echo '</p></div>';
110 110
 }
111 111
 
112 112
 function autoptimize_update_config_notice() {
113 113
     echo '<div class="updated"><p>';
114
-    _e('Autoptimize has just been updated. Please <strong>test your site now</strong> and adapt Autoptimize config if needed.', 'autoptimize' );
114
+    _e('Autoptimize has just been updated. Please <strong>test your site now</strong> and adapt Autoptimize config if needed.', 'autoptimize');
115 115
     echo '</p></div>';
116 116
 }
117 117
 
118 118
 function autoptimize_cache_unavailable_notice() {
119 119
     echo '<div class="error"><p>';
120
-    printf( __( 'Autoptimize cannot write to the cache directory (%s), please fix to enable CSS/ JS optimization!', 'autoptimize' ), AUTOPTIMIZE_CACHE_DIR );
120
+    printf(__('Autoptimize cannot write to the cache directory (%s), please fix to enable CSS/ JS optimization!', 'autoptimize'), AUTOPTIMIZE_CACHE_DIR);
121 121
     echo '</p></div>';
122 122
 }
123 123
 
@@ -126,27 +126,27 @@  discard block
 block discarded – undo
126 126
     $ao_noptimize = false;
127 127
 
128 128
     // noptimize in qs to get non-optimized page for debugging
129
-    if (array_key_exists("ao_noptimize",$_GET) || array_key_exists("ao_noptirocket",$_GET)) {
130
-        if ( ( ($_GET["ao_noptimize"]==="1") || ($_GET["ao_noptirocket"]==="1") ) && (apply_filters('autoptimize_filter_honor_qs_noptimize',true)) ) {
129
+    if (array_key_exists("ao_noptimize", $_GET) || array_key_exists("ao_noptirocket", $_GET)) {
130
+        if ((($_GET["ao_noptimize"] === "1") || ($_GET["ao_noptirocket"] === "1")) && (apply_filters('autoptimize_filter_honor_qs_noptimize', true))) {
131 131
             $ao_noptimize = true;
132 132
         }
133 133
     }
134 134
 
135 135
     // check for DONOTMINIFY constant as used by e.g. WooCommerce POS
136
-    if (defined('DONOTMINIFY') && (constant('DONOTMINIFY')===true || constant('DONOTMINIFY')==="true")) {
136
+    if (defined('DONOTMINIFY') && (constant('DONOTMINIFY') === true || constant('DONOTMINIFY') === "true")) {
137 137
         $ao_noptimize = true;
138 138
     }
139 139
 
140 140
 	// if setting says not to optimize logged in user and user is logged in
141
-	if ( get_option('autoptimize_optimize_logged','on') !== 'on' && is_user_logged_in() && current_user_can('edit_posts') ) {
141
+	if (get_option('autoptimize_optimize_logged', 'on') !== 'on' && is_user_logged_in() && current_user_can('edit_posts')) {
142 142
 		$ao_noptimize = true;
143 143
 	}
144 144
 
145 145
 	// if setting says not to optimize cart/ checkout
146
-	if ( get_option('autoptimize_optimize_checkout','on') !== 'on' ) {
146
+	if (get_option('autoptimize_optimize_checkout', 'on') !== 'on') {
147 147
 		// checking for woocommerce, easy digital downloads and wp ecommerce
148
-		foreach ( array("is_checkout","is_cart","edd_is_checkout","wpsc_is_cart","wpsc_is_checkout") as $shopCond ) {
149
-			if ( function_exists($shopCond) && $shopCond() ) {
148
+		foreach (array("is_checkout", "is_cart", "edd_is_checkout", "wpsc_is_cart", "wpsc_is_checkout") as $shopCond) {
149
+			if (function_exists($shopCond) && $shopCond()) {
150 150
 				$ao_noptimize = true;
151 151
 				break;
152 152
 			}
@@ -154,11 +154,11 @@  discard block
 block discarded – undo
154 154
 	}
155 155
 
156 156
     // filter you can use to block autoptimization on your own terms
157
-    $ao_noptimize = (bool) apply_filters( 'autoptimize_filter_noptimize', $ao_noptimize );
157
+    $ao_noptimize = (bool) apply_filters('autoptimize_filter_noptimize', $ao_noptimize);
158 158
 
159
-    if (!is_feed() && !$ao_noptimize && !is_admin() && ( !function_exists('is_customize_preview') || !is_customize_preview() ) ) {
159
+    if (!is_feed() && !$ao_noptimize && !is_admin() && (!function_exists('is_customize_preview') || !is_customize_preview())) {
160 160
         // load speedupper conditionally (true by default?)
161
-        if ( apply_filters('autoptimize_filter_speedupper', true) ) {
161
+        if (apply_filters('autoptimize_filter_speedupper', true)) {
162 162
             include(AUTOPTIMIZE_PLUGIN_DIR.'classlesses/autoptimizeSpeedupper.php');
163 163
         }
164 164
 
@@ -169,7 +169,7 @@  discard block
 block discarded – undo
169 169
         include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeBase.php');
170 170
 
171 171
         // Load extra classes and set some vars
172
-        if($conf->get('autoptimize_html')) {
172
+        if ($conf->get('autoptimize_html')) {
173 173
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeHTML.php');
174 174
             // BUG: new minify-html does not support keeping HTML comments, skipping for now
175 175
             // if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
@@ -179,7 +179,7 @@  discard block
 block discarded – undo
179 179
             // }
180 180
         }
181 181
 
182
-        if($conf->get('autoptimize_js')) {
182
+        if ($conf->get('autoptimize_js')) {
183 183
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeScripts.php');
184 184
             if (!class_exists('JSMin')) {
185 185
                 if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
@@ -188,15 +188,15 @@  discard block
 block discarded – undo
188 188
                     @include(AUTOPTIMIZE_PLUGIN_DIR.'classes/external/php/minify-2.3.1-jsmin.php');
189 189
                 }
190 190
             }
191
-            if ( ! defined( 'CONCATENATE_SCRIPTS' )) {
192
-                define('CONCATENATE_SCRIPTS',false);
191
+            if (!defined('CONCATENATE_SCRIPTS')) {
192
+                define('CONCATENATE_SCRIPTS', false);
193 193
             }
194
-            if ( ! defined( 'COMPRESS_SCRIPTS' )) {
195
-                define('COMPRESS_SCRIPTS',false);
194
+            if (!defined('COMPRESS_SCRIPTS')) {
195
+                define('COMPRESS_SCRIPTS', false);
196 196
             }
197 197
         }
198 198
 
199
-        if($conf->get('autoptimize_css')) {
199
+        if ($conf->get('autoptimize_css')) {
200 200
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeStyles.php');
201 201
             if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
202 202
                 if (!class_exists('Minify_CSS_Compressor')) {
@@ -207,13 +207,13 @@  discard block
 block discarded – undo
207 207
                     @include(AUTOPTIMIZE_PLUGIN_DIR.'classes/external/php/yui-php-cssmin-2.4.8-4_fgo.php');
208 208
                 }
209 209
             }
210
-            if ( ! defined( 'COMPRESS_CSS' )) {
211
-                define('COMPRESS_CSS',false);
210
+            if (!defined('COMPRESS_CSS')) {
211
+                define('COMPRESS_CSS', false);
212 212
             }
213 213
         }
214 214
 
215 215
         // filter to be used with care, kills all output buffers when true. use with extreme caution. you have been warned!
216
-        if (apply_filters('autoptimize_filter_obkiller',false)) {
216
+        if (apply_filters('autoptimize_filter_obkiller', false)) {
217 217
             while (ob_get_level() > 0) {
218 218
                 ob_end_clean();
219 219
             }
@@ -225,36 +225,36 @@  discard block
 block discarded – undo
225 225
 
226 226
 // Action on end, this is where the magic happens
227 227
 function autoptimize_end_buffering($content) {
228
-    if ( ((stripos($content,"<html") === false) && (stripos($content,"<!DOCTYPE html") === false)) || preg_match('/<html[^>]*(?:amp|⚡)/',$content) === 1 || stripos($content,"<xsl:stylesheet") !== false ) { return $content; }
228
+    if (((stripos($content, "<html") === false) && (stripos($content, "<!DOCTYPE html") === false)) || preg_match('/<html[^>]*(?:amp|⚡)/', $content) === 1 || stripos($content, "<xsl:stylesheet") !== false) { return $content; }
229 229
 
230 230
     // load URL constants as late as possible to allow domain mapper to kick in
231 231
     if (function_exists("domain_mapping_siteurl")) {
232
-        define('AUTOPTIMIZE_WP_SITE_URL',domain_mapping_siteurl(get_current_blog_id()));
233
-        define('AUTOPTIMIZE_WP_CONTENT_URL',str_replace(get_original_url(AUTOPTIMIZE_WP_SITE_URL),AUTOPTIMIZE_WP_SITE_URL,content_url()));
232
+        define('AUTOPTIMIZE_WP_SITE_URL', domain_mapping_siteurl(get_current_blog_id()));
233
+        define('AUTOPTIMIZE_WP_CONTENT_URL', str_replace(get_original_url(AUTOPTIMIZE_WP_SITE_URL), AUTOPTIMIZE_WP_SITE_URL, content_url()));
234 234
     } else {
235
-        define('AUTOPTIMIZE_WP_SITE_URL',site_url());
236
-        define('AUTOPTIMIZE_WP_CONTENT_URL',content_url());
235
+        define('AUTOPTIMIZE_WP_SITE_URL', site_url());
236
+        define('AUTOPTIMIZE_WP_CONTENT_URL', content_url());
237 237
     }
238 238
 
239
-    if ( is_multisite() && apply_filters( 'autoptimize_separate_blog_caches' , true ) ) {
239
+    if (is_multisite() && apply_filters('autoptimize_separate_blog_caches', true)) {
240 240
         $blog_id = get_current_blog_id();
241
-        define('AUTOPTIMIZE_CACHE_URL',AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/' );
241
+        define('AUTOPTIMIZE_CACHE_URL', AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/');
242 242
     } else {
243
-        define('AUTOPTIMIZE_CACHE_URL',AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR);
243
+        define('AUTOPTIMIZE_CACHE_URL', AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR);
244 244
     }
245
-    define('AUTOPTIMIZE_WP_ROOT_URL',str_replace(AUTOPTIMIZE_WP_CONTENT_NAME,'',AUTOPTIMIZE_WP_CONTENT_URL));
246
-    define('AUTOPTIMIZE_HASH',wp_hash(AUTOPTIMIZE_CACHE_DIR));
245
+    define('AUTOPTIMIZE_WP_ROOT_URL', str_replace(AUTOPTIMIZE_WP_CONTENT_NAME, '', AUTOPTIMIZE_WP_CONTENT_URL));
246
+    define('AUTOPTIMIZE_HASH', wp_hash(AUTOPTIMIZE_CACHE_DIR));
247 247
 
248 248
     // Config element
249 249
     $conf = autoptimizeConfig::instance();
250 250
 
251 251
     // Choose the classes
252 252
     $classes = array();
253
-    if($conf->get('autoptimize_js'))
253
+    if ($conf->get('autoptimize_js'))
254 254
         $classes[] = 'autoptimizeScripts';
255
-    if($conf->get('autoptimize_css'))
255
+    if ($conf->get('autoptimize_css'))
256 256
         $classes[] = 'autoptimizeStyles';
257
-    if($conf->get('autoptimize_html'))
257
+    if ($conf->get('autoptimize_html'))
258 258
         $classes[] = 'autoptimizeHTML';
259 259
 
260 260
     // Set some options
@@ -283,12 +283,12 @@  discard block
 block discarded – undo
283 283
         )
284 284
     );
285 285
 
286
-    $content = apply_filters( 'autoptimize_filter_html_before_minify', $content );
286
+    $content = apply_filters('autoptimize_filter_html_before_minify', $content);
287 287
 
288 288
     // Run the classes
289
-    foreach($classes as $name) {
289
+    foreach ($classes as $name) {
290 290
         $instance = new $name($content);
291
-        if($instance->read($classoptions[$name])) {
291
+        if ($instance->read($classoptions[$name])) {
292 292
             $instance->minify();
293 293
             $instance->cache();
294 294
             $content = $instance->getcontent();
@@ -296,19 +296,19 @@  discard block
 block discarded – undo
296 296
         unset($instance);
297 297
     }
298 298
     
299
-    $content = apply_filters( 'autoptimize_html_after_minify', $content );
299
+    $content = apply_filters('autoptimize_html_after_minify', $content);
300 300
     return $content;
301 301
 }
302 302
 
303
-if ( autoptimizeCache::cacheavail() ) {
303
+if (autoptimizeCache::cacheavail()) {
304 304
     $conf = autoptimizeConfig::instance();
305
-    if( $conf->get('autoptimize_html') || $conf->get('autoptimize_js') || $conf->get('autoptimize_css') ) {
305
+    if ($conf->get('autoptimize_html') || $conf->get('autoptimize_js') || $conf->get('autoptimize_css')) {
306 306
         // Hook to wordpress
307 307
         if (defined('AUTOPTIMIZE_INIT_EARLIER')) {
308
-            add_action('init','autoptimize_start_buffering',-1);
308
+            add_action('init', 'autoptimize_start_buffering', -1);
309 309
         } else {
310 310
             if (!defined('AUTOPTIMIZE_HOOK_INTO')) { define('AUTOPTIMIZE_HOOK_INTO', 'template_redirect'); }
311
-            add_action(constant("AUTOPTIMIZE_HOOK_INTO"),'autoptimize_start_buffering',2);
311
+            add_action(constant("AUTOPTIMIZE_HOOK_INTO"), 'autoptimize_start_buffering', 2);
312 312
         }
313 313
     }
314 314
 } else {
@@ -316,15 +316,15 @@  discard block
 block discarded – undo
316 316
 }
317 317
 
318 318
 function autoptimize_activate() {
319
-    register_uninstall_hook( __FILE__, 'autoptimize_uninstall' );
319
+    register_uninstall_hook(__FILE__, 'autoptimize_uninstall');
320 320
 }
321
-register_activation_hook( __FILE__, 'autoptimize_activate' );
321
+register_activation_hook(__FILE__, 'autoptimize_activate');
322 322
 
323 323
 include_once('classlesses/autoptimizeCacheChecker.php');
324 324
 
325
-add_action('plugins_loaded','includeAutoptimizeExtra');
325
+add_action('plugins_loaded', 'includeAutoptimizeExtra');
326 326
 function includeAutoptimizeExtra() {
327
-    if ( apply_filters('autoptimize_filter_extra_activate',true) ) {
327
+    if (apply_filters('autoptimize_filter_extra_activate', true)) {
328 328
         include_once('classlesses/autoptimizeExtra.php');
329 329
     }
330 330
 }
Please login to merge, or discard this patch.
classes/autoptimizeScripts.php 1 patch
Spacing   +115 added lines, -115 removed lines patch added patch discarded remove patch
@@ -1,11 +1,11 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 class autoptimizeScripts extends autoptimizeBase {
5 5
     private $scripts = array();
6
-    private $dontmove = array('document.write','html5.js','show_ads.js','google_ad','histats.com/js','statcounter.com/counter/counter.js','ws.amazon.com/widgets','media.fastclick.net','/ads/','comment-form-quicktags/quicktags.php','edToolbar','intensedebate.com','scripts.chitika.net/','_gaq.push','jotform.com/','admin-bar.min.js','GoogleAnalyticsObject','plupload.full.min.js','syntaxhighlighter','adsbygoogle','gist.github.com','_stq','nonce','post_id','data-noptimize','wordfence_logHuman');
7
-    private $domove = array('gaJsHost','load_cmc','jd.gallery.transitions.js','swfobject.embedSWF(','tiny_mce.js','tinyMCEPreInit.go');
8
-    private $domovelast = array('addthis.com','/afsonline/show_afs_search.js','disqus.js','networkedblogs.com/getnetworkwidget','infolinks.com/js/','jd.gallery.js.php','jd.gallery.transitions.js','swfobject.embedSWF(','linkwithin.com/widget.js','tiny_mce.js','tinyMCEPreInit.go');
6
+    private $dontmove = array('document.write', 'html5.js', 'show_ads.js', 'google_ad', 'histats.com/js', 'statcounter.com/counter/counter.js', 'ws.amazon.com/widgets', 'media.fastclick.net', '/ads/', 'comment-form-quicktags/quicktags.php', 'edToolbar', 'intensedebate.com', 'scripts.chitika.net/', '_gaq.push', 'jotform.com/', 'admin-bar.min.js', 'GoogleAnalyticsObject', 'plupload.full.min.js', 'syntaxhighlighter', 'adsbygoogle', 'gist.github.com', '_stq', 'nonce', 'post_id', 'data-noptimize', 'wordfence_logHuman');
7
+    private $domove = array('gaJsHost', 'load_cmc', 'jd.gallery.transitions.js', 'swfobject.embedSWF(', 'tiny_mce.js', 'tinyMCEPreInit.go');
8
+    private $domovelast = array('addthis.com', '/afsonline/show_afs_search.js', 'disqus.js', 'networkedblogs.com/getnetworkwidget', 'infolinks.com/js/', 'jd.gallery.js.php', 'jd.gallery.transitions.js', 'swfobject.embedSWF(', 'linkwithin.com/widget.js', 'tiny_mce.js', 'tinyMCEPreInit.go');
9 9
     private $trycatch = false;
10 10
     private $alreadyminified = false;
11 11
     private $forcehead = true;
@@ -21,70 +21,70 @@  discard block
 block discarded – undo
21 21
     
22 22
     //Reads the page and collects script tags
23 23
     public function read($options) {
24
-        $noptimizeJS = apply_filters( 'autoptimize_filter_js_noptimize', false, $this->content );
24
+        $noptimizeJS = apply_filters('autoptimize_filter_js_noptimize', false, $this->content);
25 25
         if ($noptimizeJS) return false;
26 26
 
27 27
         // only optimize known good JS?
28
-        $whitelistJS = apply_filters( 'autoptimize_filter_js_whitelist', '', $this->content );
28
+        $whitelistJS = apply_filters('autoptimize_filter_js_whitelist', '', $this->content);
29 29
         if (!empty($whitelistJS)) {
30
-            $this->whitelist = array_filter(array_map('trim',explode(",",$whitelistJS)));
30
+            $this->whitelist = array_filter(array_map('trim', explode(",", $whitelistJS)));
31 31
         }
32 32
 
33 33
         // is there JS we should simply remove
34
-        $removableJS = apply_filters( 'autoptimize_filter_js_removables', '', $this->content );
34
+        $removableJS = apply_filters('autoptimize_filter_js_removables', '', $this->content);
35 35
         if (!empty($removableJS)) {
36
-            $this->jsremovables = array_filter(array_map('trim',explode(",",$removableJS)));
36
+            $this->jsremovables = array_filter(array_map('trim', explode(",", $removableJS)));
37 37
         }
38 38
 
39 39
         // only header?
40
-        if( apply_filters('autoptimize_filter_js_justhead', $options['justhead']) == true ) {
41
-            $content = explode('</head>',$this->content,2);
40
+        if (apply_filters('autoptimize_filter_js_justhead', $options['justhead']) == true) {
41
+            $content = explode('</head>', $this->content, 2);
42 42
             $this->content = $content[0].'</head>';
43 43
             $this->restofcontent = $content[1];
44 44
         }
45 45
         
46 46
         // include inline?
47
-        if( apply_filters('autoptimize_js_include_inline', $options['include_inline']) == true ) {
47
+        if (apply_filters('autoptimize_js_include_inline', $options['include_inline']) == true) {
48 48
             $this->include_inline = true;
49 49
         }
50 50
 
51 51
         // filter to "late inject minified JS", default to true for now (it is faster)
52
-        $this->inject_min_late = apply_filters('autoptimize_filter_js_inject_min_late',true);
52
+        $this->inject_min_late = apply_filters('autoptimize_filter_js_inject_min_late', true);
53 53
 
54 54
         // filters to override hardcoded do(nt)move(last) array contents (array in, array out!)
55
-        $this->dontmove = apply_filters( 'autoptimize_filter_js_dontmove', $this->dontmove );        
56
-        $this->domovelast = apply_filters( 'autoptimize_filter_js_movelast', $this->domovelast );
57
-        $this->domove = apply_filters( 'autoptimize_filter_js_domove', $this->domove );
55
+        $this->dontmove = apply_filters('autoptimize_filter_js_dontmove', $this->dontmove);        
56
+        $this->domovelast = apply_filters('autoptimize_filter_js_movelast', $this->domovelast);
57
+        $this->domove = apply_filters('autoptimize_filter_js_domove', $this->domove);
58 58
 
59 59
         // get extra exclusions settings or filter
60 60
         $excludeJS = $options['js_exclude'];
61
-        $excludeJS = apply_filters( 'autoptimize_filter_js_exclude', $excludeJS, $this->content );
62
-        if ($excludeJS!=="") {
61
+        $excludeJS = apply_filters('autoptimize_filter_js_exclude', $excludeJS, $this->content);
62
+        if ($excludeJS !== "") {
63 63
             if (is_array($excludeJS)) {
64
-                if(($removeKeys = array_keys($excludeJS,"remove")) !== false) {
64
+                if (($removeKeys = array_keys($excludeJS, "remove")) !== false) {
65 65
                     foreach ($removeKeys as $removeKey) {
66 66
                         unset($excludeJS[$removeKey]);
67
-                        $this->jsremovables[]=$removeKey;
67
+                        $this->jsremovables[] = $removeKey;
68 68
                     }
69 69
                 }
70 70
                 $exclJSArr = array_keys($excludeJS);
71 71
             } else {
72
-                $exclJSArr = array_filter(array_map('trim',explode(",",$excludeJS)));
72
+                $exclJSArr = array_filter(array_map('trim', explode(",", $excludeJS)));
73 73
             }
74
-            $this->dontmove = array_merge($exclJSArr,$this->dontmove);
74
+            $this->dontmove = array_merge($exclJSArr, $this->dontmove);
75 75
         }
76 76
 
77 77
         //Should we add try-catch?
78
-        if($options['trycatch'] == true)
78
+        if ($options['trycatch'] == true)
79 79
             $this->trycatch = true;
80 80
 
81 81
         // force js in head?    
82
-        if($options['forcehead'] == true) {
82
+        if ($options['forcehead'] == true) {
83 83
             $this->forcehead = true;
84 84
         } else {
85 85
             $this->forcehead = false;
86 86
         }
87
-        $this->forcehead = apply_filters( 'autoptimize_filter_js_forcehead', $this->forcehead );
87
+        $this->forcehead = apply_filters('autoptimize_filter_js_forcehead', $this->forcehead);
88 88
 
89 89
         // get cdn url
90 90
         $this->cdn_url = $options['cdn_url'];
@@ -99,24 +99,24 @@  discard block
 block discarded – undo
99 99
         $this->content = $this->hide_comments($this->content);
100 100
 
101 101
         // Get script files
102
-        if (preg_match_all('#<script.*</script>#Usmi',$this->content,$matches)) {
103
-            foreach($matches[0] as $tag) {
102
+        if (preg_match_all('#<script.*</script>#Usmi', $this->content, $matches)) {
103
+            foreach ($matches[0] as $tag) {
104 104
                 // only consider script aggregation for types whitelisted in should_aggregate-function
105
-                if( !$this->should_aggregate($tag) ) {
106
-                    $tag='';
105
+                if (!$this->should_aggregate($tag)) {
106
+                    $tag = '';
107 107
                     continue;
108 108
                 }
109 109
 
110
-                if (preg_match('#<script[^>]*src=("|\')([^>]*)("|\')#Usmi',$tag,$source)) {
110
+                if (preg_match('#<script[^>]*src=("|\')([^>]*)("|\')#Usmi', $tag, $source)) {
111 111
                     // non-inline script
112
-                    if ($this->isremovable($tag,$this->jsremovables)) {
113
-                        $this->content = str_replace($tag,'',$this->content);
112
+                    if ($this->isremovable($tag, $this->jsremovables)) {
113
+                        $this->content = str_replace($tag, '', $this->content);
114 114
                         continue;
115 115
                     }
116
-                    $explUrl = explode('?',$source[2],2);
116
+                    $explUrl = explode('?', $source[2], 2);
117 117
                     $url = $explUrl[0];
118 118
                     $path = $this->getpath($url);
119
-                    if($path !== false && preg_match('#\.js$#',$path) && $this->ismergeable($tag)) {
119
+                    if ($path !== false && preg_match('#\.js$#', $path) && $this->ismergeable($tag)) {
120 120
                         // ok to optimize, add to array
121 121
                         $this->scripts[] = $path;
122 122
                     } else {
@@ -127,14 +127,14 @@  discard block
 block discarded – undo
127 127
                         if (is_array($excludeJS)) {
128 128
                             // should we add flags?
129 129
                             foreach ($excludeJS as $exclTag => $exclFlags) {
130
-                                if ( strpos($origTag,$exclTag)!==false && in_array($exclFlags,array("async","defer")) ) {
131
-                                   $newTag = str_replace('<script ','<script '.$exclFlags.' ',$newTag);
130
+                                if (strpos($origTag, $exclTag) !== false && in_array($exclFlags, array("async", "defer"))) {
131
+                                   $newTag = str_replace('<script ', '<script '.$exclFlags.' ', $newTag);
132 132
                                 }
133 133
                             }
134 134
                         }
135 135
                         
136 136
    						// should we minify the non-aggregated script?
137
-						if ($path && apply_filters('autoptimize_filter_js_minify_excluded',false)) {
137
+						if ($path && apply_filters('autoptimize_filter_js_minify_excluded', false)) {
138 138
 							$_CachedMinifiedUrl = $this->minify_single($path);
139 139
 
140 140
 							// replace orig URL with minified URL from cache if so
@@ -143,23 +143,23 @@  discard block
 block discarded – undo
143 143
 							}
144 144
 							
145 145
 							// remove querystring from URL in newTag
146
-							if ( !empty($explUrl[1]) ) {
147
-								$newTag = str_replace("?".$explUrl[1],"",$newTag);
146
+							if (!empty($explUrl[1])) {
147
+								$newTag = str_replace("?".$explUrl[1], "", $newTag);
148 148
 							}
149 149
 						}
150 150
 
151 151
 						// should we move the non-aggregated script?
152
-                        if( $this->ismovable($newTag) ) {
152
+                        if ($this->ismovable($newTag)) {
153 153
                             // can be moved, flags and all
154
-                            if( $this->movetolast($newTag) )    {
154
+                            if ($this->movetolast($newTag)) {
155 155
                                 $this->move['last'][] = $newTag;
156 156
                             } else {
157 157
                                 $this->move['first'][] = $newTag;
158 158
                             }
159 159
                         } else {
160 160
                             // cannot be moved, so if flag was added re-inject altered tag immediately
161
-                            if ( $origTag !== $newTag ) {
162
-                                $this->content = str_replace($origTag,$newTag,$this->content);
161
+                            if ($origTag !== $newTag) {
162
+                                $this->content = str_replace($origTag, $newTag, $this->content);
163 163
                                 $origTag = '';
164 164
                             }
165 165
                             // and forget about the $tag (not to be touched any more)
@@ -168,23 +168,23 @@  discard block
 block discarded – undo
168 168
                     }
169 169
                 } else {
170 170
                     // Inline script
171
-                    if ($this->isremovable($tag,$this->jsremovables)) {
172
-                        $this->content = str_replace($tag,'',$this->content);
171
+                    if ($this->isremovable($tag, $this->jsremovables)) {
172
+                        $this->content = str_replace($tag, '', $this->content);
173 173
                         continue;
174 174
                     }
175 175
                     
176 176
                     // unhide comments, as javascript may be wrapped in comment-tags for old times' sake
177 177
                     $tag = $this->restore_comments($tag);
178
-                    if($this->ismergeable($tag) && ( $this->include_inline )) {
179
-                        preg_match('#<script.*>(.*)</script>#Usmi',$tag,$code);
180
-                        $code = preg_replace('#.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*#sm','$1',$code[1]);
181
-                        $code = preg_replace('/(?:^\\s*<!--\\s*|\\s*(?:\\/\\/)?\\s*-->\\s*$)/','',$code);
178
+                    if ($this->ismergeable($tag) && ($this->include_inline)) {
179
+                        preg_match('#<script.*>(.*)</script>#Usmi', $tag, $code);
180
+                        $code = preg_replace('#.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*#sm', '$1', $code[1]);
181
+                        $code = preg_replace('/(?:^\\s*<!--\\s*|\\s*(?:\\/\\/)?\\s*-->\\s*$)/', '', $code);
182 182
                         $this->scripts[] = 'INLINE;'.$code;
183 183
                     } else {
184 184
                         // Can we move this?
185
-                        $autoptimize_js_moveable = apply_filters( 'autoptimize_js_moveable', '', $tag );
186
-                        if( $this->ismovable($tag) || $autoptimize_js_moveable !== '' ) {
187
-                            if( $this->movetolast($tag) || $autoptimize_js_moveable === 'last' ) {
185
+                        $autoptimize_js_moveable = apply_filters('autoptimize_js_moveable', '', $tag);
186
+                        if ($this->ismovable($tag) || $autoptimize_js_moveable !== '') {
187
+                            if ($this->movetolast($tag) || $autoptimize_js_moveable === 'last') {
188 188
                                 $this->move['last'][] = $tag;
189 189
                             } else {
190 190
                                 $this->move['first'][] = $tag;
@@ -199,7 +199,7 @@  discard block
 block discarded – undo
199 199
                 }
200 200
                 
201 201
                 //Remove the original script tag
202
-                $this->content = str_replace($tag,'',$this->content);
202
+                $this->content = str_replace($tag, '', $this->content);
203 203
             }
204 204
             
205 205
             return true;
@@ -211,39 +211,39 @@  discard block
 block discarded – undo
211 211
     
212 212
     //Joins and optimizes JS
213 213
     public function minify() {
214
-        foreach($this->scripts as $script) {
215
-            if(preg_match('#^INLINE;#',$script)) {
214
+        foreach ($this->scripts as $script) {
215
+            if (preg_match('#^INLINE;#', $script)) {
216 216
                 //Inline script
217
-                $script = preg_replace('#^INLINE;#','',$script);
218
-                $script = rtrim( $script, ";\n\t\r" ) . ';';
217
+                $script = preg_replace('#^INLINE;#', '', $script);
218
+                $script = rtrim($script, ";\n\t\r").';';
219 219
                 //Add try-catch?
220
-                if($this->trycatch) {
220
+                if ($this->trycatch) {
221 221
                     $script = 'try{'.$script.'}catch(e){}';
222 222
                 }
223
-                $tmpscript = apply_filters( 'autoptimize_js_individual_script', $script, '' );
224
-                if ( has_filter('autoptimize_js_individual_script') && !empty($tmpscript) ) {
225
-                    $script=$tmpscript;
226
-                    $this->alreadyminified=true;
223
+                $tmpscript = apply_filters('autoptimize_js_individual_script', $script, '');
224
+                if (has_filter('autoptimize_js_individual_script') && !empty($tmpscript)) {
225
+                    $script = $tmpscript;
226
+                    $this->alreadyminified = true;
227 227
                 }
228
-                $this->jscode .= "\n" . $script;
228
+                $this->jscode .= "\n".$script;
229 229
             } else {
230 230
                 //External script
231
-                if($script !== false && file_exists($script) && is_readable($script)) {
231
+                if ($script !== false && file_exists($script) && is_readable($script)) {
232 232
                     $scriptsrc = file_get_contents($script);
233 233
                     $scripthash = md5($scriptsrc);
234
-                    $scriptsrc = preg_replace('/\x{EF}\x{BB}\x{BF}/','',$scriptsrc);
235
-                    $scriptsrc = rtrim($scriptsrc,";\n\t\r").';';
234
+                    $scriptsrc = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $scriptsrc);
235
+                    $scriptsrc = rtrim($scriptsrc, ";\n\t\r").';';
236 236
 
237 237
                     //Add try-catch?
238
-                    if($this->trycatch) {
238
+                    if ($this->trycatch) {
239 239
                         $scriptsrc = 'try{'.$scriptsrc.'}catch(e){}';
240 240
                     }
241
-                    $tmpscriptsrc = apply_filters( 'autoptimize_js_individual_script', $scriptsrc, $script );
242
-                    if ( has_filter('autoptimize_js_individual_script') && !empty($tmpscriptsrc) ) {
243
-                        $scriptsrc=$tmpscriptsrc;
244
-                        $this->alreadyminified=true;
241
+                    $tmpscriptsrc = apply_filters('autoptimize_js_individual_script', $scriptsrc, $script);
242
+                    if (has_filter('autoptimize_js_individual_script') && !empty($tmpscriptsrc)) {
243
+                        $scriptsrc = $tmpscriptsrc;
244
+                        $this->alreadyminified = true;
245 245
                     } else if ($this->can_inject_late($script)) {
246
-                        $scriptsrc="/*!%%INJECTLATER".AUTOPTIMIZE_HASH."%%".base64_encode($script)."|".$scripthash."%%INJECTLATER%%*/";
246
+                        $scriptsrc = "/*!%%INJECTLATER".AUTOPTIMIZE_HASH."%%".base64_encode($script)."|".$scripthash."%%INJECTLATER%%*/";
247 247
                     }
248 248
                     $this->jscode .= "\n".$scriptsrc;
249 249
                 }/*else{
@@ -254,24 +254,24 @@  discard block
 block discarded – undo
254 254
 
255 255
         //Check for already-minified code
256 256
         $this->md5hash = md5($this->jscode);
257
-        $ccheck = new autoptimizeCache($this->md5hash,'js');
258
-        if($ccheck->check()) {
257
+        $ccheck = new autoptimizeCache($this->md5hash, 'js');
258
+        if ($ccheck->check()) {
259 259
             $this->jscode = $ccheck->retrieve();
260 260
             return true;
261 261
         }
262 262
         unset($ccheck);
263 263
         
264 264
         //$this->jscode has all the uncompressed code now.
265
-        if ($this->alreadyminified!==true) {
266
-          if (class_exists('JSMin') && apply_filters( 'autoptimize_js_do_minify' , true)) {
267
-            if (@is_callable(array("JSMin","minify"))) {
265
+        if ($this->alreadyminified !== true) {
266
+          if (class_exists('JSMin') && apply_filters('autoptimize_js_do_minify', true)) {
267
+            if (@is_callable(array("JSMin", "minify"))) {
268 268
                 $tmp_jscode = trim(JSMin::minify($this->jscode));
269 269
                 if (!empty($tmp_jscode)) {
270 270
                     $this->jscode = $tmp_jscode;
271 271
                     unset($tmp_jscode);
272 272
                 }
273 273
                 $this->jscode = $this->inject_minified($this->jscode);
274
-                $this->jscode = apply_filters( 'autoptimize_js_after_minify', $this->jscode );
274
+                $this->jscode = apply_filters('autoptimize_js_after_minify', $this->jscode);
275 275
                 return true;
276 276
             } else {
277 277
                 $this->jscode = $this->inject_minified($this->jscode);
@@ -282,16 +282,16 @@  discard block
 block discarded – undo
282 282
               return false;
283 283
           }
284 284
         }
285
-        $this->jscode = apply_filters( 'autoptimize_js_after_minify', $this->jscode );
285
+        $this->jscode = apply_filters('autoptimize_js_after_minify', $this->jscode);
286 286
         return true;
287 287
     }
288 288
     
289 289
     //Caches the JS in uncompressed, deflated and gzipped form.
290
-    public function cache()    {
291
-        $cache = new autoptimizeCache($this->md5hash,'js');
292
-        if(!$cache->check()) {
290
+    public function cache() {
291
+        $cache = new autoptimizeCache($this->md5hash, 'js');
292
+        if (!$cache->check()) {
293 293
             //Cache our code
294
-            $cache->cache($this->jscode,'text/javascript');
294
+            $cache->cache($this->jscode, 'text/javascript');
295 295
         }
296 296
         $this->url = AUTOPTIMIZE_CACHE_URL.$cache->getname();
297 297
         $this->url = $this->url_replace_cdn($this->url);
@@ -300,32 +300,32 @@  discard block
 block discarded – undo
300 300
     // Returns the content
301 301
     public function getcontent() {
302 302
         // Restore the full content
303
-        if(!empty($this->restofcontent)) {
303
+        if (!empty($this->restofcontent)) {
304 304
             $this->content .= $this->restofcontent;
305 305
             $this->restofcontent = '';
306 306
         }
307 307
         
308 308
         // Add the scripts taking forcehead/ deferred (default) into account
309
-        if($this->forcehead == true) {
310
-            $replaceTag=array("</head>","before");
311
-            $defer="";
309
+        if ($this->forcehead == true) {
310
+            $replaceTag = array("</head>", "before");
311
+            $defer = "";
312 312
         } else {
313
-            $replaceTag=array("</body>","before");
314
-            $defer="defer ";
313
+            $replaceTag = array("</body>", "before");
314
+            $defer = "defer ";
315 315
         }
316 316
         
317
-        $defer = apply_filters( 'autoptimize_filter_js_defer', $defer );
317
+        $defer = apply_filters('autoptimize_filter_js_defer', $defer);
318 318
         $bodyreplacementpayload = '<script type="text/javascript" '.$defer.'src="'.$this->url.'"></script>';
319
-        $bodyreplacementpayload = apply_filters('autoptimize_filter_js_bodyreplacementpayload',$bodyreplacementpayload);
319
+        $bodyreplacementpayload = apply_filters('autoptimize_filter_js_bodyreplacementpayload', $bodyreplacementpayload);
320 320
 
321
-        $bodyreplacement = implode('',$this->move['first']);
321
+        $bodyreplacement = implode('', $this->move['first']);
322 322
         $bodyreplacement .= $bodyreplacementpayload;
323
-        $bodyreplacement .= implode('',$this->move['last']);
323
+        $bodyreplacement .= implode('', $this->move['last']);
324 324
 
325
-        $replaceTag = apply_filters( 'autoptimize_filter_js_replacetag', $replaceTag );
325
+        $replaceTag = apply_filters('autoptimize_filter_js_replacetag', $replaceTag);
326 326
 
327
-        if (strlen($this->jscode)>0) {
328
-            $this->inject_in_html($bodyreplacement,$replaceTag);
327
+        if (strlen($this->jscode) > 0) {
328
+            $this->inject_in_html($bodyreplacement, $replaceTag);
329 329
         }
330 330
         
331 331
         // restore comments
@@ -343,19 +343,19 @@  discard block
 block discarded – undo
343 343
     
344 344
     // Checks against the white- and blacklists
345 345
     private function ismergeable($tag) {
346
-		if (apply_filters('autoptimize_filter_js_dontaggregate',false)) {
346
+		if (apply_filters('autoptimize_filter_js_dontaggregate', false)) {
347 347
 			return false;
348 348
         } else if (!empty($this->whitelist)) {
349 349
             foreach ($this->whitelist as $match) {
350
-                if(strpos($tag,$match)!==false) {
350
+                if (strpos($tag, $match) !== false) {
351 351
                     return true;
352 352
                 }
353 353
             }
354 354
             // no match with whitelist
355 355
             return false;
356 356
         } else {
357
-            foreach($this->domove as $match) {
358
-                if(strpos($tag,$match)!==false)    {
357
+            foreach ($this->domove as $match) {
358
+                if (strpos($tag, $match) !== false) {
359 359
                     // Matched something
360 360
                     return false;
361 361
                 }
@@ -365,8 +365,8 @@  discard block
 block discarded – undo
365 365
                 return false;
366 366
             }
367 367
             
368
-            foreach($this->dontmove as $match) {
369
-                if(strpos($tag,$match)!==false)    {
368
+            foreach ($this->dontmove as $match) {
369
+                if (strpos($tag, $match) !== false) {
370 370
                     //Matched something
371 371
                     return false;
372 372
                 }
@@ -379,12 +379,12 @@  discard block
 block discarded – undo
379 379
     
380 380
     // Checks againstt the blacklist
381 381
     private function ismovable($tag) {
382
-        if ($this->include_inline !== true || apply_filters('autoptimize_filter_js_unmovable',true)) {
382
+        if ($this->include_inline !== true || apply_filters('autoptimize_filter_js_unmovable', true)) {
383 383
             return false;
384 384
         }
385 385
         
386
-        foreach($this->domove as $match) {
387
-            if(strpos($tag,$match)!==false)    {
386
+        foreach ($this->domove as $match) {
387
+            if (strpos($tag, $match) !== false) {
388 388
                 // Matched something
389 389
                 return true;
390 390
             }
@@ -394,8 +394,8 @@  discard block
 block discarded – undo
394 394
             return true;
395 395
         }
396 396
         
397
-        foreach($this->dontmove as $match) {
398
-            if(strpos($tag,$match)!==false) {
397
+        foreach ($this->dontmove as $match) {
398
+            if (strpos($tag, $match) !== false) {
399 399
                 // Matched something
400 400
                 return false;
401 401
             }
@@ -406,8 +406,8 @@  discard block
 block discarded – undo
406 406
     }
407 407
     
408 408
     private function movetolast($tag) {
409
-        foreach($this->domovelast as $match) {
410
-            if(strpos($tag,$match)!==false)    {
409
+        foreach ($this->domovelast as $match) {
410
+            if (strpos($tag, $match) !== false) {
411 411
                 // Matched, return true
412 412
                 return true;
413 413
             }
@@ -433,10 +433,10 @@  discard block
 block discarded – undo
433 433
      * original function by https://github.com/zytzagoo/ on his AO fork, thanks Tomas!
434 434
      */
435 435
     public function should_aggregate($tag) {
436
-        preg_match('#<(script[^>]*)>#i',$tag,$scripttag);
437
-        if ( strpos($scripttag[1], 'type')===false ) {
436
+        preg_match('#<(script[^>]*)>#i', $tag, $scripttag);
437
+        if (strpos($scripttag[1], 'type') === false) {
438 438
             return true;
439
-        } else if ( preg_match('/type\s*=\s*["\']?(?:text|application)\/(?:javascript|ecmascript)["\']?/i', $scripttag[1]) ) {
439
+        } else if (preg_match('/type\s*=\s*["\']?(?:text|application)\/(?:javascript|ecmascript)["\']?/i', $scripttag[1])) {
440 440
             return true;
441 441
         } else {
442 442
             return false;
@@ -454,11 +454,11 @@  discard block
 block discarded – undo
454 454
      * @return bool
455 455
 	 */
456 456
 	private function can_inject_late($jsPath) {
457
-		$consider_minified_array = apply_filters('autoptimize_filter_js_consider_minified',false);
458
-        if ( $this->inject_min_late !== true ) {
457
+		$consider_minified_array = apply_filters('autoptimize_filter_js_consider_minified', false);
458
+        if ($this->inject_min_late !== true) {
459 459
             // late-inject turned off
460 460
             return false;
461
-        } else if ( (strpos($jsPath,"min.js") === false) && ( strpos($jsPath,"wp-includes/js/jquery/jquery.js") === false ) && ( str_replace($consider_minified_array, '', $jsPath) === $jsPath ) ) {
461
+        } else if ((strpos($jsPath, "min.js") === false) && (strpos($jsPath, "wp-includes/js/jquery/jquery.js") === false) && (str_replace($consider_minified_array, '', $jsPath) === $jsPath)) {
462 462
 			// file not minified based on filename & filter
463 463
 			return false;
464 464
         } else {
Please login to merge, or discard this patch.
classlesses/autoptimizeUpdateCode.php 1 patch
Spacing   +40 added lines, -40 removed lines patch added patch discarded remove patch
@@ -3,48 +3,48 @@  discard block
 block discarded – undo
3 3
 * below code handles updates and is only included by autoptimize.php if/ when needed
4 4
 */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
6
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
7 7
 
8 8
 $majorUp = false;        
9
-$autoptimize_major_version=substr($autoptimize_db_version,0,3);
9
+$autoptimize_major_version = substr($autoptimize_db_version, 0, 3);
10 10
 
11
-switch($autoptimize_major_version) {
11
+switch ($autoptimize_major_version) {
12 12
     case "1.6":
13 13
         // from back in the days when I did not yet consider multisite
14 14
         // if user was on version 1.6.x, force advanced options to be shown by default
15
-        update_option('autoptimize_show_adv','1');
15
+        update_option('autoptimize_show_adv', '1');
16 16
 
17 17
         // and remove old options
18
-        $to_delete_options=array("autoptimize_cdn_css","autoptimize_cdn_css_url","autoptimize_cdn_js","autoptimize_cdn_js_url","autoptimize_cdn_img","autoptimize_cdn_img_url","autoptimize_css_yui","autoptimize_js_yui");
18
+        $to_delete_options = array("autoptimize_cdn_css", "autoptimize_cdn_css_url", "autoptimize_cdn_js", "autoptimize_cdn_js_url", "autoptimize_cdn_img", "autoptimize_cdn_img_url", "autoptimize_css_yui", "autoptimize_js_yui");
19 19
         foreach ($to_delete_options as $del_opt) {
20
-            delete_option( $del_opt );
20
+            delete_option($del_opt);
21 21
         }
22 22
         $majorUp = true;
23 23
     case "1.7":
24 24
         // force 3.8 dashicons in CSS exclude options when upgrading from 1.7 to 1.8
25
-        if ( !is_multisite() ) {
25
+        if (!is_multisite()) {
26 26
             $css_exclude = get_option('autoptimize_css_exclude');
27 27
             if (empty($css_exclude)) {
28 28
                 $css_exclude = "admin-bar.min.css, dashicons.min.css";
29
-            } else if (strpos($css_exclude,"dashicons.min.css")===false) {
29
+            } else if (strpos($css_exclude, "dashicons.min.css") === false) {
30 30
                 $css_exclude .= ", dashicons.min.css";
31 31
             }
32
-            update_option('autoptimize_css_exclude',$css_exclude);
32
+            update_option('autoptimize_css_exclude', $css_exclude);
33 33
         } else {
34 34
             global $wpdb;
35
-            $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
35
+            $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
36 36
             $original_blog_id = get_current_blog_id();
37
-            foreach ( $blog_ids as $blog_id ) {
38
-                switch_to_blog( $blog_id );
37
+            foreach ($blog_ids as $blog_id) {
38
+                switch_to_blog($blog_id);
39 39
                 $css_exclude = get_option('autoptimize_css_exclude');
40 40
                 if (empty($css_exclude)) {
41 41
                     $css_exclude = "admin-bar.min.css, dashicons.min.css";
42
-                } else if (strpos($css_exclude,"dashicons.min.css")===false) {
42
+                } else if (strpos($css_exclude, "dashicons.min.css") === false) {
43 43
                     $css_exclude .= ", dashicons.min.css";
44 44
                 }
45
-                update_option('autoptimize_css_exclude',$css_exclude);
45
+                update_option('autoptimize_css_exclude', $css_exclude);
46 46
             }
47
-            switch_to_blog( $original_blog_id );
47
+            switch_to_blog($original_blog_id);
48 48
         }
49 49
         $majorUp = true;
50 50
     case "1.9":
@@ -52,53 +52,53 @@  discard block
 block discarded – undo
52 52
         * 2.0 will not aggregate inline CSS/JS by default, but we want users
53 53
         * upgrading from 1.9 to keep their inline code aggregated by default. 
54 54
         */
55
-        if ( !is_multisite() ) {
56
-            update_option('autoptimize_css_include_inline','on');
57
-            update_option('autoptimize_js_include_inline','on');
55
+        if (!is_multisite()) {
56
+            update_option('autoptimize_css_include_inline', 'on');
57
+            update_option('autoptimize_js_include_inline', 'on');
58 58
         } else {
59 59
             global $wpdb;
60
-            $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
60
+            $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
61 61
             $original_blog_id = get_current_blog_id();
62
-            foreach ( $blog_ids as $blog_id ) {
63
-                switch_to_blog( $blog_id );
64
-                update_option('autoptimize_css_include_inline','on');
65
-                update_option('autoptimize_js_include_inline','on');
62
+            foreach ($blog_ids as $blog_id) {
63
+                switch_to_blog($blog_id);
64
+                update_option('autoptimize_css_include_inline', 'on');
65
+                update_option('autoptimize_js_include_inline', 'on');
66 66
             }
67
-            switch_to_blog( $original_blog_id );    
67
+            switch_to_blog($original_blog_id);    
68 68
         }
69 69
         $majorUp = true;
70 70
     case "2.2":
71 71
         /*
72 72
          * 2.3 has no "remove google fonts" in main screen, moved to "extra"
73 73
          */
74
-        if ( !is_multisite() ) {
75
-            $_nogooglefont = get_option('autoptimize_css_nogooglefont','');
76
-            $_ao_extrasetting = get_option('autoptimize_extra_settings','');
77
-            if ( ($_nogooglefont == 1) && ( empty($_ao_extrasetting) ) ) {
78
-                $_aoextra_removegfonts = array("autoptimize_extra_checkbox_field_1"=>"0","autoptimize_extra_checkbox_field_0"=>"0","autoptimize_extra_radio_field_4"=>"1","autoptimize_extra_text_field_2"=>"","autoptimize_extra_text_field_3"=>"");
79
-                update_option( 'autoptimize_extra_settings', $_aoextra_removegfonts );
74
+        if (!is_multisite()) {
75
+            $_nogooglefont = get_option('autoptimize_css_nogooglefont', '');
76
+            $_ao_extrasetting = get_option('autoptimize_extra_settings', '');
77
+            if (($_nogooglefont == 1) && (empty($_ao_extrasetting))) {
78
+                $_aoextra_removegfonts = array("autoptimize_extra_checkbox_field_1"=>"0", "autoptimize_extra_checkbox_field_0"=>"0", "autoptimize_extra_radio_field_4"=>"1", "autoptimize_extra_text_field_2"=>"", "autoptimize_extra_text_field_3"=>"");
79
+                update_option('autoptimize_extra_settings', $_aoextra_removegfonts);
80 80
             }
81 81
             delete_option('autoptimize_css_nogooglefont');
82 82
         } else {
83 83
             global $wpdb;
84
-            $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
84
+            $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
85 85
             $original_blog_id = get_current_blog_id();
86
-            foreach ( $blog_ids as $blog_id ) {
87
-                switch_to_blog( $blog_id );
88
-                    $_nogooglefont = get_option('autoptimize_css_nogooglefont','');
89
-                    $_ao_extrasetting = get_option('autoptimize_extra_settings','');
90
-                    if ( ($_nogooglefont == 1) && ( empty($_ao_extrasetting) ) ) {
91
-                    $_aoextra_removegfonts = array("autoptimize_extra_checkbox_field_1"=>"0","autoptimize_extra_checkbox_field_0"=>"0","autoptimize_extra_radio_field_4"=>"1","autoptimize_extra_text_field_2"=>"","autoptimize_extra_text_field_3"=>"");
92
-                    update_option( 'autoptimize_extra_settings', $_aoextra_removegfonts );
86
+            foreach ($blog_ids as $blog_id) {
87
+                switch_to_blog($blog_id);
88
+                    $_nogooglefont = get_option('autoptimize_css_nogooglefont', '');
89
+                    $_ao_extrasetting = get_option('autoptimize_extra_settings', '');
90
+                    if (($_nogooglefont == 1) && (empty($_ao_extrasetting))) {
91
+                    $_aoextra_removegfonts = array("autoptimize_extra_checkbox_field_1"=>"0", "autoptimize_extra_checkbox_field_0"=>"0", "autoptimize_extra_radio_field_4"=>"1", "autoptimize_extra_text_field_2"=>"", "autoptimize_extra_text_field_3"=>"");
92
+                    update_option('autoptimize_extra_settings', $_aoextra_removegfonts);
93 93
                 }
94 94
                 delete_option('autoptimize_css_nogooglefont');
95 95
             }
96
-            switch_to_blog( $original_blog_id );
96
+            switch_to_blog($original_blog_id);
97 97
         }
98 98
         $majorUp = true;
99 99
     }
100 100
 
101
-if ( $majorUp === true ) {
101
+if ($majorUp === true) {
102 102
     // clear cache and notify user to check result if major upgrade
103 103
     autoptimizeCache::clearall();
104 104
     add_action('admin_notices', 'autoptimize_update_config_notice');
Please login to merge, or discard this patch.
classlesses/autoptimizeExtra.php 1 patch
Spacing   +103 added lines, -103 removed lines patch added patch discarded remove patch
@@ -1,18 +1,18 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 // initialize
5
-if ( is_admin() ) {
6
-    add_action( 'admin_menu', 'autoptimize_extra_admin' );
7
-    add_filter( 'autoptimize_filter_settingsscreen_tabs','add_autoptimize_extra_tab' );
5
+if (is_admin()) {
6
+    add_action('admin_menu', 'autoptimize_extra_admin');
7
+    add_filter('autoptimize_filter_settingsscreen_tabs', 'add_autoptimize_extra_tab');
8 8
 } else {
9 9
     autoptimize_extra_init();
10 10
 }
11 11
 
12 12
 // get option
13 13
 function autoptimize_extra_get_options() {
14
-    $_default_val = array("autoptimize_extra_checkbox_field_1"=>"0","autoptimize_extra_checkbox_field_0"=>"0","autoptimize_extra_radio_field_4"=>"1","autoptimize_extra_text_field_2"=>"","autoptimize_extra_text_field_3"=>"");
15
-    $_option_val = get_option( 'autoptimize_extra_settings' );
14
+    $_default_val = array("autoptimize_extra_checkbox_field_1"=>"0", "autoptimize_extra_checkbox_field_0"=>"0", "autoptimize_extra_radio_field_4"=>"1", "autoptimize_extra_text_field_2"=>"", "autoptimize_extra_text_field_3"=>"");
15
+    $_option_val = get_option('autoptimize_extra_settings');
16 16
     if (empty($_option_val)) {
17 17
         $_option_val = $_default_val;
18 18
     }
@@ -24,74 +24,74 @@  discard block
 block discarded – undo
24 24
     $autoptimize_extra_options = autoptimize_extra_get_options();
25 25
 
26 26
     /* disable emojis */
27
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) ) {
27
+    if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1'])) {
28 28
         autoptimize_extra_disable_emojis();
29 29
     }
30 30
     
31 31
     /* remove version from query string */
32
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) ) {
33
-        add_filter( 'script_loader_src', 'autoptimize_extra_remove_qs', 15, 1 );
34
-        add_filter( 'style_loader_src', 'autoptimize_extra_remove_qs', 15, 1 );
32
+    if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0'])) {
33
+        add_filter('script_loader_src', 'autoptimize_extra_remove_qs', 15, 1);
34
+        add_filter('style_loader_src', 'autoptimize_extra_remove_qs', 15, 1);
35 35
     }
36 36
 
37 37
     /* async JS */
38 38
     if (!empty($autoptimize_extra_options['autoptimize_extra_text_field_3'])) {
39
-        add_filter('autoptimize_filter_js_exclude','autoptimize_extra_async_js',10,1);
39
+        add_filter('autoptimize_filter_js_exclude', 'autoptimize_extra_async_js', 10, 1);
40 40
     }
41 41
 
42 42
     /* optimize google fonts */
43
-    if ( !empty( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] ) && ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] != "1" ) ) {
44
-        add_filter( 'wp_resource_hints', 'autoptimize_extra_gfonts_remove_dnsprefetch', 10, 2 );        
45
-        if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "2" ) {
46
-            add_filter('autoptimize_filter_css_removables','autoptimize_extra_remove_gfonts',10,1);
43
+    if (!empty($autoptimize_extra_options['autoptimize_extra_radio_field_4']) && ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] != "1")) {
44
+        add_filter('wp_resource_hints', 'autoptimize_extra_gfonts_remove_dnsprefetch', 10, 2);        
45
+        if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "2") {
46
+            add_filter('autoptimize_filter_css_removables', 'autoptimize_extra_remove_gfonts', 10, 1);
47 47
         } else {
48
-            add_filter('autoptimize_html_after_minify','autoptimize_extra_gfonts',10,1);
49
-            add_filter('autoptimize_extra_filter_tobepreconn','autoptimize_extra_preconnectgooglefonts',10,1);
48
+            add_filter('autoptimize_html_after_minify', 'autoptimize_extra_gfonts', 10, 1);
49
+            add_filter('autoptimize_extra_filter_tobepreconn', 'autoptimize_extra_preconnectgooglefonts', 10, 1);
50 50
         }
51 51
     }
52 52
     
53 53
     /* preconnect */
54
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn') ) {
55
-        add_filter( 'wp_resource_hints', 'autoptimize_extra_preconnect', 10, 2 );
54
+    if (!empty($autoptimize_extra_options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn')) {
55
+        add_filter('wp_resource_hints', 'autoptimize_extra_preconnect', 10, 2);
56 56
     }
57 57
 }
58 58
 
59 59
 // disable emoji's functions
60 60
 function autoptimize_extra_disable_emojis() {
61 61
     // all actions related to emojis
62
-    remove_action( 'admin_print_styles', 'print_emoji_styles' );
63
-    remove_action( 'wp_head', 'print_emoji_detection_script', 7 );
64
-    remove_action( 'admin_print_scripts', 'print_emoji_detection_script' );
65
-    remove_action( 'wp_print_styles', 'print_emoji_styles' );
66
-    remove_filter( 'wp_mail', 'wp_staticize_emoji_for_email' );
67
-    remove_filter( 'the_content_feed', 'wp_staticize_emoji' );
68
-    remove_filter( 'comment_text_rss', 'wp_staticize_emoji' );
62
+    remove_action('admin_print_styles', 'print_emoji_styles');
63
+    remove_action('wp_head', 'print_emoji_detection_script', 7);
64
+    remove_action('admin_print_scripts', 'print_emoji_detection_script');
65
+    remove_action('wp_print_styles', 'print_emoji_styles');
66
+    remove_filter('wp_mail', 'wp_staticize_emoji_for_email');
67
+    remove_filter('the_content_feed', 'wp_staticize_emoji');
68
+    remove_filter('comment_text_rss', 'wp_staticize_emoji');
69 69
 
70 70
     // filter to remove TinyMCE emojis
71
-    add_filter( 'tiny_mce_plugins', 'autoptimize_extra_disable_emojis_tinymce' );
71
+    add_filter('tiny_mce_plugins', 'autoptimize_extra_disable_emojis_tinymce');
72 72
 
73 73
     // and remove dns-prefetch for emoji
74
-    add_filter( 'wp_resource_hints', 'autoptimize_extra_emojis_remove_dns_prefetch', 10, 2 );
74
+    add_filter('wp_resource_hints', 'autoptimize_extra_emojis_remove_dns_prefetch', 10, 2);
75 75
 }
76 76
 
77
-function autoptimize_extra_disable_emojis_tinymce( $plugins ) {
78
-    if ( is_array( $plugins ) ) {
79
-        return array_diff( $plugins, array( 'wpemoji' ) );
77
+function autoptimize_extra_disable_emojis_tinymce($plugins) {
78
+    if (is_array($plugins)) {
79
+        return array_diff($plugins, array('wpemoji'));
80 80
     } else {
81 81
         return array();
82 82
     }
83 83
 }
84 84
 
85
-function autoptimize_extra_emojis_remove_dns_prefetch( $urls, $relation_type ) {
86
-    $_emoji_svg_url = apply_filters( 'emoji_svg_url', 'https://s.w.org/images/core/emoji/' );
85
+function autoptimize_extra_emojis_remove_dns_prefetch($urls, $relation_type) {
86
+    $_emoji_svg_url = apply_filters('emoji_svg_url', 'https://s.w.org/images/core/emoji/');
87 87
 
88
-    return autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_emoji_svg_url );
88
+    return autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_emoji_svg_url);
89 89
 }
90 90
 
91 91
 // remove query string function
92
-function autoptimize_extra_remove_qs( $src ) {
93
-    if ( strpos($src, '?ver=') ) {
94
-            $src = remove_query_arg( 'ver', $src );
92
+function autoptimize_extra_remove_qs($src) {
93
+    if (strpos($src, '?ver=')) {
94
+            $src = remove_query_arg('ver', $src);
95 95
     }
96 96
     return $src;
97 97
 }
@@ -103,18 +103,18 @@  discard block
 block discarded – undo
103 103
     // get exclusions
104 104
     $AO_JSexclArrayIn = array();
105 105
     if (!empty($in)) {
106
-        $AO_JSexclArrayIn = array_fill_keys(array_filter(array_map('trim',explode(",",$in))),"");
106
+        $AO_JSexclArrayIn = array_fill_keys(array_filter(array_map('trim', explode(",", $in))), "");
107 107
     }
108 108
     
109 109
     // get asyncs
110 110
     $_fromSetting = $autoptimize_extra_options['autoptimize_extra_text_field_3'];
111
-    $AO_asynced_JS = array_fill_keys(array_filter(array_map('trim',explode(",",$_fromSetting))),"");
111
+    $AO_asynced_JS = array_fill_keys(array_filter(array_map('trim', explode(",", $_fromSetting))), "");
112 112
     foreach ($AO_asynced_JS as $JSkey => $JSvalue) {
113 113
         $AO_asynced_JS[$JSkey] = "async";
114 114
     }
115 115
     
116 116
     // merge exclusions & asyncs in one array and return to AO API
117
-    $AO_excl_w_async = array_merge( $AO_JSexclArrayIn, $AO_asynced_JS );
117
+    $AO_excl_w_async = array_merge($AO_JSexclArrayIn, $AO_asynced_JS);
118 118
     return $AO_excl_w_async;
119 119
 }
120 120
 
@@ -123,25 +123,25 @@  discard block
 block discarded – undo
123 123
     $autoptimize_extra_options = autoptimize_extra_get_options();
124 124
     
125 125
     // get setting and store in array
126
-    $_to_be_preconnected = array_filter(array_map('trim',explode(",",$autoptimize_extra_options['autoptimize_extra_text_field_2'])));
127
-    $_to_be_preconnected = apply_filters( 'autoptimize_extra_filter_tobepreconn', $_to_be_preconnected );
126
+    $_to_be_preconnected = array_filter(array_map('trim', explode(",", $autoptimize_extra_options['autoptimize_extra_text_field_2'])));
127
+    $_to_be_preconnected = apply_filters('autoptimize_extra_filter_tobepreconn', $_to_be_preconnected);
128 128
 
129 129
     // walk array, extract domain and add to new array with crossorigin attribute
130 130
     foreach ($_to_be_preconnected as $_preconn_single) {
131 131
         $_preconn_parsed = parse_url($_preconn_single);
132 132
         
133
-        if ( is_array($_preconn_parsed) && empty($_preconn_parsed['scheme']) ) {
133
+        if (is_array($_preconn_parsed) && empty($_preconn_parsed['scheme'])) {
134 134
             $_preconn_domain = "//".$_preconn_parsed['host'];
135
-        } else if ( is_array($_preconn_parsed) ) {
135
+        } else if (is_array($_preconn_parsed)) {
136 136
             $_preconn_domain = $_preconn_parsed['scheme']."://".$_preconn_parsed['host'];
137 137
         }
138 138
         
139
-        if ( !empty($_preconn_domain) ) {
139
+        if (!empty($_preconn_domain)) {
140 140
             $_preconn_hint = array('href' => $_preconn_domain);
141 141
             // fonts don't get preconnected unless crossorigin flag is set, non-fonts don't get preconnected if origin flag is set
142 142
             // so hardcode fonts.gstatic.com to come with crossorigin and have filter to add other domains if needed
143
-            $_preconn_crossorigin = apply_filters( 'autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com') );
144
-            if ( in_array( $_preconn_domain, $_preconn_crossorigin ) ) {
143
+            $_preconn_crossorigin = apply_filters('autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com'));
144
+            if (in_array($_preconn_domain, $_preconn_crossorigin)) {
145 145
                 $_preconn_hint['crossorigin'] = 'anonymous';
146 146
             }
147 147
             $_new_hints[] = $_preconn_hint;
@@ -149,7 +149,7 @@  discard block
 block discarded – undo
149 149
     }
150 150
 
151 151
     // merge in wordpress' preconnect hints
152
-    if ( 'preconnect' === $relation_type && !empty($_new_hints) ) {
152
+    if ('preconnect' === $relation_type && !empty($_new_hints)) {
153 153
         $hints = array_merge($hints, $_new_hints);      
154 154
     }
155 155
     
@@ -157,10 +157,10 @@  discard block
 block discarded – undo
157 157
 }
158 158
 
159 159
 // google font functions
160
-function autoptimize_extra_gfonts_remove_dnsprefetch ( $urls, $relation_type ) {
160
+function autoptimize_extra_gfonts_remove_dnsprefetch($urls, $relation_type) {
161 161
     $_gfonts_url = "fonts.googleapis.com";
162 162
     
163
-    return autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_gfonts_url );
163
+    return autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_gfonts_url);
164 164
 }
165 165
 
166 166
 function autoptimize_extra_remove_gfonts($in) { 
@@ -172,48 +172,48 @@  discard block
 block discarded – undo
172 172
     $autoptimize_extra_options = autoptimize_extra_get_options();
173 173
     
174 174
     // extract fonts, partly based on wp rocket's extraction code
175
-    $_without_comments = preg_replace( '/<!--(.*)-->/Uis', '', $in );
176
-    preg_match_all( '#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $_without_comments, $matches );
175
+    $_without_comments = preg_replace('/<!--(.*)-->/Uis', '', $in);
176
+    preg_match_all('#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $_without_comments, $matches);
177 177
 
178 178
     $i = 0;
179 179
     $fontsCollection = 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
-    foreach ( $matches[2] as $font ) {
186
-        if ( ! preg_match( '/rel=["\']dns-prefetch["\']/', $matches[0][ $i ] ) ) {
185
+    foreach ($matches[2] as $font) {
186
+        if (!preg_match('/rel=["\']dns-prefetch["\']/', $matches[0][$i])) {
187 187
             // Get fonts name.
188
-            $font = str_replace( array( '%7C', '%7c' ) , '|', $font );
189
-            $font = explode( 'family=', $font );
190
-            $font = ( isset( $font[1] ) ) ? explode( '&', $font[1] ) : array();
188
+            $font = str_replace(array('%7C', '%7c'), '|', $font);
189
+            $font = explode('family=', $font);
190
+            $font = (isset($font[1])) ? explode('&', $font[1]) : array();
191 191
             // Add font to $fonts[$i] but make sure not to pollute with an empty family
192
-            $_thisfont = array_values( array_filter( explode( '|', reset( $font ) ) ) );
193
-            if ( !empty($_thisfont) ) {
192
+            $_thisfont = array_values(array_filter(explode('|', reset($font))));
193
+            if (!empty($_thisfont)) {
194 194
                 $fontsCollection[$i]["fonts"] = $_thisfont;
195 195
                 // And add subset if any
196
-                $subset = ( is_array( $font ) ) ? end( $font ) : '';
197
-                if ( false !== strpos( $subset, 'subset=' ) ) {
198
-                    $subset = explode( 'subset=', $subset );
199
-                    $fontsCollection[$i]["subsets"] = explode( ',', $subset[1] );
196
+                $subset = (is_array($font)) ? end($font) : '';
197
+                if (false !== strpos($subset, 'subset=')) {
198
+                    $subset = explode('subset=', $subset);
199
+                    $fontsCollection[$i]["subsets"] = explode(',', $subset[1]);
200 200
                 }
201 201
             }
202 202
             // And remove Google Fonts.
203
-            $in = str_replace( $matches[0][ $i ], '', $in );
203
+            $in = str_replace($matches[0][$i], '', $in);
204 204
         }
205 205
         $i++;
206 206
     }
207 207
 
208
-    $_fontsOut="";
209
-    if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "3" ) {
208
+    $_fontsOut = "";
209
+    if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "3") {
210 210
         // aggregate & link
211
-        $_fontsString="";
212
-        $_subsetString="";
211
+        $_fontsString = "";
212
+        $_subsetString = "";
213 213
         foreach ($fontsCollection as $font) {
214
-            $_fontsString .= '|'.trim( implode( '|' , $font["fonts"] ), '|' );
215
-            if ( !empty( $font["subsets"] ) ) {
216
-                $_subsetString .= implode( ',', $font["subsets"] ); 
214
+            $_fontsString .= '|'.trim(implode('|', $font["fonts"]), '|');
215
+            if (!empty($font["subsets"])) {
216
+                $_subsetString .= implode(',', $font["subsets"]); 
217 217
             }
218 218
         }
219 219
                     
@@ -221,17 +221,17 @@  discard block
 block discarded – undo
221 221
             $_fontsString = $_fontsString."#038;subset=".$_subsetString;
222 222
         }
223 223
 
224
-        $_fontsString = str_replace( '|', '%7C', ltrim($_fontsString,'|') );
224
+        $_fontsString = str_replace('|', '%7C', ltrim($_fontsString, '|'));
225 225
         
226
-        if ( ! empty( $_fontsString ) ) {
227
-            $_fontsOut = '<link rel="stylesheet" id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family=' . $_fontsString . '" />';
226
+        if (!empty($_fontsString)) {
227
+            $_fontsOut = '<link rel="stylesheet" id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family='.$_fontsString.'" />';
228 228
         }
229
-    } else if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4" ) {
229
+    } else if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4") {
230 230
         // aggregate & load async (webfont.js impl.)
231 231
         $_fontsArray = array();
232 232
         foreach ($fontsCollection as $_fonts) {
233
-            if ( !empty( $_fonts["subsets"] ) ) {
234
-                $_subset = implode(",",$_fonts["subsets"]);
233
+            if (!empty($_fonts["subsets"])) {
234
+                $_subset = implode(",", $_fonts["subsets"]);
235 235
                 foreach ($_fonts["fonts"] as $key => $_one_font) {
236 236
                     $_one_font = $_one_font.":".$_subset;
237 237
                     $_fonts["fonts"][$key] = $_one_font;
@@ -244,7 +244,7 @@  discard block
 block discarded – undo
244 244
         foreach ($_fontsArray as $_font) {
245 245
             $_fontsOut .= $_font."','";
246 246
         }
247
-        $_fontsOut = trim(trim($_fontsOut,"'"),",");
247
+        $_fontsOut = trim(trim($_fontsOut, "'"), ",");
248 248
         $_fontsOut .= '] },classes:false, events:false, timeout:1500};(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>';
249 249
     }
250 250
  
@@ -258,7 +258,7 @@  discard block
 block discarded – undo
258 258
 
259 259
     // preconnect to fonts.gstatic.com speed up download of static font-files
260 260
     $in[] = "https://fonts.gstatic.com";
261
-    if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4" ) {
261
+    if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4") {
262 262
         // and more preconnects for webfont.js
263 263
         $in[] = "https://ajax.googleapis.com";
264 264
         $in[] = "https://fonts.googleapis.com";
@@ -266,11 +266,11 @@  discard block
 block discarded – undo
266 266
     return $in;
267 267
 }
268 268
 
269
-function autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_remove_url ) {
270
-        if ( 'dns-prefetch' == $relation_type ) {
271
-        $_count=0;
269
+function autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_remove_url) {
270
+        if ('dns-prefetch' == $relation_type) {
271
+        $_count = 0;
272 272
         foreach ($urls as $_url) {
273
-            if ( strpos($_url, $_remove_url) !== false ) {
273
+            if (strpos($_url, $_remove_url) !== false) {
274 274
                 unset($urls[$_count]);
275 275
             }
276 276
             $_count++;
@@ -282,12 +282,12 @@  discard block
 block discarded – undo
282 282
 
283 283
 /* admin page functions */
284 284
 function autoptimize_extra_admin() { 
285
-    add_submenu_page( null, 'autoptimize_extra', 'autoptimize_extra', 'manage_options', 'autoptimize_extra', 'autoptimize_extra_options_page' );
286
-    register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
285
+    add_submenu_page(null, 'autoptimize_extra', 'autoptimize_extra', 'manage_options', 'autoptimize_extra', 'autoptimize_extra_options_page');
286
+    register_setting('autoptimize_extra_settings', 'autoptimize_extra_settings');
287 287
 }
288 288
 
289 289
 function add_autoptimize_extra_tab($in) {
290
-    $in=array_merge($in,array('autoptimize_extra' => __('Extra','autoptimize')));
290
+    $in = array_merge($in, array('autoptimize_extra' => __('Extra', 'autoptimize')));
291 291
     return $in;
292 292
 }
293 293
 
@@ -301,46 +301,46 @@  discard block
 block discarded – undo
301 301
         #autoptimize_extra_descr{font-size: 120%;}
302 302
     </style>
303 303
     <div class="wrap">
304
-    <h1><?php _e('Autoptimize Settings','autoptimize'); ?></h1>
304
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
305 305
     <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
306 306
     <form id='ao_settings_form' action='options.php' method='post'>
307 307
         <?php settings_fields('autoptimize_extra_settings'); ?>
308
-        <h2><?php _e('Extra Auto-Optimizations','autoptimize'); ?></h2>
309
-        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.','autoptimize'); ?></span>
308
+        <h2><?php _e('Extra Auto-Optimizations', 'autoptimize'); ?></h2>
309
+        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.', 'autoptimize'); ?></span>
310 310
         <table class="form-table">
311 311
             <tr>
312
-                <th scope="row"><?php _e('Remove emojis','autoptimize'); ?></th>
312
+                <th scope="row"><?php _e('Remove emojis', 'autoptimize'); ?></th>
313 313
                 <td>
314
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) && 1 == $autoptimize_extra_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>
314
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) && 1 == $autoptimize_extra_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>
315 315
                 </td>
316 316
             </tr>
317 317
             <tr>
318
-                <th scope="row"><?php _e('Remove query strings from static resources','autoptimize'); ?></th>
318
+                <th scope="row"><?php _e('Remove query strings from static resources', 'autoptimize'); ?></th>
319 319
                 <td>
320
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty( $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) && 1 == $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) echo 'checked="checked"'; ?> value='1'><?php _e('Removing query strings (or more specificaly the <code>ver</code> parameter) will not improve load time, but might improve performance scores.','autoptimize'); ?></label>
320
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) && 1 == $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) echo 'checked="checked"'; ?> value='1'><?php _e('Removing query strings (or more specificaly the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize'); ?></label>
321 321
                 </td>
322 322
             </tr>
323 323
             <tr>
324
-                <th scope="row"><?php _e('Google Fonts','autoptimize'); ?></th>
324
+                <th scope="row"><?php _e('Google Fonts', 'autoptimize'); ?></th>
325 325
                 <td>
326
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($_googlef,array(2,3,4))) {echo "checked"; } ?> ><?php _e('Leave as is','autoptimize'); ?><br/>
327
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $_googlef, true); ?> ><?php _e('Remove Google Fonts','autoptimize'); ?><br/>
328
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $_googlef, true); ?> ><?php _e('Combine and link in head','autoptimize'); ?><br/>
329
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $_googlef, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>','autoptimize'); ?><br/>
326
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($_googlef, array(2, 3, 4))) {echo "checked"; } ?> ><?php _e('Leave as is', 'autoptimize'); ?><br/>
327
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $_googlef, true); ?> ><?php _e('Remove Google Fonts', 'autoptimize'); ?><br/>
328
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $_googlef, true); ?> ><?php _e('Combine and link in head', 'autoptimize'); ?><br/>
329
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $_googlef, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize'); ?><br/>
330 330
                 </td>
331 331
             </tr>
332 332
             <tr>
333
-                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>','autoptimize'); ?></th>
333
+                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize'); ?></th>
334 334
                 <td>
335
-                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php echo $autoptimize_extra_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>
335
+                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php echo $autoptimize_extra_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>
336 336
                 </td>
337 337
             </tr>
338 338
             <tr>
339
-                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>','autoptimize'); ?></th>
339
+                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>', 'autoptimize'); ?></th>
340 340
                 <td>
341 341
                     <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php echo $autoptimize_extra_options['autoptimize_extra_text_field_3']; ?>'>
342 342
                     <br />
343
-                    <?php _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'); ?>
343
+                    <?php _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'); ?>
344 344
                 </td>
345 345
             </tr>
346 346
         </table>
Please login to merge, or discard this patch.
classes/autoptimizeCache.php 1 patch
Spacing   +61 added lines, -61 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 class autoptimizeCache {
5 5
     private $filename;
@@ -7,14 +7,14 @@  discard block
 block discarded – undo
7 7
     private $cachedir;
8 8
     private $delayed;
9 9
     
10
-    public function __construct($md5,$ext='php') {
10
+    public function __construct($md5, $ext = 'php') {
11 11
         $this->cachedir = AUTOPTIMIZE_CACHE_DIR;
12 12
         $this->delayed = AUTOPTIMIZE_CACHE_DELAY;
13 13
         $this->nogzip = AUTOPTIMIZE_CACHE_NOGZIP;
14
-        if($this->nogzip == false) {
14
+        if ($this->nogzip == false) {
15 15
             $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.php';
16 16
         } else {
17
-            if (in_array($ext, array("js","css")))     {
17
+            if (in_array($ext, array("js", "css"))) {
18 18
                 $this->filename = $ext.'/'.AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext;
19 19
             } else {
20 20
                 $this->filename = AUTOPTIMIZE_CACHEFILE_PREFIX.$md5.'.'.$ext;
@@ -23,7 +23,7 @@  discard block
 block discarded – undo
23 23
     }
24 24
     
25 25
     public function check() {
26
-        if(!file_exists($this->cachedir.$this->filename)) {
26
+        if (!file_exists($this->cachedir.$this->filename)) {
27 27
             // No cached file, sorry
28 28
             return false;
29 29
         }
@@ -32,8 +32,8 @@  discard block
 block discarded – undo
32 32
     }
33 33
     
34 34
     public function retrieve() {
35
-        if($this->check()) {
36
-            if($this->nogzip == false) {
35
+        if ($this->check()) {
36
+            if ($this->nogzip == false) {
37 37
                 return file_get_contents($this->cachedir.$this->filename.'.none');
38 38
             } else {
39 39
                 return file_get_contents($this->cachedir.$this->filename);
@@ -42,48 +42,48 @@  discard block
 block discarded – undo
42 42
         return false;
43 43
     }
44 44
     
45
-    public function cache($code,$mime) {
46
-        if($this->nogzip == false) {
45
+    public function cache($code, $mime) {
46
+        if ($this->nogzip == false) {
47 47
             $file = ($this->delayed ? 'delayed.php' : 'default.php');
48 48
             $phpcode = file_get_contents(AUTOPTIMIZE_PLUGIN_DIR.'/config/'.$file);
49
-            $phpcode = str_replace(array('%%CONTENT%%','exit;'),array($mime,''),$phpcode);
50
-            file_put_contents($this->cachedir.$this->filename,$phpcode, LOCK_EX);
51
-            file_put_contents($this->cachedir.$this->filename.'.none',$code, LOCK_EX);
52
-            if(!$this->delayed) {
49
+            $phpcode = str_replace(array('%%CONTENT%%', 'exit;'), array($mime, ''), $phpcode);
50
+            file_put_contents($this->cachedir.$this->filename, $phpcode, LOCK_EX);
51
+            file_put_contents($this->cachedir.$this->filename.'.none', $code, LOCK_EX);
52
+            if (!$this->delayed) {
53 53
                 // Compress now!
54
-                file_put_contents($this->cachedir.$this->filename.'.deflate',gzencode($code,9,FORCE_DEFLATE), LOCK_EX);
55
-                file_put_contents($this->cachedir.$this->filename.'.gzip',gzencode($code,9,FORCE_GZIP), LOCK_EX);
54
+                file_put_contents($this->cachedir.$this->filename.'.deflate', gzencode($code, 9, FORCE_DEFLATE), LOCK_EX);
55
+                file_put_contents($this->cachedir.$this->filename.'.gzip', gzencode($code, 9, FORCE_GZIP), LOCK_EX);
56 56
             }
57 57
         } else {
58 58
             // Write code to cache without doing anything else
59
-            file_put_contents($this->cachedir.$this->filename,$code, LOCK_EX);
59
+            file_put_contents($this->cachedir.$this->filename, $code, LOCK_EX);
60 60
             if (apply_filters('autoptimize_filter_cache_create_static_gzip', false)) {
61 61
                 // Create an additional cached gzip file
62
-                file_put_contents($this->cachedir.$this->filename.'.gz', gzencode($code,9,FORCE_GZIP), LOCK_EX);
62
+                file_put_contents($this->cachedir.$this->filename.'.gz', gzencode($code, 9, FORCE_GZIP), LOCK_EX);
63 63
             }
64 64
         }
65 65
     }
66 66
     
67 67
     public function getname() {
68
-        apply_filters('autoptimize_filter_cache_getname',AUTOPTIMIZE_CACHE_URL.$this->filename);
68
+        apply_filters('autoptimize_filter_cache_getname', AUTOPTIMIZE_CACHE_URL.$this->filename);
69 69
         return $this->filename;
70 70
     }
71 71
     
72 72
     static function clearall() {
73
-        if(!autoptimizeCache::cacheavail()) {
73
+        if (!autoptimizeCache::cacheavail()) {
74 74
             return false;
75 75
         }
76 76
     
77 77
         // scan the cachedirs        
78
-        foreach (array("","js","css") as $scandirName) {
78
+        foreach (array("", "js", "css") as $scandirName) {
79 79
             $scan[$scandirName] = scandir(AUTOPTIMIZE_CACHE_DIR.$scandirName);
80 80
         }
81 81
         
82 82
         // clear the cachedirs
83 83
         foreach ($scan as $scandirName=>$scanneddir) {
84
-            $thisAoCacheDir=rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName,"/")."/";
85
-            foreach($scanneddir as $file) {
86
-                if(!in_array($file,array('.','..')) && strpos($file,AUTOPTIMIZE_CACHEFILE_PREFIX) !== false && is_file($thisAoCacheDir.$file)) {
84
+            $thisAoCacheDir = rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName, "/")."/";
85
+            foreach ($scanneddir as $file) {
86
+                if (!in_array($file, array('.', '..')) && strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) !== false && is_file($thisAoCacheDir.$file)) {
87 87
                     @unlink($thisAoCacheDir.$file);
88 88
                 }
89 89
             }
@@ -98,16 +98,16 @@  discard block
 block discarded – undo
98 98
                 do_action("autoptimize_action_cachepurged");
99 99
             }
100 100
         }
101
-        add_action("shutdown","autoptimize_do_cachepurged_action",11);
101
+        add_action("shutdown", "autoptimize_do_cachepurged_action", 11);
102 102
         
103 103
         // try to purge caching plugins cache-files?
104 104
         include_once(AUTOPTIMIZE_PLUGIN_DIR.'classlesses/autoptimizePageCacheFlush.php');
105
-        add_action("autoptimize_action_cachepurged","autoptimize_flush_pagecache",10,0);
105
+        add_action("autoptimize_action_cachepurged", "autoptimize_flush_pagecache", 10, 0);
106 106
 
107 107
         // warm cache (part of speedupper)?
108
-        if ( apply_filters('autoptimize_filter_speedupper', true) && get_transient('autoptimize_warmcache_buster') == false ) {
108
+        if (apply_filters('autoptimize_filter_speedupper', true) && get_transient('autoptimize_warmcache_buster') == false) {
109 109
             set_transient('autoptimize_warmcache_buster', 'Mamsie & Liessie zehhe: ZWIJH!', HOUR_IN_SECONDS);
110
-            $warmCacheUrl = site_url()."/?ao_speedup_cachebuster=".rand(1,100000);
110
+            $warmCacheUrl = site_url()."/?ao_speedup_cachebuster=".rand(1, 100000);
111 111
             $warmCache = @wp_remote_get($warmCacheUrl);
112 112
             unset($warmCache);
113 113
         }
@@ -115,12 +115,12 @@  discard block
 block discarded – undo
115 115
         return true;
116 116
     }
117 117
 
118
-    static function stats()    {
119
-        $AOstats=get_transient("autoptimize_stats");
118
+    static function stats() {
119
+        $AOstats = get_transient("autoptimize_stats");
120 120
 
121 121
         if (empty($AOstats)) {
122 122
             // Cache not available :(
123
-            if(!autoptimizeCache::cacheavail()) {
123
+            if (!autoptimizeCache::cacheavail()) {
124 124
                 return 0;
125 125
             }
126 126
             
@@ -129,28 +129,28 @@  discard block
 block discarded – undo
129 129
             $size = 0;
130 130
             
131 131
             // scan the cachedirs        
132
-            foreach (array("","js","css") as $scandirName) {
132
+            foreach (array("", "js", "css") as $scandirName) {
133 133
                 $scan[$scandirName] = scandir(AUTOPTIMIZE_CACHE_DIR.$scandirName);
134 134
             }
135 135
             
136 136
             foreach ($scan as $scandirName=>$scanneddir) {
137
-                $thisAoCacheDir=rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName,"/")."/";
138
-                foreach($scanneddir as $file) {
139
-                    if(!in_array($file,array('.','..')) && strpos($file,AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) {
140
-                        if(is_file($thisAoCacheDir.$file)) {
141
-                            if(AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file,'.js') !== false || strpos($file,'.css') !== false || strpos($file,'.img') !== false || strpos($file,'.txt') !== false )) {
137
+                $thisAoCacheDir = rtrim(AUTOPTIMIZE_CACHE_DIR.$scandirName, "/")."/";
138
+                foreach ($scanneddir as $file) {
139
+                    if (!in_array($file, array('.', '..')) && strpos($file, AUTOPTIMIZE_CACHEFILE_PREFIX) !== false) {
140
+                        if (is_file($thisAoCacheDir.$file)) {
141
+                            if (AUTOPTIMIZE_CACHE_NOGZIP && (strpos($file, '.js') !== false || strpos($file, '.css') !== false || strpos($file, '.img') !== false || strpos($file, '.txt') !== false)) {
142 142
                                 $count++;
143
-                            } elseif(!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file,'.none') !== false) {
143
+                            } elseif (!AUTOPTIMIZE_CACHE_NOGZIP && strpos($file, '.none') !== false) {
144 144
                                 $count++;
145 145
                             }
146
-                            $size+=filesize($thisAoCacheDir.$file);
146
+                            $size += filesize($thisAoCacheDir.$file);
147 147
                         }
148 148
                     }
149 149
                 }
150 150
             }
151
-            $AOstats=array($count,$size,time());
152
-            if ($count>100) {
153
-                set_transient( "autoptimize_stats", $AOstats, apply_filters( 'autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS ) );
151
+            $AOstats = array($count, $size, time());
152
+            if ($count > 100) {
153
+                set_transient("autoptimize_stats", $AOstats, apply_filters('autoptimize_filter_cache_statsexpiry', HOUR_IN_SECONDS));
154 154
             }
155 155
         }
156 156
         // print the number of instances
@@ -158,36 +158,36 @@  discard block
 block discarded – undo
158 158
     }    
159 159
 
160 160
     static function cacheavail() {
161
-        if(!defined('AUTOPTIMIZE_CACHE_DIR')) {
161
+        if (!defined('AUTOPTIMIZE_CACHE_DIR')) {
162 162
             // We didn't set a cache
163 163
             return false;
164 164
         }
165 165
         
166
-        foreach (array("","js","css") as $checkDir) {
167
-            if(!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) {
166
+        foreach (array("", "js", "css") as $checkDir) {
167
+            if (!autoptimizeCache::checkCacheDir(AUTOPTIMIZE_CACHE_DIR.$checkDir)) {
168 168
                 return false;
169 169
             }
170 170
         }
171 171
         
172 172
         /** write index.html here to avoid prying eyes */
173
-        $indexFile=AUTOPTIMIZE_CACHE_DIR.'/index.html';
174
-        if(!is_file($indexFile)) {
175
-            @file_put_contents($indexFile,'<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>');
173
+        $indexFile = AUTOPTIMIZE_CACHE_DIR.'/index.html';
174
+        if (!is_file($indexFile)) {
175
+            @file_put_contents($indexFile, '<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>');
176 176
         }
177 177
 
178 178
         /** write .htaccess here to overrule wp_super_cache */
179
-        $htAccess=AUTOPTIMIZE_CACHE_DIR.'/.htaccess';
180
-        if(!is_file($htAccess)) {
179
+        $htAccess = AUTOPTIMIZE_CACHE_DIR.'/.htaccess';
180
+        if (!is_file($htAccess)) {
181 181
             /** 
182 182
              * create wp-content/AO_htaccess_tmpl with 
183 183
              * whatever htaccess rules you might need
184 184
              * if you want to override default AO htaccess
185 185
              */
186
-            $htaccess_tmpl=WP_CONTENT_DIR."/AO_htaccess_tmpl";
186
+            $htaccess_tmpl = WP_CONTENT_DIR."/AO_htaccess_tmpl";
187 187
             if (is_file($htaccess_tmpl)) { 
188
-                $htAccessContent=file_get_contents($htaccess_tmpl);
188
+                $htAccessContent = file_get_contents($htaccess_tmpl);
189 189
             } else if (is_multisite() || AUTOPTIMIZE_CACHE_NOGZIP == false) {
190
-                $htAccessContent='<IfModule mod_expires.c>
190
+                $htAccessContent = '<IfModule mod_expires.c>
191 191
         ExpiresActive On
192 192
         ExpiresByType text/css A30672000
193 193
         ExpiresByType text/javascript A30672000
@@ -213,7 +213,7 @@  discard block
 block discarded – undo
213 213
     </Files>
214 214
 </IfModule>';
215 215
             } else {
216
-                $htAccessContent='<IfModule mod_expires.c>
216
+                $htAccessContent = '<IfModule mod_expires.c>
217 217
         ExpiresActive On
218 218
         ExpiresByType text/css A30672000
219 219
         ExpiresByType text/javascript A30672000
@@ -239,7 +239,7 @@  discard block
 block discarded – undo
239 239
     </Files>
240 240
 </IfModule>';
241 241
             }
242
-            @file_put_contents($htAccess,$htAccessContent);
242
+            @file_put_contents($htAccess, $htAccessContent);
243 243
         }
244 244
 
245 245
         // All OK
@@ -248,22 +248,22 @@  discard block
 block discarded – undo
248 248
 
249 249
     static function checkCacheDir($dir) {
250 250
         // Check and create if not exists
251
-        if(!file_exists($dir))    {
252
-            @mkdir($dir,0775,true);
253
-            if(!file_exists($dir))    {
251
+        if (!file_exists($dir)) {
252
+            @mkdir($dir, 0775, true);
253
+            if (!file_exists($dir)) {
254 254
                 return false;
255 255
             }
256 256
         }
257 257
 
258 258
         // check if we can now write
259
-        if(!is_writable($dir))    {
259
+        if (!is_writable($dir)) {
260 260
             return false;
261 261
         }
262 262
 
263 263
         // and write index.html here to avoid prying eyes
264
-        $indexFile=$dir.'/index.html';
265
-        if(!is_file($indexFile)) {
266
-            @file_put_contents($indexFile,'<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>');
264
+        $indexFile = $dir.'/index.html';
265
+        if (!is_file($indexFile)) {
266
+            @file_put_contents($indexFile, '<html><head><meta name="robots" content="noindex, nofollow"></head><body>Generated by <a href="http://wordpress.org/extend/plugins/autoptimize/" rel="nofollow">Autoptimize</a></body></html>');
267 267
         }
268 268
         
269 269
         return true;
Please login to merge, or discard this patch.