| Index: src/harmony-simd.js
 | 
| diff --git a/src/harmony-simd.js b/src/harmony-simd.js
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..4a1538237ef5859d987c864bd09d70942ee706f5
 | 
| --- /dev/null
 | 
| +++ b/src/harmony-simd.js
 | 
| @@ -0,0 +1,89 @@
 | 
| +// Copyright 2015 the V8 project authors. All rights reserved.
 | 
| +// Use of this source code is governed by a BSD-style license that can be
 | 
| +// found in the LICENSE file.
 | 
| +
 | 
| +var $float32x4ToString;
 | 
| +
 | 
| +(function(global, utils) {
 | 
| +
 | 
| +"use strict";
 | 
| +
 | 
| +%CheckIsBootstrapping();
 | 
| +
 | 
| +// -------------------------------------------------------------------
 | 
| +// Imports
 | 
| +
 | 
| +var GlobalSIMD = global.SIMD;
 | 
| +var GlobalFloat32x4 = GlobalSIMD.Float32x4;
 | 
| +
 | 
| +//-------------------------------------------------------------------
 | 
| +
 | 
| +function Float32x4Constructor(x, y, z, w) {
 | 
| +  if (%_IsConstructCall()) throw MakeTypeError(kNotConstructor, "Float32x4");
 | 
| +  if (!IS_NUMBER(x) || !IS_NUMBER(y) || !IS_NUMBER(z) || !IS_NUMBER(w)) {
 | 
| +    throw MakeTypeError(kInvalidArgument);
 | 
| +  }
 | 
| +  return %CreateFloat32x4(x, y, z, w);
 | 
| +}
 | 
| +
 | 
| +function Float32x4Splat(s) {
 | 
| +  return %CreateFloat32x4(s, s, s, s);
 | 
| +}
 | 
| +
 | 
| +function Float32x4CheckJS(a) {
 | 
| +  return %Float32x4Check(a);
 | 
| +}
 | 
| +
 | 
| +function Float32x4ToString() {
 | 
| +  if (!(IS_FLOAT32X4(this) || IS_FLOAT32X4_WRAPPER(this))) {
 | 
| +    throw MakeTypeError(kIncompatibleMethodReceiver,
 | 
| +                        "Float32x4.prototype.toString", this);
 | 
| +  }
 | 
| +  var value = %_ValueOf(this);
 | 
| +  var w = GlobalFloat32x4.extractLane(value, 0),
 | 
| +      x = GlobalFloat32x4.extractLane(value, 1),
 | 
| +      y = GlobalFloat32x4.extractLane(value, 2),
 | 
| +      z = GlobalFloat32x4.extractLane(value, 3);
 | 
| +  return "Float32x4(" + w + ", " + x + ", " + y + ", " + z + ")";
 | 
| +}
 | 
| +
 | 
| +function Float32x4ValueOf() {
 | 
| +  if (!(IS_FLOAT32X4(this) || IS_FLOAT32X4_WRAPPER(this))) {
 | 
| +    throw MakeTypeError(kIncompatibleMethodReceiver,
 | 
| +                        "Float32x4.prototype.valueOf", this);
 | 
| +  }
 | 
| +  return %_ValueOf(this);
 | 
| +}
 | 
| +
 | 
| +//-------------------------------------------------------------------
 | 
| +
 | 
| +function Float32x4ExtractLaneJS(value, lane) {
 | 
| +  return %Float32x4ExtractLane(value, lane);
 | 
| +}
 | 
| +
 | 
| +// -------------------------------------------------------------------
 | 
| +
 | 
| +%AddNamedProperty(GlobalSIMD, symbolToStringTag, 'SIMD', READ_ONLY | DONT_ENUM);
 | 
| +%AddNamedProperty(GlobalSIMD, 'float32x4', GlobalFloat32x4, DONT_ENUM);
 | 
| +
 | 
| +%SetCode(GlobalFloat32x4, Float32x4Constructor);
 | 
| +%FunctionSetPrototype(GlobalFloat32x4, {});
 | 
| +%AddNamedProperty(
 | 
| +    GlobalFloat32x4.prototype, 'constructor', GlobalFloat32x4, DONT_ENUM);
 | 
| +%AddNamedProperty(
 | 
| +    GlobalFloat32x4, symbolToStringTag, 'Float32x4', DONT_ENUM | READ_ONLY);
 | 
| +
 | 
| +utils.InstallFunctions(GlobalFloat32x4.prototype, DONT_ENUM, [
 | 
| +  'valueOf', Float32x4ValueOf,
 | 
| +  'toString', Float32x4ToString,
 | 
| +]);
 | 
| +
 | 
| +utils.InstallFunctions(GlobalFloat32x4, DONT_ENUM, [
 | 
| +  'splat', Float32x4Splat,
 | 
| +  'check', Float32x4CheckJS,
 | 
| +  'extractLane', Float32x4ExtractLaneJS,
 | 
| +]);
 | 
| +
 | 
| +$float32x4ToString = Float32x4ToString;
 | 
| +
 | 
| +})
 | 
| 
 |