[webkit-dev] null clients of Page

Dean Jackson dino at apple.com
Mon Aug 16 21:43:43 PDT 2010


It was suggested I bring this to webkit-dev.

There was some recent work to move the many parameters passed to the Page constructor into a single PageClients structure. The current assumption is that if a feature is enabled (at runtime or compile time) then Page will always get a non-null client for that feature.

This allows the Page constructor to have something like this:

, m_deviceMotionController(RuntimeEnabledFeatures::deviceMotionEnabled() ? n
ew DeviceMotionController(pageClients.deviceMotionClient) : 0)

and DeviceMotionController's constructor has an ASSERT(m_client).

The problem is that not every Page needs every client. SVGImage, for example, creates a Page without all clients. Some platform ports branch around this code. The current solution is to create EmptyClient implementations.

https://bugs.webkit.org/show_bug.cgi?id=43848
https://bugs.webkit.org/show_bug.cgi?id=43533

Related discussion: https://lists.webkit.org/pipermail/webkit-dev/2010-July/013597.html

Wouldn't it be easier to allow null clients than to have these EmptyClient implementations? 

Dean



More information about the webkit-dev mailing list