Completed
Pull Request — master (#72)
by
unknown
02:55
created
classes/autoptimizeScripts.php 1 patch
Spacing   +107 added lines, -107 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','blogcatalog.com/w','tweetmeme.com/i','mybloglog.com/','histats.com/js','ads.smowtion.com/ad.js','statcounter.com/counter/counter.js','widgets.amung.us','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');
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', 'blogcatalog.com/w', 'tweetmeme.com/i', 'mybloglog.com/', 'histats.com/js', 'ads.smowtion.com/ad.js', 'statcounter.com/counter/counter.js', 'widgets.amung.us', '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');
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', "" );
28
+        $whitelistJS = apply_filters('autoptimize_filter_js_whitelist', "");
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', '');
34
+        $removableJS = apply_filters('autoptimize_filter_js_removables', '');
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 );
62
-        if ($excludeJS!=="") {
61
+        $excludeJS = apply_filters('autoptimize_filter_js_exclude', $excludeJS);
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 116
                     
117
-                    $url = current(explode('?',$source[2],2));
117
+                    $url = current(explode('?', $source[2], 2));
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 {
@@ -125,14 +125,14 @@  discard block
 block discarded – undo
125 125
                             // should we add flags?
126 126
                             $origTag = $tag;
127 127
                             foreach ($excludeJS as $exclTag => $exclFlags) {
128
-                                if ( strpos($origTag,$exclTag)!==false && in_array($exclFlags,array("async","defer")) ) {
129
-                                   $tag = str_replace('<script ','<script '.$exclFlags.' ',$tag);
128
+                                if (strpos($origTag, $exclTag) !== false && in_array($exclFlags, array("async", "defer"))) {
129
+                                   $tag = str_replace('<script ', '<script '.$exclFlags.' ', $tag);
130 130
                                 }
131 131
                             }
132 132
                         }
133
-                        if($this->ismovable($tag)) {
133
+                        if ($this->ismovable($tag)) {
134 134
                             // can be moved, flags and all
135
-                            if($this->movetolast($tag))    {
135
+                            if ($this->movetolast($tag)) {
136 136
                                 $this->move['last'][] = $tag;
137 137
                             } else {
138 138
                                 $this->move['first'][] = $tag;
@@ -140,7 +140,7 @@  discard block
 block discarded – undo
140 140
                         } else {
141 141
                             // cannot be moved, so if flag was added re-inject altered tag immediately
142 142
                             if ($origTag && $origTag !== $tag) {
143
-                                $this->content = str_replace($origTag,$tag,$this->content);
143
+                                $this->content = str_replace($origTag, $tag, $this->content);
144 144
                                 $origTag = '';
145 145
                             }
146 146
                             // and forget about the $tag (not to be touched any more)
@@ -149,23 +149,23 @@  discard block
 block discarded – undo
149 149
                     }
150 150
                 } else {
151 151
                     // Inline script
152
-                    if ($this->isremovable($tag,$this->jsremovables)) {
153
-                        $this->content = str_replace($tag,'',$this->content);
152
+                    if ($this->isremovable($tag, $this->jsremovables)) {
153
+                        $this->content = str_replace($tag, '', $this->content);
154 154
                         continue;
155 155
                     }
156 156
                     
157 157
                     // unhide comments, as javascript may be wrapped in comment-tags for old times' sake
158 158
                     $tag = $this->restore_comments($tag);
159
-                    if($this->ismergeable($tag) && ( $this->include_inline )) {
160
-                        preg_match('#<script.*>(.*)</script>#Usmi',$tag,$code);
161
-                        $code = preg_replace('#.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*#sm','$1',$code[1]);
162
-                        $code = preg_replace('/(?:^\\s*<!--\\s*|\\s*(?:\\/\\/)?\\s*-->\\s*$)/','',$code);
159
+                    if ($this->ismergeable($tag) && ($this->include_inline)) {
160
+                        preg_match('#<script.*>(.*)</script>#Usmi', $tag, $code);
161
+                        $code = preg_replace('#.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*#sm', '$1', $code[1]);
162
+                        $code = preg_replace('/(?:^\\s*<!--\\s*|\\s*(?:\\/\\/)?\\s*-->\\s*$)/', '', $code);
163 163
                         $this->scripts[] = 'INLINE;'.$code;
164 164
                     } else {
165 165
                         // Can we move this?
166
-                        $autoptimize_js_moveable = apply_filters( 'autoptimize_js_moveable', '', $tag );
167
-                        if( $this->ismovable($tag) || $autoptimize_js_moveable !== '' ) {
168
-                            if( $this->movetolast($tag) || $autoptimize_js_moveable === 'last' ) {
166
+                        $autoptimize_js_moveable = apply_filters('autoptimize_js_moveable', '', $tag);
167
+                        if ($this->ismovable($tag) || $autoptimize_js_moveable !== '') {
168
+                            if ($this->movetolast($tag) || $autoptimize_js_moveable === 'last') {
169 169
                                 $this->move['last'][] = $tag;
170 170
                             } else {
171 171
                                 $this->move['first'][] = $tag;
@@ -180,7 +180,7 @@  discard block
 block discarded – undo
180 180
                 }
181 181
                 
182 182
                 //Remove the original script tag
183
-                $this->content = str_replace($tag,'',$this->content);
183
+                $this->content = str_replace($tag, '', $this->content);
184 184
             }
185 185
             
186 186
             return true;
@@ -192,37 +192,37 @@  discard block
 block discarded – undo
192 192
     
193 193
     //Joins and optimizes JS
194 194
     public function minify() {
195
-        foreach($this->scripts as $script) {
196
-            if(preg_match('#^INLINE;#',$script)) {
195
+        foreach ($this->scripts as $script) {
196
+            if (preg_match('#^INLINE;#', $script)) {
197 197
                 //Inline script
198
-                $script = preg_replace('#^INLINE;#','',$script);
199
-                $script = rtrim( $script, ";\n\t\r" ) . ';';
198
+                $script = preg_replace('#^INLINE;#', '', $script);
199
+                $script = rtrim($script, ";\n\t\r").';';
200 200
                 //Add try-catch?
201
-                if($this->trycatch) {
201
+                if ($this->trycatch) {
202 202
                     $script = 'try{'.$script.'}catch(e){}';
203 203
                 }
204
-                $tmpscript = apply_filters( 'autoptimize_js_individual_script', $script, "" );
205
-                if ( has_filter('autoptimize_js_individual_script') && !empty($tmpscript) ) {
206
-                    $script=$tmpscript;
207
-                    $this->alreadyminified=true;
204
+                $tmpscript = apply_filters('autoptimize_js_individual_script', $script, "");
205
+                if (has_filter('autoptimize_js_individual_script') && !empty($tmpscript)) {
206
+                    $script = $tmpscript;
207
+                    $this->alreadyminified = true;
208 208
                 }
209
-                $this->jscode .= "\n" . $script;
209
+                $this->jscode .= "\n".$script;
210 210
             } else {
211 211
                 //External script
212
-                if($script !== false && file_exists($script) && is_readable($script)) {
212
+                if ($script !== false && file_exists($script) && is_readable($script)) {
213 213
                     $scriptsrc = file_get_contents($script);
214
-                    $scriptsrc = preg_replace('/\x{EF}\x{BB}\x{BF}/','',$scriptsrc);
215
-                    $scriptsrc = rtrim($scriptsrc,";\n\t\r").';';
214
+                    $scriptsrc = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $scriptsrc);
215
+                    $scriptsrc = rtrim($scriptsrc, ";\n\t\r").';';
216 216
                     //Add try-catch?
217
-                    if($this->trycatch) {
217
+                    if ($this->trycatch) {
218 218
                         $scriptsrc = 'try{'.$scriptsrc.'}catch(e){}';
219 219
                     }
220
-                    $tmpscriptsrc = apply_filters( 'autoptimize_js_individual_script', $scriptsrc, $script );
221
-                    if ( has_filter('autoptimize_js_individual_script') && !empty($tmpscriptsrc) ) {
222
-                        $scriptsrc=$tmpscriptsrc;
223
-                        $this->alreadyminified=true;
224
-                    } else if ((( strpos($script,"min.js") !== false ) || ( strpos($script,"wp-includes/js/jquery/jquery.js") !== false )) && ( $this->inject_min_late === true )) {
225
-                        $scriptsrc="%%INJECTLATER%%".base64_encode($script)."|".md5($scriptsrc)."%%INJECTLATER%%";
220
+                    $tmpscriptsrc = apply_filters('autoptimize_js_individual_script', $scriptsrc, $script);
221
+                    if (has_filter('autoptimize_js_individual_script') && !empty($tmpscriptsrc)) {
222
+                        $scriptsrc = $tmpscriptsrc;
223
+                        $this->alreadyminified = true;
224
+                    } else if (((strpos($script, "min.js") !== false) || (strpos($script, "wp-includes/js/jquery/jquery.js") !== false)) && ($this->inject_min_late === true)) {
225
+                        $scriptsrc = "%%INJECTLATER%%".base64_encode($script)."|".md5($scriptsrc)."%%INJECTLATER%%";
226 226
                     }
227 227
                     $this->jscode .= "\n".$scriptsrc;
228 228
                 }/*else{
@@ -233,24 +233,24 @@  discard block
 block discarded – undo
233 233
 
234 234
         //Check for already-minified code
235 235
         $this->md5hash = md5($this->jscode);
236
-        $ccheck = new autoptimizeCache($this->md5hash,'js');
237
-        if($ccheck->check()) {
236
+        $ccheck = new autoptimizeCache($this->md5hash, 'js');
237
+        if ($ccheck->check()) {
238 238
             $this->jscode = $ccheck->retrieve();
239 239
             return true;
240 240
         }
241 241
         unset($ccheck);
242 242
         
243 243
         //$this->jscode has all the uncompressed code now.
244
-        if ($this->alreadyminified!==true) {
245
-          if (class_exists('JSMin') && apply_filters( 'autoptimize_js_do_minify' , true)) {
246
-            if (@is_callable(array("JSMin","minify"))) {
244
+        if ($this->alreadyminified !== true) {
245
+          if (class_exists('JSMin') && apply_filters('autoptimize_js_do_minify', true)) {
246
+            if (@is_callable(array("JSMin", "minify"))) {
247 247
                 $tmp_jscode = trim(JSMin::minify($this->jscode));
248 248
                 if (!empty($tmp_jscode)) {
249 249
                     $this->jscode = $tmp_jscode;
250 250
                     unset($tmp_jscode);
251 251
                 }
252 252
                 $this->jscode = $this->inject_minified($this->jscode);
253
-                $this->jscode = apply_filters( 'autoptimize_js_after_minify', $this->jscode );
253
+                $this->jscode = apply_filters('autoptimize_js_after_minify', $this->jscode);
254 254
                 return true;
255 255
             } else {
256 256
                 $this->jscode = $this->inject_minified($this->jscode);
@@ -265,11 +265,11 @@  discard block
 block discarded – undo
265 265
     }
266 266
     
267 267
     //Caches the JS in uncompressed, deflated and gzipped form.
268
-    public function cache()    {
269
-        $cache = new autoptimizeCache($this->md5hash,'js');
270
-        if(!$cache->check()) {
268
+    public function cache() {
269
+        $cache = new autoptimizeCache($this->md5hash, 'js');
270
+        if (!$cache->check()) {
271 271
             //Cache our code
272
-            $cache->cache($this->jscode,'text/javascript');
272
+            $cache->cache($this->jscode, 'text/javascript');
273 273
         }
274 274
         $this->url = AUTOPTIMIZE_CACHE_URL.$cache->getname();
275 275
         $this->url = $this->url_replace_cdn($this->url);
@@ -278,32 +278,32 @@  discard block
 block discarded – undo
278 278
     // Returns the content
279 279
     public function getcontent() {
280 280
         // Restore the full content
281
-        if(!empty($this->restofcontent)) {
281
+        if (!empty($this->restofcontent)) {
282 282
             $this->content .= $this->restofcontent;
283 283
             $this->restofcontent = '';
284 284
         }
285 285
         
286 286
         // Add the scripts taking forcehead/ deferred (default) into account
287
-        if($this->forcehead == true) {
288
-            $replaceTag=array("</head>","before");
289
-            $defer="";
287
+        if ($this->forcehead == true) {
288
+            $replaceTag = array("</head>", "before");
289
+            $defer = "";
290 290
         } else {
291
-            $replaceTag=array("</body>","before");
292
-            $defer="defer ";
291
+            $replaceTag = array("</body>", "before");
292
+            $defer = "defer ";
293 293
         }
294 294
         
295
-        $defer = apply_filters( 'autoptimize_filter_js_defer', $defer );
295
+        $defer = apply_filters('autoptimize_filter_js_defer', $defer);
296 296
         $bodyreplacementpayload = '<script type="text/javascript" '.$defer.'src="'.$this->url.'"></script>';
297
-        $bodyreplacementpayload = apply_filters('autoptimize_filter_js_bodyreplacementpayload',$bodyreplacementpayload);
297
+        $bodyreplacementpayload = apply_filters('autoptimize_filter_js_bodyreplacementpayload', $bodyreplacementpayload);
298 298
 
299
-        $bodyreplacement = implode('',$this->move['first']);
299
+        $bodyreplacement = implode('', $this->move['first']);
300 300
         $bodyreplacement .= $bodyreplacementpayload;
301
-        $bodyreplacement .= implode('',$this->move['last']);
301
+        $bodyreplacement .= implode('', $this->move['last']);
302 302
 
303
-        $replaceTag = apply_filters( 'autoptimize_filter_js_replacetag', $replaceTag );
303
+        $replaceTag = apply_filters('autoptimize_filter_js_replacetag', $replaceTag);
304 304
 
305
-        if (strlen($this->jscode)>0) {
306
-            $this->inject_in_html($bodyreplacement,$replaceTag);
305
+        if (strlen($this->jscode) > 0) {
306
+            $this->inject_in_html($bodyreplacement, $replaceTag);
307 307
         }
308 308
         
309 309
         // restore comments
@@ -323,15 +323,15 @@  discard block
 block discarded – undo
323 323
     private function ismergeable($tag) {
324 324
         if (!empty($this->whitelist)) {
325 325
             foreach ($this->whitelist as $match) {
326
-                if(strpos($tag,$match)!==false) {
326
+                if (strpos($tag, $match) !== false) {
327 327
                     return true;
328 328
                 }
329 329
             }
330 330
             // no match with whitelist
331 331
             return false;
332 332
         } else {
333
-            foreach($this->domove as $match) {
334
-                if(strpos($tag,$match)!==false)    {
333
+            foreach ($this->domove as $match) {
334
+                if (strpos($tag, $match) !== false) {
335 335
                     // Matched something
336 336
                     return false;
337 337
                 }
@@ -341,8 +341,8 @@  discard block
 block discarded – undo
341 341
                 return false;
342 342
             }
343 343
             
344
-            foreach($this->dontmove as $match) {
345
-                if(strpos($tag,$match)!==false)    {
344
+            foreach ($this->dontmove as $match) {
345
+                if (strpos($tag, $match) !== false) {
346 346
                     //Matched something
347 347
                     return false;
348 348
                 }
@@ -355,12 +355,12 @@  discard block
 block discarded – undo
355 355
     
356 356
     // Checks againstt the blacklist
357 357
     private function ismovable($tag) {
358
-        if ($this->include_inline !== true || apply_filters('autoptimize_filter_js_unmovable',true)) {
358
+        if ($this->include_inline !== true || apply_filters('autoptimize_filter_js_unmovable', true)) {
359 359
             return false;
360 360
         }
361 361
         
362
-        foreach($this->domove as $match) {
363
-            if(strpos($tag,$match)!==false)    {
362
+        foreach ($this->domove as $match) {
363
+            if (strpos($tag, $match) !== false) {
364 364
                 // Matched something
365 365
                 return true;
366 366
             }
@@ -370,8 +370,8 @@  discard block
 block discarded – undo
370 370
             return true;
371 371
         }
372 372
         
373
-        foreach($this->dontmove as $match) {
374
-            if(strpos($tag,$match)!==false) {
373
+        foreach ($this->dontmove as $match) {
374
+            if (strpos($tag, $match) !== false) {
375 375
                 // Matched something
376 376
                 return false;
377 377
             }
@@ -382,8 +382,8 @@  discard block
 block discarded – undo
382 382
     }
383 383
     
384 384
     private function movetolast($tag) {
385
-        foreach($this->domovelast as $match) {
386
-            if(strpos($tag,$match)!==false)    {
385
+        foreach ($this->domovelast as $match) {
386
+            if (strpos($tag, $match) !== false) {
387 387
                 // Matched, return true
388 388
                 return true;
389 389
             }
@@ -409,10 +409,10 @@  discard block
 block discarded – undo
409 409
      * original function by https://github.com/zytzagoo/ on his AO fork, thanks Tomas!
410 410
      */
411 411
     public function should_aggregate($tag) {
412
-        preg_match('#<(script[^>]*)>#i',$tag,$scripttag);
413
-        if ( strpos($scripttag[1], 'type')===false ) {
412
+        preg_match('#<(script[^>]*)>#i', $tag, $scripttag);
413
+        if (strpos($scripttag[1], 'type') === false) {
414 414
             return true;
415
-        } else if ( preg_match('/type\s*=\s*["\']?(?:text|application)\/(?:javascript|ecmascript)["\']?/i', $scripttag[1]) ) {
415
+        } else if (preg_match('/type\s*=\s*["\']?(?:text|application)\/(?:javascript|ecmascript)["\']?/i', $scripttag[1])) {
416 416
             return true;
417 417
         } else {
418 418
             return false;
Please login to merge, or discard this patch.
autoptimize.php 1 patch
Spacing   +65 added lines, -65 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,25 +28,25 @@  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',str_replace(AUTOPTIMIZE_WP_CONTENT_NAME,'',WP_CONTENT_DIR));
48
+define('AUTOPTIMIZE_CACHE_DELAY', true);
49
+define('WP_ROOT_DIR', str_replace(AUTOPTIMIZE_WP_CONTENT_NAME, '', WP_CONTENT_DIR));
50 50
 
51 51
 // Initialize the cache at least once
52 52
 $conf = autoptimizeConfig::instance();
@@ -54,59 +54,59 @@  discard block
 block discarded – undo
54 54
 /* Check if we're updating, in which case we might need to do stuff and flush the cache
55 55
 to avoid old versions of aggregated files lingering around */
56 56
 
57
-$autoptimize_version="2.1.0";
58
-$autoptimize_db_version=get_option('autoptimize_version','none');
57
+$autoptimize_version = "2.1.0";
58
+$autoptimize_db_version = get_option('autoptimize_version', 'none');
59 59
 
60 60
 if ($autoptimize_db_version !== $autoptimize_version) {
61
-    if ($autoptimize_db_version==="none") {
61
+    if ($autoptimize_db_version === "none") {
62 62
         add_action('admin_notices', 'autoptimize_install_config_notice');
63 63
     } else {
64 64
         // updating, include the update-code
65 65
         include(AUTOPTIMIZE_PLUGIN_DIR.'classlesses/autoptimizeUpdateCode.php');
66 66
     }
67 67
 
68
-    update_option('autoptimize_version',$autoptimize_version);
69
-    $autoptimize_db_version=$autoptimize_version;
68
+    update_option('autoptimize_version', $autoptimize_version);
69
+    $autoptimize_db_version = $autoptimize_version;
70 70
 }
71 71
 
72 72
 // Load translations
73 73
 function autoptimize_load_plugin_textdomain() {
74
-    load_plugin_textdomain('autoptimize',false,plugin_basename(dirname( __FILE__ )).'/localization');
74
+    load_plugin_textdomain('autoptimize', false, plugin_basename(dirname(__FILE__)).'/localization');
75 75
 }
76
-add_action( 'init', 'autoptimize_load_plugin_textdomain' );
76
+add_action('init', 'autoptimize_load_plugin_textdomain');
77 77
 
78
-function autoptimize_uninstall(){
78
+function autoptimize_uninstall() {
79 79
     autoptimizeCache::clearall();
80 80
 
81
-    $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_css_nogooglefont");
81
+    $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_css_nogooglefont");
82 82
 
83
-    if ( !is_multisite() ) {
84
-        foreach ($delete_options as $del_opt) {    delete_option( $del_opt ); }
83
+    if (!is_multisite()) {
84
+        foreach ($delete_options as $del_opt) {    delete_option($del_opt); }
85 85
     } else {
86 86
         global $wpdb;
87
-        $blog_ids = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
87
+        $blog_ids = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
88 88
         $original_blog_id = get_current_blog_id();
89
-        foreach ( $blog_ids as $blog_id ) {
90
-            switch_to_blog( $blog_id );
91
-            foreach ($delete_options as $del_opt) {    delete_option( $del_opt ); }
89
+        foreach ($blog_ids as $blog_id) {
90
+            switch_to_blog($blog_id);
91
+            foreach ($delete_options as $del_opt) {    delete_option($del_opt); }
92 92
         }
93
-        switch_to_blog( $original_blog_id );
93
+        switch_to_blog($original_blog_id);
94 94
     }
95 95
 
96
-    if ( wp_get_schedule( 'ao_cachechecker' ) ) {
97
-        wp_clear_scheduled_hook( 'ao_cachechecker' );
96
+    if (wp_get_schedule('ao_cachechecker')) {
97
+        wp_clear_scheduled_hook('ao_cachechecker');
98 98
     }
99 99
 }
100 100
 
101 101
 function autoptimize_install_config_notice() {
102 102
     echo '<div class="updated"><p>';
103
-    _e('Thank you for installing and activating Autoptimize. Please configure it under "Settings" -> "Autoptimize" to start improving your site\'s performance.', 'autoptimize' );
103
+    _e('Thank you for installing and activating Autoptimize. Please configure it under "Settings" -> "Autoptimize" to start improving your site\'s performance.', 'autoptimize');
104 104
     echo '</p></div>';
105 105
 }
106 106
 
107 107
 function autoptimize_update_config_notice() {
108 108
     echo '<div class="updated"><p>';
109
-    _e('Autoptimize has just been updated. Please <strong>test your site now</strong> and adapt Autoptimize config if needed.', 'autoptimize' );
109
+    _e('Autoptimize has just been updated. Please <strong>test your site now</strong> and adapt Autoptimize config if needed.', 'autoptimize');
110 110
     echo '</p></div>';
111 111
 }
112 112
 
@@ -126,21 +126,21 @@  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)) {
130
-        if ( ($_GET["ao_noptimize"]==="1") && (apply_filters('autoptimize_filter_honor_qs_noptimize',true)) ) {
129
+    if (array_key_exists("ao_noptimize", $_GET)) {
130
+        if (($_GET["ao_noptimize"] === "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
     // filter you can use to block autoptimization on your own terms
141
-    $ao_noptimize = (bool) apply_filters( 'autoptimize_filter_noptimize', $ao_noptimize );
141
+    $ao_noptimize = (bool) apply_filters('autoptimize_filter_noptimize', $ao_noptimize);
142 142
 
143
-    if (!is_feed() && !$ao_noptimize && !is_admin() && ( !function_exists('is_customize_preview') || !is_customize_preview() ) ) {
143
+    if (!is_feed() && !$ao_noptimize && !is_admin() && (!function_exists('is_customize_preview') || !is_customize_preview())) {
144 144
         // Config element
145 145
         $conf = autoptimizeConfig::instance();
146 146
 
@@ -148,7 +148,7 @@  discard block
 block discarded – undo
148 148
         include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeBase.php');
149 149
 
150 150
         // Load extra classes and set some vars
151
-        if($conf->get('autoptimize_html')) {
151
+        if ($conf->get('autoptimize_html')) {
152 152
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeHTML.php');
153 153
             // BUG: new minify-html does not support keeping HTML comments, skipping for now
154 154
             // if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
@@ -158,7 +158,7 @@  discard block
 block discarded – undo
158 158
             // }
159 159
         }
160 160
 
161
-        if($conf->get('autoptimize_js')) {
161
+        if ($conf->get('autoptimize_js')) {
162 162
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeScripts.php');
163 163
             if (!class_exists('JSMin')) {
164 164
                 if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
@@ -167,15 +167,15 @@  discard block
 block discarded – undo
167 167
                     @include(AUTOPTIMIZE_PLUGIN_DIR.'classes/external/php/minify-2.3.1-jsmin.php');
168 168
                 }
169 169
             }
170
-            if ( ! defined( 'CONCATENATE_SCRIPTS' )) {
171
-                define('CONCATENATE_SCRIPTS',false);
170
+            if (!defined('CONCATENATE_SCRIPTS')) {
171
+                define('CONCATENATE_SCRIPTS', false);
172 172
             }
173
-            if ( ! defined( 'COMPRESS_SCRIPTS' )) {
174
-                define('COMPRESS_SCRIPTS',false);
173
+            if (!defined('COMPRESS_SCRIPTS')) {
174
+                define('COMPRESS_SCRIPTS', false);
175 175
             }
176 176
         }
177 177
 
178
-        if($conf->get('autoptimize_css')) {
178
+        if ($conf->get('autoptimize_css')) {
179 179
             include(AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeStyles.php');
180 180
             if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) {
181 181
                 if (!class_exists('Minify_CSS_Compressor')) {
@@ -186,13 +186,13 @@  discard block
 block discarded – undo
186 186
                     @include(AUTOPTIMIZE_PLUGIN_DIR.'classes/external/php/yui-php-cssmin-2.4.8-4_fgo.php');
187 187
                 }
188 188
             }
189
-            if ( ! defined( 'COMPRESS_CSS' )) {
190
-                define('COMPRESS_CSS',false);
189
+            if (!defined('COMPRESS_CSS')) {
190
+                define('COMPRESS_CSS', false);
191 191
             }
192 192
         }
193 193
 
194 194
         // filter to be used with care, kills all output buffers when true. use with extreme caution. you have been warned!
195
-        if (apply_filters('autoptimize_filter_obkiller',false)) {
195
+        if (apply_filters('autoptimize_filter_obkiller', false)) {
196 196
             while (ob_get_level() > 0) {
197 197
                 ob_end_clean();
198 198
             }
@@ -205,35 +205,35 @@  discard block
 block discarded – undo
205 205
 
206 206
 // Action on end, this is where the magic happens
207 207
 function autoptimize_end_buffering($content) {
208
-    if ( ((stripos($content,"<html") === false) && (stripos($content,"<!DOCTYPE html") === false)) || preg_match('/<html[^>]*(?:amp|⚡)/',$content) === 1 || stripos($content,"<xsl:stylesheet") !== false ) { return $content; }
208
+    if (((stripos($content, "<html") === false) && (stripos($content, "<!DOCTYPE html") === false)) || preg_match('/<html[^>]*(?:amp|⚡)/', $content) === 1 || stripos($content, "<xsl:stylesheet") !== false) { return $content; }
209 209
     
210 210
     // load URL constants as late as possible to allow domain mapper to kick in
211 211
     if (function_exists("domain_mapping_siteurl")) {
212
-        define('AUTOPTIMIZE_WP_SITE_URL',domain_mapping_siteurl(get_current_blog_id()));
213
-        define('AUTOPTIMIZE_WP_CONTENT_URL',str_replace(get_original_url(AUTOPTIMIZE_WP_SITE_URL),AUTOPTIMIZE_WP_SITE_URL,content_url()));
212
+        define('AUTOPTIMIZE_WP_SITE_URL', domain_mapping_siteurl(get_current_blog_id()));
213
+        define('AUTOPTIMIZE_WP_CONTENT_URL', str_replace(get_original_url(AUTOPTIMIZE_WP_SITE_URL), AUTOPTIMIZE_WP_SITE_URL, content_url()));
214 214
     } else {
215
-        define('AUTOPTIMIZE_WP_SITE_URL',site_url());
216
-        define('AUTOPTIMIZE_WP_CONTENT_URL',content_url());
215
+        define('AUTOPTIMIZE_WP_SITE_URL', site_url());
216
+        define('AUTOPTIMIZE_WP_CONTENT_URL', content_url());
217 217
     }
218 218
 
219
-    if ( is_multisite() && apply_filters( 'autoptimize_separate_blog_caches' , true ) ) {
219
+    if (is_multisite() && apply_filters('autoptimize_separate_blog_caches', true)) {
220 220
         $blog_id = get_current_blog_id();
221
-        define('AUTOPTIMIZE_CACHE_URL',AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/' );
221
+        define('AUTOPTIMIZE_CACHE_URL', AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR.$blog_id.'/');
222 222
     } else {
223
-        define('AUTOPTIMIZE_CACHE_URL',AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR);
223
+        define('AUTOPTIMIZE_CACHE_URL', AUTOPTIMIZE_WP_CONTENT_URL.AUTOPTIMIZE_CACHE_CHILD_DIR);
224 224
     }
225
-    define('AUTOPTIMIZE_WP_ROOT_URL',str_replace(AUTOPTIMIZE_WP_CONTENT_NAME,'',AUTOPTIMIZE_WP_CONTENT_URL));
225
+    define('AUTOPTIMIZE_WP_ROOT_URL', str_replace(AUTOPTIMIZE_WP_CONTENT_NAME, '', AUTOPTIMIZE_WP_CONTENT_URL));
226 226
 
227 227
     // Config element
228 228
     $conf = autoptimizeConfig::instance();
229 229
 
230 230
     // Choose the classes
231 231
     $classes = array();
232
-    if($conf->get('autoptimize_js'))
232
+    if ($conf->get('autoptimize_js'))
233 233
         $classes[] = 'autoptimizeScripts';
234
-    if($conf->get('autoptimize_css'))
234
+    if ($conf->get('autoptimize_css'))
235 235
         $classes[] = 'autoptimizeStyles';
236
-    if($conf->get('autoptimize_html'))
236
+    if ($conf->get('autoptimize_html'))
237 237
         $classes[] = 'autoptimizeHTML';
238 238
 
239 239
     // Set some options
@@ -262,12 +262,12 @@  discard block
 block discarded – undo
262 262
         )
263 263
     );
264 264
 
265
-    $content = apply_filters( 'autoptimize_filter_html_before_minify', $content );
265
+    $content = apply_filters('autoptimize_filter_html_before_minify', $content);
266 266
 
267 267
     // Run the classes
268
-    foreach($classes as $name) {
268
+    foreach ($classes as $name) {
269 269
         $instance = new $name($content);
270
-        if($instance->read($classoptions[$name])) {
270
+        if ($instance->read($classoptions[$name])) {
271 271
             $instance->minify();
272 272
             $instance->cache();
273 273
             $content = $instance->getcontent();
@@ -275,18 +275,18 @@  discard block
 block discarded – undo
275 275
         unset($instance);
276 276
     }
277 277
     
278
-    $content = apply_filters( 'autoptimize_html_after_minify', $content );
278
+    $content = apply_filters('autoptimize_html_after_minify', $content);
279 279
     return $content;
280 280
 }
281 281
 
282
-if ( autoptimizeCache::cacheavail() ) {
282
+if (autoptimizeCache::cacheavail()) {
283 283
     $conf = autoptimizeConfig::instance();
284
-    if( $conf->get('autoptimize_html') || $conf->get('autoptimize_js') || $conf->get('autoptimize_css') ) {
284
+    if ($conf->get('autoptimize_html') || $conf->get('autoptimize_js') || $conf->get('autoptimize_css')) {
285 285
         // Hook to wordpress
286 286
         if (defined('AUTOPTIMIZE_INIT_EARLIER')) {
287
-            add_action('init','autoptimize_start_buffering',-1);
287
+            add_action('init', 'autoptimize_start_buffering', -1);
288 288
         } else {
289
-            add_action('template_redirect','autoptimize_start_buffering',2);
289
+            add_action('template_redirect', 'autoptimize_start_buffering', 2);
290 290
         }
291 291
     }
292 292
 } else {
Please login to merge, or discard this patch.