Bug 218381

Summary: [WTF] Coding style issues in MediaTime.h
Product: WebKit Reporter: Philippe Normand <pnormand>
Component: Web Template FrameworkAssignee: Philippe Normand <pnormand>
Status: NEW    
Severity: Normal CC: achristensen, benjamin, cdumez, cmarcelo, eric.carlson, ews-watchlist, glenn, jer.noble, philipj, sergio, 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=218228
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch achristensen: review+, achristensen: commit-queue-

Philippe Normand
Reported 2020-10-30 04:43:37 PDT
ERROR: Source/WTF/wtf/MediaTime.h:34: Alphabetical sorting problem. [build/include_order] [4] ERROR: Source/WTF/wtf/MediaTime.h:69: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:70: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:75: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:76: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:77: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:78: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:93: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:94: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:95: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:96: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:97: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:98: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:99: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fun ction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:100: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fu nction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:101: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fu nction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:109: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fu nction definition out-of-line. [build/webcore_export] [4] ERROR: Source/WTF/wtf/MediaTime.h:110: Inline functions should not be in classes annotated with WTF_EXPORT_PRIVATE. Remove the macro from the class and apply it to each appropriate method, or move the inline fu nction definition out-of-line. [build/webcore_export] [4]
Attachments
Patch (7.50 KB, patch)
2020-10-30 04:51 PDT, Philippe Normand
no flags
Patch (5.79 KB, patch)
2020-11-16 02:27 PST, Philippe Normand
no flags
Patch (9.01 KB, patch)
2020-11-16 05:08 PST, Philippe Normand
no flags
Patch (8.84 KB, patch)
2020-11-16 10:39 PST, Philippe Normand
achristensen: review+
achristensen: commit-queue-
Philippe Normand
Comment 1 2020-10-30 04:51:16 PDT
Yusuke Suzuki
Comment 2 2020-10-30 21:03:10 PDT
Comment on attachment 412731 [details] Patch I think these functions are small and should be inline function. So defining in the header is better. Let's remove WTF_EXPORT_PRIVATE from the class, and annotate some of actually exported functions with WTF_EXPORT_PRIVATE.
Radar WebKit Bug Importer
Comment 3 2020-11-06 03:44:16 PST
Philippe Normand
Comment 4 2020-11-16 02:27:21 PST
Philippe Normand
Comment 5 2020-11-16 02:28:13 PST
(In reply to Yusuke Suzuki from comment #2) > Comment on attachment 412731 [details] > Patch > > I think these functions are small and should be inline function. So defining > in the header is better. Let's remove WTF_EXPORT_PRIVATE from the class, and > annotate some of actually exported functions with WTF_EXPORT_PRIVATE. Thanks for the review Yusuke, the patch is updated accordingly, hopefully :)
Philippe Normand
Comment 6 2020-11-16 05:08:47 PST
Alex Christensen
Comment 7 2020-11-16 10:21:52 PST
Comment on attachment 414216 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=414216&action=review > Source/WTF/wtf/MediaTime.h:68 > + inline MediaTime& operator+=(const MediaTime& rhs) { return *this = *this + rhs; } I don't think the "inline" keyword is needed here
Philippe Normand
Comment 8 2020-11-16 10:39:46 PST
Alex Christensen
Comment 9 2020-11-16 11:06:19 PST
Comment on attachment 414252 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=414252&action=review > Source/WTF/wtf/MediaTime.h:74 > + inline bool operator<(const MediaTime& rhs) const { return compare(rhs) == LessThan; } here either. > Source/WTF/wtf/MediaTime.h:92 > + inline bool isValid() const { return m_timeFlags & Valid; } ditto > Source/WTF/wtf/MediaTime.h:107 > + inline const int64_t& timeValue() const { return m_timeValue; } ditto
Philippe Normand
Comment 10 2020-11-17 04:19:28 PST
If no inline specifier remains in this patch I'm not sure why Yusuke r-'ed the initial patch.
Yusuke Suzuki
Comment 11 2020-12-02 16:59:00 PST
(In reply to Philippe Normand from comment #10) > If no inline specifier remains in this patch I'm not sure why Yusuke r-'ed > the initial patch. In C++, inline attribute is not for inlining. If you define function in header, compiler will decide whether inlines or not regardless of inline attribute is attached or not. But unless LTO is enabled (WTF / JSC is not LTO enabled for now), function defined in cpp will not be inlined. So the patch should define function in header, and inline attribute is not necessary.
Note You need to log in before you can comment on or make changes to this bug.