RESOLVED FIXED 183357
[WTF] Set canInitializeWithMemset = true if T is an integral type
https://bugs.webkit.org/show_bug.cgi?id=183357
Summary [WTF] Set canInitializeWithMemset = true if T is an integral type
Yusuke Suzuki
Reported 2018-03-05 23:55:18 PST
[WTF] Set canInitializeWithMemset = true if T is an integral type
Attachments
Patch (7.09 KB, patch)
2018-03-06 00:15 PST, Yusuke Suzuki
no flags
Archive of layout-test-results from ews206 for win-future (12.01 MB, application/zip)
2018-03-06 02:40 PST, EWS Watchlist
no flags
Patch (7.09 KB, patch)
2018-03-06 08:25 PST, Yusuke Suzuki
darin: review+
Yusuke Suzuki
Comment 1 2018-03-06 00:15:02 PST
EWS Watchlist
Comment 2 2018-03-06 02:40:22 PST
Comment on attachment 335071 [details] Patch Attachment 335071 [details] did not pass win-ews (win): Output: http://webkit-queues.webkit.org/results/6822587 New failing tests: http/tests/preload/download_resources.html
EWS Watchlist
Comment 3 2018-03-06 02:40:33 PST
Created attachment 335079 [details] Archive of layout-test-results from ews206 for win-future The attached test failures were seen while running run-webkit-tests on the win-ews. Bot: ews206 Port: win-future Platform: CYGWIN_NT-6.1-2.9.0-0.318-5-3-x86_64-64bit
Yusuke Suzuki
Comment 4 2018-03-06 08:25:51 PST
Darin Adler
Comment 5 2018-03-07 20:07:57 PST
Comment on attachment 335098 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=335098&action=review > Source/WTF/wtf/Vector.h:71 > + static void initializeIfNecessary(T*, T*) { } I am not sure what "if necessary" means here. I think a C++ expert would call this initializeUnlessConstructorIsTrivial or initializeIfConstructorIsNonTrivial. > Source/WTF/wtf/VectorTraits.h:52 > + static const bool canInitializeWithMemset = std::is_integral<T>::value; Why can’t we just set this to true? Are there types that return true for is_pod and can’t be initialized with memset?
Yusuke Suzuki
Comment 6 2018-03-07 22:38:29 PST
Comment on attachment 335098 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=335098&action=review >> Source/WTF/wtf/Vector.h:71 >> + static void initializeIfNecessary(T*, T*) { } > > I am not sure what "if necessary" means here. I think a C++ expert would call this initializeUnlessConstructorIsTrivial or initializeIfConstructorIsNonTrivial. Our Vector<> intentionally does not initialize backing store if T is POD (this is described in Vector.h constructor). This `initializeIfNecessary()` does that: do not initialize if T is POD. `initializeIfNonPOD` would be fine I think. changed. >> Source/WTF/wtf/VectorTraits.h:52 >> + static const bool canInitializeWithMemset = std::is_integral<T>::value; > > Why can’t we just set this to true? Are there types that return true for is_pod and can’t be initialized with memset? I think it is OK: even `double` can be initialized with 0. Changed.
Yusuke Suzuki
Comment 7 2018-03-07 22:44:48 PST
Radar WebKit Bug Importer
Comment 8 2018-03-08 09:29:08 PST
Radar WebKit Bug Importer
Comment 9 2018-03-08 09:29:08 PST
Note You need to log in before you can comment on or make changes to this bug.