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

Side by Side Diff: src/macros.py

Issue 1287033002: [runtime] Simplify CHECK_OBJECT_COERCIBLE. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years, 4 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 | « no previous file | no next file » | 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 118 matching lines...) Expand 10 before | Expand all | Expand 10 after
129 129
130 # Macro for ECMAScript 5 queries of the type: 130 # Macro for ECMAScript 5 queries of the type:
131 # "IsCallable(O)" 131 # "IsCallable(O)"
132 # We assume here that this is the same as being either a function or a function 132 # We assume here that this is the same as being either a function or a function
133 # proxy. That ignores host objects with [[Call]] methods, but in most situations 133 # proxy. That ignores host objects with [[Call]] methods, but in most situations
134 # we cannot handle those anyway. 134 # we cannot handle those anyway.
135 macro IS_SPEC_FUNCTION(arg) = (%_ClassOf(arg) === 'Function'); 135 macro IS_SPEC_FUNCTION(arg) = (%_ClassOf(arg) === 'Function');
136 136
137 # Macro for ES6 CheckObjectCoercible 137 # Macro for ES6 CheckObjectCoercible
138 # Will throw a TypeError of the form "[functionName] called on null or undefined ". 138 # Will throw a TypeError of the form "[functionName] called on null or undefined ".
139 macro CHECK_OBJECT_COERCIBLE(arg, functionName) = if (IS_NULL_OR_UNDEFINED(arg) && !IS_UNDETECTABLE(arg)) throw MakeTypeError(kCalledOnNullOrUndefined, function Name); 139 macro CHECK_OBJECT_COERCIBLE(arg, functionName) = if (IS_NULL(%IS_VAR(arg)) || I S_UNDEFINED(arg)) throw MakeTypeError(kCalledOnNullOrUndefined, functionName);
140 140
141 # Indices in bound function info retrieved by %BoundFunctionGetBindings(...). 141 # Indices in bound function info retrieved by %BoundFunctionGetBindings(...).
142 define kBoundFunctionIndex = 0; 142 define kBoundFunctionIndex = 0;
143 define kBoundThisIndex = 1; 143 define kBoundThisIndex = 1;
144 define kBoundArgumentsStartIndex = 2; 144 define kBoundArgumentsStartIndex = 2;
145 145
146 # Inline macros. Use %IS_VAR to make sure arg is evaluated only once. 146 # Inline macros. Use %IS_VAR to make sure arg is evaluated only once.
147 macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg)); 147 macro NUMBER_IS_NAN(arg) = (!%_IsSmi(%IS_VAR(arg)) && !(arg == arg));
148 macro NUMBER_IS_FINITE(arg) = (%_IsSmi(%IS_VAR(arg)) || ((arg == arg) && (arg != 1/0) && (arg != -1/0))); 148 macro NUMBER_IS_FINITE(arg) = (%_IsSmi(%IS_VAR(arg)) || ((arg == arg) && (arg != 1/0) && (arg != -1/0)));
149 macro TO_INTEGER(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToInteger($toNumbe r(arg))); 149 macro TO_INTEGER(arg) = (%_IsSmi(%IS_VAR(arg)) ? arg : %NumberToInteger($toNumbe r(arg)));
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after
305 define NOT_FOUND = -1; 305 define NOT_FOUND = -1;
306 306
307 # Check whether debug is active. 307 # Check whether debug is active.
308 define DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0); 308 define DEBUG_IS_ACTIVE = (%_DebugIsActive() != 0);
309 macro DEBUG_IS_STEPPING(function) = (%_DebugIsActive() != 0 && %DebugCallbackSup portsStepping(function)); 309 macro DEBUG_IS_STEPPING(function) = (%_DebugIsActive() != 0 && %DebugCallbackSup portsStepping(function));
310 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);
311 311
312 # SharedFlag equivalents 312 # SharedFlag equivalents
313 define kNotShared = false; 313 define kNotShared = false;
314 define kShared = true; 314 define kShared = true;
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698