r80572 MediaWiki - Code Review archive

Repository:MediaWiki
Revision:r80571‎ | r80572 | r80573 >
Date:16:26, 19 January 2011
Author:krinkle
Status:ok (Comments)
Tags:
Comment:
Fix bug in mw.Map + fix bug 26801 + wrapper mediawiki.special.upload.js
* Map.prototype.exists was checking the type of the wrong variable. Fixed now, checking multiple at once is now possible (as documented)
* bug 26801: No references to legacy globals, use mw.config everywhere in core (grep search for 'wg' in /resources returned only
* Addressed some JS Lint warnings (combining var statements, faster and less code);
* Removed trailing tabs and spaces
Modified paths:
  • /trunk/phase3/resources/mediawiki.special/mediawiki.special.upload.js (modified) (history)
  • /trunk/phase3/resources/mediawiki.util/mediawiki.util.js (modified) (history)
  • /trunk/phase3/resources/mediawiki.util/mediawiki.util.test.js (modified) (history)
  • /trunk/phase3/resources/mediawiki/mediawiki.js (modified) (history)

Diff [purge]

Index: trunk/phase3/resources/mediawiki.util/mediawiki.util.test.js
@@ -6,7 +6,7 @@
77 * @author Krinkle <krinklemail@gmail.com>
88 */
99
10 -(function ($, mw) {
 10+( function( $, mw ) {
1111
1212 mediaWiki.test = {
1313
@@ -25,26 +25,27 @@
2626 * if result is different but does contain this it will not return ERROR but PARTIALLY
2727 */
2828 'addTest' : function( code, result, contain ) {
29 - if (!contain) {
 29+ if ( !contain ) {
3030 contain = result;
3131 }
3232 this.addedTests.push( [code, result, contain] );
33 - this.$table.append( '<tr><td>' + mw.html.escape(code).replace(/ /g, '&nbsp;&nbsp;' )
34 - + '</td><td>' + mw.html.escape(result).replace(/ /g, '&nbsp;&nbsp;' )
 33+ this.$table.append( '<tr><td>' + mw.html.escape( code ).replace(/ /g, '&nbsp;&nbsp;' )
 34+ + '</td><td>' + mw.html.escape( result ).replace(/ /g, '&nbsp;&nbsp;' )
3535 + '</td><td></td><td>?</td></tr>' );
3636 },
3737
3838 /* Initialisation */
3939 'initialised' : false,
40 - 'init' : function () {
 40+ 'init' : function() {
4141 if ( this.initialised === false ) {
4242 this.initialised = true;
43 - $(function () {
44 - if ( wgCanonicalSpecialPageName == 'Blankpage'
 43+ // jQuery document ready
 44+ $( function() {
 45+ if ( mw.config.get( 'wgCanonicalSpecialPageName' ) == 'Blankpage'
4546 && mw.util.getParamValue( 'action' ) === 'mwutiltest' ) {
4647
4748 // Build page
48 - document.title = 'mediaWiki.util JavaScript Test - ' + wgSiteName;
 49+ document.title = 'mediaWiki.util JavaScript Test - ' + mw.config.get( 'wgSiteName' );
4950 $( '#firstHeading' ).text( 'mediaWiki.util JavaScript Test' );
5051 mw.util.$content.html(
5152 '<p>Below is a list of tests to confirm proper functionality of the mediaWiki.util functions</p>'
@@ -133,8 +134,8 @@
134135 numberofpasseds = 0,
135136 numberofpartials = 0,
136137 numberoferrors = 0,
137 - $testrows;
138 - $testrows = mw.test.$table.find( 'tr' );
 138+ $testrows = mw.test.$table.find( 'tr' );
 139+
139140 $.each( mw.test.addedTests, function( i ) {
140141 numberoftests++;
141142
@@ -146,7 +147,7 @@
147148 $thisrow = $testrows.eq( i + 1 );
148149 $thisrow.find( '> td' ).eq(2).html( mw.html.escape( doesreturn ).replace(/ /g, '&nbsp;&nbsp;' ) );
149150
150 - if (doesreturn.indexOf(shouldcontain) !== -1) {
 151+ if ( doesreturn.indexOf( shouldcontain ) !== -1 ) {
151152 if (doesreturn == shouldreturn){
152153 $thisrow.find( '> td' ).eq(3).css( 'background', '#EFE' ).text( 'OK' );
153154 numberofpasseds++;
@@ -165,11 +166,11 @@
166167 numberofpartials + ' partially passed test(s). </p>' );
167168
168169 }
169 - });
 170+ } );
170171 }
171172 }
172173 };
173174
174175 mediaWiki.test.init();
175176
176 -})(jQuery, mediaWiki);
 177+} )(jQuery, mediaWiki);
\ No newline at end of file
Index: trunk/phase3/resources/mediawiki.util/mediawiki.util.js
@@ -65,7 +65,7 @@
6666 } else {
6767 mw.util.$content = $( '#content' );
6868 }
69 -
 69+
7070 /* Enable makeCollapse */
7171 $( '.mw-collapsible' ).makeCollapsible();
7272
@@ -81,7 +81,7 @@
8282 mw.util.toggleToc( $(this) );
8383 } );
8484 $tocTitle.append( $tocToggleLink.wrap( '<span class="toctoggle">' ).parent().prepend( '&nbsp;[' ).append( ']&nbsp;' ) );
85 -
 85+
8686 if ( hideTocCookie == '1' ) {
8787 // Cookie says user want toc hidden
8888 $tocToggleLink.click();
@@ -147,7 +147,7 @@
148148 */
149149 'toggleToc' : function( $toggleLink ) {
150150 var $tocList = $( '#toc ul:first' );
151 -
 151+
152152 // This function shouldn't be called if there's no TOC,
153153 // but just in case...
154154 if ( $tocList.size() ) {
@@ -177,9 +177,16 @@
178178 * Get the full URL to a page name
179179 *
180180 * @param str Page name to link to
 181+ * @return Full URL for page with name of 'str' or false on error
181182 */
182183 'wikiGetlink' : function( str ) {
183 - return wgServer + wgArticlePath.replace( '$1', this.wikiUrlencode( str ) );
 184+
 185+ // Exist check is needed since replace() can only be called on a string
 186+ if ( mw.config.exists( ['wgServer', 'wgArticlePath'] ) ) {
 187+ return mw.config.get( 'wgServer' ) + mw.config.get( 'wgArticlePath' ).replace( '$1', this.wikiUrlencode( str ) );
 188+ } else {
 189+ return false;
 190+ }
184191 },
185192
186193 /**
@@ -382,12 +389,12 @@
383390 * @return boolean True on success, false on failure
384391 */
385392 'jsMessage' : function( message, className ) {
386 -
 393+
387394 if ( !arguments.length || message === '' || message === null ) {
388 -
 395+
389396 $( '#mw-js-message' ).empty().hide();
390 - return true; // Emptying and hiding message is intended behaviour, return true
391 -
 397+ return true; // Emptying and hiding message is intended behaviour, return true
 398+
392399 } else {
393400 // We special-case skin structures provided by the software. Skins that
394401 // choose to abandon or significantly modify our formatting can just define
@@ -401,11 +408,11 @@
402409 return false;
403410 }
404411 }
405 -
 412+
406413 if ( className ) {
407414 $messageDiv.attr( 'class', 'mw-js-message-' + className );
408415 }
409 -
 416+
410417 if ( typeof message === 'object' ) {
411418 $messageDiv.empty();
412419 $messageDiv.append( message ); // Append new content
@@ -417,7 +424,7 @@
418425 return true;
419426 }
420427 },
421 -
 428+
422429 /**
423430 * Validate a string as representing a valid e-mail address
424431 * according to HTML5 specification. Please note the specification
@@ -429,7 +436,7 @@
430437 if( mailtxt === '' ) {
431438 return null;
432439 }
433 -
 440+
434441 /**
435442 * HTML5 defines a string as valid e-mail address if it matches
436443 * the ABNF:
@@ -440,7 +447,7 @@
441448 *
442449 * (see STD 68 / RFC 5234 http://tools.ietf.org/html/std68):
443450 */
444 -
 451+
445452 /**
446453 * First, define the RFC 5322 'atext' which is pretty easy :
447454 * atext = ALPHA / DIGIT / ; Printable US-ASCII
@@ -456,7 +463,7 @@
457464 "~"
458465 */
459466 var rfc5322_atext = "a-z0-9!#$%&'*+-/=?^_`{|}~",
460 -
 467+
461468 /**
462469 * Next define the RFC 1034 'ldh-str'
463470 * <domain> ::= <subdomain> | " "
@@ -467,7 +474,7 @@
468475 * <let-dig> ::= <letter> | <digit>
469476 */
470477 rfc1034_ldh_str = "a-z0-9-",
471 -
 478+
472479 HTML5_email_regexp = new RegExp(
473480 // start of string
474481 '^'
Index: trunk/phase3/resources/mediawiki.special/mediawiki.special.upload.js
@@ -3,7 +3,7 @@
44 * Note that additional code still lives in skins/common/upload.js
55 */
66
7 -$( function() {
 7+jQuery( function( $ ) {
88 /**
99 * Is the FileAPI available with sufficient functionality?
1010 */
@@ -21,9 +21,9 @@
2222 * @return boolean
2323 */
2424 function fileIsPreviewable( file ) {
25 - var known = ['image/png', 'image/gif', 'image/jpeg', 'image/svg+xml'];
26 - var tooHuge = 10 * 1024 * 1024;
27 - return ($.inArray( file.type, known ) !== -1) && file.size > 0 && file.size < tooHuge;
 25+ var known = ['image/png', 'image/gif', 'image/jpeg', 'image/svg+xml'],
 26+ tooHuge = 10 * 1024 * 1024;
 27+ return ( $.inArray( file.type, known ) !== -1 ) && file.size > 0 && file.size < tooHuge;
2828 }
2929
3030 /**
@@ -39,9 +39,8 @@
4040 * @param {File} file
4141 */
4242 function showPreview( file ) {
43 - var previewSize = 180;
44 -
45 - var thumb = $( '<div id="mw-upload-thumbnail" class="thumb tright">' +
 43+ var previewSize = 180,
 44+ thumb = $( '<div id="mw-upload-thumbnail" class="thumb tright">' +
4645 '<div class="thumbinner">' +
4746 '<canvas width="' + previewSize + '" height="' + previewSize + '" ></canvas>' +
4847 '<div class="thumbcaption"><div class="filename"></div><div class="fileinfo"></div></div>' +
@@ -50,18 +49,18 @@
5150 thumb.find( '.filename' ).text( file.name ).end()
5251 .find( '.fileinfo' ).text( prettySize( file.size ) ).end();
5352
54 - var ctx = thumb.find( 'canvas' )[0].getContext( '2d' );
55 - var spinner = new Image();
 53+ var ctx = thumb.find( 'canvas' )[0].getContext( '2d' ),
 54+ spinner = new Image();
5655 spinner.onload = function() {
5756 ctx.drawImage( spinner, (previewSize - spinner.width) / 2,
5857 (previewSize - spinner.height) / 2 );
5958 };
60 - spinner.src = wgScriptPath + '/skins/common/images/spinner.gif';
 59+ spinner.src = mw.config.get( 'wgScriptPath' ) + '/skins/common/images/spinner.gif';
6160 $( '#mw-htmlform-source' ).parent().prepend( thumb );
6261
6362 fetchPreview( file, function( dataURL ) {
64 - var img = new Image();
65 - var rotation = 0;
 63+ var img = new Image(),
 64+ rotation = 0;
6665 img.onload = function() {
6766 // Fit the image within the previewSizexpreviewSize box
6867 if ( img.width > img.height ) {
Index: trunk/phase3/resources/mediawiki/mediawiki.js
@@ -195,7 +195,7 @@
196196 * @return boolean Existence of key(s)
197197 */
198198 Map.prototype.exists = function( selection ) {
199 - if ( typeof keys === 'object' ) {
 199+ if ( typeof selection === 'object' ) {
200200 for ( var s = 0; s < selection.length; s++ ) {
201201 if ( !( selection[s] in this.values ) ) {
202202 return false;

Follow-up revisions

RevisionCommit summaryAuthorDate
r91504Partial backport of r80572 per bug 29726: failure in map.exists in WebKit bro...brion23:31, 5 July 2011
r91505Partial backport of r80572 per bug 29726: failure in map.exists in WebKit bro...brion23:34, 5 July 2011

Comments

#Comment by He7d3r (talk | contribs)   14:37, 7 May 2011

== 'Blankpage' --> === 'Blankpage'

#Comment by Krinkle (talk | contribs)   13:03, 8 May 2011

Why ?

A (something) to string comparison doesn't have to be strict and is also slower in most browsers AFAIK.


The JSHint validator only warns for non-strict comparisons to 0, null, , false etc. which is indeed wrong in most cases.

#Comment by He7d3r (talk | contribs)   20:24, 8 May 2011

Hmm.. Ok then.

#Comment by Krinkle (talk | contribs)   21:05, 8 May 2011

A non-strict comparison only compares the values unrelated to their types.

A strict comparison only returns true if both the value and the type are the same.

There's only 1 kind of variable that can be equal to a non-empty string (ie. "Blankpage"), so there's no need to check the type.

However comparing things like numbers, boolean or empty values need strict comparison (but only if you need them to be). For example:

  • If one needs a variable to be 1 (either as a number or as a string "1"). non-strict comparison to == 1 is perfect imho
  • If one needs someting to be 0 (as a number, not a string or boolean false), then a strict comparison to === 0 is needed. Because '0' (string) has the same value, but a different type.
  • If one needs a variable to be equal to a certain word, then a non-strict comparison to == 'my word' is suffecient and can't fail as there are no non-strings that can have the same value.
  • etc.

Hope that made sense :)

#Comment by He7d3r (talk | contribs)   21:45, 8 May 2011

Yes. I think I understood. Thanks! =)

#Comment by Brion VIBBER (talk | contribs)   23:24, 5 July 2011

Marking for backport to 1.17 per bug 29726: if it doesn't apply cleanly, the relevant part that's actually needed is this fix for a miswritten var name:

-		if ( typeof keys === 'object' ) {
+		if ( typeof selection === 'object' ) {
#Comment by Krinkle (talk | contribs)   23:26, 5 July 2011

Clean patch attached to the bug.

#Comment by Brion VIBBER (talk | contribs)   23:36, 5 July 2011

And applied on r91504 (REL_1_17) and r91505 (1.17wmf1)

Status & tagging log