blob: b2a785697b3ba03472fbbc985a927b53fc4c8040 [file] [log] [blame]
Ben Murdoch4a90d5f2016-03-22 12:00:34 +00001# Copyright 2006-2009 the V8 project authors. All rights reserved.
2# Redistribution and use in source and binary forms, with or without
3# modification, are permitted provided that the following conditions are
4# met:
5#
6# * Redistributions of source code must retain the above copyright
7# notice, this list of conditions and the following disclaimer.
8# * Redistributions in binary form must reproduce the above
9# copyright notice, this list of conditions and the following
10# disclaimer in the documentation and/or other materials provided
11# with the distribution.
12# * Neither the name of Google Inc. nor the names of its
13# contributors may be used to endorse or promote products derived
14# from this software without specific prior written permission.
15#
16# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28# Dictionary that is passed as defines for js2c.py.
29# Used for defines that must be defined for all native JS files.
30
31define NONE = 0;
32define READ_ONLY = 1;
33define DONT_ENUM = 2;
34define DONT_DELETE = 4;
35define NEW_ONE_BYTE_STRING = true;
36define NEW_TWO_BYTE_STRING = false;
37
38# Constants used for getter and setter operations.
39define GETTER = 0;
40define SETTER = 1;
41
42# Safe maximum number of arguments to push to stack, when multiplied by
43# pointer size. Used by Function.prototype.apply(), Reflect.apply() and
44# Reflect.construct().
45define kSafeArgumentsLength = 0x800000;
46
47# 2^53 - 1
48define kMaxSafeInteger = 9007199254740991;
49
50# 2^32 - 1
51define kMaxUint32 = 4294967295;
52
53# Strict mode flags for passing to %SetProperty
54define kSloppyMode = 0;
55define kStrictMode = 1;
56
57# Native cache ids.
58define STRING_TO_REGEXP_CACHE_ID = 0;
59
60# Type query macros.
61#
62# Note: We have special support for typeof(foo) === 'bar' in the compiler.
63# It will *not* generate a runtime typeof call for the most important
64# values of 'bar'.
65macro IS_ARRAY(arg) = (%_IsArray(arg));
66macro IS_ARRAYBUFFER(arg) = (%_ClassOf(arg) === 'ArrayBuffer');
67macro IS_BOOLEAN(arg) = (typeof(arg) === 'boolean');
68macro IS_BOOLEAN_WRAPPER(arg) = (%_ClassOf(arg) === 'Boolean');
69macro IS_DATAVIEW(arg) = (%_ClassOf(arg) === 'DataView');
Ben Murdoch097c5b22016-05-18 11:27:45 +010070macro IS_DATE(arg) = (%IsDate(arg));
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000071macro IS_ERROR(arg) = (%_ClassOf(arg) === 'Error');
Ben Murdoch097c5b22016-05-18 11:27:45 +010072macro IS_FUNCTION(arg) = (%IsFunction(arg));
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000073macro IS_GENERATOR(arg) = (%_ClassOf(arg) === 'Generator');
74macro IS_GLOBAL(arg) = (%_ClassOf(arg) === 'global');
75macro IS_MAP(arg) = (%_ClassOf(arg) === 'Map');
76macro IS_MAP_ITERATOR(arg) = (%_ClassOf(arg) === 'Map Iterator');
77macro IS_NULL(arg) = (arg === null);
78macro IS_NULL_OR_UNDEFINED(arg) = (arg == null);
79macro IS_NUMBER(arg) = (typeof(arg) === 'number');
80macro IS_NUMBER_WRAPPER(arg) = (%_ClassOf(arg) === 'Number');
81macro IS_OBJECT(arg) = (typeof(arg) === 'object');
82macro IS_PROXY(arg) = (%_IsJSProxy(arg));
83macro IS_REGEXP(arg) = (%_IsRegExp(arg));
84macro IS_SCRIPT(arg) = (%_ClassOf(arg) === 'Script');
85macro IS_SET(arg) = (%_ClassOf(arg) === 'Set');
86macro IS_SET_ITERATOR(arg) = (%_ClassOf(arg) === 'Set Iterator');
87macro IS_SHAREDARRAYBUFFER(arg) = (%_ClassOf(arg) === 'SharedArrayBuffer');
Ben Murdoch097c5b22016-05-18 11:27:45 +010088macro IS_SIMD_VALUE(arg) = (%IsSimdValue(arg));
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000089macro IS_STRING(arg) = (typeof(arg) === 'string');
90macro IS_STRING_WRAPPER(arg) = (%_ClassOf(arg) === 'String');
91macro IS_STRONG(arg) = (%IsStrong(arg));
92macro IS_SYMBOL(arg) = (typeof(arg) === 'symbol');
93macro IS_SYMBOL_WRAPPER(arg) = (%_ClassOf(arg) === 'Symbol');
94macro IS_UNDEFINED(arg) = (arg === (void 0));
95macro IS_WEAKMAP(arg) = (%_ClassOf(arg) === 'WeakMap');
96macro IS_WEAKSET(arg) = (%_ClassOf(arg) === 'WeakSet');
97
98# Macro for ES queries of the type: "Type(O) is Object."
99macro IS_RECEIVER(arg) = (%_IsJSReceiver(arg));
100
101# Macro for ES queries of the type: "IsCallable(O)"
102macro IS_CALLABLE(arg) = (typeof(arg) === 'function');
103
104# Macro for ES6 CheckObjectCoercible
105# Will throw a TypeError of the form "[functionName] called on null or undefined".
106macro CHECK_OBJECT_COERCIBLE(arg, functionName) = if (IS_NULL(%IS_VAR(arg)) || IS_UNDEFINED(arg)) throw MakeTypeError(kCalledOnNullOrUndefined, functionName);
107
108# Inline macros. Use %IS_VAR to make sure arg is evaluated only once.
109macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg));
110macro NUMBER_IS_FINITE(arg) = (%_IsSmi(%IS_VAR(arg)) || ((arg == arg) && (arg != 1/0) && (arg != -1/0)));
111macro TO_BOOLEAN(arg) = (!!(arg));
112macro TO_INTEGER(arg) = (%_ToInteger(arg));
113macro TO_INTEGER_MAP_MINUS_ZERO(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToIntegerMapMinusZero(arg));
114macro TO_INT32(arg) = ((arg) | 0);
115macro TO_UINT32(arg) = ((arg) >>> 0);
116macro TO_LENGTH(arg) = (%_ToLength(arg));
Ben Murdoch4a90d5f2016-03-22 12:00:34 +0000117macro TO_STRING(arg) = (%_ToString(arg));
118macro TO_NUMBER(arg) = (%_ToNumber(arg));
119macro TO_OBJECT(arg) = (%_ToObject(arg));
120macro TO_PRIMITIVE(arg) = (%_ToPrimitive(arg));
121macro TO_PRIMITIVE_NUMBER(arg) = (%_ToPrimitive_Number(arg));
122macro TO_PRIMITIVE_STRING(arg) = (%_ToPrimitive_String(arg));
123macro TO_NAME(arg) = (%_ToName(arg));
124macro JSON_NUMBER_TO_STRING(arg) = ((%_IsSmi(%IS_VAR(arg)) || arg - arg == 0) ? %_NumberToString(arg) : "null");
125macro HAS_OWN_PROPERTY(arg, index) = (%_Call(ObjectHasOwnProperty, arg, index));
126macro HAS_INDEX(array, index, is_array) = ((is_array && %_HasFastPackedElements(%IS_VAR(array))) ? (index < array.length) : (index in array));
127
128# Private names.
129macro IS_PRIVATE(sym) = (%SymbolIsPrivate(sym));
130macro HAS_PRIVATE(obj, sym) = (%HasOwnProperty(obj, sym));
131macro HAS_DEFINED_PRIVATE(obj, sym) = (!IS_UNDEFINED(obj[sym]));
132macro GET_PRIVATE(obj, sym) = (obj[sym]);
133macro SET_PRIVATE(obj, sym, val) = (obj[sym] = val);
134
135# Constants. The compiler constant folds them.
136define INFINITY = (1/0);
137define UNDEFINED = (void 0);
138
139# Macros implemented in Python.
140python macro CHAR_CODE(str) = ord(str[1]);
141
142# Constants used on an array to implement the properties of the RegExp object.
143define REGEXP_NUMBER_OF_CAPTURES = 0;
144define REGEXP_FIRST_CAPTURE = 3;
145
146# Macros for internal slot access.
147macro REGEXP_GLOBAL(regexp) = (%_RegExpFlags(regexp) & 1);
148macro REGEXP_IGNORE_CASE(regexp) = (%_RegExpFlags(regexp) & 2);
149macro REGEXP_MULTILINE(regexp) = (%_RegExpFlags(regexp) & 4);
150macro REGEXP_STICKY(regexp) = (%_RegExpFlags(regexp) & 8);
151macro REGEXP_UNICODE(regexp) = (%_RegExpFlags(regexp) & 16);
152macro REGEXP_SOURCE(regexp) = (%_RegExpSource(regexp));
153
154# We can't put macros in macros so we use constants here.
155# REGEXP_NUMBER_OF_CAPTURES
156macro NUMBER_OF_CAPTURES(array) = ((array)[0]);
157
158# Last input and last subject of regexp matches.
159define LAST_SUBJECT_INDEX = 1;
160macro LAST_SUBJECT(array) = ((array)[1]);
161macro LAST_INPUT(array) = ((array)[2]);
162
163# REGEXP_FIRST_CAPTURE
164macro CAPTURE(index) = (3 + (index));
165define CAPTURE0 = 3;
166define CAPTURE1 = 4;
167
168# For the regexp capture override array. This has the same
169# format as the arguments to a function called from
170# String.prototype.replace.
171macro OVERRIDE_MATCH(override) = ((override)[0]);
172macro OVERRIDE_POS(override) = ((override)[(override).length - 2]);
173macro OVERRIDE_SUBJECT(override) = ((override)[(override).length - 1]);
174# 1-based so index of 1 returns the first capture
175macro OVERRIDE_CAPTURE(override, index) = ((override)[(index)]);
176
177# PropertyDescriptor return value indices - must match
178# PropertyDescriptorIndices in runtime-object.cc.
179define IS_ACCESSOR_INDEX = 0;
180define VALUE_INDEX = 1;
181define GETTER_INDEX = 2;
182define SETTER_INDEX = 3;
183define WRITABLE_INDEX = 4;
184define ENUMERABLE_INDEX = 5;
185define CONFIGURABLE_INDEX = 6;
186
187# For messages.js
188# Matches Script::Type from objects.h
189define TYPE_NATIVE = 0;
190define TYPE_EXTENSION = 1;
191define TYPE_NORMAL = 2;
192
193# Matches Script::CompilationType from objects.h
194define COMPILATION_TYPE_HOST = 0;
195define COMPILATION_TYPE_EVAL = 1;
196define COMPILATION_TYPE_JSON = 2;
197
198# Matches Messages::kNoLineNumberInfo from v8.h
199define kNoLineNumberInfo = 0;
200
201# Must match PropertyFilter in property-details.h
202define PROPERTY_FILTER_NONE = 0;
203define PROPERTY_FILTER_ONLY_ENUMERABLE = 2;
204define PROPERTY_FILTER_SKIP_STRINGS = 8;
205define PROPERTY_FILTER_SKIP_SYMBOLS = 16;
206
207# Use for keys, values and entries iterators.
208define ITERATOR_KIND_KEYS = 1;
209define ITERATOR_KIND_VALUES = 2;
210define ITERATOR_KIND_ENTRIES = 3;
211
212macro FIXED_ARRAY_GET(array, index) = (%_FixedArrayGet(array, (index) | 0));
213macro FIXED_ARRAY_SET(array, index, value) = (%_FixedArraySet(array, (index) | 0, value));
214# TODO(adamk): Find a more robust way to force Smi representation.
215macro FIXED_ARRAY_SET_SMI(array, index, value) = (FIXED_ARRAY_SET(array, index, (value) | 0));
216
217macro ORDERED_HASH_TABLE_BUCKET_COUNT(table) = (FIXED_ARRAY_GET(table, 0));
218macro ORDERED_HASH_TABLE_ELEMENT_COUNT(table) = (FIXED_ARRAY_GET(table, 1));
219macro ORDERED_HASH_TABLE_SET_ELEMENT_COUNT(table, count) = (FIXED_ARRAY_SET_SMI(table, 1, count));
220macro ORDERED_HASH_TABLE_DELETED_COUNT(table) = (FIXED_ARRAY_GET(table, 2));
221macro ORDERED_HASH_TABLE_SET_DELETED_COUNT(table, count) = (FIXED_ARRAY_SET_SMI(table, 2, count));
222macro ORDERED_HASH_TABLE_BUCKET_AT(table, bucket) = (FIXED_ARRAY_GET(table, 3 + (bucket)));
223macro ORDERED_HASH_TABLE_SET_BUCKET_AT(table, bucket, entry) = (FIXED_ARRAY_SET(table, 3 + (bucket), entry));
224
225macro ORDERED_HASH_TABLE_HASH_TO_BUCKET(hash, numBuckets) = (hash & ((numBuckets) - 1));
226
227macro ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets) = (3 + (numBuckets) + ((entry) << 1));
228macro ORDERED_HASH_SET_KEY_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets)));
229macro ORDERED_HASH_SET_CHAIN_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_SET_ENTRY_TO_INDEX(entry, numBuckets) + 1));
230
231macro ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) = (3 + (numBuckets) + ((entry) * 3));
232macro ORDERED_HASH_MAP_KEY_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets)));
233macro ORDERED_HASH_MAP_VALUE_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) + 1));
234macro ORDERED_HASH_MAP_CHAIN_AT(table, entry, numBuckets) = (FIXED_ARRAY_GET(table, ORDERED_HASH_MAP_ENTRY_TO_INDEX(entry, numBuckets) + 2));
235
236# Must match OrderedHashTable::kNotFound.
237define NOT_FOUND = -1;
238
239# Check whether debug is active.
240define DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0);
241macro DEBUG_PREPARE_STEP_IN_IF_STEPPING(function) = if (%_DebugIsActive() != 0) %DebugPrepareStepInIfStepping(function);
242
243# SharedFlag equivalents
244define kNotShared = false;
245define kShared = true;
246
247# UseCounters from include/v8.h
248define kUseAsm = 0;
249define kBreakIterator = 1;
250define kLegacyConst = 2;
251define kMarkDequeOverflow = 3;
252define kStoreBufferOverflow = 4;
253define kSlotsBufferOverflow = 5;
254define kObjectObserve = 6;
255define kForcedGC = 7;
256define kSloppyMode = 8;
257define kStrictMode = 9;
258define kStrongMode = 10;
259define kRegExpPrototypeStickyGetter = 11;
260define kRegExpPrototypeToString = 12;
261define kRegExpPrototypeUnicodeGetter = 13;
262define kIntlV8Parse = 14;
263define kIntlPattern = 15;
264define kIntlResolved = 16;
265define kPromiseChain = 17;
266define kPromiseAccept = 18;
267define kPromiseDefer = 19;