Bug 144905

Summary: Purge PassRefPtr create() factory functions in WebCore/css
Product: WebKit Reporter: Joonghun Park <jh718.park>
Component: WebCore Misc.Assignee: Joonghun Park <jh718.park>
Status: RESOLVED FIXED    
Severity: Normal CC: buildbot, commit-queue, darin, gyuyoung.kim, ossy, rniwa, zan
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 144092    
Attachments:
Description Flags
<WIP>
none
Patch
none
Patch
none
Patch
none
Patch
none
<WIP>
none
Patch
none
Patch
none
<WIP> only first and last comment have been addressed in this patch
none
Patch
none
Patch
none
Archive of layout-test-results from ews100 for mac-mavericks
none
Archive of layout-test-results from ews107 for mac-mavericks-wk2
none
Patch
none
Patch none

Joonghun Park
Reported 2015-05-12 00:15:57 PDT
Return Ref instead of PassRefPtr in create() factory functions in html, because the factory can't return null.
Attachments
<WIP> (44.85 KB, patch)
2015-05-12 06:56 PDT, Joonghun Park
no flags
Patch (52.48 KB, patch)
2015-05-12 20:43 PDT, Joonghun Park
no flags
Patch (53.28 KB, patch)
2015-05-12 21:12 PDT, Joonghun Park
no flags
Patch (53.08 KB, patch)
2015-05-12 21:33 PDT, Joonghun Park
no flags
Patch (53.46 KB, patch)
2015-05-12 22:14 PDT, Joonghun Park
no flags
<WIP> (53.64 KB, patch)
2015-05-13 17:10 PDT, Joonghun Park
no flags
Patch (54.35 KB, patch)
2015-05-13 20:44 PDT, Joonghun Park
no flags
Patch (54.35 KB, patch)
2015-05-13 21:07 PDT, Joonghun Park
no flags
<WIP> only first and last comment have been addressed in this patch (122.99 KB, patch)
2015-05-27 17:25 PDT, Joonghun Park
no flags
Patch (123.57 KB, patch)
2015-05-28 00:39 PDT, Joonghun Park
no flags
Patch (124.93 KB, patch)
2015-05-28 05:48 PDT, Joonghun Park
no flags
Archive of layout-test-results from ews100 for mac-mavericks (560.75 KB, application/zip)
2015-05-28 06:54 PDT, Build Bot
no flags
Archive of layout-test-results from ews107 for mac-mavericks-wk2 (591.72 KB, application/zip)
2015-05-28 07:01 PDT, Build Bot
no flags
Patch (126.22 KB, patch)
2015-05-30 22:29 PDT, Joonghun Park
no flags
Patch (126.25 KB, patch)
2015-06-02 14:33 PDT, Joonghun Park
no flags
Joonghun Park
Comment 1 2015-05-12 06:56:47 PDT
Joonghun Park
Comment 2 2015-05-12 20:43:54 PDT
Joonghun Park
Comment 3 2015-05-12 21:12:48 PDT
Joonghun Park
Comment 4 2015-05-12 21:33:57 PDT
Darin Adler
Comment 5 2015-05-12 21:39:01 PDT
Comment on attachment 253016 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253016&action=review > Source/WebCore/css/CSSPrimitiveValue.h:394 > + CSSPrimitiveValue::CSSPrimitiveValue(DashboardRegion*) Need to remove the CSSPrimitiveValue:: prefix here.
Joonghun Park
Comment 6 2015-05-12 21:43:56 PDT
(In reply to comment #5) > Comment on attachment 253016 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253016&action=review > > > Source/WebCore/css/CSSPrimitiveValue.h:394 > > + CSSPrimitiveValue::CSSPrimitiveValue(DashboardRegion*) > > Need to remove the CSSPrimitiveValue:: prefix here. Oh, I missed it. Thank you for your comment :)
Joonghun Park
Comment 7 2015-05-12 22:14:28 PDT
Joonghun Park
Comment 8 2015-05-13 17:10:31 PDT
Joonghun Park
Comment 9 2015-05-13 20:44:15 PDT
Joonghun Park
Comment 10 2015-05-13 21:07:46 PDT
Darin Adler
Comment 11 2015-05-17 11:03:47 PDT
Comment on attachment 253092 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253092&action=review review- because the CSSPrimitiveValue part seems wrong; otherwise all looks fine > Source/WebCore/css/BasicShapeFunctions.cpp:52 > +static RefPtr<CSSPrimitiveValue> basicShapeRadiusToCSSValue(const RenderStyle* style, CSSValuePool& pool, const BasicShapeRadius& radius) Seems like this should return Ref. The failure case that currently returns null could and should be changed to return another value. Callers can’t handle null! Also seems that the style argument should be changed to a reference rather than a pointer. > Source/WebCore/css/CSSPrimitiveValue.h:42 > +#if ENABLE(DASHBOARD_SUPPORT) > class DashboardRegion; > +#endif Please don’t do this. It’s OK to forward declare this even if it’s not used. If you did want to make it conditional we’d move it to a separate paragraph. > Source/WebCore/css/CSSPrimitiveValue.h:393 > + init(Ref<T>(*val)); What guarantees the pointer is non-null here? We can’t just do a * on a pointer that might be null. > Source/WebCore/css/CSSPrimitiveValue.h:400 > + CSSPrimitiveValue(CSSBasicShape*); > + CSSPrimitiveValue(CSSCalcValue*); > +#if ENABLE(DASHBOARD_SUPPORT) > + CSSPrimitiveValue(DashboardRegion*); > +#endif Why are these needed? I think this is a bad idea. > Source/WebCore/css/CSSPrimitiveValue.h:428 > + void init(RefPtr<DashboardRegion>&&); // FIXME: Dashboard region should not be a primitive value. Why RefPtr instead of Ref? Do callers really need to do this with null? > Source/WebCore/css/CSSPrimitiveValue.h:431 > + void init(RefPtr<CSSBasicShape>&&); > + void init(RefPtr<CSSCalcValue>&&); Why RefPtr instead of Ref? Do callers really need to do this with null? > Source/WebCore/css/CSSPrimitiveValue.h:457 > +#if ENABLE(DASHBOARD_SUPPORT) > DashboardRegion* region; > +#endif I don’t think this is an improvement. Lets go a little lighter on the #if here, unless you are sure we should do it. I think it does no harm to compile this on platforms that don’t support it. > Source/WebCore/css/FontLoader.cpp:53 > + return adoptRef<LoadFontCallback>(*new LoadFontCallback(numLoading, fontLoader, loadCallback, errorCallback)); I don’t understand the use of adoptRef<LoadFontCallback> here. Should just be adoptRef with no <> after it.
Joonghun Park
Comment 12 2015-05-27 17:25:12 PDT
Created attachment 253822 [details] <WIP> only first and last comment have been addressed in this patch
Joonghun Park
Comment 13 2015-05-28 00:27:28 PDT
(In reply to comment #11) > Comment on attachment 253092 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253092&action=review > > review- because the CSSPrimitiveValue part seems wrong; otherwise all looks > fine > > > Source/WebCore/css/BasicShapeFunctions.cpp:52 > > +static RefPtr<CSSPrimitiveValue> basicShapeRadiusToCSSValue(const RenderStyle* style, CSSValuePool& pool, const BasicShapeRadius& radius) > > Seems like this should return Ref. The failure case that currently returns > null could and should be changed to return another value. Callers can’t > handle null! Also seems that the style argument should be changed to a > reference rather than a pointer. > I changed this to Ref. And let default return be pool.createIdentifierValue(CSSValueClosestSide). I'm not sure this is right decision. > > Source/WebCore/css/CSSPrimitiveValue.h:42 > > +#if ENABLE(DASHBOARD_SUPPORT) > > class DashboardRegion; > > +#endif > > Please don’t do this. It’s OK to forward declare this even if it’s not used. > If you did want to make it conditional we’d move it to a separate paragraph. > I removed #if directive as you said because it is not necessary. > > Source/WebCore/css/CSSPrimitiveValue.h:393 > > + init(Ref<T>(*val)); > > What guarantees the pointer is non-null here? We can’t just do a * on a > pointer that might be null. > About this, I don't have a good idea. I just added a null check to this, but it doesn't seem right. Do you have any advice? > > Source/WebCore/css/CSSPrimitiveValue.h:400 > > + CSSPrimitiveValue(CSSBasicShape*); > > + CSSPrimitiveValue(CSSCalcValue*); > > +#if ENABLE(DASHBOARD_SUPPORT) > > + CSSPrimitiveValue(DashboardRegion*); > > +#endif > > Why are these needed? I think this is a bad idea. > I removed other things except CSSPrimitveValue(CSSCalcValue*), because without this one, 'error: call of overloaded ‘init(WTF::Ref<WebCore::CSSCalcValue>)’ is ambiguous' occurs. > > Source/WebCore/css/CSSPrimitiveValue.h:428 > > + void init(RefPtr<DashboardRegion>&&); // FIXME: Dashboard region should not be a primitive value. > > Why RefPtr instead of Ref? Do callers really need to do this with null? > I changed this one with Ref according to your comment. > > Source/WebCore/css/CSSPrimitiveValue.h:431 > > + void init(RefPtr<CSSBasicShape>&&); > > + void init(RefPtr<CSSCalcValue>&&); > > Why RefPtr instead of Ref? Do callers really need to do this with null? > I changed this one with Ref according to your comment. > > Source/WebCore/css/CSSPrimitiveValue.h:457 > > +#if ENABLE(DASHBOARD_SUPPORT) > > DashboardRegion* region; > > +#endif > > I don’t think this is an improvement. Lets go a little lighter on the #if > here, unless you are sure we should do it. I think it does no harm to > compile this on platforms that don’t support it. > As you said, I removed this unnecessary guard. > > Source/WebCore/css/FontLoader.cpp:53 > > + return adoptRef<LoadFontCallback>(*new LoadFontCallback(numLoading, fontLoader, loadCallback, errorCallback)); > > I don’t understand the use of adoptRef<LoadFontCallback> here. Should just > be adoptRef with no <> after it. I revised this one.
Joonghun Park
Comment 14 2015-05-28 00:39:16 PDT
Joonghun Park
Comment 15 2015-05-28 05:48:04 PDT
Build Bot
Comment 16 2015-05-28 06:53:57 PDT
Comment on attachment 253843 [details] Patch Attachment 253843 [details] did not pass mac-ews (mac): Output: http://webkit-queues.appspot.com/results/6173793483489280 New failing tests: fast/css/large-value-csstext.html
Build Bot
Comment 17 2015-05-28 06:54:00 PDT
Created attachment 253844 [details] Archive of layout-test-results from ews100 for mac-mavericks The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews100 Port: mac-mavericks Platform: Mac OS X 10.9.5
Build Bot
Comment 18 2015-05-28 07:00:50 PDT
Comment on attachment 253843 [details] Patch Attachment 253843 [details] did not pass mac-wk2-ews (mac-wk2): Output: http://webkit-queues.appspot.com/results/6116746251468800 New failing tests: fast/css/large-value-csstext.html
Build Bot
Comment 19 2015-05-28 07:01:23 PDT
Created attachment 253845 [details] Archive of layout-test-results from ews107 for mac-mavericks-wk2 The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews. Bot: ews107 Port: mac-mavericks-wk2 Platform: Mac OS X 10.9.5
Darin Adler
Comment 20 2015-05-28 13:01:15 PDT
Comment on attachment 253843 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253843&action=review > Source/WebCore/css/BasicShapeFunctions.cpp:63 > - ASSERT_NOT_REACHED(); > - return 0; > + return pool.createIdentifierValue(CSSValueClosestSide); Should not delete the ASSERT_NOT_REACHED. > Source/WebCore/css/BasicShapeFunctions.cpp:74 > - RefPtr<CSSBasicShapeCircle> circleValue = CSSBasicShapeCircle::create(); > + Ref<CSSBasicShapeCircle> circleValue = CSSBasicShapeCircle::create(); Maybe auto instead of writing out the type? > Source/WebCore/css/BasicShapeFunctions.cpp:84 > - RefPtr<CSSBasicShapeEllipse> ellipseValue = CSSBasicShapeEllipse::create(); > + Ref<CSSBasicShapeEllipse> ellipseValue = CSSBasicShapeEllipse::create(); Maybe auto instead of writing out the type? > Source/WebCore/css/BasicShapeFunctions.cpp:95 > - RefPtr<CSSBasicShapePolygon> polygonValue = CSSBasicShapePolygon::create(); > + Ref<CSSBasicShapePolygon> polygonValue = CSSBasicShapePolygon::create(); Maybe auto instead of writing out the type? > Source/WebCore/css/BasicShapeFunctions.cpp:126 > + return pool.createValue(basicShapeValue.releaseNonNull()); This is wrong. If we hit the default case above then basicShapeValue is null. Really need to fix that. > Source/WebCore/css/CSSComputedStyleDeclaration.cpp:1956 > + return fillSizeToCSSValue(layers->size(), *style.get()); No need for the ".get()" here. Same for all the other sites below! > Source/WebCore/css/CSSParser.cpp:5604 > Blank line here seems out of place (between declaration and initialization of lineNames). > Source/WebCore/css/CSSParser.cpp:5605 > + if (previousNamedAreaTrailingLineNames != nullptr) WebKit coding style says you just do: if (previousNamedAreaTrailingLineNames) > Source/WebCore/css/CSSPrimitiveValue.cpp:240 > +CSSPrimitiveValue::CSSPrimitiveValue(CSSCalcValue* val) Please use the name "value", not "val". > Source/WebCore/css/CSSPrimitiveValue.cpp:316 > + RefPtr<CSSCalcValue> calcValue = CSSCalcValue::create(length.calculationValue(), style); > + init(WTF::move(calcValue)); This would read better without the local variable and you could remove the braces too. > Source/WebCore/css/CSSPrimitiveValue.h:392 > + if (!val) > + init(Ref<T>(*val)); This looks like it will break everything; I bet it’s why tests are failing! I think you mean if (val). But also is this behavior OK for null pointers. > Source/WebCore/css/CSSPrimitiveValue.h:395 > + CSSPrimitiveValue(CSSCalcValue*); Pretty messy. Maybe we can change this at the call site to use Ref or RefPtr rather than a raw pointer.
Joonghun Park
Comment 21 2015-05-30 21:33:05 PDT
(In reply to comment #20) > Comment on attachment 253843 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253843&action=review > > > Source/WebCore/css/BasicShapeFunctions.cpp:63 > > - ASSERT_NOT_REACHED(); > > - return 0; > > + return pool.createIdentifierValue(CSSValueClosestSide); > > Should not delete the ASSERT_NOT_REACHED. > I readded ASSERT_NOT_REACHED here. > > Source/WebCore/css/BasicShapeFunctions.cpp:74 > > - RefPtr<CSSBasicShapeCircle> circleValue = CSSBasicShapeCircle::create(); > > + Ref<CSSBasicShapeCircle> circleValue = CSSBasicShapeCircle::create(); > > Maybe auto instead of writing out the type? > I changed the type as auto instead. > > Source/WebCore/css/BasicShapeFunctions.cpp:84 > > - RefPtr<CSSBasicShapeEllipse> ellipseValue = CSSBasicShapeEllipse::create(); > > + Ref<CSSBasicShapeEllipse> ellipseValue = CSSBasicShapeEllipse::create(); > > Maybe auto instead of writing out the type? > ditto. > > Source/WebCore/css/BasicShapeFunctions.cpp:95 > > - RefPtr<CSSBasicShapePolygon> polygonValue = CSSBasicShapePolygon::create(); > > + Ref<CSSBasicShapePolygon> polygonValue = CSSBasicShapePolygon::create(); > > Maybe auto instead of writing out the type? > ditto. > > Source/WebCore/css/BasicShapeFunctions.cpp:126 > > + return pool.createValue(basicShapeValue.releaseNonNull()); > > This is wrong. If we hit the default case above then basicShapeValue is > null. Really need to fix that. > It seems that Ref<BasicShape> basicShapeForValue(); function is implemented as same as this one because CSSBasicShape is abstract class and type() is pure virtual. This is the same for BasicShape class too. For readability it could be an option to add ASSERT_NOT_REACHED in default in both basicShapeForValue() and valueForBasicShape(). But by releaseNonNull(), null check assert is already being done, so it doesn't seems to be necessary. > > Source/WebCore/css/CSSComputedStyleDeclaration.cpp:1956 > > + return fillSizeToCSSValue(layers->size(), *style.get()); > > No need for the ".get()" here. Same for all the other sites below! > Ah, truly it is :) Thank you for your pointing out. > > Source/WebCore/css/CSSParser.cpp:5604 > > > > Blank line here seems out of place (between declaration and initialization > of lineNames). > I removed this unnecessary blank line. > > Source/WebCore/css/CSSParser.cpp:5605 > > + if (previousNamedAreaTrailingLineNames != nullptr) > > WebKit coding style says you just do: > > if (previousNamedAreaTrailingLineNames) > I revised this one as you commented. > > Source/WebCore/css/CSSPrimitiveValue.cpp:240 > > +CSSPrimitiveValue::CSSPrimitiveValue(CSSCalcValue* val) > > Please use the name "value", not "val". > I removed ctor CSSPrimitiveValue(T* value) for now, because it is being used no more, and I was not sure just adding if (val) is right behavior, as you commented also. > > Source/WebCore/css/CSSPrimitiveValue.cpp:316 > > + RefPtr<CSSCalcValue> calcValue = CSSCalcValue::create(length.calculationValue(), style); > > + init(WTF::move(calcValue)); > > This would read better without the local variable and you could remove the > braces too. > I revised this one as you commented. > > Source/WebCore/css/CSSPrimitiveValue.h:392 > > + if (!val) > > + init(Ref<T>(*val)); > > This looks like it will break everything; I bet it’s why tests are failing! > I think you mean if (val). But also is this behavior OK for null pointers. > For now I removed this ctor as I wrote above. > > Source/WebCore/css/CSSPrimitiveValue.h:395 > > + CSSPrimitiveValue(CSSCalcValue*); > > Pretty messy. Maybe we can change this at the call site to use Ref or RefPtr > rather than a raw pointer. I revised the callsites to use Ref or RefPtr instead of raw pointers.
Joonghun Park
Comment 22 2015-05-30 22:29:22 PDT
Darin Adler
Comment 23 2015-06-01 10:08:32 PDT
Comment on attachment 253971 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=253971&action=review > Source/WebCore/css/CSSComputedStyleDeclaration.cpp:2744 > - return cssValuePool().createValue(firstRegion.release()); > + return cssValuePool().createValue(firstRegion.releaseNonNull()); I don’t see a guarantee here that there is a firstRegion. Can’t count be zero? I’m talking about a runtime problem here, not an assertion. Naturally releaseNonNull will assert, but I am talking about in production without assertions present to inform us. > Source/WebCore/css/CSSPrimitiveValue.h:418 > + void init(RefPtr<CSSCalcValue>&&); Need to explain why this one is a RefPtr instead of a Ref.
Joonghun Park
Comment 24 2015-06-02 14:24:13 PDT
(In reply to comment #23) > Comment on attachment 253971 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=253971&action=review > > > Source/WebCore/css/CSSComputedStyleDeclaration.cpp:2744 > > - return cssValuePool().createValue(firstRegion.release()); > > + return cssValuePool().createValue(firstRegion.releaseNonNull()); > > I don’t see a guarantee here that there is a firstRegion. Can’t count be > zero? > As you pointing out, it seems that if getPropertyValue is called when dashboardRegion was not being set, count can be zero. So I revised init parameter type to RefPtr<DashboardRegion>&&. > I’m talking about a runtime problem here, not an assertion. Naturally > releaseNonNull will assert, but I am talking about in production without > assertions present to inform us. > > > Source/WebCore/css/CSSPrimitiveValue.h:418 > > + void init(RefPtr<CSSCalcValue>&&); > > Need to explain why this one is a RefPtr instead of a Ref. In CSSCalculationValue.h, the two CSSCalcValue::create()'s return type is RefPtr because they can return nullptr, and init(CSSCalcValue::create(length.calculationValue(), style)); is called in CSSPrimitiveValue::CSSPrimitiveValue(const Length&, const RenderStyle&) for example. So I used RefPtr for CSSCalcValue.
Joonghun Park
Comment 25 2015-06-02 14:33:39 PDT
WebKit Commit Bot
Comment 26 2015-06-04 21:46:44 PDT
Comment on attachment 254104 [details] Patch Clearing flags on attachment: 254104 Committed r185238: <http://trac.webkit.org/changeset/185238>
WebKit Commit Bot
Comment 27 2015-06-04 21:46:52 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.