2009-03-11 14:00:55 +00:00
|
|
|
# Copyright 2006-2009 the V8 project authors. All rights reserved.
|
2008-07-03 15:10:15 +00:00
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions are
|
|
|
|
# met:
|
|
|
|
#
|
|
|
|
# * Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# * Redistributions in binary form must reproduce the above
|
|
|
|
# copyright notice, this list of conditions and the following
|
|
|
|
# disclaimer in the documentation and/or other materials provided
|
|
|
|
# with the distribution.
|
|
|
|
# * Neither the name of Google Inc. nor the names of its
|
|
|
|
# contributors may be used to endorse or promote products derived
|
|
|
|
# from this software without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
# Dictionary that is passed as defines for js2c.py.
|
2012-01-16 12:38:59 +00:00
|
|
|
# Used for defines that must be defined for all native JS files.
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
const NONE = 0;
|
|
|
|
const READ_ONLY = 1;
|
|
|
|
const DONT_ENUM = 2;
|
2008-07-03 15:10:15 +00:00
|
|
|
const DONT_DELETE = 4;
|
2012-12-05 15:49:22 +00:00
|
|
|
const NEW_ONE_BYTE_STRING = true;
|
|
|
|
const NEW_TWO_BYTE_STRING = false;
|
2008-07-03 15:10:15 +00:00
|
|
|
|
|
|
|
# Constants used for getter and setter operations.
|
|
|
|
const GETTER = 0;
|
|
|
|
const SETTER = 1;
|
|
|
|
|
|
|
|
const NO_HINT = 0;
|
|
|
|
const NUMBER_HINT = 1;
|
|
|
|
const STRING_HINT = 2;
|
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
# For date.js.
|
|
|
|
const HoursPerDay = 24;
|
|
|
|
const MinutesPerHour = 60;
|
|
|
|
const SecondsPerMinute = 60;
|
|
|
|
const msPerSecond = 1000;
|
|
|
|
const msPerMinute = 60000;
|
|
|
|
const msPerHour = 3600000;
|
|
|
|
const msPerDay = 86400000;
|
2009-06-16 06:52:04 +00:00
|
|
|
const msPerMonth = 2592000000;
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
# Note: kDayZeroInJulianDay = ToJulianDay(1970, 0, 1).
|
|
|
|
const kInvalidDate = 'Invalid Date';
|
|
|
|
const kDayZeroInJulianDay = 2440588;
|
|
|
|
const kMonthMask = 0x1e0;
|
|
|
|
const kDayMask = 0x01f;
|
|
|
|
const kYearShift = 9;
|
|
|
|
const kMonthShift = 5;
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2010-03-02 13:29:26 +00:00
|
|
|
# Limits for parts of the date, so that we support all the dates that
|
|
|
|
# ECMA 262 - 15.9.1.1 requires us to, but at the same time be sure that
|
|
|
|
# the date (days since 1970) is in SMI range.
|
|
|
|
const kMinYear = -1000000;
|
|
|
|
const kMaxYear = 1000000;
|
|
|
|
const kMinMonth = -10000000;
|
|
|
|
const kMaxMonth = 10000000;
|
|
|
|
|
2015-03-19 14:47:18 +00:00
|
|
|
# Safe maximum number of arguments to push to stack, when multiplied by
|
|
|
|
# pointer size. Used by Function.prototype.apply(), Reflect.apply() and
|
|
|
|
# Reflect.construct().
|
|
|
|
const kSafeArgumentsLength = 0x800000;
|
|
|
|
|
2014-04-17 11:37:59 +00:00
|
|
|
# Strict mode flags for passing to %SetProperty
|
|
|
|
const kSloppyMode = 0;
|
|
|
|
const kStrictMode = 1;
|
|
|
|
|
2010-04-14 14:46:15 +00:00
|
|
|
# Native cache ids.
|
|
|
|
const STRING_TO_REGEXP_CACHE_ID = 0;
|
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
# Type query macros.
|
2010-02-19 13:07:37 +00:00
|
|
|
#
|
|
|
|
# Note: We have special support for typeof(foo) === 'bar' in the compiler.
|
|
|
|
# It will *not* generate a runtime typeof call for the most important
|
|
|
|
# values of 'bar'.
|
2008-07-03 15:10:15 +00:00
|
|
|
macro IS_NULL(arg) = (arg === null);
|
|
|
|
macro IS_NULL_OR_UNDEFINED(arg) = (arg == null);
|
2014-04-17 13:55:03 +00:00
|
|
|
macro IS_UNDEFINED(arg) = (arg === (void 0));
|
2008-07-03 15:10:15 +00:00
|
|
|
macro IS_NUMBER(arg) = (typeof(arg) === 'number');
|
|
|
|
macro IS_STRING(arg) = (typeof(arg) === 'string');
|
|
|
|
macro IS_BOOLEAN(arg) = (typeof(arg) === 'boolean');
|
2013-03-22 16:33:50 +00:00
|
|
|
macro IS_SYMBOL(arg) = (typeof(arg) === 'symbol');
|
2009-11-19 07:41:32 +00:00
|
|
|
macro IS_OBJECT(arg) = (%_IsObject(arg));
|
2009-06-29 10:45:16 +00:00
|
|
|
macro IS_ARRAY(arg) = (%_IsArray(arg));
|
2009-11-19 07:41:32 +00:00
|
|
|
macro IS_FUNCTION(arg) = (%_IsFunction(arg));
|
2010-02-19 13:07:37 +00:00
|
|
|
macro IS_REGEXP(arg) = (%_IsRegExp(arg));
|
2012-01-05 12:55:06 +00:00
|
|
|
macro IS_SET(arg) = (%_ClassOf(arg) === 'Set');
|
|
|
|
macro IS_MAP(arg) = (%_ClassOf(arg) === 'Map');
|
|
|
|
macro IS_WEAKMAP(arg) = (%_ClassOf(arg) === 'WeakMap');
|
2013-07-22 08:32:24 +00:00
|
|
|
macro IS_WEAKSET(arg) = (%_ClassOf(arg) === 'WeakSet');
|
2009-06-29 10:45:16 +00:00
|
|
|
macro IS_DATE(arg) = (%_ClassOf(arg) === 'Date');
|
|
|
|
macro IS_NUMBER_WRAPPER(arg) = (%_ClassOf(arg) === 'Number');
|
|
|
|
macro IS_STRING_WRAPPER(arg) = (%_ClassOf(arg) === 'String');
|
2013-03-22 16:33:50 +00:00
|
|
|
macro IS_SYMBOL_WRAPPER(arg) = (%_ClassOf(arg) === 'Symbol');
|
2009-06-29 10:45:16 +00:00
|
|
|
macro IS_BOOLEAN_WRAPPER(arg) = (%_ClassOf(arg) === 'Boolean');
|
|
|
|
macro IS_ERROR(arg) = (%_ClassOf(arg) === 'Error');
|
|
|
|
macro IS_SCRIPT(arg) = (%_ClassOf(arg) === 'Script');
|
|
|
|
macro IS_ARGUMENTS(arg) = (%_ClassOf(arg) === 'Arguments');
|
2009-06-30 11:08:37 +00:00
|
|
|
macro IS_GLOBAL(arg) = (%_ClassOf(arg) === 'global');
|
2013-04-29 11:18:27 +00:00
|
|
|
macro IS_ARRAYBUFFER(arg) = (%_ClassOf(arg) === 'ArrayBuffer');
|
2013-06-21 13:02:38 +00:00
|
|
|
macro IS_DATAVIEW(arg) = (%_ClassOf(arg) === 'DataView');
|
2013-04-17 15:01:25 +00:00
|
|
|
macro IS_GENERATOR(arg) = (%_ClassOf(arg) === 'Generator');
|
2014-06-03 00:34:01 +00:00
|
|
|
macro IS_SET_ITERATOR(arg) = (%_ClassOf(arg) === 'Set Iterator');
|
|
|
|
macro IS_MAP_ITERATOR(arg) = (%_ClassOf(arg) === 'Map Iterator');
|
2010-01-19 14:15:47 +00:00
|
|
|
macro IS_UNDETECTABLE(arg) = (%_IsUndetectableObject(arg));
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2010-05-10 08:58:41 +00:00
|
|
|
# Macro for ECMAScript 5 queries of the type:
|
|
|
|
# "Type(O) is object."
|
2011-09-13 11:42:57 +00:00
|
|
|
# This is the same as being either a function or an object in V8 terminology
|
|
|
|
# (including proxies).
|
2010-07-16 11:21:08 +00:00
|
|
|
# In addition, an undetectable object is also included by this.
|
2011-09-13 11:42:57 +00:00
|
|
|
macro IS_SPEC_OBJECT(arg) = (%_IsSpecObject(arg));
|
|
|
|
|
|
|
|
# Macro for ECMAScript 5 queries of the type:
|
|
|
|
# "IsCallable(O)"
|
|
|
|
# We assume here that this is the same as being either a function or a function
|
|
|
|
# proxy. That ignores host objects with [[Call]] methods, but in most situations
|
|
|
|
# we cannot handle those anyway.
|
|
|
|
macro IS_SPEC_FUNCTION(arg) = (%_ClassOf(arg) === 'Function');
|
2010-05-10 08:58:41 +00:00
|
|
|
|
2014-01-22 12:15:57 +00:00
|
|
|
# Macro for ES6 CheckObjectCoercible
|
|
|
|
# Will throw a TypeError of the form "[functionName] called on null or undefined".
|
|
|
|
macro CHECK_OBJECT_COERCIBLE(arg, functionName) = if (IS_NULL_OR_UNDEFINED(arg) && !IS_UNDETECTABLE(arg)) throw MakeTypeError('called_on_null_or_undefined', [functionName]);
|
|
|
|
|
2011-10-17 12:44:16 +00:00
|
|
|
# Indices in bound function info retrieved by %BoundFunctionGetBindings(...).
|
|
|
|
const kBoundFunctionIndex = 0;
|
|
|
|
const kBoundThisIndex = 1;
|
|
|
|
const kBoundArgumentsStartIndex = 2;
|
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
# Inline macros. Use %IS_VAR to make sure arg is evaluated only once.
|
|
|
|
macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg));
|
2011-09-05 11:08:57 +00:00
|
|
|
macro NUMBER_IS_FINITE(arg) = (%_IsSmi(%IS_VAR(arg)) || ((arg == arg) && (arg != 1/0) && (arg != -1/0)));
|
2010-08-23 11:46:59 +00:00
|
|
|
macro TO_INTEGER(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToInteger(ToNumber(arg)));
|
2013-07-05 12:57:38 +00:00
|
|
|
macro TO_INTEGER_FOR_SIDE_EFFECT(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : ToNumber(arg));
|
2010-07-02 20:09:33 +00:00
|
|
|
macro TO_INTEGER_MAP_MINUS_ZERO(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToIntegerMapMinusZero(ToNumber(arg)));
|
2010-02-19 13:07:37 +00:00
|
|
|
macro TO_INT32(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : (arg >> 0));
|
|
|
|
macro TO_UINT32(arg) = (arg >>> 0);
|
|
|
|
macro TO_STRING_INLINE(arg) = (IS_STRING(%IS_VAR(arg)) ? arg : NonStringToString(arg));
|
2011-01-05 13:52:00 +00:00
|
|
|
macro TO_NUMBER_INLINE(arg) = (IS_NUMBER(%IS_VAR(arg)) ? arg : NonNumberToNumber(arg));
|
2011-05-12 16:19:03 +00:00
|
|
|
macro TO_OBJECT_INLINE(arg) = (IS_SPEC_OBJECT(%IS_VAR(arg)) ? arg : ToObject(arg));
|
2011-05-30 09:23:17 +00:00
|
|
|
macro JSON_NUMBER_TO_STRING(arg) = ((%_IsSmi(%IS_VAR(arg)) || arg - arg == 0) ? %_NumberToString(arg) : "null");
|
2014-09-17 14:01:25 +00:00
|
|
|
macro HAS_OWN_PROPERTY(obj, index) = (%_CallFunction(obj, index, ObjectHasOwnProperty));
|
Array.prototype.{every, filter, find, findIndex, forEach, map, some}: Use fresh primitive wrapper for calls.
When the receiver is a primitive value, it's cast to an Object before entering the loop. Instead, it should be cast to an Object for each function call while in the loop.
BUG=v8:3536
LOG=Y
R=arv@chromium.org, svenpanne@chromium.org, wingo@igalia.com
Review URL: https://codereview.chromium.org/553413002
Patch from Diego Pino <dpino@igalia.com>.
git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@24620 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
2014-10-15 09:11:32 +00:00
|
|
|
macro SHOULD_CREATE_WRAPPER(functionName, receiver) = (!IS_SPEC_OBJECT(receiver) && %IsSloppyModeFunction(functionName));
|
2014-12-04 18:46:33 +00:00
|
|
|
macro HAS_INDEX(array, index, is_array) = ((is_array && %_HasFastPackedElements(%IS_VAR(array))) ? (index < array.length) : (index in array));
|
2008-07-03 15:10:15 +00:00
|
|
|
|
Provide private symbols through internal APIs
Adds a notion of private symbols, mainly intended for internal use, especially, self-hosting of built-in types that would otherwise require new C++ classes.
On the JS side (i.e., in built-ins), private properties can be created and accessed through a set of macros:
NEW_PRIVATE(print_name)
HAS_PRIVATE(obj, sym)
GET_PRIVATE(obj, sym)
SET_PRIVATE(obj, sym, val)
DELETE_PRIVATE(obj, sym)
In the V8 API, they are accessible via a new class Private, and respective HasPrivate/Get/Private/SetPrivate/DeletePrivate methods on calss Object.
These APIs are designed and restricted such that their implementation can later be replaced by whatever ES7+ will officially provide.
R=yangguo@chromium.org
BUG=
Review URL: https://codereview.chromium.org/48923002
git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@17683 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
2013-11-13 10:34:06 +00:00
|
|
|
# Private names.
|
2014-05-20 09:13:26 +00:00
|
|
|
# GET_PRIVATE should only be used if the property is known to exists on obj
|
|
|
|
# itself (it should really use %GetOwnProperty, but that would be way slower).
|
2014-08-20 19:21:56 +00:00
|
|
|
macro GLOBAL_PRIVATE(name) = (%CreateGlobalPrivateOwnSymbol(name));
|
2014-09-24 08:12:58 +00:00
|
|
|
macro NEW_PRIVATE_OWN(name) = (%CreatePrivateOwnSymbol(name));
|
2014-01-09 15:57:30 +00:00
|
|
|
macro IS_PRIVATE(sym) = (%SymbolIsPrivate(sym));
|
2014-05-22 15:27:57 +00:00
|
|
|
macro HAS_PRIVATE(obj, sym) = (%HasOwnProperty(obj, sym));
|
2014-08-20 19:21:56 +00:00
|
|
|
macro HAS_DEFINED_PRIVATE(obj, sym) = (!IS_UNDEFINED(obj[sym]));
|
Provide private symbols through internal APIs
Adds a notion of private symbols, mainly intended for internal use, especially, self-hosting of built-in types that would otherwise require new C++ classes.
On the JS side (i.e., in built-ins), private properties can be created and accessed through a set of macros:
NEW_PRIVATE(print_name)
HAS_PRIVATE(obj, sym)
GET_PRIVATE(obj, sym)
SET_PRIVATE(obj, sym, val)
DELETE_PRIVATE(obj, sym)
In the V8 API, they are accessible via a new class Private, and respective HasPrivate/Get/Private/SetPrivate/DeletePrivate methods on calss Object.
These APIs are designed and restricted such that their implementation can later be replaced by whatever ES7+ will officially provide.
R=yangguo@chromium.org
BUG=
Review URL: https://codereview.chromium.org/48923002
git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@17683 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
2013-11-13 10:34:06 +00:00
|
|
|
macro GET_PRIVATE(obj, sym) = (obj[sym]);
|
|
|
|
macro SET_PRIVATE(obj, sym, val) = (obj[sym] = val);
|
|
|
|
macro DELETE_PRIVATE(obj, sym) = (delete obj[sym]);
|
|
|
|
|
2013-10-17 10:02:45 +00:00
|
|
|
# Constants. The compiler constant folds them.
|
|
|
|
const NAN = $NaN;
|
|
|
|
const INFINITY = (1/0);
|
|
|
|
const UNDEFINED = (void 0);
|
|
|
|
|
2008-10-03 07:36:03 +00:00
|
|
|
# Macros implemented in Python.
|
|
|
|
python macro CHAR_CODE(str) = ord(str[1]);
|
2008-07-03 15:10:15 +00:00
|
|
|
|
2009-03-11 14:00:55 +00:00
|
|
|
# Constants used on an array to implement the properties of the RegExp object.
|
|
|
|
const REGEXP_NUMBER_OF_CAPTURES = 0;
|
2009-03-17 12:44:20 +00:00
|
|
|
const REGEXP_FIRST_CAPTURE = 3;
|
2009-03-11 14:00:55 +00:00
|
|
|
|
|
|
|
# We can't put macros in macros so we use constants here.
|
|
|
|
# REGEXP_NUMBER_OF_CAPTURES
|
|
|
|
macro NUMBER_OF_CAPTURES(array) = ((array)[0]);
|
|
|
|
|
2010-03-23 14:47:02 +00:00
|
|
|
# Limit according to ECMA 262 15.9.1.1
|
|
|
|
const MAX_TIME_MS = 8640000000000000;
|
2010-12-16 13:02:09 +00:00
|
|
|
# Limit which is MAX_TIME_MS + msPerMonth.
|
|
|
|
const MAX_TIME_BEFORE_UTC = 8640002592000000;
|
2010-03-23 14:47:02 +00:00
|
|
|
|
2009-06-29 12:41:18 +00:00
|
|
|
# Gets the value of a Date object. If arg is not a Date object
|
|
|
|
# a type error is thrown.
|
2012-03-09 12:07:29 +00:00
|
|
|
macro CHECK_DATE(arg) = if (%_ClassOf(arg) !== 'Date') ThrowDateTypeError();
|
|
|
|
macro LOCAL_DATE_VALUE(arg) = (%_DateField(arg, 0) + %_DateField(arg, 21));
|
|
|
|
macro UTC_DATE_VALUE(arg) = (%_DateField(arg, 0));
|
|
|
|
|
|
|
|
macro LOCAL_YEAR(arg) = (%_DateField(arg, 1));
|
|
|
|
macro LOCAL_MONTH(arg) = (%_DateField(arg, 2));
|
|
|
|
macro LOCAL_DAY(arg) = (%_DateField(arg, 3));
|
|
|
|
macro LOCAL_WEEKDAY(arg) = (%_DateField(arg, 4));
|
|
|
|
macro LOCAL_HOUR(arg) = (%_DateField(arg, 5));
|
|
|
|
macro LOCAL_MIN(arg) = (%_DateField(arg, 6));
|
|
|
|
macro LOCAL_SEC(arg) = (%_DateField(arg, 7));
|
|
|
|
macro LOCAL_MS(arg) = (%_DateField(arg, 8));
|
|
|
|
macro LOCAL_DAYS(arg) = (%_DateField(arg, 9));
|
|
|
|
macro LOCAL_TIME_IN_DAY(arg) = (%_DateField(arg, 10));
|
|
|
|
|
|
|
|
macro UTC_YEAR(arg) = (%_DateField(arg, 11));
|
|
|
|
macro UTC_MONTH(arg) = (%_DateField(arg, 12));
|
|
|
|
macro UTC_DAY(arg) = (%_DateField(arg, 13));
|
|
|
|
macro UTC_WEEKDAY(arg) = (%_DateField(arg, 14));
|
|
|
|
macro UTC_HOUR(arg) = (%_DateField(arg, 15));
|
|
|
|
macro UTC_MIN(arg) = (%_DateField(arg, 16));
|
|
|
|
macro UTC_SEC(arg) = (%_DateField(arg, 17));
|
|
|
|
macro UTC_MS(arg) = (%_DateField(arg, 18));
|
|
|
|
macro UTC_DAYS(arg) = (%_DateField(arg, 19));
|
|
|
|
macro UTC_TIME_IN_DAY(arg) = (%_DateField(arg, 20));
|
|
|
|
|
|
|
|
macro TIMEZONE_OFFSET(arg) = (%_DateField(arg, 21));
|
|
|
|
|
|
|
|
macro SET_UTC_DATE_VALUE(arg, value) = (%DateSetValue(arg, value, 1));
|
|
|
|
macro SET_LOCAL_DATE_VALUE(arg, value) = (%DateSetValue(arg, value, 0));
|
2009-06-29 12:41:18 +00:00
|
|
|
|
2009-10-08 12:36:12 +00:00
|
|
|
# Last input and last subject of regexp matches.
|
2012-04-23 18:56:07 +00:00
|
|
|
const LAST_SUBJECT_INDEX = 1;
|
2009-03-17 12:44:20 +00:00
|
|
|
macro LAST_SUBJECT(array) = ((array)[1]);
|
|
|
|
macro LAST_INPUT(array) = ((array)[2]);
|
2009-03-11 14:00:55 +00:00
|
|
|
|
|
|
|
# REGEXP_FIRST_CAPTURE
|
2009-03-17 12:44:20 +00:00
|
|
|
macro CAPTURE(index) = (3 + (index));
|
|
|
|
const CAPTURE0 = 3;
|
|
|
|
const CAPTURE1 = 4;
|
2010-05-27 07:43:43 +00:00
|
|
|
|
2012-04-13 11:03:22 +00:00
|
|
|
# For the regexp capture override array. This has the same
|
|
|
|
# format as the arguments to a function called from
|
|
|
|
# String.prototype.replace.
|
|
|
|
macro OVERRIDE_MATCH(override) = ((override)[0]);
|
|
|
|
macro OVERRIDE_POS(override) = ((override)[(override).length - 2]);
|
|
|
|
macro OVERRIDE_SUBJECT(override) = ((override)[(override).length - 1]);
|
|
|
|
# 1-based so index of 1 returns the first capture
|
|
|
|
macro OVERRIDE_CAPTURE(override, index) = ((override)[(index)]);
|
|
|
|
|
2011-09-01 11:28:10 +00:00
|
|
|
# PropertyDescriptor return value indices - must match
|
2014-10-10 14:59:53 +00:00
|
|
|
# PropertyDescriptorIndices in runtime-object.cc.
|
2010-05-27 07:43:43 +00:00
|
|
|
const IS_ACCESSOR_INDEX = 0;
|
|
|
|
const VALUE_INDEX = 1;
|
|
|
|
const GETTER_INDEX = 2;
|
|
|
|
const SETTER_INDEX = 3;
|
|
|
|
const WRITABLE_INDEX = 4;
|
|
|
|
const ENUMERABLE_INDEX = 5;
|
|
|
|
const CONFIGURABLE_INDEX = 6;
|
2011-09-01 11:57:02 +00:00
|
|
|
|
|
|
|
# For messages.js
|
|
|
|
# Matches Script::Type from objects.h
|
|
|
|
const TYPE_NATIVE = 0;
|
|
|
|
const TYPE_EXTENSION = 1;
|
|
|
|
const TYPE_NORMAL = 2;
|
|
|
|
|
|
|
|
# Matches Script::CompilationType from objects.h
|
|
|
|
const COMPILATION_TYPE_HOST = 0;
|
|
|
|
const COMPILATION_TYPE_EVAL = 1;
|
|
|
|
const COMPILATION_TYPE_JSON = 2;
|
|
|
|
|
|
|
|
# Matches Messages::kNoLineNumberInfo from v8.h
|
|
|
|
const kNoLineNumberInfo = 0;
|
2014-01-09 15:57:30 +00:00
|
|
|
|
|
|
|
# Matches PropertyAttributes from property-details.h
|
|
|
|
const PROPERTY_ATTRIBUTES_NONE = 0;
|
|
|
|
const PROPERTY_ATTRIBUTES_STRING = 8;
|
|
|
|
const PROPERTY_ATTRIBUTES_SYMBOLIC = 16;
|
|
|
|
const PROPERTY_ATTRIBUTES_PRIVATE_SYMBOL = 32;
|
2014-04-17 17:45:32 +00:00
|
|
|
|
|
|
|
# Use for keys, values and entries iterators.
|
|
|
|
const ITERATOR_KIND_KEYS = 1;
|
|
|
|
const ITERATOR_KIND_VALUES = 2;
|
|
|
|
const ITERATOR_KIND_ENTRIES = 3;
|
2014-06-23 07:10:25 +00:00
|
|
|
|
2015-04-07 00:11:48 +00:00
|
|
|
macro FIXED_ARRAY_GET(array, index) = (%_FixedArrayGet(array, (index) | 0));
|
|
|
|
macro FIXED_ARRAY_SET(array, index, value) = (%_FixedArraySet(array, (index) | 0, value));
|
|
|
|
# TODO(adamk): Find a more robust way to force Smi representation.
|
|
|
|
macro FIXED_ARRAY_SET_SMI(array, index, value) = (FIXED_ARRAY_SET(array, index, (value) | 0));
|
|
|
|
|
|
|
|
macro ORDERED_HASH_TABLE_BUCKET_COUNT(table) = (FIXED_ARRAY_GET(table, 0));
|
|
|
|
macro ORDERED_HASH_TABLE_ELEMENT_COUNT(table) = (FIXED_ARRAY_GET(table, 1));
|
|
|
|
macro ORDERED_HASH_TABLE_SET_ELEMENT_COUNT(table, count) = (FIXED_ARRAY_SET_SMI(table, 1, count));
|
|
|
|
macro ORDERED_HASH_TABLE_DELETED_COUNT(table) = (FIXED_ARRAY_GET(table, 2));
|
|
|
|
macro ORDERED_HASH_TABLE_SET_DELETED_COUNT(table, count) = (FIXED_ARRAY_SET_SMI(table, 2, count));
|
|
|
|
macro ORDERED_HASH_TABLE_BUCKET_AT(table, bucket) = (FIXED_ARRAY_GET(table, 3 + (bucket)));
|
|
|
|
macro ORDERED_HASH_TABLE_SET_BUCKET_AT(table, bucket, entry) = (FIXED_ARRAY_SET(table, 3 + (bucket), entry));
|
|
|
|
|
|
|
|
macro ORDERED_HASH_TABLE_HASH_TO_BUCKET(hash, numBuckets) = (hash & ((numBuckets) - 1));
|
|
|
|
|
|
|
|
macro ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets) = (3 + (numBuckets) + ((entry) << 1));
|
|
|
|
macro ORDERED_HASH_SET_KEY_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets)));
|
|
|
|
macro ORDERED_HASH_SET_CHAIN_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets) + 1));
|
|
|
|
|
|
|
|
macro ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) = (3 + (numBuckets) + ((entry) * 3));
|
|
|
|
macro ORDERED_HASH_MAP_KEY_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets)));
|
|
|
|
macro ORDERED_HASH_MAP_VALUE_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) + 1));
|
|
|
|
macro ORDERED_HASH_MAP_CHAIN_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) + 2));
|
|
|
|
|
|
|
|
# Must match OrderedHashTable::kNotFound.
|
|
|
|
const NOT_FOUND = -1;
|
|
|
|
|
2014-06-23 07:10:25 +00:00
|
|
|
# Check whether debug is active.
|
|
|
|
const DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0);
|
2014-11-18 09:50:12 +00:00
|
|
|
macro DEBUG_IS_STEPPING(function) = (%_DebugIsActive() != 0 && %DebugCallbackSupportsStepping(function));
|
|
|
|
macro DEBUG_PREPARE_STEP_IN_IF_STEPPING(function) = if (DEBUG_IS_STEPPING(function)) %DebugPrepareStepInIfStepping(function);
|