Bug 118582

Summary: Introduce toHTMLVideoElement
Product: WebKit Reporter: Kangil Han <kangil.han>
Component: WebCore Misc.Assignee: Kangil Han <kangil.han>
Status: RESOLVED FIXED    
Severity: Normal CC: benjamin, buildbot, commit-queue, eric.carlson, esprehn+autocc, glenn, gyuyoung.kim, jer.noble, kling, koivisto, rniwa
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch none

Kangil Han
Reported 2013-07-11 19:10:02 PDT
Introduce isHTMLVideoElement and toHTMLVideoElement
Attachments
Patch (33.55 KB, patch)
2013-07-11 19:13 PDT, Kangil Han
no flags
Patch (9.32 KB, patch)
2013-07-13 23:13 PDT, Kangil Han
no flags
Kangil Han
Comment 1 2013-07-11 19:13:46 PDT
Build Bot
Comment 2 2013-07-11 19:38:08 PDT
Build Bot
Comment 3 2013-07-11 19:50:48 PDT
Kangil Han
Comment 4 2013-07-11 20:06:42 PDT
@kling: Would you please give me a hint how I can fix below build error? :) [Build error log] /Volumes/Data/EWS/WebKit/Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:71:9: fatal error: 'WebCore/HTMLVideoElement.h' file not found #import <WebCore/HTMLVideoElement.h> ^ 1 error generated.
Ryosuke Niwa
Comment 5 2013-07-11 20:09:04 PDT
Comment on attachment 206502 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=206502&action=review > Source/WebCore/html/HTMLVideoElement.h:109 > +inline bool isHTMLVideoElement(const Node* node) > +{ > + return node->hasTagName(HTMLNames::videoTag); > +} > + > +inline bool isHTMLVideoElement(const Element* element) > +{ > + return element->hasTagName(HTMLNames::videoTag); > +} I don't think adding these helper functions is a good idea. We don't do that for most of other elements at least. > Source/WebCore/html/HTMLVideoElement.h:115 > +inline HTMLVideoElement* toHTMLVideoElement(Node* node) > +{ > + ASSERT_WITH_SECURITY_IMPLICATION(!node || isHTMLVideoElement(node)); > + return static_cast<HTMLVideoElement*>(node); > +} We certainly do this.
Gyuyoung Kim
Comment 6 2013-07-11 23:01:18 PDT
Comment on attachment 206502 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=206502&action=review > Source/WebCore/html/HTMLVideoElement.h:106 > +inline bool isHTMLVideoElement(const Element* element) When I tried to add this function to svg, Benjamin and I noticed that we don't need to add this function. Is Element a child class which inherits Node ?
Kangil Han
Comment 7 2013-07-11 23:37:44 PDT
Hi rniwa! FOA, thx for the review. :) (In reply to comment #5) > (From update of attachment 206502 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=206502&action=review > > > Source/WebCore/html/HTMLVideoElement.h:109 > > +inline bool isHTMLVideoElement(const Node* node) > > +{ > > + return node->hasTagName(HTMLNames::videoTag); > > +} > > + > > +inline bool isHTMLVideoElement(const Element* element) > > +{ > > + return element->hasTagName(HTMLNames::videoTag); > > +} > > I don't think adding these helper functions is a good idea. > We don't do that for most of other elements at least. > I've adopted isFooElement for some time and several patches have been landed. Actually, introducing isFooElement and toFooElement are agreed with anttik and kling. Therefore, if you wouldn't have strong objection for this, I would like to proceed adoption in WebKit. :)
Kangil Han
Comment 8 2013-07-11 23:39:24 PDT
Hi gyuyoung! (In reply to comment #6) > (From update of attachment 206502 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=206502&action=review > > > Source/WebCore/html/HTMLVideoElement.h:106 > > +inline bool isHTMLVideoElement(const Element* element) > > When I tried to add this function to svg, Benjamin and I noticed that we don't need to add this function. Is Element a child class which inherits Node ? Node::hasTagName includes Node::isElementNode check and this is not necessary for Element. This is why we need overloading isFooElement(Element*) function. :)
Gyuyoung Kim
Comment 9 2013-07-12 00:10:18 PDT
(In reply to comment #8) > Hi gyuyoung! > > (In reply to comment #6) > > (From update of attachment 206502 [details] [details]) > > View in context: https://bugs.webkit.org/attachment.cgi?id=206502&action=review > > > > > Source/WebCore/html/HTMLVideoElement.h:106 > > > +inline bool isHTMLVideoElement(const Element* element) > > > > When I tried to add this function to svg, Benjamin and I noticed that we don't need to add this function. Is Element a child class which inherits Node ? > > Node::hasTagName includes Node::isElementNode check and this is not necessary for Element. This is why we need overloading isFooElement(Element*) function. :) Though I don't know how much we can get benefit from it, looks make sense to me. BTW, do you have any number about it ?
Kangil Han
Comment 10 2013-07-12 00:37:17 PDT
(In reply to comment #9) > > Though I don't know how much we can get benefit from it, looks make sense to me. BTW, do you have any number about it ? I don't have any profile data. :) But, I can tell you about review history on this. During isFooElement(Node*) adoption, anttik, kling and I had found a regression in code. [before] element->hasTagName(fooTag) [after] isFooElement(element) means, element->isElementNode() && element->hasTagName(fooTag) so redundant 'element->isElementNode()' call had happened. then, we've concluded to use isFooElement(Node*) and overloading isFooElement(Element*). That's where we are so far. ;)
Ryosuke Niwa
Comment 11 2013-07-12 00:39:35 PDT
Can't we auto-generate these is<tagName> functions instead?
Kangil Han
Comment 12 2013-07-12 01:41:51 PDT
(In reply to comment #11) > Can't we auto-generate these is<tagName> functions instead? Would you please point out an example for reference? :)
Ryosuke Niwa
Comment 13 2013-07-12 02:38:17 PDT
(In reply to comment #12) > (In reply to comment #11) > > Can't we auto-generate these is<tagName> functions instead? > > Would you please point out an example for reference? :) http://trac.webkit.org/browser/trunk/Source/WebCore/html/HTMLTagNames.in
Kangil Han
Comment 14 2013-07-13 23:07:11 PDT
Alright. :) Summing up, 1. toFooElement is recommended 2. isFooElement wouldn't be because every element cannot adopt this. Nevertheless, if we want, let's use automation like HTMLTagNames.in and I would like to focus what I can do now. So I am going to introduce toHTMLVideoElement in this bug and will do the same for other elements. During these introductions, I will think about necessity of isFooElement. :)
Kangil Han
Comment 15 2013-07-13 23:13:34 PDT
WebKit Commit Bot
Comment 16 2013-07-14 01:56:19 PDT
Comment on attachment 206625 [details] Patch Clearing flags on attachment: 206625 Committed r152614: <http://trac.webkit.org/changeset/152614>
WebKit Commit Bot
Comment 17 2013-07-14 01:56:23 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.