builtin_typedarrays.go 51 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445
  1. package goja
  2. import (
  3. "fmt"
  4. "math"
  5. "sort"
  6. "unsafe"
  7. "github.com/dop251/goja/unistring"
  8. )
  9. type typedArraySortCtx struct {
  10. ta *typedArrayObject
  11. compare func(FunctionCall) Value
  12. needValidate bool
  13. }
  14. func (ctx *typedArraySortCtx) Len() int {
  15. return ctx.ta.length
  16. }
  17. func (ctx *typedArraySortCtx) Less(i, j int) bool {
  18. if ctx.needValidate {
  19. ctx.ta.viewedArrayBuf.ensureNotDetached(true)
  20. ctx.needValidate = false
  21. }
  22. offset := ctx.ta.offset
  23. if ctx.compare != nil {
  24. x := ctx.ta.typedArray.get(offset + i)
  25. y := ctx.ta.typedArray.get(offset + j)
  26. res := ctx.compare(FunctionCall{
  27. This: _undefined,
  28. Arguments: []Value{x, y},
  29. }).ToNumber()
  30. ctx.needValidate = true
  31. if i, ok := res.(valueInt); ok {
  32. return i < 0
  33. }
  34. f := res.ToFloat()
  35. if f < 0 {
  36. return true
  37. }
  38. if f > 0 {
  39. return false
  40. }
  41. if math.Signbit(f) {
  42. return true
  43. }
  44. return false
  45. }
  46. return ctx.ta.typedArray.less(offset+i, offset+j)
  47. }
  48. func (ctx *typedArraySortCtx) Swap(i, j int) {
  49. if ctx.needValidate {
  50. ctx.ta.viewedArrayBuf.ensureNotDetached(true)
  51. ctx.needValidate = false
  52. }
  53. offset := ctx.ta.offset
  54. ctx.ta.typedArray.swap(offset+i, offset+j)
  55. }
  56. func allocByteSlice(size int) (b []byte) {
  57. defer func() {
  58. if x := recover(); x != nil {
  59. panic(rangeError(fmt.Sprintf("Buffer size is too large: %d", size)))
  60. }
  61. }()
  62. if size < 0 {
  63. panic(rangeError(fmt.Sprintf("Invalid buffer size: %d", size)))
  64. }
  65. b = make([]byte, size)
  66. return
  67. }
  68. func (r *Runtime) builtin_newArrayBuffer(args []Value, newTarget *Object) *Object {
  69. if newTarget == nil {
  70. panic(r.needNew("ArrayBuffer"))
  71. }
  72. b := r._newArrayBuffer(r.getPrototypeFromCtor(newTarget, r.global.ArrayBuffer, r.global.ArrayBufferPrototype), nil)
  73. if len(args) > 0 {
  74. b.data = allocByteSlice(r.toIndex(args[0]))
  75. }
  76. return b.val
  77. }
  78. func (r *Runtime) arrayBufferProto_getByteLength(call FunctionCall) Value {
  79. o := r.toObject(call.This)
  80. if b, ok := o.self.(*arrayBufferObject); ok {
  81. if b.ensureNotDetached(false) {
  82. return intToValue(int64(len(b.data)))
  83. }
  84. return intToValue(0)
  85. }
  86. panic(r.NewTypeError("Object is not ArrayBuffer: %s", o))
  87. }
  88. func (r *Runtime) arrayBufferProto_slice(call FunctionCall) Value {
  89. o := r.toObject(call.This)
  90. if b, ok := o.self.(*arrayBufferObject); ok {
  91. l := int64(len(b.data))
  92. start := relToIdx(call.Argument(0).ToInteger(), l)
  93. var stop int64
  94. if arg := call.Argument(1); arg != _undefined {
  95. stop = arg.ToInteger()
  96. } else {
  97. stop = l
  98. }
  99. stop = relToIdx(stop, l)
  100. newLen := max(stop-start, 0)
  101. ret := r.speciesConstructor(o, r.global.ArrayBuffer)([]Value{intToValue(newLen)}, nil)
  102. if ab, ok := ret.self.(*arrayBufferObject); ok {
  103. if newLen > 0 {
  104. b.ensureNotDetached(true)
  105. if ret == o {
  106. panic(r.NewTypeError("Species constructor returned the same ArrayBuffer"))
  107. }
  108. if int64(len(ab.data)) < newLen {
  109. panic(r.NewTypeError("Species constructor returned an ArrayBuffer that is too small: %d", len(ab.data)))
  110. }
  111. ab.ensureNotDetached(true)
  112. copy(ab.data, b.data[start:stop])
  113. }
  114. return ret
  115. }
  116. panic(r.NewTypeError("Species constructor did not return an ArrayBuffer: %s", ret.String()))
  117. }
  118. panic(r.NewTypeError("Object is not ArrayBuffer: %s", o))
  119. }
  120. func (r *Runtime) arrayBuffer_isView(call FunctionCall) Value {
  121. if o, ok := call.Argument(0).(*Object); ok {
  122. if _, ok := o.self.(*dataViewObject); ok {
  123. return valueTrue
  124. }
  125. if _, ok := o.self.(*typedArrayObject); ok {
  126. return valueTrue
  127. }
  128. }
  129. return valueFalse
  130. }
  131. func (r *Runtime) newDataView(args []Value, newTarget *Object) *Object {
  132. if newTarget == nil {
  133. panic(r.needNew("DataView"))
  134. }
  135. proto := r.getPrototypeFromCtor(newTarget, r.global.DataView, r.global.DataViewPrototype)
  136. var bufArg Value
  137. if len(args) > 0 {
  138. bufArg = args[0]
  139. }
  140. var buffer *arrayBufferObject
  141. if o, ok := bufArg.(*Object); ok {
  142. if b, ok := o.self.(*arrayBufferObject); ok {
  143. buffer = b
  144. }
  145. }
  146. if buffer == nil {
  147. panic(r.NewTypeError("First argument to DataView constructor must be an ArrayBuffer"))
  148. }
  149. var byteOffset, byteLen int
  150. if len(args) > 1 {
  151. offsetArg := nilSafe(args[1])
  152. byteOffset = r.toIndex(offsetArg)
  153. buffer.ensureNotDetached(true)
  154. if byteOffset > len(buffer.data) {
  155. panic(r.newError(r.global.RangeError, "Start offset %s is outside the bounds of the buffer", offsetArg.String()))
  156. }
  157. }
  158. if len(args) > 2 && args[2] != nil && args[2] != _undefined {
  159. byteLen = r.toIndex(args[2])
  160. if byteOffset+byteLen > len(buffer.data) {
  161. panic(r.newError(r.global.RangeError, "Invalid DataView length %d", byteLen))
  162. }
  163. } else {
  164. byteLen = len(buffer.data) - byteOffset
  165. }
  166. o := &Object{runtime: r}
  167. b := &dataViewObject{
  168. baseObject: baseObject{
  169. class: classObject,
  170. val: o,
  171. prototype: proto,
  172. extensible: true,
  173. },
  174. viewedArrayBuf: buffer,
  175. byteOffset: byteOffset,
  176. byteLen: byteLen,
  177. }
  178. o.self = b
  179. b.init()
  180. return o
  181. }
  182. func (r *Runtime) dataViewProto_getBuffer(call FunctionCall) Value {
  183. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  184. return dv.viewedArrayBuf.val
  185. }
  186. panic(r.NewTypeError("Method get DataView.prototype.buffer called on incompatible receiver %s", call.This.String()))
  187. }
  188. func (r *Runtime) dataViewProto_getByteLen(call FunctionCall) Value {
  189. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  190. dv.viewedArrayBuf.ensureNotDetached(true)
  191. return intToValue(int64(dv.byteLen))
  192. }
  193. panic(r.NewTypeError("Method get DataView.prototype.byteLength called on incompatible receiver %s", call.This.String()))
  194. }
  195. func (r *Runtime) dataViewProto_getByteOffset(call FunctionCall) Value {
  196. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  197. dv.viewedArrayBuf.ensureNotDetached(true)
  198. return intToValue(int64(dv.byteOffset))
  199. }
  200. panic(r.NewTypeError("Method get DataView.prototype.byteOffset called on incompatible receiver %s", call.This.String()))
  201. }
  202. func (r *Runtime) dataViewProto_getFloat32(call FunctionCall) Value {
  203. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  204. return floatToValue(float64(dv.viewedArrayBuf.getFloat32(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 4))))
  205. }
  206. panic(r.NewTypeError("Method DataView.prototype.getFloat32 called on incompatible receiver %s", call.This.String()))
  207. }
  208. func (r *Runtime) dataViewProto_getFloat64(call FunctionCall) Value {
  209. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  210. return floatToValue(dv.viewedArrayBuf.getFloat64(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 8)))
  211. }
  212. panic(r.NewTypeError("Method DataView.prototype.getFloat64 called on incompatible receiver %s", call.This.String()))
  213. }
  214. func (r *Runtime) dataViewProto_getInt8(call FunctionCall) Value {
  215. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  216. idx, _ := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 1)
  217. return intToValue(int64(dv.viewedArrayBuf.getInt8(idx)))
  218. }
  219. panic(r.NewTypeError("Method DataView.prototype.getInt8 called on incompatible receiver %s", call.This.String()))
  220. }
  221. func (r *Runtime) dataViewProto_getInt16(call FunctionCall) Value {
  222. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  223. return intToValue(int64(dv.viewedArrayBuf.getInt16(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 2))))
  224. }
  225. panic(r.NewTypeError("Method DataView.prototype.getInt16 called on incompatible receiver %s", call.This.String()))
  226. }
  227. func (r *Runtime) dataViewProto_getInt32(call FunctionCall) Value {
  228. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  229. return intToValue(int64(dv.viewedArrayBuf.getInt32(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 4))))
  230. }
  231. panic(r.NewTypeError("Method DataView.prototype.getInt32 called on incompatible receiver %s", call.This.String()))
  232. }
  233. func (r *Runtime) dataViewProto_getUint8(call FunctionCall) Value {
  234. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  235. idx, _ := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 1)
  236. return intToValue(int64(dv.viewedArrayBuf.getUint8(idx)))
  237. }
  238. panic(r.NewTypeError("Method DataView.prototype.getUint8 called on incompatible receiver %s", call.This.String()))
  239. }
  240. func (r *Runtime) dataViewProto_getUint16(call FunctionCall) Value {
  241. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  242. return intToValue(int64(dv.viewedArrayBuf.getUint16(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 2))))
  243. }
  244. panic(r.NewTypeError("Method DataView.prototype.getUint16 called on incompatible receiver %s", call.This.String()))
  245. }
  246. func (r *Runtime) dataViewProto_getUint32(call FunctionCall) Value {
  247. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  248. return intToValue(int64(dv.viewedArrayBuf.getUint32(dv.getIdxAndByteOrder(call.Argument(0), call.Argument(1), 4))))
  249. }
  250. panic(r.NewTypeError("Method DataView.prototype.getUint32 called on incompatible receiver %s", call.This.String()))
  251. }
  252. func (r *Runtime) dataViewProto_setFloat32(call FunctionCall) Value {
  253. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  254. val := toFloat32(call.Argument(1))
  255. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 4)
  256. dv.viewedArrayBuf.setFloat32(idx, val, bo)
  257. return _undefined
  258. }
  259. panic(r.NewTypeError("Method DataView.prototype.setFloat32 called on incompatible receiver %s", call.This.String()))
  260. }
  261. func (r *Runtime) dataViewProto_setFloat64(call FunctionCall) Value {
  262. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  263. val := call.Argument(1).ToFloat()
  264. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 8)
  265. dv.viewedArrayBuf.setFloat64(idx, val, bo)
  266. return _undefined
  267. }
  268. panic(r.NewTypeError("Method DataView.prototype.setFloat64 called on incompatible receiver %s", call.This.String()))
  269. }
  270. func (r *Runtime) dataViewProto_setInt8(call FunctionCall) Value {
  271. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  272. val := toInt8(call.Argument(1))
  273. idx, _ := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 1)
  274. dv.viewedArrayBuf.setInt8(idx, val)
  275. return _undefined
  276. }
  277. panic(r.NewTypeError("Method DataView.prototype.setInt8 called on incompatible receiver %s", call.This.String()))
  278. }
  279. func (r *Runtime) dataViewProto_setInt16(call FunctionCall) Value {
  280. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  281. val := toInt16(call.Argument(1))
  282. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 2)
  283. dv.viewedArrayBuf.setInt16(idx, val, bo)
  284. return _undefined
  285. }
  286. panic(r.NewTypeError("Method DataView.prototype.setInt16 called on incompatible receiver %s", call.This.String()))
  287. }
  288. func (r *Runtime) dataViewProto_setInt32(call FunctionCall) Value {
  289. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  290. val := toInt32(call.Argument(1))
  291. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 4)
  292. dv.viewedArrayBuf.setInt32(idx, val, bo)
  293. return _undefined
  294. }
  295. panic(r.NewTypeError("Method DataView.prototype.setInt32 called on incompatible receiver %s", call.This.String()))
  296. }
  297. func (r *Runtime) dataViewProto_setUint8(call FunctionCall) Value {
  298. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  299. val := toUint8(call.Argument(1))
  300. idx, _ := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 1)
  301. dv.viewedArrayBuf.setUint8(idx, val)
  302. return _undefined
  303. }
  304. panic(r.NewTypeError("Method DataView.prototype.setUint8 called on incompatible receiver %s", call.This.String()))
  305. }
  306. func (r *Runtime) dataViewProto_setUint16(call FunctionCall) Value {
  307. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  308. val := toUint16(call.Argument(1))
  309. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 2)
  310. dv.viewedArrayBuf.setUint16(idx, val, bo)
  311. return _undefined
  312. }
  313. panic(r.NewTypeError("Method DataView.prototype.setUint16 called on incompatible receiver %s", call.This.String()))
  314. }
  315. func (r *Runtime) dataViewProto_setUint32(call FunctionCall) Value {
  316. if dv, ok := r.toObject(call.This).self.(*dataViewObject); ok {
  317. val := toUint32(call.Argument(1))
  318. idx, bo := dv.getIdxAndByteOrder(call.Argument(0), call.Argument(2), 4)
  319. dv.viewedArrayBuf.setUint32(idx, val, bo)
  320. return _undefined
  321. }
  322. panic(r.NewTypeError("Method DataView.prototype.setUint32 called on incompatible receiver %s", call.This.String()))
  323. }
  324. func (r *Runtime) typedArrayProto_getBuffer(call FunctionCall) Value {
  325. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  326. return ta.viewedArrayBuf.val
  327. }
  328. panic(r.NewTypeError("Method get TypedArray.prototype.buffer called on incompatible receiver %s", call.This.String()))
  329. }
  330. func (r *Runtime) typedArrayProto_getByteLen(call FunctionCall) Value {
  331. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  332. if ta.viewedArrayBuf.data == nil {
  333. return _positiveZero
  334. }
  335. return intToValue(int64(ta.length) * int64(ta.elemSize))
  336. }
  337. panic(r.NewTypeError("Method get TypedArray.prototype.byteLength called on incompatible receiver %s", call.This.String()))
  338. }
  339. func (r *Runtime) typedArrayProto_getLength(call FunctionCall) Value {
  340. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  341. if ta.viewedArrayBuf.data == nil {
  342. return _positiveZero
  343. }
  344. return intToValue(int64(ta.length))
  345. }
  346. panic(r.NewTypeError("Method get TypedArray.prototype.length called on incompatible receiver %s", call.This.String()))
  347. }
  348. func (r *Runtime) typedArrayProto_getByteOffset(call FunctionCall) Value {
  349. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  350. if ta.viewedArrayBuf.data == nil {
  351. return _positiveZero
  352. }
  353. return intToValue(int64(ta.offset) * int64(ta.elemSize))
  354. }
  355. panic(r.NewTypeError("Method get TypedArray.prototype.byteOffset called on incompatible receiver %s", call.This.String()))
  356. }
  357. func (r *Runtime) typedArrayProto_copyWithin(call FunctionCall) Value {
  358. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  359. ta.viewedArrayBuf.ensureNotDetached(true)
  360. l := int64(ta.length)
  361. var relEnd int64
  362. to := toIntStrict(relToIdx(call.Argument(0).ToInteger(), l))
  363. from := toIntStrict(relToIdx(call.Argument(1).ToInteger(), l))
  364. if end := call.Argument(2); end != _undefined {
  365. relEnd = end.ToInteger()
  366. } else {
  367. relEnd = l
  368. }
  369. final := toIntStrict(relToIdx(relEnd, l))
  370. data := ta.viewedArrayBuf.data
  371. offset := ta.offset
  372. elemSize := ta.elemSize
  373. if final > from {
  374. ta.viewedArrayBuf.ensureNotDetached(true)
  375. copy(data[(offset+to)*elemSize:], data[(offset+from)*elemSize:(offset+final)*elemSize])
  376. }
  377. return call.This
  378. }
  379. panic(r.NewTypeError("Method TypedArray.prototype.copyWithin called on incompatible receiver %s", call.This.String()))
  380. }
  381. func (r *Runtime) typedArrayProto_entries(call FunctionCall) Value {
  382. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  383. ta.viewedArrayBuf.ensureNotDetached(true)
  384. return r.createArrayIterator(ta.val, iterationKindKeyValue)
  385. }
  386. panic(r.NewTypeError("Method TypedArray.prototype.entries called on incompatible receiver %s", call.This.String()))
  387. }
  388. func (r *Runtime) typedArrayProto_every(call FunctionCall) Value {
  389. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  390. ta.viewedArrayBuf.ensureNotDetached(true)
  391. callbackFn := r.toCallable(call.Argument(0))
  392. fc := FunctionCall{
  393. This: call.Argument(1),
  394. Arguments: []Value{nil, nil, call.This},
  395. }
  396. for k := 0; k < ta.length; k++ {
  397. ta.viewedArrayBuf.ensureNotDetached(true)
  398. fc.Arguments[0] = ta.typedArray.get(ta.offset + k)
  399. fc.Arguments[1] = intToValue(int64(k))
  400. if !callbackFn(fc).ToBoolean() {
  401. return valueFalse
  402. }
  403. }
  404. return valueTrue
  405. }
  406. panic(r.NewTypeError("Method TypedArray.prototype.every called on incompatible receiver %s", call.This.String()))
  407. }
  408. func (r *Runtime) typedArrayProto_fill(call FunctionCall) Value {
  409. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  410. ta.viewedArrayBuf.ensureNotDetached(true)
  411. l := int64(ta.length)
  412. k := toIntStrict(relToIdx(call.Argument(1).ToInteger(), l))
  413. var relEnd int64
  414. if endArg := call.Argument(2); endArg != _undefined {
  415. relEnd = endArg.ToInteger()
  416. } else {
  417. relEnd = l
  418. }
  419. final := toIntStrict(relToIdx(relEnd, l))
  420. value := ta.typedArray.toRaw(call.Argument(0))
  421. ta.viewedArrayBuf.ensureNotDetached(true)
  422. for ; k < final; k++ {
  423. ta.typedArray.setRaw(ta.offset+k, value)
  424. }
  425. return call.This
  426. }
  427. panic(r.NewTypeError("Method TypedArray.prototype.fill called on incompatible receiver %s", call.This.String()))
  428. }
  429. func (r *Runtime) typedArrayProto_filter(call FunctionCall) Value {
  430. o := r.toObject(call.This)
  431. if ta, ok := o.self.(*typedArrayObject); ok {
  432. ta.viewedArrayBuf.ensureNotDetached(true)
  433. callbackFn := r.toCallable(call.Argument(0))
  434. fc := FunctionCall{
  435. This: call.Argument(1),
  436. Arguments: []Value{nil, nil, call.This},
  437. }
  438. buf := make([]byte, 0, ta.length*ta.elemSize)
  439. captured := 0
  440. for k := 0; k < ta.length; k++ {
  441. ta.viewedArrayBuf.ensureNotDetached(true)
  442. fc.Arguments[0] = ta.typedArray.get(k)
  443. fc.Arguments[1] = intToValue(int64(k))
  444. if callbackFn(fc).ToBoolean() {
  445. i := (ta.offset + k) * ta.elemSize
  446. buf = append(buf, ta.viewedArrayBuf.data[i:i+ta.elemSize]...)
  447. captured++
  448. }
  449. }
  450. c := r.speciesConstructorObj(o, ta.defaultCtor)
  451. ab := r._newArrayBuffer(r.global.ArrayBufferPrototype, nil)
  452. ab.data = buf
  453. kept := r.toConstructor(ta.defaultCtor)([]Value{ab.val}, ta.defaultCtor)
  454. if c == ta.defaultCtor {
  455. return kept
  456. } else {
  457. ret := r.typedArrayCreate(c, []Value{intToValue(int64(captured))})
  458. keptTa := kept.self.(*typedArrayObject)
  459. for i := 0; i < captured; i++ {
  460. ret.typedArray.set(i, keptTa.typedArray.get(i))
  461. }
  462. return ret.val
  463. }
  464. }
  465. panic(r.NewTypeError("Method TypedArray.prototype.filter called on incompatible receiver %s", call.This.String()))
  466. }
  467. func (r *Runtime) typedArrayProto_find(call FunctionCall) Value {
  468. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  469. ta.viewedArrayBuf.ensureNotDetached(true)
  470. predicate := r.toCallable(call.Argument(0))
  471. fc := FunctionCall{
  472. This: call.Argument(1),
  473. Arguments: []Value{nil, nil, call.This},
  474. }
  475. for k := 0; k < ta.length; k++ {
  476. ta.viewedArrayBuf.ensureNotDetached(true)
  477. val := ta.typedArray.get(ta.offset + k)
  478. fc.Arguments[0] = val
  479. fc.Arguments[1] = intToValue(int64(k))
  480. if predicate(fc).ToBoolean() {
  481. return val
  482. }
  483. }
  484. return _undefined
  485. }
  486. panic(r.NewTypeError("Method TypedArray.prototype.find called on incompatible receiver %s", call.This.String()))
  487. }
  488. func (r *Runtime) typedArrayProto_findIndex(call FunctionCall) Value {
  489. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  490. ta.viewedArrayBuf.ensureNotDetached(true)
  491. predicate := r.toCallable(call.Argument(0))
  492. fc := FunctionCall{
  493. This: call.Argument(1),
  494. Arguments: []Value{nil, nil, call.This},
  495. }
  496. for k := 0; k < ta.length; k++ {
  497. ta.viewedArrayBuf.ensureNotDetached(true)
  498. fc.Arguments[0] = ta.typedArray.get(ta.offset + k)
  499. fc.Arguments[1] = intToValue(int64(k))
  500. if predicate(fc).ToBoolean() {
  501. return fc.Arguments[1]
  502. }
  503. }
  504. return intToValue(-1)
  505. }
  506. panic(r.NewTypeError("Method TypedArray.prototype.findIndex called on incompatible receiver %s", call.This.String()))
  507. }
  508. func (r *Runtime) typedArrayProto_forEach(call FunctionCall) Value {
  509. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  510. ta.viewedArrayBuf.ensureNotDetached(true)
  511. callbackFn := r.toCallable(call.Argument(0))
  512. fc := FunctionCall{
  513. This: call.Argument(1),
  514. Arguments: []Value{nil, nil, call.This},
  515. }
  516. for k := 0; k < ta.length; k++ {
  517. ta.viewedArrayBuf.ensureNotDetached(true)
  518. if val := ta.typedArray.get(k); val != nil {
  519. fc.Arguments[0] = val
  520. fc.Arguments[1] = intToValue(int64(k))
  521. callbackFn(fc)
  522. }
  523. }
  524. return _undefined
  525. }
  526. panic(r.NewTypeError("Method TypedArray.prototype.forEach called on incompatible receiver %s", call.This.String()))
  527. }
  528. func (r *Runtime) typedArrayProto_includes(call FunctionCall) Value {
  529. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  530. ta.viewedArrayBuf.ensureNotDetached(true)
  531. length := int64(ta.length)
  532. if length == 0 {
  533. return valueFalse
  534. }
  535. n := call.Argument(1).ToInteger()
  536. if n >= length {
  537. return valueFalse
  538. }
  539. if n < 0 {
  540. n = max(length+n, 0)
  541. }
  542. ta.viewedArrayBuf.ensureNotDetached(true)
  543. searchElement := call.Argument(0)
  544. if searchElement == _negativeZero {
  545. searchElement = _positiveZero
  546. }
  547. if ta.typedArray.typeMatch(searchElement) {
  548. se := ta.typedArray.toRaw(searchElement)
  549. for k := toIntStrict(n); k < ta.length; k++ {
  550. if ta.typedArray.getRaw(ta.offset+k) == se {
  551. return valueTrue
  552. }
  553. }
  554. }
  555. return valueFalse
  556. }
  557. panic(r.NewTypeError("Method TypedArray.prototype.includes called on incompatible receiver %s", call.This.String()))
  558. }
  559. func (r *Runtime) typedArrayProto_indexOf(call FunctionCall) Value {
  560. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  561. ta.viewedArrayBuf.ensureNotDetached(true)
  562. length := int64(ta.length)
  563. if length == 0 {
  564. return intToValue(-1)
  565. }
  566. n := call.Argument(1).ToInteger()
  567. if n >= length {
  568. return intToValue(-1)
  569. }
  570. if n < 0 {
  571. n = max(length+n, 0)
  572. }
  573. ta.viewedArrayBuf.ensureNotDetached(true)
  574. searchElement := call.Argument(0)
  575. if searchElement == _negativeZero {
  576. searchElement = _positiveZero
  577. }
  578. if !IsNaN(searchElement) && ta.typedArray.typeMatch(searchElement) {
  579. se := ta.typedArray.toRaw(searchElement)
  580. for k := toIntStrict(n); k < ta.length; k++ {
  581. if ta.typedArray.getRaw(ta.offset+k) == se {
  582. return intToValue(int64(k))
  583. }
  584. }
  585. }
  586. return intToValue(-1)
  587. }
  588. panic(r.NewTypeError("Method TypedArray.prototype.indexOf called on incompatible receiver %s", call.This.String()))
  589. }
  590. func (r *Runtime) typedArrayProto_join(call FunctionCall) Value {
  591. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  592. ta.viewedArrayBuf.ensureNotDetached(true)
  593. s := call.Argument(0)
  594. var sep valueString
  595. if s != _undefined {
  596. sep = s.toString()
  597. } else {
  598. sep = asciiString(",")
  599. }
  600. l := ta.length
  601. if l == 0 {
  602. return stringEmpty
  603. }
  604. var buf valueStringBuilder
  605. ta.viewedArrayBuf.ensureNotDetached(true)
  606. element0 := ta.typedArray.get(0)
  607. if element0 != nil && element0 != _undefined && element0 != _null {
  608. buf.WriteString(element0.toString())
  609. }
  610. for i := 1; i < l; i++ {
  611. ta.viewedArrayBuf.ensureNotDetached(true)
  612. buf.WriteString(sep)
  613. element := ta.typedArray.get(i)
  614. if element != nil && element != _undefined && element != _null {
  615. buf.WriteString(element.toString())
  616. }
  617. }
  618. return buf.String()
  619. }
  620. panic(r.NewTypeError("Method TypedArray.prototype.join called on incompatible receiver"))
  621. }
  622. func (r *Runtime) typedArrayProto_keys(call FunctionCall) Value {
  623. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  624. ta.viewedArrayBuf.ensureNotDetached(true)
  625. return r.createArrayIterator(ta.val, iterationKindKey)
  626. }
  627. panic(r.NewTypeError("Method TypedArray.prototype.keys called on incompatible receiver %s", call.This.String()))
  628. }
  629. func (r *Runtime) typedArrayProto_lastIndexOf(call FunctionCall) Value {
  630. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  631. ta.viewedArrayBuf.ensureNotDetached(true)
  632. length := int64(ta.length)
  633. if length == 0 {
  634. return intToValue(-1)
  635. }
  636. var fromIndex int64
  637. if len(call.Arguments) < 2 {
  638. fromIndex = length - 1
  639. } else {
  640. fromIndex = call.Argument(1).ToInteger()
  641. if fromIndex >= 0 {
  642. fromIndex = min(fromIndex, length-1)
  643. } else {
  644. fromIndex += length
  645. if fromIndex < 0 {
  646. fromIndex = -1 // prevent underflow in toIntStrict() on 32-bit platforms
  647. }
  648. }
  649. }
  650. ta.viewedArrayBuf.ensureNotDetached(true)
  651. searchElement := call.Argument(0)
  652. if searchElement == _negativeZero {
  653. searchElement = _positiveZero
  654. }
  655. if !IsNaN(searchElement) && ta.typedArray.typeMatch(searchElement) {
  656. se := ta.typedArray.toRaw(searchElement)
  657. for k := toIntStrict(fromIndex); k >= 0; k-- {
  658. if ta.typedArray.getRaw(ta.offset+k) == se {
  659. return intToValue(int64(k))
  660. }
  661. }
  662. }
  663. return intToValue(-1)
  664. }
  665. panic(r.NewTypeError("Method TypedArray.prototype.lastIndexOf called on incompatible receiver %s", call.This.String()))
  666. }
  667. func (r *Runtime) typedArrayProto_map(call FunctionCall) Value {
  668. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  669. ta.viewedArrayBuf.ensureNotDetached(true)
  670. callbackFn := r.toCallable(call.Argument(0))
  671. fc := FunctionCall{
  672. This: call.Argument(1),
  673. Arguments: []Value{nil, nil, call.This},
  674. }
  675. dst := r.typedArraySpeciesCreate(ta, []Value{intToValue(int64(ta.length))})
  676. for i := 0; i < ta.length; i++ {
  677. ta.viewedArrayBuf.ensureNotDetached(true)
  678. fc.Arguments[0] = ta.typedArray.get(ta.offset + i)
  679. fc.Arguments[1] = intToValue(int64(i))
  680. dst.typedArray.set(i, callbackFn(fc))
  681. }
  682. return dst.val
  683. }
  684. panic(r.NewTypeError("Method TypedArray.prototype.map called on incompatible receiver %s", call.This.String()))
  685. }
  686. func (r *Runtime) typedArrayProto_reduce(call FunctionCall) Value {
  687. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  688. ta.viewedArrayBuf.ensureNotDetached(true)
  689. callbackFn := r.toCallable(call.Argument(0))
  690. fc := FunctionCall{
  691. This: _undefined,
  692. Arguments: []Value{nil, nil, nil, call.This},
  693. }
  694. k := 0
  695. if len(call.Arguments) >= 2 {
  696. fc.Arguments[0] = call.Argument(1)
  697. } else {
  698. if ta.length > 0 {
  699. fc.Arguments[0] = ta.typedArray.get(ta.offset + 0)
  700. k = 1
  701. }
  702. }
  703. if fc.Arguments[0] == nil {
  704. panic(r.NewTypeError("Reduce of empty array with no initial value"))
  705. }
  706. for ; k < ta.length; k++ {
  707. ta.viewedArrayBuf.ensureNotDetached(true)
  708. idx := valueInt(k)
  709. fc.Arguments[1] = ta.typedArray.get(ta.offset + k)
  710. fc.Arguments[2] = idx
  711. fc.Arguments[0] = callbackFn(fc)
  712. }
  713. return fc.Arguments[0]
  714. }
  715. panic(r.NewTypeError("Method TypedArray.prototype.reduce called on incompatible receiver %s", call.This.String()))
  716. }
  717. func (r *Runtime) typedArrayProto_reduceRight(call FunctionCall) Value {
  718. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  719. ta.viewedArrayBuf.ensureNotDetached(true)
  720. callbackFn := r.toCallable(call.Argument(0))
  721. fc := FunctionCall{
  722. This: _undefined,
  723. Arguments: []Value{nil, nil, nil, call.This},
  724. }
  725. k := ta.length - 1
  726. if len(call.Arguments) >= 2 {
  727. fc.Arguments[0] = call.Argument(1)
  728. } else {
  729. if k >= 0 {
  730. fc.Arguments[0] = ta.typedArray.get(ta.offset + k)
  731. k--
  732. }
  733. }
  734. if fc.Arguments[0] == nil {
  735. panic(r.NewTypeError("Reduce of empty array with no initial value"))
  736. }
  737. for ; k >= 0; k-- {
  738. ta.viewedArrayBuf.ensureNotDetached(true)
  739. idx := valueInt(k)
  740. fc.Arguments[1] = ta.typedArray.get(ta.offset + k)
  741. fc.Arguments[2] = idx
  742. fc.Arguments[0] = callbackFn(fc)
  743. }
  744. return fc.Arguments[0]
  745. }
  746. panic(r.NewTypeError("Method TypedArray.prototype.reduceRight called on incompatible receiver %s", call.This.String()))
  747. }
  748. func (r *Runtime) typedArrayProto_reverse(call FunctionCall) Value {
  749. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  750. ta.viewedArrayBuf.ensureNotDetached(true)
  751. l := ta.length
  752. middle := l / 2
  753. for lower := 0; lower != middle; lower++ {
  754. upper := l - lower - 1
  755. ta.typedArray.swap(ta.offset+lower, ta.offset+upper)
  756. }
  757. return call.This
  758. }
  759. panic(r.NewTypeError("Method TypedArray.prototype.reverse called on incompatible receiver %s", call.This.String()))
  760. }
  761. func (r *Runtime) typedArrayProto_set(call FunctionCall) Value {
  762. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  763. srcObj := call.Argument(0).ToObject(r)
  764. targetOffset := toIntStrict(call.Argument(1).ToInteger())
  765. if targetOffset < 0 {
  766. panic(r.newError(r.global.RangeError, "offset should be >= 0"))
  767. }
  768. ta.viewedArrayBuf.ensureNotDetached(true)
  769. targetLen := ta.length
  770. if src, ok := srcObj.self.(*typedArrayObject); ok {
  771. src.viewedArrayBuf.ensureNotDetached(true)
  772. srcLen := src.length
  773. if x := srcLen + targetOffset; x < 0 || x > targetLen {
  774. panic(r.newError(r.global.RangeError, "Source is too large"))
  775. }
  776. if src.defaultCtor == ta.defaultCtor {
  777. copy(ta.viewedArrayBuf.data[(ta.offset+targetOffset)*ta.elemSize:],
  778. src.viewedArrayBuf.data[src.offset*src.elemSize:(src.offset+srcLen)*src.elemSize])
  779. } else {
  780. curSrc := uintptr(unsafe.Pointer(&src.viewedArrayBuf.data[src.offset*src.elemSize]))
  781. endSrc := curSrc + uintptr(srcLen*src.elemSize)
  782. curDst := uintptr(unsafe.Pointer(&ta.viewedArrayBuf.data[(ta.offset+targetOffset)*ta.elemSize]))
  783. dstOffset := ta.offset + targetOffset
  784. srcOffset := src.offset
  785. if ta.elemSize == src.elemSize {
  786. if curDst <= curSrc || curDst >= endSrc {
  787. for i := 0; i < srcLen; i++ {
  788. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  789. }
  790. } else {
  791. for i := srcLen - 1; i >= 0; i-- {
  792. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  793. }
  794. }
  795. } else {
  796. x := int(curDst-curSrc) / (src.elemSize - ta.elemSize)
  797. if x < 0 {
  798. x = 0
  799. } else if x > srcLen {
  800. x = srcLen
  801. }
  802. if ta.elemSize < src.elemSize {
  803. for i := x; i < srcLen; i++ {
  804. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  805. }
  806. for i := x - 1; i >= 0; i-- {
  807. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  808. }
  809. } else {
  810. for i := 0; i < x; i++ {
  811. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  812. }
  813. for i := srcLen - 1; i >= x; i-- {
  814. ta.typedArray.set(dstOffset+i, src.typedArray.get(srcOffset+i))
  815. }
  816. }
  817. }
  818. }
  819. } else {
  820. targetLen := ta.length
  821. srcLen := toIntStrict(toLength(srcObj.self.getStr("length", nil)))
  822. if x := srcLen + targetOffset; x < 0 || x > targetLen {
  823. panic(r.newError(r.global.RangeError, "Source is too large"))
  824. }
  825. for i := 0; i < srcLen; i++ {
  826. val := nilSafe(srcObj.self.getIdx(valueInt(i), nil))
  827. ta.viewedArrayBuf.ensureNotDetached(true)
  828. ta.typedArray.set(targetOffset+i, val)
  829. }
  830. }
  831. return _undefined
  832. }
  833. panic(r.NewTypeError("Method TypedArray.prototype.set called on incompatible receiver %s", call.This.String()))
  834. }
  835. func (r *Runtime) typedArrayProto_slice(call FunctionCall) Value {
  836. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  837. ta.viewedArrayBuf.ensureNotDetached(true)
  838. length := int64(ta.length)
  839. start := toIntStrict(relToIdx(call.Argument(0).ToInteger(), length))
  840. var e int64
  841. if endArg := call.Argument(1); endArg != _undefined {
  842. e = endArg.ToInteger()
  843. } else {
  844. e = length
  845. }
  846. end := toIntStrict(relToIdx(e, length))
  847. count := end - start
  848. if count < 0 {
  849. count = 0
  850. }
  851. dst := r.typedArraySpeciesCreate(ta, []Value{intToValue(int64(count))})
  852. if dst.defaultCtor == ta.defaultCtor {
  853. if count > 0 {
  854. ta.viewedArrayBuf.ensureNotDetached(true)
  855. offset := ta.offset
  856. elemSize := ta.elemSize
  857. copy(dst.viewedArrayBuf.data, ta.viewedArrayBuf.data[(offset+start)*elemSize:(offset+start+count)*elemSize])
  858. }
  859. } else {
  860. for i := 0; i < count; i++ {
  861. ta.viewedArrayBuf.ensureNotDetached(true)
  862. dst.typedArray.set(i, ta.typedArray.get(ta.offset+start+i))
  863. }
  864. }
  865. return dst.val
  866. }
  867. panic(r.NewTypeError("Method TypedArray.prototype.slice called on incompatible receiver %s", call.This.String()))
  868. }
  869. func (r *Runtime) typedArrayProto_some(call FunctionCall) Value {
  870. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  871. ta.viewedArrayBuf.ensureNotDetached(true)
  872. callbackFn := r.toCallable(call.Argument(0))
  873. fc := FunctionCall{
  874. This: call.Argument(1),
  875. Arguments: []Value{nil, nil, call.This},
  876. }
  877. for k := 0; k < ta.length; k++ {
  878. ta.viewedArrayBuf.ensureNotDetached(true)
  879. fc.Arguments[0] = ta.typedArray.get(ta.offset + k)
  880. fc.Arguments[1] = intToValue(int64(k))
  881. if callbackFn(fc).ToBoolean() {
  882. return valueTrue
  883. }
  884. }
  885. return valueFalse
  886. }
  887. panic(r.NewTypeError("Method TypedArray.prototype.some called on incompatible receiver %s", call.This.String()))
  888. }
  889. func (r *Runtime) typedArrayProto_sort(call FunctionCall) Value {
  890. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  891. ta.viewedArrayBuf.ensureNotDetached(true)
  892. var compareFn func(FunctionCall) Value
  893. if arg := call.Argument(0); arg != _undefined {
  894. compareFn = r.toCallable(arg)
  895. }
  896. ctx := typedArraySortCtx{
  897. ta: ta,
  898. compare: compareFn,
  899. }
  900. sort.Stable(&ctx)
  901. return call.This
  902. }
  903. panic(r.NewTypeError("Method TypedArray.prototype.sort called on incompatible receiver %s", call.This.String()))
  904. }
  905. func (r *Runtime) typedArrayProto_subarray(call FunctionCall) Value {
  906. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  907. l := int64(ta.length)
  908. beginIdx := relToIdx(call.Argument(0).ToInteger(), l)
  909. var relEnd int64
  910. if endArg := call.Argument(1); endArg != _undefined {
  911. relEnd = endArg.ToInteger()
  912. } else {
  913. relEnd = l
  914. }
  915. endIdx := relToIdx(relEnd, l)
  916. newLen := max(endIdx-beginIdx, 0)
  917. return r.typedArraySpeciesCreate(ta, []Value{ta.viewedArrayBuf.val,
  918. intToValue((int64(ta.offset) + beginIdx) * int64(ta.elemSize)),
  919. intToValue(newLen),
  920. }).val
  921. }
  922. panic(r.NewTypeError("Method TypedArray.prototype.subarray called on incompatible receiver %s", call.This.String()))
  923. }
  924. func (r *Runtime) typedArrayProto_toLocaleString(call FunctionCall) Value {
  925. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  926. length := ta.length
  927. var buf valueStringBuilder
  928. for i := 0; i < length; i++ {
  929. ta.viewedArrayBuf.ensureNotDetached(true)
  930. if i > 0 {
  931. buf.WriteRune(',')
  932. }
  933. item := ta.typedArray.get(i)
  934. r.writeItemLocaleString(item, &buf)
  935. }
  936. return buf.String()
  937. }
  938. panic(r.NewTypeError("Method TypedArray.prototype.toLocaleString called on incompatible receiver %s", call.This.String()))
  939. }
  940. func (r *Runtime) typedArrayProto_values(call FunctionCall) Value {
  941. if ta, ok := r.toObject(call.This).self.(*typedArrayObject); ok {
  942. ta.viewedArrayBuf.ensureNotDetached(true)
  943. return r.createArrayIterator(ta.val, iterationKindValue)
  944. }
  945. panic(r.NewTypeError("Method TypedArray.prototype.values called on incompatible receiver %s", call.This.String()))
  946. }
  947. func (r *Runtime) typedArrayProto_toStringTag(call FunctionCall) Value {
  948. if obj, ok := call.This.(*Object); ok {
  949. if ta, ok := obj.self.(*typedArrayObject); ok {
  950. return nilSafe(ta.defaultCtor.self.getStr("name", nil))
  951. }
  952. }
  953. return _undefined
  954. }
  955. func (r *Runtime) newTypedArray([]Value, *Object) *Object {
  956. panic(r.NewTypeError("Abstract class TypedArray not directly constructable"))
  957. }
  958. func (r *Runtime) typedArray_from(call FunctionCall) Value {
  959. mapFn := call.Argument(1)
  960. if mapFn == _undefined {
  961. mapFn = nil
  962. }
  963. return r.typedArrayFrom(r.toObject(call.This), call.Argument(0).ToObject(r), mapFn, call.Argument(2))
  964. }
  965. func (r *Runtime) typedArray_of(call FunctionCall) Value {
  966. ta := r.typedArrayCreate(r.toObject(call.This), []Value{intToValue(int64(len(call.Arguments)))})
  967. for i, val := range call.Arguments {
  968. ta.typedArray.set(i, val)
  969. }
  970. return ta.val
  971. }
  972. func (r *Runtime) allocateTypedArray(newTarget *Object, length int, taCtor typedArrayObjectCtor) *Object {
  973. buf := r._newArrayBuffer(r.global.ArrayBufferPrototype, nil)
  974. ta := taCtor(buf, 0, length, r.getPrototypeFromCtor(newTarget, nil, r.global.TypedArrayPrototype))
  975. if length > 0 {
  976. buf.data = allocByteSlice(length * ta.elemSize)
  977. }
  978. return ta.val
  979. }
  980. func (r *Runtime) typedArraySpeciesCreate(ta *typedArrayObject, args []Value) *typedArrayObject {
  981. return r.typedArrayCreate(r.speciesConstructorObj(ta.val, ta.defaultCtor), args)
  982. }
  983. func (r *Runtime) typedArrayCreate(ctor *Object, args []Value) *typedArrayObject {
  984. o := r.toConstructor(ctor)(args, ctor)
  985. if ta, ok := o.self.(*typedArrayObject); ok {
  986. ta.viewedArrayBuf.ensureNotDetached(true)
  987. if len(args) == 1 {
  988. if l, ok := args[0].(valueInt); ok {
  989. if ta.length < int(l) {
  990. panic(r.NewTypeError("Derived TypedArray constructor created an array which was too small"))
  991. }
  992. }
  993. }
  994. return ta
  995. }
  996. panic(r.NewTypeError("Invalid TypedArray: %s", o))
  997. }
  998. func (r *Runtime) typedArrayFrom(ctor, items *Object, mapFn, thisValue Value) *Object {
  999. var mapFc func(call FunctionCall) Value
  1000. if mapFn != nil {
  1001. mapFc = r.toCallable(mapFn)
  1002. if thisValue == nil {
  1003. thisValue = _undefined
  1004. }
  1005. }
  1006. usingIter := toMethod(items.self.getSym(SymIterator, nil))
  1007. if usingIter != nil {
  1008. iter := r.getIterator(items, usingIter)
  1009. var values []Value
  1010. r.iterate(iter, func(item Value) {
  1011. values = append(values, item)
  1012. })
  1013. ta := r.typedArrayCreate(ctor, []Value{intToValue(int64(len(values)))})
  1014. if mapFc == nil {
  1015. for idx, val := range values {
  1016. ta.typedArray.set(idx, val)
  1017. }
  1018. } else {
  1019. fc := FunctionCall{
  1020. This: thisValue,
  1021. Arguments: []Value{nil, nil},
  1022. }
  1023. for idx, val := range values {
  1024. fc.Arguments[0], fc.Arguments[1] = val, intToValue(int64(idx))
  1025. val = mapFc(fc)
  1026. ta.typedArray.set(idx, val)
  1027. }
  1028. }
  1029. return ta.val
  1030. }
  1031. length := toIntStrict(toLength(items.self.getStr("length", nil)))
  1032. ta := r.typedArrayCreate(ctor, []Value{intToValue(int64(length))})
  1033. if mapFc == nil {
  1034. for i := 0; i < length; i++ {
  1035. ta.typedArray.set(i, nilSafe(items.self.getIdx(valueInt(i), nil)))
  1036. }
  1037. } else {
  1038. fc := FunctionCall{
  1039. This: thisValue,
  1040. Arguments: []Value{nil, nil},
  1041. }
  1042. for i := 0; i < length; i++ {
  1043. idx := valueInt(i)
  1044. fc.Arguments[0], fc.Arguments[1] = items.self.getIdx(idx, nil), idx
  1045. ta.typedArray.set(i, mapFc(fc))
  1046. }
  1047. }
  1048. return ta.val
  1049. }
  1050. func (r *Runtime) _newTypedArrayFromArrayBuffer(ab *arrayBufferObject, args []Value, newTarget *Object, taCtor typedArrayObjectCtor) *Object {
  1051. ta := taCtor(ab, 0, 0, r.getPrototypeFromCtor(newTarget, nil, r.global.TypedArrayPrototype))
  1052. var byteOffset int
  1053. if len(args) > 1 && args[1] != nil && args[1] != _undefined {
  1054. byteOffset = r.toIndex(args[1])
  1055. if byteOffset%ta.elemSize != 0 {
  1056. panic(r.newError(r.global.RangeError, "Start offset of %s should be a multiple of %d", newTarget.self.getStr("name", nil), ta.elemSize))
  1057. }
  1058. }
  1059. ab.ensureNotDetached(true)
  1060. var length int
  1061. if len(args) > 2 && args[2] != nil && args[2] != _undefined {
  1062. length = r.toIndex(args[2])
  1063. if byteOffset+length*ta.elemSize > len(ab.data) {
  1064. panic(r.newError(r.global.RangeError, "Invalid typed array length: %d", length))
  1065. }
  1066. } else {
  1067. if len(ab.data)%ta.elemSize != 0 {
  1068. panic(r.newError(r.global.RangeError, "Byte length of %s should be a multiple of %d", newTarget.self.getStr("name", nil), ta.elemSize))
  1069. }
  1070. length = (len(ab.data) - byteOffset) / ta.elemSize
  1071. }
  1072. ta.offset = byteOffset / ta.elemSize
  1073. ta.length = length
  1074. return ta.val
  1075. }
  1076. func (r *Runtime) _newTypedArrayFromTypedArray(src *typedArrayObject, newTarget *Object) *Object {
  1077. dst := r.typedArrayCreate(newTarget, []Value{_positiveZero})
  1078. src.viewedArrayBuf.ensureNotDetached(true)
  1079. l := src.length
  1080. dst.viewedArrayBuf.prototype = r.getPrototypeFromCtor(r.toObject(src.viewedArrayBuf.getStr("constructor", nil)), r.global.ArrayBuffer, r.global.ArrayBufferPrototype)
  1081. dst.viewedArrayBuf.data = allocByteSlice(toIntStrict(int64(l) * int64(dst.elemSize)))
  1082. if src.defaultCtor == dst.defaultCtor {
  1083. copy(dst.viewedArrayBuf.data, src.viewedArrayBuf.data[src.offset*src.elemSize:])
  1084. dst.length = src.length
  1085. return dst.val
  1086. }
  1087. dst.length = l
  1088. for i := 0; i < l; i++ {
  1089. dst.typedArray.set(i, src.typedArray.get(src.offset+i))
  1090. }
  1091. return dst.val
  1092. }
  1093. func (r *Runtime) _newTypedArray(args []Value, newTarget *Object, taCtor typedArrayObjectCtor) *Object {
  1094. if newTarget == nil {
  1095. panic(r.needNew("TypedArray"))
  1096. }
  1097. if len(args) > 0 {
  1098. if obj, ok := args[0].(*Object); ok {
  1099. switch o := obj.self.(type) {
  1100. case *arrayBufferObject:
  1101. return r._newTypedArrayFromArrayBuffer(o, args, newTarget, taCtor)
  1102. case *typedArrayObject:
  1103. return r._newTypedArrayFromTypedArray(o, newTarget)
  1104. default:
  1105. return r.typedArrayFrom(newTarget, obj, nil, nil)
  1106. }
  1107. }
  1108. }
  1109. var l int
  1110. if len(args) > 0 {
  1111. if arg0 := args[0]; arg0 != nil {
  1112. l = r.toIndex(arg0)
  1113. }
  1114. }
  1115. return r.allocateTypedArray(newTarget, l, taCtor)
  1116. }
  1117. func (r *Runtime) newUint8Array(args []Value, newTarget *Object) *Object {
  1118. return r._newTypedArray(args, newTarget, r.newUint8ArrayObject)
  1119. }
  1120. func (r *Runtime) newUint8ClampedArray(args []Value, newTarget *Object) *Object {
  1121. return r._newTypedArray(args, newTarget, r.newUint8ClampedArrayObject)
  1122. }
  1123. func (r *Runtime) newInt8Array(args []Value, newTarget *Object) *Object {
  1124. return r._newTypedArray(args, newTarget, r.newInt8ArrayObject)
  1125. }
  1126. func (r *Runtime) newUint16Array(args []Value, newTarget *Object) *Object {
  1127. return r._newTypedArray(args, newTarget, r.newUint16ArrayObject)
  1128. }
  1129. func (r *Runtime) newInt16Array(args []Value, newTarget *Object) *Object {
  1130. return r._newTypedArray(args, newTarget, r.newInt16ArrayObject)
  1131. }
  1132. func (r *Runtime) newUint32Array(args []Value, newTarget *Object) *Object {
  1133. return r._newTypedArray(args, newTarget, r.newUint32ArrayObject)
  1134. }
  1135. func (r *Runtime) newInt32Array(args []Value, newTarget *Object) *Object {
  1136. return r._newTypedArray(args, newTarget, r.newInt32ArrayObject)
  1137. }
  1138. func (r *Runtime) newFloat32Array(args []Value, newTarget *Object) *Object {
  1139. return r._newTypedArray(args, newTarget, r.newFloat32ArrayObject)
  1140. }
  1141. func (r *Runtime) newFloat64Array(args []Value, newTarget *Object) *Object {
  1142. return r._newTypedArray(args, newTarget, r.newFloat64ArrayObject)
  1143. }
  1144. func (r *Runtime) createArrayBufferProto(val *Object) objectImpl {
  1145. b := newBaseObjectObj(val, r.global.ObjectPrototype, classObject)
  1146. byteLengthProp := &valueProperty{
  1147. accessor: true,
  1148. configurable: true,
  1149. getterFunc: r.newNativeFunc(r.arrayBufferProto_getByteLength, nil, "get byteLength", nil, 0),
  1150. }
  1151. b._put("byteLength", byteLengthProp)
  1152. b._putProp("constructor", r.global.ArrayBuffer, true, false, true)
  1153. b._putProp("slice", r.newNativeFunc(r.arrayBufferProto_slice, nil, "slice", nil, 2), true, false, true)
  1154. b._putSym(SymToStringTag, valueProp(asciiString("ArrayBuffer"), false, false, true))
  1155. return b
  1156. }
  1157. func (r *Runtime) createArrayBuffer(val *Object) objectImpl {
  1158. o := r.newNativeConstructOnly(val, r.builtin_newArrayBuffer, r.global.ArrayBufferPrototype, "ArrayBuffer", 1)
  1159. o._putProp("isView", r.newNativeFunc(r.arrayBuffer_isView, nil, "isView", nil, 1), true, false, true)
  1160. o._putSym(SymSpecies, &valueProperty{
  1161. getterFunc: r.newNativeFunc(r.returnThis, nil, "get [Symbol.species]", nil, 0),
  1162. accessor: true,
  1163. configurable: true,
  1164. })
  1165. return o
  1166. }
  1167. func (r *Runtime) createDataViewProto(val *Object) objectImpl {
  1168. b := newBaseObjectObj(val, r.global.ObjectPrototype, classObject)
  1169. b._put("buffer", &valueProperty{
  1170. accessor: true,
  1171. configurable: true,
  1172. getterFunc: r.newNativeFunc(r.dataViewProto_getBuffer, nil, "get buffer", nil, 0),
  1173. })
  1174. b._put("byteLength", &valueProperty{
  1175. accessor: true,
  1176. configurable: true,
  1177. getterFunc: r.newNativeFunc(r.dataViewProto_getByteLen, nil, "get byteLength", nil, 0),
  1178. })
  1179. b._put("byteOffset", &valueProperty{
  1180. accessor: true,
  1181. configurable: true,
  1182. getterFunc: r.newNativeFunc(r.dataViewProto_getByteOffset, nil, "get byteOffset", nil, 0),
  1183. })
  1184. b._putProp("constructor", r.global.DataView, true, false, true)
  1185. b._putProp("getFloat32", r.newNativeFunc(r.dataViewProto_getFloat32, nil, "getFloat32", nil, 1), true, false, true)
  1186. b._putProp("getFloat64", r.newNativeFunc(r.dataViewProto_getFloat64, nil, "getFloat64", nil, 1), true, false, true)
  1187. b._putProp("getInt8", r.newNativeFunc(r.dataViewProto_getInt8, nil, "getInt8", nil, 1), true, false, true)
  1188. b._putProp("getInt16", r.newNativeFunc(r.dataViewProto_getInt16, nil, "getInt16", nil, 1), true, false, true)
  1189. b._putProp("getInt32", r.newNativeFunc(r.dataViewProto_getInt32, nil, "getInt32", nil, 1), true, false, true)
  1190. b._putProp("getUint8", r.newNativeFunc(r.dataViewProto_getUint8, nil, "getUint8", nil, 1), true, false, true)
  1191. b._putProp("getUint16", r.newNativeFunc(r.dataViewProto_getUint16, nil, "getUint16", nil, 1), true, false, true)
  1192. b._putProp("getUint32", r.newNativeFunc(r.dataViewProto_getUint32, nil, "getUint32", nil, 1), true, false, true)
  1193. b._putProp("setFloat32", r.newNativeFunc(r.dataViewProto_setFloat32, nil, "setFloat32", nil, 2), true, false, true)
  1194. b._putProp("setFloat64", r.newNativeFunc(r.dataViewProto_setFloat64, nil, "setFloat64", nil, 2), true, false, true)
  1195. b._putProp("setInt8", r.newNativeFunc(r.dataViewProto_setInt8, nil, "setInt8", nil, 2), true, false, true)
  1196. b._putProp("setInt16", r.newNativeFunc(r.dataViewProto_setInt16, nil, "setInt16", nil, 2), true, false, true)
  1197. b._putProp("setInt32", r.newNativeFunc(r.dataViewProto_setInt32, nil, "setInt32", nil, 2), true, false, true)
  1198. b._putProp("setUint8", r.newNativeFunc(r.dataViewProto_setUint8, nil, "setUint8", nil, 2), true, false, true)
  1199. b._putProp("setUint16", r.newNativeFunc(r.dataViewProto_setUint16, nil, "setUint16", nil, 2), true, false, true)
  1200. b._putProp("setUint32", r.newNativeFunc(r.dataViewProto_setUint32, nil, "setUint32", nil, 2), true, false, true)
  1201. b._putSym(SymToStringTag, valueProp(asciiString("DataView"), false, false, true))
  1202. return b
  1203. }
  1204. func (r *Runtime) createDataView(val *Object) objectImpl {
  1205. o := r.newNativeConstructOnly(val, r.newDataView, r.global.DataViewPrototype, "DataView", 3)
  1206. return o
  1207. }
  1208. func (r *Runtime) createTypedArrayProto(val *Object) objectImpl {
  1209. b := newBaseObjectObj(val, r.global.ObjectPrototype, classObject)
  1210. b._put("buffer", &valueProperty{
  1211. accessor: true,
  1212. configurable: true,
  1213. getterFunc: r.newNativeFunc(r.typedArrayProto_getBuffer, nil, "get buffer", nil, 0),
  1214. })
  1215. b._put("byteLength", &valueProperty{
  1216. accessor: true,
  1217. configurable: true,
  1218. getterFunc: r.newNativeFunc(r.typedArrayProto_getByteLen, nil, "get byteLength", nil, 0),
  1219. })
  1220. b._put("byteOffset", &valueProperty{
  1221. accessor: true,
  1222. configurable: true,
  1223. getterFunc: r.newNativeFunc(r.typedArrayProto_getByteOffset, nil, "get byteOffset", nil, 0),
  1224. })
  1225. b._putProp("constructor", r.global.TypedArray, true, false, true)
  1226. b._putProp("copyWithin", r.newNativeFunc(r.typedArrayProto_copyWithin, nil, "copyWithin", nil, 2), true, false, true)
  1227. b._putProp("entries", r.newNativeFunc(r.typedArrayProto_entries, nil, "entries", nil, 0), true, false, true)
  1228. b._putProp("every", r.newNativeFunc(r.typedArrayProto_every, nil, "every", nil, 1), true, false, true)
  1229. b._putProp("fill", r.newNativeFunc(r.typedArrayProto_fill, nil, "fill", nil, 1), true, false, true)
  1230. b._putProp("filter", r.newNativeFunc(r.typedArrayProto_filter, nil, "filter", nil, 1), true, false, true)
  1231. b._putProp("find", r.newNativeFunc(r.typedArrayProto_find, nil, "find", nil, 1), true, false, true)
  1232. b._putProp("findIndex", r.newNativeFunc(r.typedArrayProto_findIndex, nil, "findIndex", nil, 1), true, false, true)
  1233. b._putProp("forEach", r.newNativeFunc(r.typedArrayProto_forEach, nil, "forEach", nil, 1), true, false, true)
  1234. b._putProp("includes", r.newNativeFunc(r.typedArrayProto_includes, nil, "includes", nil, 1), true, false, true)
  1235. b._putProp("indexOf", r.newNativeFunc(r.typedArrayProto_indexOf, nil, "indexOf", nil, 1), true, false, true)
  1236. b._putProp("join", r.newNativeFunc(r.typedArrayProto_join, nil, "join", nil, 1), true, false, true)
  1237. b._putProp("keys", r.newNativeFunc(r.typedArrayProto_keys, nil, "keys", nil, 0), true, false, true)
  1238. b._putProp("lastIndexOf", r.newNativeFunc(r.typedArrayProto_lastIndexOf, nil, "lastIndexOf", nil, 1), true, false, true)
  1239. b._put("length", &valueProperty{
  1240. accessor: true,
  1241. configurable: true,
  1242. getterFunc: r.newNativeFunc(r.typedArrayProto_getLength, nil, "get length", nil, 0),
  1243. })
  1244. b._putProp("map", r.newNativeFunc(r.typedArrayProto_map, nil, "map", nil, 1), true, false, true)
  1245. b._putProp("reduce", r.newNativeFunc(r.typedArrayProto_reduce, nil, "reduce", nil, 1), true, false, true)
  1246. b._putProp("reduceRight", r.newNativeFunc(r.typedArrayProto_reduceRight, nil, "reduceRight", nil, 1), true, false, true)
  1247. b._putProp("reverse", r.newNativeFunc(r.typedArrayProto_reverse, nil, "reverse", nil, 0), true, false, true)
  1248. b._putProp("set", r.newNativeFunc(r.typedArrayProto_set, nil, "set", nil, 1), true, false, true)
  1249. b._putProp("slice", r.newNativeFunc(r.typedArrayProto_slice, nil, "slice", nil, 2), true, false, true)
  1250. b._putProp("some", r.newNativeFunc(r.typedArrayProto_some, nil, "some", nil, 1), true, false, true)
  1251. b._putProp("sort", r.newNativeFunc(r.typedArrayProto_sort, nil, "sort", nil, 1), true, false, true)
  1252. b._putProp("subarray", r.newNativeFunc(r.typedArrayProto_subarray, nil, "subarray", nil, 2), true, false, true)
  1253. b._putProp("toLocaleString", r.newNativeFunc(r.typedArrayProto_toLocaleString, nil, "toLocaleString", nil, 0), true, false, true)
  1254. b._putProp("toString", r.global.arrayToString, true, false, true)
  1255. valuesFunc := r.newNativeFunc(r.typedArrayProto_values, nil, "values", nil, 0)
  1256. b._putProp("values", valuesFunc, true, false, true)
  1257. b._putSym(SymIterator, valueProp(valuesFunc, true, false, true))
  1258. b._putSym(SymToStringTag, &valueProperty{
  1259. getterFunc: r.newNativeFunc(r.typedArrayProto_toStringTag, nil, "get [Symbol.toStringTag]", nil, 0),
  1260. accessor: true,
  1261. configurable: true,
  1262. })
  1263. return b
  1264. }
  1265. func (r *Runtime) createTypedArray(val *Object) objectImpl {
  1266. o := r.newNativeConstructOnly(val, r.newTypedArray, r.global.TypedArrayPrototype, "TypedArray", 0)
  1267. o._putProp("from", r.newNativeFunc(r.typedArray_from, nil, "from", nil, 1), true, false, true)
  1268. o._putProp("of", r.newNativeFunc(r.typedArray_of, nil, "of", nil, 0), true, false, true)
  1269. o._putSym(SymSpecies, &valueProperty{
  1270. getterFunc: r.newNativeFunc(r.returnThis, nil, "get [Symbol.species]", nil, 0),
  1271. accessor: true,
  1272. configurable: true,
  1273. })
  1274. return o
  1275. }
  1276. func (r *Runtime) addPrototype(ctor *Object, proto *Object) *baseObject {
  1277. p := r.newBaseObject(proto, classObject)
  1278. p._putProp("constructor", ctor, true, false, true)
  1279. ctor.self._putProp("prototype", p.val, false, false, false)
  1280. return p
  1281. }
  1282. func (r *Runtime) typedArrayCreator(ctor func(args []Value, newTarget *Object) *Object, name unistring.String, bytesPerElement int) func(val *Object) objectImpl {
  1283. return func(val *Object) objectImpl {
  1284. o := r.newNativeConstructOnly(val, ctor, nil, name, 3)
  1285. o.prototype = r.global.TypedArray
  1286. proto := r.addPrototype(o.val, r.global.TypedArrayPrototype)
  1287. bpe := intToValue(int64(bytesPerElement))
  1288. o._putProp("BYTES_PER_ELEMENT", bpe, false, false, false)
  1289. proto._putProp("BYTES_PER_ELEMENT", bpe, false, false, false)
  1290. return o
  1291. }
  1292. }
  1293. func (r *Runtime) initTypedArrays() {
  1294. r.global.ArrayBufferPrototype = r.newLazyObject(r.createArrayBufferProto)
  1295. r.global.ArrayBuffer = r.newLazyObject(r.createArrayBuffer)
  1296. r.addToGlobal("ArrayBuffer", r.global.ArrayBuffer)
  1297. r.global.DataViewPrototype = r.newLazyObject(r.createDataViewProto)
  1298. r.global.DataView = r.newLazyObject(r.createDataView)
  1299. r.addToGlobal("DataView", r.global.DataView)
  1300. r.global.TypedArrayPrototype = r.newLazyObject(r.createTypedArrayProto)
  1301. r.global.TypedArray = r.newLazyObject(r.createTypedArray)
  1302. r.global.Uint8Array = r.newLazyObject(r.typedArrayCreator(r.newUint8Array, "Uint8Array", 1))
  1303. r.addToGlobal("Uint8Array", r.global.Uint8Array)
  1304. r.global.Uint8ClampedArray = r.newLazyObject(r.typedArrayCreator(r.newUint8ClampedArray, "Uint8ClampedArray", 1))
  1305. r.addToGlobal("Uint8ClampedArray", r.global.Uint8ClampedArray)
  1306. r.global.Int8Array = r.newLazyObject(r.typedArrayCreator(r.newInt8Array, "Int8Array", 1))
  1307. r.addToGlobal("Int8Array", r.global.Int8Array)
  1308. r.global.Uint16Array = r.newLazyObject(r.typedArrayCreator(r.newUint16Array, "Uint16Array", 2))
  1309. r.addToGlobal("Uint16Array", r.global.Uint16Array)
  1310. r.global.Int16Array = r.newLazyObject(r.typedArrayCreator(r.newInt16Array, "Int16Array", 2))
  1311. r.addToGlobal("Int16Array", r.global.Int16Array)
  1312. r.global.Uint32Array = r.newLazyObject(r.typedArrayCreator(r.newUint32Array, "Uint32Array", 4))
  1313. r.addToGlobal("Uint32Array", r.global.Uint32Array)
  1314. r.global.Int32Array = r.newLazyObject(r.typedArrayCreator(r.newInt32Array, "Int32Array", 4))
  1315. r.addToGlobal("Int32Array", r.global.Int32Array)
  1316. r.global.Float32Array = r.newLazyObject(r.typedArrayCreator(r.newFloat32Array, "Float32Array", 4))
  1317. r.addToGlobal("Float32Array", r.global.Float32Array)
  1318. r.global.Float64Array = r.newLazyObject(r.typedArrayCreator(r.newFloat64Array, "Float64Array", 8))
  1319. r.addToGlobal("Float64Array", r.global.Float64Array)
  1320. }