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.

194 lines
9.0 KiB

1 year ago
  1. export class Buffer extends Uint8Array {
  2. length: number
  3. write(string: string, offset?: number, length?: number, encoding?: string): number;
  4. toString(encoding?: string, start?: number, end?: number): string;
  5. toJSON(): { type: 'Buffer', data: any[] };
  6. equals(otherBuffer: Buffer): boolean;
  7. compare(otherBuffer: Uint8Array, targetStart?: number, targetEnd?: number, sourceStart?: number, sourceEnd?: number): number;
  8. copy(targetBuffer: Buffer, targetStart?: number, sourceStart?: number, sourceEnd?: number): number;
  9. slice(start?: number, end?: number): Buffer;
  10. writeUIntLE(value: number, offset: number, byteLength: number, noAssert?: boolean): number;
  11. writeUIntBE(value: number, offset: number, byteLength: number, noAssert?: boolean): number;
  12. writeIntLE(value: number, offset: number, byteLength: number, noAssert?: boolean): number;
  13. writeIntBE(value: number, offset: number, byteLength: number, noAssert?: boolean): number;
  14. readUIntLE(offset: number, byteLength: number, noAssert?: boolean): number;
  15. readUIntBE(offset: number, byteLength: number, noAssert?: boolean): number;
  16. readIntLE(offset: number, byteLength: number, noAssert?: boolean): number;
  17. readIntBE(offset: number, byteLength: number, noAssert?: boolean): number;
  18. readUInt8(offset: number, noAssert?: boolean): number;
  19. readUInt16LE(offset: number, noAssert?: boolean): number;
  20. readUInt16BE(offset: number, noAssert?: boolean): number;
  21. readUInt32LE(offset: number, noAssert?: boolean): number;
  22. readUInt32BE(offset: number, noAssert?: boolean): number;
  23. readBigUInt64LE(offset: number): BigInt;
  24. readBigUInt64BE(offset: number): BigInt;
  25. readInt8(offset: number, noAssert?: boolean): number;
  26. readInt16LE(offset: number, noAssert?: boolean): number;
  27. readInt16BE(offset: number, noAssert?: boolean): number;
  28. readInt32LE(offset: number, noAssert?: boolean): number;
  29. readInt32BE(offset: number, noAssert?: boolean): number;
  30. readBigInt64LE(offset: number): BigInt;
  31. readBigInt64BE(offset: number): BigInt;
  32. readFloatLE(offset: number, noAssert?: boolean): number;
  33. readFloatBE(offset: number, noAssert?: boolean): number;
  34. readDoubleLE(offset: number, noAssert?: boolean): number;
  35. readDoubleBE(offset: number, noAssert?: boolean): number;
  36. reverse(): this;
  37. swap16(): Buffer;
  38. swap32(): Buffer;
  39. swap64(): Buffer;
  40. writeUInt8(value: number, offset: number, noAssert?: boolean): number;
  41. writeUInt16LE(value: number, offset: number, noAssert?: boolean): number;
  42. writeUInt16BE(value: number, offset: number, noAssert?: boolean): number;
  43. writeUInt32LE(value: number, offset: number, noAssert?: boolean): number;
  44. writeUInt32BE(value: number, offset: number, noAssert?: boolean): number;
  45. writeBigUInt64LE(value: number, offset: number): BigInt;
  46. writeBigUInt64BE(value: number, offset: number): BigInt;
  47. writeInt8(value: number, offset: number, noAssert?: boolean): number;
  48. writeInt16LE(value: number, offset: number, noAssert?: boolean): number;
  49. writeInt16BE(value: number, offset: number, noAssert?: boolean): number;
  50. writeInt32LE(value: number, offset: number, noAssert?: boolean): number;
  51. writeInt32BE(value: number, offset: number, noAssert?: boolean): number;
  52. writeBigInt64LE(value: number, offset: number): BigInt;
  53. writeBigInt64BE(value: number, offset: number): BigInt;
  54. writeFloatLE(value: number, offset: number, noAssert?: boolean): number;
  55. writeFloatBE(value: number, offset: number, noAssert?: boolean): number;
  56. writeDoubleLE(value: number, offset: number, noAssert?: boolean): number;
  57. writeDoubleBE(value: number, offset: number, noAssert?: boolean): number;
  58. fill(value: any, offset?: number, end?: number): this;
  59. indexOf(value: string | number | Buffer, byteOffset?: number, encoding?: string): number;
  60. lastIndexOf(value: string | number | Buffer, byteOffset?: number, encoding?: string): number;
  61. includes(value: string | number | Buffer, byteOffset?: number, encoding?: string): boolean;
  62. /**
  63. * Allocates a new buffer containing the given {str}.
  64. *
  65. * @param str String to store in buffer.
  66. * @param encoding encoding to use, optional. Default is 'utf8'
  67. */
  68. constructor (str: string, encoding?: string);
  69. /**
  70. * Allocates a new buffer of {size} octets.
  71. *
  72. * @param size count of octets to allocate.
  73. */
  74. constructor (size: number);
  75. /**
  76. * Allocates a new buffer containing the given {array} of octets.
  77. *
  78. * @param array The octets to store.
  79. */
  80. constructor (array: Uint8Array);
  81. /**
  82. * Produces a Buffer backed by the same allocated memory as
  83. * the given {ArrayBuffer}.
  84. *
  85. *
  86. * @param arrayBuffer The ArrayBuffer with which to share memory.
  87. */
  88. constructor (arrayBuffer: ArrayBuffer);
  89. /**
  90. * Allocates a new buffer containing the given {array} of octets.
  91. *
  92. * @param array The octets to store.
  93. */
  94. constructor (array: any[]);
  95. /**
  96. * Copies the passed {buffer} data onto a new {Buffer} instance.
  97. *
  98. * @param buffer The buffer to copy.
  99. */
  100. constructor (buffer: Buffer);
  101. prototype: Buffer;
  102. /**
  103. * Allocates a new Buffer using an {array} of octets.
  104. *
  105. * @param array
  106. */
  107. static from(array: any[]): Buffer;
  108. /**
  109. * When passed a reference to the .buffer property of a TypedArray instance,
  110. * the newly created Buffer will share the same allocated memory as the TypedArray.
  111. * The optional {byteOffset} and {length} arguments specify a memory range
  112. * within the {arrayBuffer} that will be shared by the Buffer.
  113. *
  114. * @param arrayBuffer The .buffer property of a TypedArray or a new ArrayBuffer()
  115. * @param byteOffset
  116. * @param length
  117. */
  118. static from(arrayBuffer: ArrayBuffer, byteOffset?: number, length?: number): Buffer;
  119. /**
  120. * Copies the passed {buffer} data onto a new Buffer instance.
  121. *
  122. * @param buffer
  123. */
  124. static from(buffer: Buffer | Uint8Array): Buffer;
  125. /**
  126. * Creates a new Buffer containing the given JavaScript string {str}.
  127. * If provided, the {encoding} parameter identifies the character encoding.
  128. * If not provided, {encoding} defaults to 'utf8'.
  129. *
  130. * @param str
  131. */
  132. static from(str: string, encoding?: string): Buffer;
  133. /**
  134. * Returns true if {obj} is a Buffer
  135. *
  136. * @param obj object to test.
  137. */
  138. static isBuffer(obj: any): obj is Buffer;
  139. /**
  140. * Returns true if {encoding} is a valid encoding argument.
  141. * Valid string encodings in Node 0.12: 'ascii'|'utf8'|'utf16le'|'ucs2'(alias of 'utf16le')|'base64'|'binary'(deprecated)|'hex'
  142. *
  143. * @param encoding string to test.
  144. */
  145. static isEncoding(encoding: string): boolean;
  146. /**
  147. * Gives the actual byte length of a string. encoding defaults to 'utf8'.
  148. * This is not the same as String.prototype.length since that returns the number of characters in a string.
  149. *
  150. * @param string string to test.
  151. * @param encoding encoding used to evaluate (defaults to 'utf8')
  152. */
  153. static byteLength(string: string, encoding?: string): number;
  154. /**
  155. * Returns a buffer which is the result of concatenating all the buffers in the list together.
  156. *
  157. * If the list has no items, or if the totalLength is 0, then it returns a zero-length buffer.
  158. * If the list has exactly one item, then the first item of the list is returned.
  159. * If the list has more than one item, then a new Buffer is created.
  160. *
  161. * @param list An array of Buffer objects to concatenate
  162. * @param totalLength Total length of the buffers when concatenated.
  163. * If totalLength is not provided, it is read from the buffers in the list. However, this adds an additional loop to the function, so it is faster to provide the length explicitly.
  164. */
  165. static concat(list: Uint8Array[], totalLength?: number): Buffer;
  166. /**
  167. * The same as buf1.compare(buf2).
  168. */
  169. static compare(buf1: Uint8Array, buf2: Uint8Array): number;
  170. /**
  171. * Allocates a new buffer of {size} octets.
  172. *
  173. * @param size count of octets to allocate.
  174. * @param fill if specified, buffer will be initialized by calling buf.fill(fill).
  175. * If parameter is omitted, buffer will be filled with zeros.
  176. * @param encoding encoding used for call to buf.fill while initializing
  177. */
  178. static alloc(size: number, fill?: string | Buffer | number, encoding?: string): Buffer;
  179. /**
  180. * Allocates a new buffer of {size} octets, leaving memory not initialized, so the contents
  181. * of the newly created Buffer are unknown and may contain sensitive data.
  182. *
  183. * @param size count of octets to allocate
  184. */
  185. static allocUnsafe(size: number): Buffer;
  186. /**
  187. * Allocates a new non-pooled buffer of {size} octets, leaving memory not initialized, so the contents
  188. * of the newly created Buffer are unknown and may contain sensitive data.
  189. *
  190. * @param size count of octets to allocate
  191. */
  192. static allocUnsafeSlow(size: number): Buffer;
  193. }