resourceloader: Minor optimisation in variable declarations
authorTimo Tijhof <krinklemail@gmail.com>
Sat, 9 Mar 2019 04:56:54 +0000 (04:56 +0000)
committerTimo Tijhof <krinklemail@gmail.com>
Sat, 9 Mar 2019 05:10:08 +0000 (05:10 +0000)
Trying out Safari after a while and, it's Dev Tools have a
way to see the compiler's type inference, showing that Safari
is not able to always detect some numbers as non-optional.

While I generally avoid optimising for an optimiser, I believe
being more explicit is always better or equal. Plus, it saves a
few bytes while at it.

Change-Id: I4084452a74c51953ff0a1609b3b52d696f14a7e1

resources/src/startup/mediawiki.js

index 28f57db..e110b95 100644 (file)
         */
        function fnv132( str ) {
                var hash = 0x811C9DC5,
-                       i;
+                       i = 0;
 
                /* eslint-disable no-bitwise */
-               for ( i = 0; i < str.length; i++ ) {
+               for ( ; i < str.length; i++ ) {
                        hash += ( hash << 1 ) + ( hash << 4 ) + ( hash << 7 ) + ( hash << 8 ) + ( hash << 24 );
                        hash ^= str.charCodeAt( i );
                }
                         * @return {boolean} True if all modules are in state 'ready', false otherwise
                         */
                        function allReady( modules ) {
-                               var i;
-                               for ( i = 0; i < modules.length; i++ ) {
+                               var i = 0;
+                               for ( ; i < modules.length; i++ ) {
                                        if ( mw.loader.getState( modules[ i ] ) !== 'ready' ) {
                                                return false;
                                        }
                         * @return {boolean} True if no modules are in state 'error' or 'missing', false otherwise
                         */
                        function anyFailed( modules ) {
-                               var i, state;
-                               for ( i = 0; i < modules.length; i++ ) {
+                               var state,
+                                       i = 0;
+                               for ( ; i < modules.length; i++ ) {
                                        state = mw.loader.getState( modules[ i ] );
                                        if ( state === 'error' || state === 'missing' ) {
                                                return true;
                         * @throws {Error} If an unregistered module or a dependency loop is encountered
                         */
                        function resolve( modules ) {
-                               var i, resolved = [];
-                               for ( i = 0; i < modules.length; i++ ) {
+                               var resolved = [],
+                                       i = 0;
+                               for ( ; i < modules.length; i++ ) {
                                        sortDependencies( modules[ i ], resolved );
                                }
                                return resolved;
                         * @return {Array} List of dependencies.
                         */
                        function resolveStubbornly( modules ) {
-                               var i, saved, resolved = [];
-                               for ( i = 0; i < modules.length; i++ ) {
+                               var saved,
+                                       resolved = [],
+                                       i = 0;
+                               for ( ; i < modules.length; i++ ) {
                                        saved = resolved.slice();
                                        try {
                                                sortDependencies( modules[ i ], resolved );
                                 * @private
                                 */
                                work: function () {
-                                       var q, batch, implementations, sourceModules;
-
-                                       batch = [];
+                                       var implementations, sourceModules,
+                                               batch = [],
+                                               q = 0;
 
                                        // Appends a list of modules from the queue to the batch
-                                       for ( q = 0; q < queue.length; q++ ) {
+                                       for ( ; q < queue.length; q++ ) {
                                                // Only load modules which are registered
                                                if ( queue[ q ] in registry && registry[ queue[ q ] ].state === 'registered' ) {
                                                        // Prevent duplicate entries