Bug 39602

Summary: Add IDBDatabase's attributes
Product: WebKit Reporter: Jeremy Orlow <jorlow>
Component: New BugsAssignee: Jeremy Orlow <jorlow>
Status: RESOLVED FIXED    
Severity: Normal CC: andreip, fishd, steveblock
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Other   
OS: OS X 10.5   
Attachments:
Description Flags
Patch
none
Patch steveblock: review+

Jeremy Orlow
Reported 2010-05-24 10:05:04 PDT
Add IDBDatabase's attributes
Attachments
Patch (29.07 KB, patch)
2010-05-25 07:58 PDT, Jeremy Orlow
no flags
Patch (36.92 KB, patch)
2010-05-26 03:31 PDT, Jeremy Orlow
steveblock: review+
Jeremy Orlow
Comment 1 2010-05-25 07:58:30 PDT
Jeremy Orlow
Comment 2 2010-05-25 08:03:16 PDT
+ darin for WebKit API review + andrei for informal review of the whole thing
Darin Fisher (:fishd, Google)
Comment 3 2010-05-25 08:04:21 PDT
Comment on attachment 57019 [details] Patch WebKit/chromium/public/WebIDBDatabase.h:43 + // FIXME: These should be purely virtual. no need for this FIXME. it is helpful for API method to have default implementations. that way it is easier to change the API. WebKit/chromium/src/IDBDatabaseProxy.cpp:72 + WebKit::WebVector<WebKit::WebString> webStrings = m_webIDBDatabase->objectStores(); would it be helpful to define a WebStringList class that works like WebNodeList? that way the cost of copying the strings out can be deferred to the embedder.
Jeremy Orlow
Comment 4 2010-05-25 08:12:55 PDT
(In reply to comment #3) > (From update of attachment 57019 [details]) > WebKit/chromium/public/WebIDBDatabase.h:43 > + // FIXME: These should be purely virtual. > no need for this FIXME. it is helpful for API method to have default > implementations. that way it is easier to change the API. In the DOMStorage code, I've only added these in as long as needed in order to get the patches landed. I'm happy to leave them in forever, but I feel like the extra effort to keep things clean (and ensure we're properly implementing all the interfaces) is good. If you're all right with it, I'd like to try and keep this stuff purely virtual....at least until someone else depends on the Chromium API and so we need to keep backwards compat code in longer. > > WebKit/chromium/src/IDBDatabaseProxy.cpp:72 > + WebKit::WebVector<WebKit::WebString> webStrings = m_webIDBDatabase->objectStores(); > would it be helpful to define a WebStringList class that works like WebNodeList? > that way the cost of copying the strings out can be deferred to the embedder. That's probably a good idea. Can I do it in a subsequent patch please?
Andrei Popescu
Comment 5 2010-05-25 08:46:56 PDT
Looks good, I have two comments: 1. I think you should leave a FIXME in the IDBDatabaseRequest IDL file, to make it clear that it's incomplete. Right now, all the methods are missing. 2. Jonas' draft spec drops the 'modifyDatabase' param from the IndexedDatabaseRequest::open() method. https://docs.google.com/a/google.com/View?id=dfs2skx2_4g3s5f857 I think we should then drop it too, as it's not entirely clear what is it for. And, as discussed, we should be implementing his draft anyway, right?
Darin Fisher (:fishd, Google)
Comment 6 2010-05-25 09:15:54 PDT
> > WebKit/chromium/src/IDBDatabaseProxy.cpp:72 > > + WebKit::WebVector<WebKit::WebString> webStrings = m_webIDBDatabase->objectStores(); > > would it be helpful to define a WebStringList class that works like WebNodeList? > > that way the cost of copying the strings out can be deferred to the embedder. > > That's probably a good idea. Can I do it in a subsequent patch please? Yes, certainly.
Jeremy Orlow
Comment 7 2010-05-26 03:31:59 PDT
Andrei Popescu
Comment 8 2010-05-26 03:39:29 PDT
LGTM. Steve should have a look, too.
Steve Block
Comment 9 2010-05-26 04:29:09 PDT
Comment on attachment 57086 [details] Patch The class names are very confusing! Is there a description of what they all mean somewhere? WebCore/storage/IDBDatabaseImpl.cpp:50 + } Why the empty impl?
Jeremy Orlow
Comment 10 2010-05-26 04:34:19 PDT
(In reply to comment #9) > (From update of attachment 57086 [details]) > The class names are very confusing! Is there a description of what they all mean somewhere? > > WebCore/storage/IDBDatabaseImpl.cpp:50 > + } > Why the empty impl? I can avoid including DOMSecurityList.h in the header. As the file gets fleshed out, I'm sure there'll be more stuff that we can just forward declare rather than define.
Jeremy Orlow
Comment 11 2010-05-26 04:35:06 PDT
(In reply to comment #9) > (From update of attachment 57086 [details]) > The class names are very confusing! Is there a description of what they all mean somewhere? We're working to change the names in the spec. When this happens, we'll rename them here.
Steve Block
Comment 12 2010-05-26 04:37:49 PDT
(In reply to comment #10) > (In reply to comment #9) > > (From update of attachment 57086 [details] [details]) > > The class names are very confusing! Is there a description of what they all mean somewhere? > > > > WebCore/storage/IDBDatabaseImpl.cpp:50 > > + } > > Why the empty impl? > > I can avoid including DOMSecurityList.h in the header. I meant the empty destructor
Jeremy Orlow
Comment 13 2010-05-26 04:43:53 PDT
Jeremy Orlow
Comment 14 2010-05-26 04:45:54 PDT
(In reply to comment #12) > (In reply to comment #10) > > (In reply to comment #9) > > > (From update of attachment 57086 [details] [details] [details]) > > > The class names are very confusing! Is there a description of what they all mean somewhere? > > > > > > WebCore/storage/IDBDatabaseImpl.cpp:50 > > > + } > > > Why the empty impl? > > > > I can avoid including DOMSecurityList.h in the header. > I meant the empty destructor I know. If I made the destructor inline (even implicitly inline) then all children destructors would also need to be available. It's viral and pretty soon you're including the world just to have a destructor in some cases. So making the destructor explicit, putting it in your .cpp file, and just forward declaring most stuff in the .h instead of including other .h files is a common pattern.
Note You need to log in before you can comment on or make changes to this bug.