RESOLVED FIXED 111956
PDFPlugin: Return PDFKit's data instead of the original resource data for save/etc.
https://bugs.webkit.org/show_bug.cgi?id=111956
Summary PDFPlugin: Return PDFKit's data instead of the original resource data for sav...
Tim Horton
Reported 2013-03-10 23:20:22 PDT
Attachments
patch (7.96 KB, patch)
2013-03-10 23:25 PDT, Tim Horton
webkit-ews: commit-queue-
patch (7.98 KB, patch)
2013-03-11 00:15 PDT, Tim Horton
ap: review+
ap: commit-queue-
patch (17.21 KB, patch)
2013-03-11 14:59 PDT, Tim Horton
no flags
appease stylebot (17.21 KB, patch)
2013-03-11 15:17 PDT, Tim Horton
ap: review+
Tim Horton
Comment 1 2013-03-10 23:25:14 PDT
Early Warning System Bot
Comment 2 2013-03-10 23:36:54 PDT
EFL EWS Bot
Comment 3 2013-03-11 00:02:16 PDT
Tim Horton
Comment 4 2013-03-11 00:15:43 PDT
Alexey Proskuryakov
Comment 5 2013-03-11 10:09:06 PDT
Comment on attachment 192411 [details] patch View in context: https://bugs.webkit.org/attachment.cgi?id=192411&action=review Looks fine overall, and the comments should be easily addressable. > Source/WebKit2/WebProcess/Plugins/Netscape/NetscapePlugin.h:251 > - virtual bool getResourceData(const unsigned char*& /* bytes */, unsigned& /* length */) const OVERRIDE { return false; } > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const OVERRIDE { return WebCore::SharedBuffer::create(); } I think that returning 0 would be more idiomatic than returning an empty buffer. It probably doesn't match too much here, but PassRefPtr<WebCore::SharedBuffer>() is a little faster than returning 0. > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm:-679 > - if (m_data && m_pdfDocument) { > - bytes = CFDataGetBytePtr(m_data.get()); > - length = CFDataGetLength(m_data.get()); Do we still have a reason to preserve m_data? > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm:680 > + NSData* pdfData = [m_pdfDocument.get() dataRepresentation]; Misplaced star. > Source/WebKit2/WebProcess/Plugins/Plugin.h:34 > +#include <WebCore/SharedBuffer.h> Is this #include actually needed? > Source/WebKit2/WebProcess/Plugins/Plugin.h:267 > - virtual bool getResourceData(const unsigned char*& bytes, unsigned& length) const = 0; > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const = 0; We normally use "get" prefix with functions that return result in a reference, like this one used to do. Also, there is nothing in the name that allows for the proposed behavior - it doesn't say "ForSaving", for example. Did you check other call sites to confirm that it's OK to return mutated PDF data? I see that there is only one call site changed in the patch, but I didn't check what happens in UI process. > Source/WebKit2/WebProcess/Plugins/PluginProxy.h:136 > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const OVERRIDE { return WebCore::SharedBuffer::create(); } Here as well, I'd return a null pointer. > Source/WebKit2/WebProcess/Plugins/PluginView.h:104 > - bool getResourceData(const unsigned char*& bytes, unsigned& length) const; > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const; Unsure why this this function is virtual now.
Tim Horton
Comment 6 2013-03-11 13:20:07 PDT
(In reply to comment #5) > (From update of attachment 192411 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=192411&action=review > > Looks fine overall, and the comments should be easily addressable. > > > Source/WebKit2/WebProcess/Plugins/Netscape/NetscapePlugin.h:251 > > - virtual bool getResourceData(const unsigned char*& /* bytes */, unsigned& /* length */) const OVERRIDE { return false; } > > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const OVERRIDE { return WebCore::SharedBuffer::create(); } > > I think that returning 0 would be more idiomatic than returning an empty buffer. > > It probably doesn't match too much here, but PassRefPtr<WebCore::SharedBuffer>() is a little faster than returning 0. > > > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm:-679 > > - if (m_data && m_pdfDocument) { > > - bytes = CFDataGetBytePtr(m_data.get()); > > - length = CFDataGetLength(m_data.get()); > > Do we still have a reason to preserve m_data? Not ... really. We construct it piecemeal, so we need to have it while loading, but once we create our PDFDocument we could throw it away. This brought up a good point, though, download and open-in-preview should use the mutated data too. > > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm:680 > > + NSData* pdfData = [m_pdfDocument.get() dataRepresentation]; > > Misplaced star. > > > Source/WebKit2/WebProcess/Plugins/Plugin.h:34 > > +#include <WebCore/SharedBuffer.h> > > Is this #include actually needed? I think so, I'll check. > > Source/WebKit2/WebProcess/Plugins/Plugin.h:267 > > - virtual bool getResourceData(const unsigned char*& bytes, unsigned& length) const = 0; > > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const = 0; > > We normally use "get" prefix with functions that return result in a reference, like this one used to do. Also, there is nothing in the name that allows for the proposed behavior - it doesn't say "ForSaving", for example. liveResourceData()? (it's not necessarily just for saving) > Did you check other call sites to confirm that it's OK to return mutated PDF data? I see that there is only one call site changed in the patch, but I didn't check what happens in UI process. I added getResourceData, so it shouldn't be a problem. > > Source/WebKit2/WebProcess/Plugins/PluginProxy.h:136 > > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const OVERRIDE { return WebCore::SharedBuffer::create(); } > > Here as well, I'd return a null pointer. > > > Source/WebKit2/WebProcess/Plugins/PluginView.h:104 > > - bool getResourceData(const unsigned char*& bytes, unsigned& length) const; > > + virtual PassRefPtr<WebCore::SharedBuffer> getResourceData() const; > > Unsure why this this function is virtual now. Copy-paste-o.
Alexey Proskuryakov
Comment 7 2013-03-11 13:37:49 PDT
> > Is this #include actually needed? > > I think so, I'll check. A forward declaration is sufficient for a type in RefPtr or OwnPtr, as long as the object itself is not accessed. Most of the time, this means that constructors and destructors should not be inline, which is a good idea for polymorphic classes anyway.
Tim Horton
Comment 8 2013-03-11 14:59:44 PDT
WebKit Review Bot
Comment 9 2013-03-11 15:01:14 PDT
Attachment 192568 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'Source/WebKit2/ChangeLog', u'Source/WebKit2/WebProcess/Plugins/Netscape/NetscapePlugin.cpp', u'Source/WebKit2/WebProcess/Plugins/Netscape/NetscapePlugin.h', u'Source/WebKit2/WebProcess/Plugins/PDF/PDFPlugin.mm', u'Source/WebKit2/WebProcess/Plugins/PDF/PDFPluginAnnotation.h', u'Source/WebKit2/WebProcess/Plugins/PDF/PDFPluginAnnotation.mm', u'Source/WebKit2/WebProcess/Plugins/PDF/PDFPluginChoiceAnnotation.mm', u'Source/WebKit2/WebProcess/Plugins/PDF/PDFPluginTextAnnotation.mm', u'Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.h', u'Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm', u'Source/WebKit2/WebProcess/Plugins/Plugin.h', u'Source/WebKit2/WebProcess/Plugins/PluginProxy.cpp', u'Source/WebKit2/WebProcess/Plugins/PluginProxy.h', u'Source/WebKit2/WebProcess/Plugins/PluginView.cpp', u'Source/WebKit2/WebProcess/Plugins/PluginView.h', u'Source/WebKit2/WebProcess/WebPage/WebPage.cpp']" exit_code: 1 Source/WebKit2/ChangeLog:35: Need whitespace between colon and description [changelog/filechangedescriptionwhitespace] [5] Total errors found: 1 in 16 files If any of these errors are false positives, please file a bug against check-webkit-style.
Tim Horton
Comment 10 2013-03-11 15:17:45 PDT
Created attachment 192572 [details] appease stylebot
Alexey Proskuryakov
Comment 11 2013-03-11 15:51:52 PDT
Comment on attachment 192572 [details] appease stylebot View in context: https://bugs.webkit.org/attachment.cgi?id=192572&action=review > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.h:75 > + RetainPtr<NSData> liveData() const; > + RetainPtr<NSData> rawData() const { return (NSData *)m_data.get(); } Looks like returning a pointer should work for both. > Source/WebKit2/WebProcess/Plugins/PDF/SimplePDFPlugin.mm:689 > + if (!m_pdfDocument) > + return 0; Is this check necessary? > Source/WebKit2/WebProcess/Plugins/PluginView.cpp:909 > - return false; > + return PassRefPtr<WebCore::SharedBuffer>(); My advice was probably not that good - the unimportant win in performance is not worth it.
Tim Horton
Comment 12 2013-03-11 22:12:43 PDT
Note You need to log in before you can comment on or make changes to this bug.