Commit 7fcbde16 authored by Santiago Aboy Solanes's avatar Santiago Aboy Solanes Committed by Commit Bot

[CSA][cleanup] TNodify builtins regexp gen

Bug: v8:6949, v8:9396
Change-Id: I035a00f61077e49377c9cd39ae1b216a80c98e6b
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1803615Reviewed-by: 's avatarDan Elphick <delphick@chromium.org>
Commit-Queue: Santiago Aboy Solanes <solanes@chromium.org>
Cr-Commit-Position: refs/heads/master@{#63848}
parent c3d7f5f1
This diff is collapsed.
...@@ -139,17 +139,17 @@ class RegExpBuiltinsAssembler : public CodeStubAssembler { ...@@ -139,17 +139,17 @@ class RegExpBuiltinsAssembler : public CodeStubAssembler {
// Performs fast path checks on the given object itself, but omits prototype // Performs fast path checks on the given object itself, but omits prototype
// checks. // checks.
Node* IsFastRegExpNoPrototype(SloppyTNode<Context> context, TNode<BoolT> IsFastRegExpNoPrototype(TNode<Context> context,
SloppyTNode<Object> object); TNode<Object> object);
Node* IsFastRegExpNoPrototype(SloppyTNode<Context> context, TNode<BoolT> IsFastRegExpNoPrototype(TNode<Context> context,
SloppyTNode<Object> object, TNode<Object> object, TNode<Map> map);
SloppyTNode<Map> map);
// For debugging only. Uses a slow GetProperty call to fetch object.exec. // For debugging only. Uses a slow GetProperty call to fetch object.exec.
TNode<BoolT> IsFastRegExpWithOriginalExec(TNode<Context> context, TNode<BoolT> IsFastRegExpWithOriginalExec(TNode<Context> context,
TNode<JSRegExp> object); TNode<JSRegExp> object);
void BranchIfFastRegExpResult(Node* const context, Node* const object, void BranchIfFastRegExpResult(const TNode<Context> context,
const TNode<Object> object,
Label* if_isunmodified, Label* if_ismodified); Label* if_isunmodified, Label* if_ismodified);
TNode<String> FlagsGetter(TNode<Context> context, TNode<Object> regexp, TNode<String> FlagsGetter(TNode<Context> context, TNode<Object> regexp,
...@@ -167,10 +167,14 @@ class RegExpBuiltinsAssembler : public CodeStubAssembler { ...@@ -167,10 +167,14 @@ class RegExpBuiltinsAssembler : public CodeStubAssembler {
TNode<BoolT> FlagGetter(TNode<Context> context, TNode<Object> regexp, TNode<BoolT> FlagGetter(TNode<Context> context, TNode<Object> regexp,
JSRegExp::Flag flag, bool is_fastpath); JSRegExp::Flag flag, bool is_fastpath);
Node* RegExpInitialize(Node* const context, Node* const regexp, TNode<Object> RegExpInitialize(const TNode<Context> context,
Node* const maybe_pattern, Node* const maybe_flags); const TNode<JSRegExp> regexp,
const TNode<Object> maybe_pattern,
const TNode<Object> maybe_flags);
TNode<Object> RegExpExec(TNode<Context> context, Node* regexp, Node* string); TNode<Object> RegExpExec(TNode<Context> context,
TNode<JSReceiver> maybe_regexp,
TNode<String> string);
TNode<Number> AdvanceStringIndex(SloppyTNode<String> string, TNode<Number> AdvanceStringIndex(SloppyTNode<String> string,
SloppyTNode<Number> index, SloppyTNode<Number> index,
......
...@@ -22,7 +22,7 @@ namespace regexp { ...@@ -22,7 +22,7 @@ namespace regexp {
BranchIfFastRegExp_Permissive(o) otherwise return true, return false; BranchIfFastRegExp_Permissive(o) otherwise return true, return false;
} }
extern macro RegExpBuiltinsAssembler::RegExpExec(Context, JSAny, JSAny): extern macro RegExpBuiltinsAssembler::RegExpExec(Context, JSReceiver, String):
JSAny; JSAny;
extern macro extern macro
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment