You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					60 lines
				
				1.7 KiB
			
		
		
			
		
	
	
					60 lines
				
				1.7 KiB
			| 
											2 years ago
										 | 'use strict'; | ||
|  | 
 | ||
|  | // Note: we can't get significant speed boost here.
 | ||
|  | // So write code to minimize size - no pregenerated tables
 | ||
|  | // and array tools dependencies.
 | ||
|  | 
 | ||
|  | // (C) 1995-2013 Jean-loup Gailly and Mark Adler
 | ||
|  | // (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin
 | ||
|  | //
 | ||
|  | // This software is provided 'as-is', without any express or implied
 | ||
|  | // warranty. In no event will the authors be held liable for any damages
 | ||
|  | // arising from the use of this software.
 | ||
|  | //
 | ||
|  | // Permission is granted to anyone to use this software for any purpose,
 | ||
|  | // including commercial applications, and to alter it and redistribute it
 | ||
|  | // freely, subject to the following restrictions:
 | ||
|  | //
 | ||
|  | // 1. The origin of this software must not be misrepresented; you must not
 | ||
|  | //   claim that you wrote the original software. If you use this software
 | ||
|  | //   in a product, an acknowledgment in the product documentation would be
 | ||
|  | //   appreciated but is not required.
 | ||
|  | // 2. Altered source versions must be plainly marked as such, and must not be
 | ||
|  | //   misrepresented as being the original software.
 | ||
|  | // 3. This notice may not be removed or altered from any source distribution.
 | ||
|  | 
 | ||
|  | // Use ordinary array, since untyped makes no boost here
 | ||
|  | function makeTable() { | ||
|  |   var c, table = []; | ||
|  | 
 | ||
|  |   for (var n = 0; n < 256; n++) { | ||
|  |     c = n; | ||
|  |     for (var k = 0; k < 8; k++) { | ||
|  |       c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1)); | ||
|  |     } | ||
|  |     table[n] = c; | ||
|  |   } | ||
|  | 
 | ||
|  |   return table; | ||
|  | } | ||
|  | 
 | ||
|  | // Create table on load. Just 255 signed longs. Not a problem.
 | ||
|  | var crcTable = makeTable(); | ||
|  | 
 | ||
|  | 
 | ||
|  | function crc32(crc, buf, len, pos) { | ||
|  |   var t = crcTable, | ||
|  |       end = pos + len; | ||
|  | 
 | ||
|  |   crc ^= -1; | ||
|  | 
 | ||
|  |   for (var i = pos; i < end; i++) { | ||
|  |     crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF]; | ||
|  |   } | ||
|  | 
 | ||
|  |   return (crc ^ (-1)); // >>> 0;
 | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | module.exports = crc32; |