Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(26)

Side by Side Diff: src/macros.py

Issue 1319133002: [es6] Implement spec compliant ToName (actually ToPropertyKey). (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@ToPrimitive
Patch Set: Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/full-codegen/full-codegen.cc ('k') | src/runtime.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright 2006-2009 the V8 project authors. All rights reserved. 1 # Copyright 2006-2009 the V8 project authors. All rights reserved.
2 # Redistribution and use in source and binary forms, with or without 2 # Redistribution and use in source and binary forms, with or without
3 # modification, are permitted provided that the following conditions are 3 # modification, are permitted provided that the following conditions are
4 # met: 4 # met:
5 # 5 #
6 # * Redistributions of source code must retain the above copyright 6 # * Redistributions of source code must retain the above copyright
7 # notice, this list of conditions and the following disclaimer. 7 # notice, this list of conditions and the following disclaimer.
8 # * Redistributions in binary form must reproduce the above 8 # * Redistributions in binary form must reproduce the above
9 # copyright notice, this list of conditions and the following 9 # copyright notice, this list of conditions and the following
10 # disclaimer in the documentation and/or other materials provided 10 # disclaimer in the documentation and/or other materials provided
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after
149 macro TO_INTEGER_FOR_SIDE_EFFECT(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : ToNumber( arg)); 149 macro TO_INTEGER_FOR_SIDE_EFFECT(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : ToNumber( arg));
150 macro TO_INTEGER_MAP_MINUS_ZERO(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToI ntegerMapMinusZero(ToNumber(arg))); 150 macro TO_INTEGER_MAP_MINUS_ZERO(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToI ntegerMapMinusZero(ToNumber(arg)));
151 macro TO_INT32(arg) = (arg | 0); 151 macro TO_INT32(arg) = (arg | 0);
152 macro TO_UINT32(arg) = (arg >>> 0); 152 macro TO_UINT32(arg) = (arg >>> 0);
153 macro TO_STRING_INLINE(arg) = (IS_STRING(%IS_VAR(arg)) ? arg : $nonStringToStrin g(arg)); 153 macro TO_STRING_INLINE(arg) = (IS_STRING(%IS_VAR(arg)) ? arg : $nonStringToStrin g(arg));
154 macro TO_NUMBER_INLINE(arg) = (IS_NUMBER(%IS_VAR(arg)) ? arg : $nonNumberToNumbe r(arg)); 154 macro TO_NUMBER_INLINE(arg) = (IS_NUMBER(%IS_VAR(arg)) ? arg : $nonNumberToNumbe r(arg));
155 macro TO_OBJECT(arg) = (%_ToObject(arg)); 155 macro TO_OBJECT(arg) = (%_ToObject(arg));
156 macro TO_PRIMITIVE(arg) = (%_ToPrimitive(arg)); 156 macro TO_PRIMITIVE(arg) = (%_ToPrimitive(arg));
157 macro TO_PRIMITIVE_NUMBER(arg) = (%_ToPrimitive_Number(arg)); 157 macro TO_PRIMITIVE_NUMBER(arg) = (%_ToPrimitive_Number(arg));
158 macro TO_PRIMITIVE_STRING(arg) = (%_ToPrimitive_String(arg)); 158 macro TO_PRIMITIVE_STRING(arg) = (%_ToPrimitive_String(arg));
159 macro TO_NAME(arg) = (%_ToName(arg));
159 macro JSON_NUMBER_TO_STRING(arg) = ((%_IsSmi(%IS_VAR(arg)) || arg - arg == 0) ? %_NumberToString(arg) : "null"); 160 macro JSON_NUMBER_TO_STRING(arg) = ((%_IsSmi(%IS_VAR(arg)) || arg - arg == 0) ? %_NumberToString(arg) : "null");
160 macro HAS_OWN_PROPERTY(arg, index) = (%_CallFunction(arg, index, ObjectHasOwnPro perty)); 161 macro HAS_OWN_PROPERTY(arg, index) = (%_CallFunction(arg, index, ObjectHasOwnPro perty));
161 macro SHOULD_CREATE_WRAPPER(functionName, receiver) = (!IS_SPEC_OBJECT(receiver) && %IsSloppyModeFunction(functionName)); 162 macro SHOULD_CREATE_WRAPPER(functionName, receiver) = (!IS_SPEC_OBJECT(receiver) && %IsSloppyModeFunction(functionName));
162 macro HAS_INDEX(array, index, is_array) = ((is_array && %_HasFastPackedElements( %IS_VAR(array))) ? (index < array.length) : (index in array)); 163 macro HAS_INDEX(array, index, is_array) = ((is_array && %_HasFastPackedElements( %IS_VAR(array))) ? (index < array.length) : (index in array));
163 164
164 # Private names. 165 # Private names.
165 macro IS_PRIVATE(sym) = (%SymbolIsPrivate(sym)); 166 macro IS_PRIVATE(sym) = (%SymbolIsPrivate(sym));
166 macro HAS_PRIVATE(obj, sym) = (%HasOwnProperty(obj, sym)); 167 macro HAS_PRIVATE(obj, sym) = (%HasOwnProperty(obj, sym));
167 macro HAS_DEFINED_PRIVATE(obj, sym) = (!IS_UNDEFINED(obj[sym])); 168 macro HAS_DEFINED_PRIVATE(obj, sym) = (!IS_UNDEFINED(obj[sym]));
168 macro GET_PRIVATE(obj, sym) = (obj[sym]); 169 macro GET_PRIVATE(obj, sym) = (obj[sym]);
(...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after
304 define NOT_FOUND = -1; 305 define NOT_FOUND = -1;
305 306
306 # Check whether debug is active. 307 # Check whether debug is active.
307 define DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0); 308 define DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0);
308 macro DEBUG_IS_STEPPING(function) = (%_DebugIsActive() != 0 && %DebugCallbackSup portsStepping(function)); 309 macro DEBUG_IS_STEPPING(function) = (%_DebugIsActive() != 0 && %DebugCallbackSup portsStepping(function));
309 macro DEBUG_PREPARE_STEP_IN_IF_STEPPING(function) = if (DEBUG_IS_STEPPING(functi on)) %DebugPrepareStepInIfStepping(function); 310 macro DEBUG_PREPARE_STEP_IN_IF_STEPPING(function) = if (DEBUG_IS_STEPPING(functi on)) %DebugPrepareStepInIfStepping(function);
310 311
311 # SharedFlag equivalents 312 # SharedFlag equivalents
312 define kNotShared = false; 313 define kNotShared = false;
313 define kShared = true; 314 define kShared = true;
OLDNEW
« no previous file with comments | « src/full-codegen/full-codegen.cc ('k') | src/runtime.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698