RESOLVED FIXED 41547
Turn on adoptRef assertion for RefCounted
https://bugs.webkit.org/show_bug.cgi?id=41547
Summary Turn on adoptRef assertion for RefCounted
Darin Adler
Reported 2010-07-02 16:00:30 PDT
Turn on adoptRef assertion for RefCounted
Attachments
Patch (26.70 KB, patch)
2010-07-02 16:20 PDT, Darin Adler
abarth: review+
Darin Adler
Comment 1 2010-07-02 16:20:06 PDT
Adam Barth
Comment 2 2010-07-07 03:49:54 PDT
Comment on attachment 60415 [details] Patch A bunch of minor comments below. Really glad to see this patch! Thanks for picking up this project and running with it. WebCore/html/FileStreamProxy.cpp:60 + proxy->ref(); This seems like a bad design. The way we solved this problem in Chrome is by having specialized Task objects that understood how to ref/deref the objects that they operated upon. It took a few iterations of the design to get it right, but we got rid of almost all the instances of this (error-prone) pattern. WebCore/page/EventSource.cpp:71 + PassRefPtr<EventSource> EventSource::create(const String& url, ScriptExecutionContext* context, ExceptionCode& ec) This change is slightly complex, but looks like a nice win in terms of readability. WebCore/page/EventSource.h:  + EventSource(const String& url, ScriptExecutionContext* context, ExceptionCode& ec); Yeah, having the ec in the constructor seems like nonsense semantically. Constructors that can fail don't make much sense. WebCore/storage/StorageAreaSync.h:44 + static PassRefPtr<StorageAreaSync> create(PassRefPtr<StorageSyncManager>, PassRefPtr<StorageAreaImpl>, const String& databaseIdentifier); We should improve the linter to find Strings passed by value. WebCore/workers/SharedWorker.cpp:  + ASSERT(!ec); What happend to this assert? WebCore/workers/SharedWorker.cpp:60 + KURL scriptURL = worker->resolveURL(url, ec); Can we get an ec without scriptURL being empty? Do we need to return like the old code did? WebCore/workers/Worker.cpp:63 + KURL scriptURL = worker->resolveURL(url, ec); Same ec question. WebCore/workers/Worker.cpp:67 + worker->m_scriptLoader = new WorkerScriptLoader(ResourceRequestBase::TargetIsWorker); Naked new? WebCore/workers/Worker.h:57 + virtual ~Worker(); !
Darin Adler
Comment 3 2010-07-07 12:51:31 PDT
(In reply to comment #2) > WebCore/html/FileStreamProxy.cpp:60 > + proxy->ref(); > This seems like a bad design. The way we solved this problem in Chrome is by having specialized Task objects that understood how to ref/deref the objects that they operated upon. It took a few iterations of the design to get it right, but we got rid of almost all the instances of this (error-prone) pattern. Good feedback for the engineers working on FileSystemProxy.cpp, Kinuko Yasuda and Jian Li. I believe both work for Google so maybe you can talk to them in person? I wasn’t changing the design; just refactoring to work with the new assertion. I just moved the ref out of the constructor into the create function. > WebCore/workers/SharedWorker.cpp:  > + ASSERT(!ec); > What happend to this assert? I replaced an unimportant assertion with the more important one. The function returns null when it fails. The fact that it also returns an exception code is only for the convenience of JavaScript. I changed the code to assert that the return value is non-null. An alternative would be to keep the !ec assertion and initialize ec to zero. I don’t feel strongly either way. > WebCore/workers/SharedWorker.cpp:60 > + KURL scriptURL = worker->resolveURL(url, ec); > Can we get an ec without scriptURL being empty? Do we need to return like the old code did? We can't. This function always returns a null scriptURL when there is an exception. We don't need code to explicitly check the exception. Generally speaking, exception codes are not a good way for our internal code to work. They are good for one purpose only, to provide exceptions for the binding layer. I think a good general guideline is that when possible, internal code should do nothing with the exceptions except pass them out to the binding layer, and should indicate failure in other ways. > WebCore/workers/Worker.cpp:63 > + KURL scriptURL = worker->resolveURL(url, ec); > Same ec question. Same answer. > WebCore/workers/Worker.cpp:67 > + worker->m_scriptLoader = new WorkerScriptLoader(ResourceRequestBase::TargetIsWorker); > Naked new? That's an error. This should have an adoptPtr. Once we turn off LOOSE_OWN_PTR it will be an error to omit the adoptPtr. I'll add it, but generally speaking I'll get to those in another patch. > WebCore/workers/Worker.h:57 > + virtual ~Worker(); > ! The destructor was already virtual because the base class, AbstractWorker, has a virtual destructor. I was simply fixing a style mistake. Generally speaking in WebKit we always want to explicitly declare functions virtual rather than letting them be virtual implicitly because they overload virtual function from the base class.
Kinuko Yasuda
Comment 4 2010-07-07 13:12:49 PDT
(In reply to comment #3) > (In reply to comment #2) > > WebCore/html/FileStreamProxy.cpp:60 > > + proxy->ref(); > > This seems like a bad design. The way we solved this problem in Chrome is by having specialized Task objects that understood how to ref/deref the objects that they operated upon. It took a few iterations of the design to get it right, but we got rid of almost all the instances of this (error-prone) pattern. > > Good feedback for the engineers working on FileSystemProxy.cpp, Kinuko Yasuda and Jian Li. I believe both work for Google so maybe you can talk to them in person? I wasn’t changing the design; just refactoring to work with the new assertion. I just moved the ref out of the constructor into the create function. Thanks for the feedback, that's true that this design is very error-prone. I'll open a new bug to fix FileStreamProxy design right.
Darin Adler
Comment 5 2010-07-07 13:55:58 PDT
WebKit Review Bot
Comment 6 2010-07-07 14:24:17 PDT
http://trac.webkit.org/changeset/62696 might have broken GTK Linux 64-bit Debug
Adam Barth
Comment 7 2010-07-07 14:27:27 PDT
abarth: http://build.webkit.org/results/GTK%20Linux%2064-bit%20Debug/r62696%20(9359)/results.html abarth: darin: someone set us up the svg crash abarth: ASSERTION FAILED: !m_adoptionIsRequired abarth: (../../JavaScriptCore/wtf/RefCounted.h:37 void WTF::RefCountedBase::ref())
Darin Adler
Comment 8 2010-07-07 17:43:46 PDT
(In reply to comment #7) > abarth: http://build.webkit.org/results/GTK%20Linux%2064-bit%20Debug/r62696%20(9359)/results.html > abarth: darin: someone set us up the svg crash > abarth: ASSERTION FAILED: !m_adoptionIsRequired > abarth: (../../JavaScriptCore/wtf/RefCounted.h:37 void WTF::RefCountedBase::ref()) I wonder why this is GTK-specific. These same tests don't seem to have this problem on the non-GTK platforms. Could someone show me the backtrace so I can fix this?
Adam Barth
Comment 9 2010-07-08 08:49:58 PDT
Seems to also have caused problems on Leopard Debug platform/mac/plugins/webScriptObject-exception-deadlock.html http/tests/workers/shared-worker-redirect.html http://build.webkit.org/results/Leopard%20Intel%20Debug%20(Tests)/r62785%20(17026)/results.html
Note You need to log in before you can comment on or make changes to this bug.