You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CachedRenderPagesModel.java 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /* $Id$ */
  18. package org.apache.fop.area;
  19. import java.io.BufferedInputStream;
  20. import java.io.BufferedOutputStream;
  21. import java.io.IOException;
  22. import java.io.InputStream;
  23. import java.io.ObjectInputStream;
  24. import java.io.ObjectOutputStream;
  25. import java.io.OutputStream;
  26. import java.net.URI;
  27. import java.util.HashMap;
  28. import java.util.Iterator;
  29. import java.util.Map;
  30. import org.xml.sax.SAXException;
  31. import org.apache.commons.io.IOUtils;
  32. import org.apache.xmlgraphics.io.TempResourceURIGenerator;
  33. import org.apache.fop.apps.FOPException;
  34. import org.apache.fop.apps.FOUserAgent;
  35. import org.apache.fop.fonts.FontInfo;
  36. /**
  37. * A simple cached render pages model.
  38. * If the page is prepared for later rendering then this saves
  39. * the page contents to a file and once the page is resolved
  40. * the contents are reloaded.
  41. */
  42. public class CachedRenderPagesModel extends RenderPagesModel {
  43. private Map<PageViewport, URI> pageMap = new HashMap<PageViewport, URI>();
  44. /** Base directory to save temporary file in, typically points to the user's temp dir. */
  45. private final URI tempBaseURI;
  46. private static final TempResourceURIGenerator TEMP_URI_GENERATOR
  47. = new TempResourceURIGenerator("cached-pages");
  48. /**
  49. * Main Constructor
  50. * @param userAgent FOUserAgent object for process
  51. * @param outputFormat the MIME type of the output format to use (ex. "application/pdf").
  52. * @param fontInfo FontInfo object
  53. * @param stream OutputStream
  54. * @throws FOPException if the renderer cannot be properly initialized
  55. */
  56. public CachedRenderPagesModel(FOUserAgent userAgent, String outputFormat,
  57. FontInfo fontInfo, OutputStream stream) throws FOPException {
  58. super(userAgent, outputFormat, fontInfo, stream);
  59. tempBaseURI = TEMP_URI_GENERATOR.generate();
  60. }
  61. /** {@inheritDoc} */
  62. @Override
  63. protected boolean checkPreparedPages(PageViewport newpage, boolean renderUnresolved) {
  64. for (Iterator iter = prepared.iterator(); iter.hasNext();) {
  65. PageViewport pageViewport = (PageViewport)iter.next();
  66. if (pageViewport.isResolved() || renderUnresolved) {
  67. if (pageViewport != newpage) {
  68. try {
  69. // load page from cache
  70. URI tempURI = pageMap.get(pageViewport);
  71. log.debug("Loading page from: " + tempURI);
  72. InputStream inStream = renderer.getUserAgent().getResourceResolver().getResource(tempURI);
  73. ObjectInputStream in = new ObjectInputStream(new BufferedInputStream(inStream));
  74. try {
  75. pageViewport.loadPage(in);
  76. } finally {
  77. IOUtils.closeQuietly(inStream);
  78. IOUtils.closeQuietly(in);
  79. }
  80. pageMap.remove(pageViewport);
  81. } catch (Exception e) {
  82. AreaEventProducer eventProducer = AreaEventProducer.Provider.get(
  83. renderer.getUserAgent().getEventBroadcaster());
  84. eventProducer.pageLoadError(this, pageViewport.getPageNumberString(), e);
  85. }
  86. }
  87. renderPage(pageViewport);
  88. pageViewport.clear();
  89. iter.remove();
  90. } else {
  91. if (!renderer.supportsOutOfOrder()) {
  92. break;
  93. }
  94. }
  95. }
  96. if (newpage != null && newpage.getPage() != null) {
  97. savePage(newpage);
  98. newpage.clear();
  99. }
  100. return renderer.supportsOutOfOrder() || prepared.isEmpty();
  101. }
  102. /**
  103. * Save a page.
  104. * It saves the contents of the page to a file.
  105. *
  106. * @param page the page to prepare
  107. */
  108. protected void savePage(PageViewport page) {
  109. try {
  110. // save page to cache
  111. ObjectOutputStream tempstream;
  112. String fname = "/fop-page-" + page.getPageIndex() + ".ser";
  113. URI tempURI = URI.create(tempBaseURI + fname);
  114. OutputStream outStream = renderer.getUserAgent().getResourceResolver().getOutputStream(tempURI);
  115. tempstream = new ObjectOutputStream(new BufferedOutputStream(outStream));
  116. try {
  117. page.savePage(tempstream);
  118. } finally {
  119. IOUtils.closeQuietly(tempstream);
  120. }
  121. pageMap.put(page, tempURI);
  122. if (log.isDebugEnabled()) {
  123. log.debug("Page saved to temporary file: " + tempURI);
  124. }
  125. } catch (IOException ioe) {
  126. AreaEventProducer eventProducer
  127. = AreaEventProducer.Provider.get(
  128. renderer.getUserAgent().getEventBroadcaster());
  129. eventProducer.pageSaveError(this, page.getPageNumberString(), ioe);
  130. }
  131. }
  132. /** {@inheritDoc} */
  133. @Override
  134. public void endDocument() throws SAXException {
  135. super.endDocument();
  136. }
  137. }