| Index: runtime/lib/byte_array.cc
|
| diff --git a/runtime/lib/byte_array.cc b/runtime/lib/byte_array.cc
|
| index 87afb4c10efda7b0b4876710c2ff0e6d64b0afd0..7b76e68c5fafc230a43b1c11baa86941654d2211 100644
|
| --- a/runtime/lib/byte_array.cc
|
| +++ b/runtime/lib/byte_array.cc
|
| @@ -4,6 +4,7 @@
|
|
|
| #include "vm/bootstrap_natives.h"
|
|
|
| +#include "vm/bigint_operations.h"
|
| #include "vm/exceptions.h"
|
| #include "vm/native_entry.h"
|
| #include "vm/object.h"
|
| @@ -60,21 +61,57 @@ DEFINE_NATIVE_ENTRY(ByteArray_setRange, 5) {
|
| ByteArray::Copy(dst, dst_start_value, src, src_start_value, length_value);
|
| }
|
|
|
| +#define GETTER_ARGUMENTS(ArrayT, ValueT) \
|
| + GET_NATIVE_ARGUMENT(ArrayT, array, arguments->At(0)); \
|
| + GET_NATIVE_ARGUMENT(Smi, index, arguments->At(1)); \
|
| + RangeCheck(array, index.Value(), sizeof(ValueT));
|
|
|
| -#define GETTER(ArrayT, ObjectT, ValueT) \
|
| +
|
| +#define SETTER_ARGUMENTS(ArrayT, ObjectT, ValueT) \
|
| GET_NATIVE_ARGUMENT(ArrayT, array, arguments->At(0)); \
|
| GET_NATIVE_ARGUMENT(Smi, index, arguments->At(1)); \
|
| RangeCheck(array, index.Value(), sizeof(ValueT)); \
|
| + GET_NATIVE_ARGUMENT(ObjectT, integer_value, arguments->At(2));
|
| +
|
| +
|
| +#define GETTER(ArrayT, ObjectT, ValueT) \
|
| + GETTER_ARGUMENTS(ArrayT, ValueT); \
|
| ValueT result = array.UnalignedAt<ValueT>(index.Value()); \
|
| arguments->SetReturn(ObjectT::Handle(ObjectT::New(result)));
|
|
|
|
|
| #define SETTER(ArrayT, ObjectT, Getter, ValueT) \
|
| - GET_NATIVE_ARGUMENT(ArrayT, array, arguments->At(0)); \
|
| - GET_NATIVE_ARGUMENT(Smi, index, arguments->At(1)); \
|
| - RangeCheck(array, index.Value(), sizeof(ValueT)); \
|
| - GET_NATIVE_ARGUMENT(ObjectT, value, arguments->At(2)); \
|
| - array.SetUnalignedAt<ValueT>(index.Value(), value.Getter());
|
| + SETTER_ARGUMENTS(ArrayT, ObjectT, ValueT); \
|
| + array.SetUnalignedAt<ValueT>(index.Value(), integer_value.Getter());
|
| +
|
| +
|
| +#define GETTER_UINT64(ArrayT) \
|
| + GETTER_ARGUMENTS(ArrayT, uint64_t); \
|
| + uint64_t value = array.UnalignedAt<uint64_t>(index.Value()); \
|
| + Integer& result = Integer::Handle(); \
|
| + if (value > static_cast<uint64_t>(Mint::kMaxValue)) { \
|
| + result = BigintOperations::NewFromUint64(value); \
|
| + } else if (value > static_cast<uint64_t>(Smi::kMaxValue)) { \
|
| + result = Mint::New(value); \
|
| + } else { \
|
| + result = Smi::New(value); \
|
| + } \
|
| + arguments->SetReturn(result);
|
| +
|
| +
|
| +#define SETTER_UINT64(ArrayT) \
|
| + SETTER_ARGUMENTS(ArrayT, Integer, uint64_t); \
|
| + uint64_t value; \
|
| + if (integer_value.IsBigint()) { \
|
| + Bigint& bigint_value = Bigint::Handle(); \
|
| + bigint_value ^= integer_value.raw(); \
|
| + ASSERT(BigintOperations::FitsIntoUint64(bigint_value)); \
|
| + value = BigintOperations::AbsToUint64(bigint_value); \
|
| + } else { \
|
| + ASSERT(integer_value.IsMint() || integer_value.IsSmi()); \
|
| + value = integer_value.AsInt64Value(); \
|
| + } \
|
| + array.SetUnalignedAt<uint64_t>(index.Value(), value);
|
|
|
|
|
| DEFINE_NATIVE_ENTRY(InternalByteArray_getInt8, 2) {
|
| @@ -148,12 +185,12 @@ DEFINE_NATIVE_ENTRY(InternalByteArray_setInt64, 3) {
|
|
|
|
|
| DEFINE_NATIVE_ENTRY(InternalByteArray_getUint64, 2) {
|
| - UNIMPLEMENTED(); // TODO(cshapiro): need getter implementation.
|
| + GETTER_UINT64(InternalByteArray);
|
| }
|
|
|
|
|
| DEFINE_NATIVE_ENTRY(InternalByteArray_setUint64, 3) {
|
| - UNIMPLEMENTED(); // TODO(cshapiro): need setter implementation.
|
| + SETTER_UINT64(InternalByteArray);
|
| }
|
|
|
|
|
| @@ -248,12 +285,12 @@ DEFINE_NATIVE_ENTRY(ExternalByteArray_setInt64, 3) {
|
|
|
|
|
| DEFINE_NATIVE_ENTRY(ExternalByteArray_getUint64, 2) {
|
| - UNIMPLEMENTED(); // TODO(cshapiro): need getter implementation.
|
| + GETTER_UINT64(ExternalByteArray);
|
| }
|
|
|
|
|
| DEFINE_NATIVE_ENTRY(ExternalByteArray_setUint64, 3) {
|
| - UNIMPLEMENTED(); // TODO(cshapiro): need setter implementation.
|
| + SETTER_UINT64(ExternalByteArray);
|
| }
|
|
|
|
|
|
|