|  | 
|  | 1 | +'use strict'; | 
|  | 2 | + | 
|  | 3 | +require('../common'); | 
|  | 4 | +const assert = require('assert'); | 
|  | 5 | + | 
|  | 6 | +const buf = Buffer.from([0x1, 0x2, 0x3, 0x4]); | 
|  | 7 | + | 
|  | 8 | +assert.strictEqual(buf, buf.swap16()); | 
|  | 9 | +assert.deepStrictEqual(buf, Buffer.from([0x2, 0x1, 0x4, 0x3])); | 
|  | 10 | + | 
|  | 11 | +assert.strictEqual(buf, buf.swap32()); | 
|  | 12 | +assert.deepStrictEqual(buf, Buffer.from([0x3, 0x4, 0x1, 0x2])); | 
|  | 13 | + | 
|  | 14 | +const buf_array = []; | 
|  | 15 | +for (var i = 1; i < 33; i++) | 
|  | 16 | +  buf_array.push(i); | 
|  | 17 | +const buf2 = Buffer.from(buf_array); | 
|  | 18 | +buf2.swap32(); | 
|  | 19 | +assert.deepStrictEqual(buf2, | 
|  | 20 | +    Buffer.from([0x04, 0x03, 0x02, 0x01, 0x08, 0x07, 0x06, 0x05, 0x0c, | 
|  | 21 | +                 0x0b, 0x0a, 0x09, 0x10, 0x0f, 0x0e, 0x0d, 0x14, 0x13, | 
|  | 22 | +                 0x12, 0x11, 0x18, 0x17, 0x16, 0x15, 0x1c, 0x1b, 0x1a, | 
|  | 23 | +                 0x19, 0x20, 0x1f, 0x1e, 0x1d])); | 
|  | 24 | +buf2.swap16(); | 
|  | 25 | +assert.deepStrictEqual(buf2, | 
|  | 26 | +    Buffer.from([0x03, 0x04, 0x01, 0x02, 0x07, 0x08, 0x05, 0x06, 0x0b, | 
|  | 27 | +                 0x0c, 0x09, 0x0a, 0x0f, 0x10, 0x0d, 0x0e, 0x13, 0x14, | 
|  | 28 | +                 0x11, 0x12, 0x17, 0x18, 0x15, 0x16, 0x1b, 0x1c, 0x19, | 
|  | 29 | +                 0x1a, 0x1f, 0x20, 0x1d, 0x1e])); | 
|  | 30 | + | 
|  | 31 | +const buf3 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7]); | 
|  | 32 | +buf3.slice(1, 5).swap32(); | 
|  | 33 | +assert.deepStrictEqual(buf3, Buffer.from([0x1, 0x5, 0x4, 0x3, 0x2, 0x6, 0x7])); | 
|  | 34 | + | 
|  | 35 | +buf3.slice(1, 5).swap16(); | 
|  | 36 | +assert.deepStrictEqual(buf3, Buffer.from([0x1, 0x4, 0x5, 0x2, 0x3, 0x6, 0x7])); | 
|  | 37 | + | 
|  | 38 | +// Force use of native code (Buffer size above threshold limit for js impl) | 
|  | 39 | +const buf4 = Buffer.allocUnsafe(1024).fill([0x1, 0x2, 0x3, 0x4]); | 
|  | 40 | +const buf5 = Buffer.allocUnsafe(1024).fill([0x2, 0x1, 0x4, 0x3]); | 
|  | 41 | +const buf6 = Buffer.allocUnsafe(1024) | 
|  | 42 | +                   .fill([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]); | 
|  | 43 | +const buf7 = Buffer.allocUnsafe(1024) | 
|  | 44 | +                   .fill([0x4, 0x3, 0x2, 0x1, 0x8, 0x7, 0x6, 0x5]); | 
|  | 45 | + | 
|  | 46 | +buf4.swap16(); | 
|  | 47 | +assert.deepStrictEqual(buf4, buf5); | 
|  | 48 | + | 
|  | 49 | +buf6.swap32(); | 
|  | 50 | +assert.deepStrictEqual(buf6, buf7); | 
|  | 51 | + | 
|  | 52 | + | 
|  | 53 | +const re16 = /Buffer size must be a multiple of 16-bits/; | 
|  | 54 | +const re32 = /Buffer size must be a multiple of 32-bits/; | 
|  | 55 | + | 
|  | 56 | +assert.throws(() => Buffer.from(buf3).swap16(), re16); | 
|  | 57 | +assert.throws(() => Buffer.alloc(1025).swap16(), re16); | 
|  | 58 | +assert.throws(() => Buffer.from(buf3).swap32(), re32); | 
|  | 59 | +assert.throws(() => buf3.slice(1, 3).swap32(), re32); | 
|  | 60 | +assert.throws(() => Buffer.alloc(1025).swap32(), re32); | 
0 commit comments