}
}
+static PdfResult doPage(PdfContext* pdfContext, SkCanvas* canvas, SkPdfPageObjectDictionary* skobj) {
+ if (!skobj) {
+ return kIgnoreError_PdfResult;
+ }
+
+ if (!skobj->isContentsAStream(pdfContext->fPdfDoc)) {
+ return kNYI_PdfResult;
+ }
+
+ SkPdfStream* stream = skobj->getContentsAsStream(pdfContext->fPdfDoc);
+
+ if (!stream) {
+ return kIgnoreError_PdfResult;
+ }
+
+ if (CheckRecursiveRendering::IsInRendering(skobj)) {
+ // Oops, corrupt PDF!
+ return kIgnoreError_PdfResult;
+ }
+ CheckRecursiveRendering checkRecursion(skobj);
+
+
+ PdfOp_q(pdfContext, canvas, NULL);
+
+ canvas->save();
+
+ if (skobj->Resources(pdfContext->fPdfDoc)) {
+ pdfContext->fGraphicsState.fResources = skobj->Resources(pdfContext->fPdfDoc);
+ }
+
+ // TODO(edisonn): refactor common path with doXObject()
+ // This is a group?
+ if (skobj->has_Group()) {
+ //TransparencyGroupDictionary* ...
+ }
+
+ SkPdfNativeTokenizer* tokenizer =
+ pdfContext->fPdfDoc->tokenizerOfStream(stream, pdfContext->fTmpPageAllocator);
+ if (tokenizer != NULL) {
+ PdfMainLooper looper(NULL, tokenizer, pdfContext, canvas);
+ looper.loop();
+ delete tokenizer;
+ }
+
+ // TODO(edisonn): should we restore the variable stack at the same state?
+ // There could be operands left, that could be consumed by a parent tokenizer when we pop.
+ canvas->restore();
+ PdfOp_Q(pdfContext, canvas, NULL);
+ return kPartial_PdfResult;
+}
+
PdfResult PdfOp_q(PdfContext* pdfContext, SkCanvas* canvas, PdfTokenLooper** looper) {
pdfContext->fStateStack.push(pdfContext->fGraphicsState);
canvas->save();
PdfContext pdfContext(fPdfDoc);
- SkPdfNativeTokenizer* tokenizer = fPdfDoc->tokenizerOfPage(page, pdfContext.fTmpPageAllocator);
- if (!tokenizer) {
- // TODO(edisonn): report/warning/debug
- return false;
- }
-
pdfContext.fOriginalMatrix = SkMatrix::I();
pdfContext.fGraphicsState.fResources = fPdfDoc->pageResources(page);
canvas->setMatrix(pdfContext.fOriginalMatrix);
-// erase with red before?
+ doPage(&pdfContext, canvas, fPdfDoc->page(page));
+
+ // TODO(edisonn:) erase with white before draw?
// SkPaint paint;
-// paint.setColor(SK_ColorRED);
+// paint.setColor(SK_ColorWHITE);
// canvas->drawRect(rect, paint);
- PdfMainLooper looper(NULL, tokenizer, &pdfContext, canvas);
- looper.loop();
-
- delete tokenizer;
canvas->flush();
return true;
return fPages.count();
}
+SkPdfPageObjectDictionary* SkNativeParsedPDF::page(int page) {
+ SkASSERT(page >= 0 && page < fPages.count());
+ return fPages[page];
+}
+
+
SkPdfResourceDictionary* SkNativeParsedPDF::pageResources(int page) {
+ SkASSERT(page >= 0 && page < fPages.count());
return fPages[page]->Resources(this);
}
// TODO(edisonn): generation/updates not supported now
//int gen = ref->referenceGeneration();
- SkASSERT(!(id < 0 || id > fObjects.count()));
-
// TODO(edisonn): verify id and gen expected
if (id < 0 || id >= fObjects.count()) {
// TODO(edisonn): report error/warning