Bug 72801

Summary: Cannot print USPS shipping labels
Product: WebKit Reporter: Mike McNeil <mmcneil>
Component: PDFAssignee: mitz
Status: RESOLVED FIXED    
Severity: Normal CC: ap, mitz, mmcneil
Priority: P1 Keywords: InRadar, Regression
Version: 528+ (Nightly build)   
Hardware: Mac (Intel)   
OS: OS X 10.7   
URL: http://www.usps.com
Attachments:
Description Flags
Screen shot of URL
none
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame
none
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame
none
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame ap: review+

Mike McNeil
Reported 2011-11-19 09:44:41 PST
Created attachment 115952 [details] Screen shot of URL The process of printing a label on usps.com results in a label being downloaded in Safari 5.1. Does not currently work in Webkit. This process used to result in a print dialogue, however that doesn't happen anymore in either Safari or Webkit. https://sss-web.usps.com/cns/printPreparation.do
Attachments
Screen shot of URL (48.90 KB, application/pdf)
2011-11-19 09:44 PST, Mike McNeil
no flags
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame (15.87 KB, patch)
2011-12-29 11:25 PST, mitz
no flags
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame (15.87 KB, patch)
2011-12-29 11:27 PST, mitz
no flags
Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame (17.17 KB, patch)
2011-12-31 12:23 PST, mitz
ap: review+
Alexey Proskuryakov
Comment 1 2011-11-21 16:46:22 PST
Mike McNeil
Comment 2 2011-12-03 07:18:34 PST
Went through the entire label creation & printing process, address book bug 73657/73183 has been fixed. Still unable to get the label to print. Anything I can do to assist or provide more information? Version 5.1.2 (7534.52.7, r101927) https://sss-web.usps.com/cns/printPreparation.do
Alexey Proskuryakov
Comment 3 2011-12-03 11:04:56 PST
Thank you. This cause of this problem is well understood, and its importance is also well understood.
mitz
Comment 4 2011-12-29 11:25:37 PST
Created attachment 120760 [details] Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame Together with fixing bug 75232, this patch resolves the issue.
mitz
Comment 5 2011-12-29 11:27:47 PST
Created attachment 120761 [details] Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame
Alexey Proskuryakov
Comment 6 2011-12-31 11:14:41 PST
Comment on attachment 120761 [details] Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame View in context: https://bugs.webkit.org/attachment.cgi?id=120761&action=review Looks great. Does this depend on bug 75232? > Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.cpp:838 > + WebPage* page = frame->page(); > + if (!page) We have a check for pageless frame here, but not in BuiltInPDFView::initialize() or BuiltInPDFView::isActive(). Can page actually be null? > Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.cpp:841 > + page->sendSync(Messages::WebPageProxy::PrintFrame(frame->frameID()), Messages::WebPageProxy::PrintFrame::Reply()); I'd have routed this through WebCore, for instance to make use of PageGroupLoadDeferrer once Chrome::print starts using it. > Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.h:35 > +typedef const struct OpaqueJSContext* JSContextRef; > +typedef struct OpaqueJSValue* JSObjectRef; > +typedef const struct OpaqueJSValue* JSValueRef; :( > Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.h:139 > - virtual void disconnectFromPage() { m_page = 0; } > + virtual void disconnectFromPage() { m_frame = 0; } This is now a little bit surprising.
Alexey Proskuryakov
Comment 7 2011-12-31 11:15:15 PST
> Does this depend on bug 75232? I now see the answer above.
mitz
Comment 8 2011-12-31 12:18:08 PST
Comment on attachment 120761 [details] Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame View in context: https://bugs.webkit.org/attachment.cgi?id=120761&action=review >> Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.cpp:838 >> + if (!page) > > We have a check for pageless frame here, but not in BuiltInPDFView::initialize() or BuiltInPDFView::isActive(). Can page actually be null? I’m quite certain it *cannot* be null in initialize(). I’m going to be paranoid and add a null check in isActive() rather than try to reason about lots of code outside this class. In this function, in particular, I don’t want to make any assumptions, in case Doc is ever extended to have something like setTimeout. >> Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.cpp:841 >> + page->sendSync(Messages::WebPageProxy::PrintFrame(frame->frameID()), Messages::WebPageProxy::PrintFrame::Reply()); > > I'd have routed this through WebCore, for instance to make use of PageGroupLoadDeferrer once Chrome::print starts using it. Good idea. I’ll do that. >> Source/WebKit2/WebProcess/Plugins/PDF/BuiltInPDFView.h:35 >> +typedef const struct OpaqueJSValue* JSValueRef; > > :( You’ll thank me when JavaScriptCore public headers change and you don’t have to recompile all files that include this header!
mitz
Comment 9 2011-12-31 12:23:57 PST
Created attachment 120831 [details] Make BuiltInPDFView execute JavaScript in PDF documents with a Doc object capable of printing the frame
mitz
Comment 10 2011-12-31 12:59:18 PST
Note You need to log in before you can comment on or make changes to this bug.