Bug 211037

Summary: [JSC] isCallable is redundant with isFunction
Product: WebKit Reporter: Ross Kirsling <ross.kirsling>
Component: New BugsAssignee: Ross Kirsling <ross.kirsling>
Status: RESOLVED FIXED    
Severity: Normal CC: ashvayka, darin, ews-watchlist, keith_miller, mark.lam, msaboff, saam, tzagallo, webkit-bug-importer, ysuzuki
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=211053
https://bugs.webkit.org/show_bug.cgi?id=211059
https://bugs.webkit.org/show_bug.cgi?id=211140
Attachments:
Description Flags
Patch
none
Patch none

Ross Kirsling
Reported 2020-04-25 18:34:53 PDT
[JSC] isCallable is redundant with isFunction
Attachments
Patch (12.13 KB, patch)
2020-04-25 18:42 PDT, Ross Kirsling
no flags
Patch (12.13 KB, patch)
2020-04-25 20:07 PDT, Ross Kirsling
no flags
Ross Kirsling
Comment 1 2020-04-25 18:42:25 PDT
Ross Kirsling
Comment 2 2020-04-25 20:07:19 PDT
Yusuke Suzuki
Comment 3 2020-04-25 20:22:57 PDT
Comment on attachment 397606 [details] Patch r=me
EWS
Comment 4 2020-04-25 22:07:26 PDT
Committed r260722: <https://trac.webkit.org/changeset/260722> All reviewed patches have been landed. Closing bug and clearing flags on attachment 397606 [details].
Radar WebKit Bug Importer
Comment 5 2020-04-25 22:08:14 PDT
Darin Adler
Comment 6 2020-04-26 09:47:47 PDT
Two other thoughts: 1) Is there something analogous we should be doing with getConstructData? 2) Seems that getCallData could be changed to have a return value, instead of a return value plus two out arguments, and be renamed to callData. Could be more elegant and similar in performance, maybe better.
Alexey Shvayka
Comment 7 2020-04-26 11:16:39 PDT
(In reply to EWS from comment #4) > Committed r260722: <https://trac.webkit.org/changeset/260722> I really like this change, especially the usage of isFunction's fast path. Great job, Ross! We might also want to use isFunction() in JSObjectIsFunction() of JSObjectRef.cpp. (In reply to Darin Adler from comment #6) > 2) Seems that getCallData could be changed to have a return value, instead > of a return value plus two out arguments, and be renamed to callData. Could > be more elegant and similar in performance, maybe better. getCallData() seems to be nicely aligned with getConstructData(): they both return a value + one out argument. However, isConstructor() has an overload which returns a value + two out arguments, with only one call site. It would be nice to use getConstructData() instead.
Ross Kirsling
Comment 8 2020-04-26 13:42:28 PDT
I hadn't looked into getConstructData but I'll do so in a follow-up bug! (In reply to Alexey Shvayka from comment #7) > We might also want to use isFunction() in JSObjectIsFunction() of > JSObjectRef.cpp. Oops, yeah, that was an oversight on my part! Will add to the next patch.
Saam Barati
Comment 9 2020-04-28 09:12:31 PDT
Comment on attachment 397606 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=397606&action=review > Source/JavaScriptCore/ChangeLog:9 > + Where CallData is needed, getCallData should be used; where CallData is not needed, isFunction should be used. I’m not a fan of us having the “isFunction” name. I would’ve opted for isCallable everywhere. isFunction js ambiguous when I read it. E.g, Is it asking if it’s a JSFunction? All JSFunctions are callable, not all callable objects are JSFunctions
Saam Barati
Comment 10 2020-04-28 09:14:12 PDT
(In reply to Saam Barati from comment #9) > Comment on attachment 397606 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=397606&action=review > > > Source/JavaScriptCore/ChangeLog:9 > > + Where CallData is needed, getCallData should be used; where CallData is not needed, isFunction should be used. > > I’m not a fan of us having the “isFunction” name. I would’ve opted for > isCallable everywhere. isFunction js ambiguous when I read it. E.g, Is it > asking if it’s a JSFunction? > > All JSFunctions are callable, not all callable objects are JSFunctions Oops, I meant “is ambiguous”, not “js ambiguous”
Darin Adler
Comment 11 2020-04-28 10:14:34 PDT
I suggest using do-webcore-rename to rename isFunction to isCallable. There’s very little else besides the isFunction in JavaScriptCore to collide so it should be largely mechanical.
Ross Kirsling
Comment 12 2020-04-28 12:09:05 PDT
Yeah, I agree with that renaming direction. On the plus side, it'll be easier now that everything's clear-cut. Will open a new ticket shortly.
Note You need to log in before you can comment on or make changes to this bug.