RESOLVED FIXED 140347
Make 'TypeName' parameter unnecessary in CSSPropertyNames.in
https://bugs.webkit.org/show_bug.cgi?id=140347
Summary Make 'TypeName' parameter unnecessary in CSSPropertyNames.in
Chris Dumez
Reported 2015-01-11 21:57:50 PST
Make 'TypeName' parameter unnecessary in CSSPropertyNames.in.
Attachments
Patch (54.62 KB, patch)
2015-01-11 22:11 PST, Chris Dumez
no flags
Patch (59.71 KB, patch)
2015-01-12 17:21 PST, Chris Dumez
no flags
Patch (59.72 KB, patch)
2015-01-12 17:26 PST, Chris Dumez
no flags
Patch (60.26 KB, patch)
2015-01-12 18:52 PST, Chris Dumez
no flags
Patch (59.73 KB, patch)
2015-01-12 18:56 PST, Chris Dumez
no flags
Patch (54.56 KB, patch)
2015-01-13 12:41 PST, Chris Dumez
no flags
Patch (54.32 KB, patch)
2015-01-13 15:58 PST, Chris Dumez
no flags
Chris Dumez
Comment 1 2015-01-11 22:11:04 PST
Darin Adler
Comment 2 2015-01-12 08:20:31 PST
Comment on attachment 244431 [details] Patch Here are the Windows build errors: 1>C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\include\private\wtf/Optional.h(176): error C2621: 'WTF::Optional<WebCore::GridTrackSize>::m_value' : illegal union member; type 'WebCore::GridTrackSize' has a copy constructor (C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\obj32\WebCore\DerivedSources\StyleBuilder.cpp) C:\cygwin\home\buildbot\WebKit\Source\WebCore\css\StyleBuilderConverter.h(911) : see reference to class template instantiation 'WTF::Optional<WebCore::GridTrackSize>' being compiled 1>C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\include\private\wtf/Optional.h(177): warning C4408: anonymous union did not declare any data members (C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\obj32\WebCore\DerivedSources\StyleBuilder.cpp) 1>C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\include\private\wtf/Optional.h(176): error C2621: 'WTF::Optional<WebCore::GridPosition>::m_value' : illegal union member; type 'WebCore::GridPosition' has a copy constructor (C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\obj32\WebCore\DerivedSources\StyleBuilder.cpp) C:\cygwin\home\buildbot\WebKit\Source\WebCore\css\StyleBuilderConverter.h(920) : see reference to class template instantiation 'WTF::Optional<WebCore::GridPosition>' being compiled 1>C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\include\private\wtf/Optional.h(176): error C2621: 'WTF::Optional<WebCore::Length>::m_value' : illegal union member; type 'WebCore::Length' has a copy constructor (C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\obj32\WebCore\DerivedSources\StyleBuilder.cpp) C:\cygwin\home\buildbot\WebKit\Source\WebCore\css\StyleBuilderConverter.h(969) : see reference to class template instantiation 'WTF::Optional<WebCore::Length>' being compiled 1>C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\include\private\wtf/Optional.h(176): error C2621: 'WTF::Optional<WebCore::FilterOperations>::m_value' : illegal union member; type 'WebCore::FilterOperations' has a copy constructor (C:\cygwin\home\buildbot\WebKit\WebKitBuild\Release\obj32\WebCore\DerivedSources\StyleBuilder.cpp) C:\cygwin\home\buildbot\WebKit\Source\WebCore\css\StyleBuilderConverter.h(1033) : see reference to class template instantiation 'WTF::Optional<WebCore::FilterOperations>' being compiled Looks like WTF::Optional doesn’t work well with the Visual Studio compiler. I wonder how this can be fixed.
Anders Carlsson
Comment 3 2015-01-12 08:28:54 PST
(In reply to comment #2) > > Looks like WTF::Optional doesn’t work well with the Visual Studio compiler. > I wonder how this can be fixed. Looks like it's because VS doesn't support unrestricted unions?
Chris Dumez
Comment 4 2015-01-12 09:52:13 PST
(In reply to comment #3) > (In reply to comment #2) > > > > Looks like WTF::Optional doesn’t work well with the Visual Studio compiler. > > I wonder how this can be fixed. > > Looks like it's because VS doesn't support unrestricted unions? Indeed, unrestricted union are still not supported by Visual studio according to: http://msdn.microsoft.com/en-us/library/hh567368.aspx
Chris Dumez
Comment 5 2015-01-12 10:28:58 PST
(In reply to comment #4) > (In reply to comment #3) > > (In reply to comment #2) > > > > > > Looks like WTF::Optional doesn’t work well with the Visual Studio compiler. > > > I wonder how this can be fixed. > > > > Looks like it's because VS doesn't support unrestricted unions? > > Indeed, unrestricted union are still not supported by Visual studio > according to: > http://msdn.microsoft.com/en-us/library/hh567368.aspx Maybe we can use std::aligned_storage? This seems to be what boost is using for boost::optional.
Anders Carlsson
Comment 6 2015-01-12 10:33:15 PST
(In reply to comment #5) > (In reply to comment #4) > > (In reply to comment #3) > > > (In reply to comment #2) > > > > > > > > Looks like WTF::Optional doesn’t work well with the Visual Studio compiler. > > > > I wonder how this can be fixed. > > > > > > Looks like it's because VS doesn't support unrestricted unions? > > > > Indeed, unrestricted union are still not supported by Visual studio > > according to: > > http://msdn.microsoft.com/en-us/library/hh567368.aspx > > Maybe we can use std::aligned_storage? This seems to be what boost is using > for boost::optional. Yup, aligned_storage + placement new, just like NeverDestroyed does.
Chris Dumez
Comment 7 2015-01-12 12:29:50 PST
Comment on attachment 244431 [details] Patch I am working on fixing the MSVC build by using aligned_storage + placement new, instead of an unrestricted union in Optional.h.
Chris Dumez
Comment 8 2015-01-12 17:21:33 PST
Chris Dumez
Comment 9 2015-01-12 17:26:04 PST
Chris Dumez
Comment 10 2015-01-12 18:52:00 PST
Chris Dumez
Comment 11 2015-01-12 18:56:52 PST
Chris Dumez
Comment 12 2015-01-12 19:56:15 PST
Comment on attachment 244487 [details] Patch green bubbles!
Chris Dumez
Comment 13 2015-01-13 11:57:51 PST
Chris Dumez
Comment 14 2015-01-13 12:41:46 PST
Chris Dumez
Comment 15 2015-01-13 13:59:29 PST
Comment on attachment 244536 [details] Patch The dependency has landed, the patch is ready for review.
Sam Weinig
Comment 16 2015-01-13 15:19:19 PST
Comment on attachment 244536 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=244536&action=review > Source/WebCore/css/StyleBuilderConverter.h:916 > + Optional<GridTrackSize> optionalTrackSize; > + GridTrackSize trackSize; > + if (createGridTrackSize(value, trackSize, styleResolver)) > + optionalTrackSize = trackSize; > + return optionalTrackSize; I prefer to structure this type of thing like: { GridTrackSize trackSize; if (createGridTrackSize(value, trackSize, styleResolver)) return trackSize; return Nullopt; }
Chris Dumez
Comment 17 2015-01-13 15:58:34 PST
Chris Dumez
Comment 18 2015-01-13 15:58:58 PST
(In reply to comment #16) > Comment on attachment 244536 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=244536&action=review > > > Source/WebCore/css/StyleBuilderConverter.h:916 > > + Optional<GridTrackSize> optionalTrackSize; > > + GridTrackSize trackSize; > > + if (createGridTrackSize(value, trackSize, styleResolver)) > > + optionalTrackSize = trackSize; > > + return optionalTrackSize; > > I prefer to structure this type of thing like: > { > GridTrackSize trackSize; > if (createGridTrackSize(value, trackSize, styleResolver)) > return trackSize; > return Nullopt; > } Done.
Darin Adler
Comment 19 2015-01-14 11:31:28 PST
Comment on attachment 244559 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=244559&action=review > Source/WebCore/css/StyleBuilderConverter.h:1006 > marqueeLength = Length(1, Fixed); // 1px. > - return true; > + break; I think these would read better as return statements instead of assignment with a break; it’s sort of the switch version of our “early return”. Might be nice to come back and clean that up even after landing this patch. > Source/WebCore/css/StyleBuilderConverter.h:1030 > + if (styleResolver.createFilterOperations(value, operations)) > + return operations; > + return Nullopt; I know Sam asked you to write it this way. I like it the opposite way with the early return for the error case. if (!x) return Nullopt. Others have told me this is not good for optimizers that like to predict that branches *are* taken, but I like the pattern where the success path and main logic is the main flow of the function and the failures or optimized cases are earlier drains.
WebKit Commit Bot
Comment 20 2015-01-14 12:11:43 PST
Comment on attachment 244559 [details] Patch Clearing flags on attachment: 244559 Committed r178434: <http://trac.webkit.org/changeset/178434>
WebKit Commit Bot
Comment 21 2015-01-14 12:11:52 PST
All reviewed patches have been landed. Closing bug.
Csaba Osztrogonác
Comment 22 2015-01-14 14:47:12 PST
Comment on attachment 244559 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=244559&action=review > Source/WebCore/css/StyleBuilderConverter.h:996 > + return perspective < 0 ? Nullopt : perspective; It broke the EFL build, but unfortunately you didn't have any chance to catch it before landing, because EFL EWS is offline long time ago. :( In file included from DerivedSources/WebCore/StyleBuilder.cpp:9:0: ../../Source/WebCore/css/StyleBuilderConverter.h: In static member function ‘static WTF::Optional<float> WebCore::StyleBuilderConverter::convertPerspective(WebCore::StyleResolver&, WebCore::CSSValue&)’: ../../Source/WebCore/css/StyleBuilderConverter.h:996:40: error: enumeral and non-enumeral type in conditional expression [-Werror] return perspective < 0 ? Nullopt : perspective; ^ cc1plus: all warnings being treated as errors I filed a new bug report to fix it: bug140467
Sam Weinig
Comment 23 2015-01-15 12:54:30 PST
(In reply to comment #19) > Comment on attachment 244559 [details] > > > Source/WebCore/css/StyleBuilderConverter.h:1030 > > + if (styleResolver.createFilterOperations(value, operations)) > > + return operations; > > + return Nullopt; > > I know Sam asked you to write it this way. I like it the opposite way with > the early return for the error case. if (!x) return Nullopt. Others have > told me this is not good for optimizers that like to predict that branches > *are* taken, but I like the pattern where the success path and main logic is > the main flow of the function and the failures or optimized cases are > earlier drains. The part I was really trying to comment on was the direct returning of Nullopt and the value, and avoiding the Optional<> local. I also tend to prefer the early return for the error case.
Note You need to log in before you can comment on or make changes to this bug.