aboutsummaryrefslogtreecommitdiffstats
path: root/src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java
diff options
context:
space:
mode:
authorJeremias Maerki <jeremias@apache.org>2002-08-12 16:56:22 +0000
committerJeremias Maerki <jeremias@apache.org>2002-08-12 16:56:22 +0000
commit5c5eb3de6a5e2061ba1926529347694571c7845f (patch)
tree71b6a23e7f5b80364c93830d5c946f1fc68c8fb0 /src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java
parent7f538e55202188c51844ff3b37220bc3ddf177b0 (diff)
downloadxmlgraphics-fop-5c5eb3de6a5e2061ba1926529347694571c7845f.tar.gz
xmlgraphics-fop-5c5eb3de6a5e2061ba1926529347694571c7845f.zip
Replaced the PostScript filters with the refactored ones from the maintenance
branch. (JM) Added a RunLengthEncode filter for the PostScript renderer. Submitted by: "Stephen Wolke" <smwolke@geistig.com> git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@195079 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java')
-rw-r--r--src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java205
1 files changed, 205 insertions, 0 deletions
diff --git a/src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java b/src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java
new file mode 100644
index 000000000..a006bc5b6
--- /dev/null
+++ b/src/org/apache/fop/render/ps/RunLengthEncodeOutputStream.java
@@ -0,0 +1,205 @@
+/*
+ * $Id$
+ * Copyright (C) 2002 The Apache Software Foundation. All rights reserved.
+ * For details on use and redistribution please refer to the
+ * LICENSE file included with these sources.
+ */
+package org.apache.fop.render.ps;
+
+import java.io.FilterOutputStream;
+import java.io.OutputStream;
+import java.io.IOException;
+
+/**
+ * This class applies a RunLengthEncode filter to the stream.
+ *
+ * @author <a href="mailto:smwolke@geistig.com">Stephen Wolke</a>
+ * @version $Id$
+ */
+
+public class RunLengthEncodeOutputStream extends FilterOutputStream
+ implements Finalizable {
+
+ private final static int MAX_SEQUENCE_COUNT = 127;
+ private final static int END_OF_DATA = 128;
+ private final static int BYTE_MAX = 256;
+
+ private final static int NOT_IDENTIFY_SEQUENCE = 0;
+ private final static int START_SEQUENCE = 1;
+ private final static int IN_SEQUENCE = 2;
+ private final static int NOT_IN_SEQUENCE = 3;
+
+ private int runCount = 0;
+ private int isSequence = NOT_IDENTIFY_SEQUENCE;
+ private byte[] runBuffer = new byte[MAX_SEQUENCE_COUNT + 1];
+
+
+ /**
+ * Constructor for the RunLengthEncode Filter.
+ *
+ * @param out The OutputStream to write to
+ */
+ public RunLengthEncodeOutputStream(OutputStream out) {
+ super(out);
+ }
+
+
+ /**
+ * @see java.io.OutputStream#write(int)
+ * @param b the <code>byte</code>.
+ * @exception IOException if an I/O error occurs. In particular,
+ * an <code>IOException</code> may be thrown if the
+ * output stream has been closed.
+ */
+ public void write(byte b)
+ throws java.io.IOException {
+ runBuffer[runCount] = b;
+
+ switch (runCount) {
+ case 0:
+ runCount = 0;
+ isSequence = NOT_IDENTIFY_SEQUENCE;
+ runCount++;
+ break;
+ case 1:
+ if (runBuffer[runCount] != runBuffer[runCount - 1]) {
+ isSequence = NOT_IN_SEQUENCE;
+ }
+ runCount++;
+ break;
+ case 2:
+ if (runBuffer[runCount] != runBuffer[runCount - 1]) {
+ isSequence = NOT_IN_SEQUENCE;
+ } else {
+ if (isSequence == NOT_IN_SEQUENCE) {
+ isSequence = START_SEQUENCE;
+ } else {
+ isSequence = IN_SEQUENCE;
+ }
+ }
+ runCount++;
+ break;
+ case MAX_SEQUENCE_COUNT:
+ if (isSequence == IN_SEQUENCE) {
+ out.write(BYTE_MAX - (MAX_SEQUENCE_COUNT - 1));
+ out.write(runBuffer[runCount - 1]);
+ runBuffer[0] = runBuffer[runCount];
+ runCount = 1;
+ } else {
+ out.write(MAX_SEQUENCE_COUNT);
+ out.write(runBuffer, 0, runCount + 1);
+ runCount = 0;
+ }
+ isSequence = NOT_IDENTIFY_SEQUENCE;
+ break;
+ default:
+ switch (isSequence) {
+ case IN_SEQUENCE:
+ if (runBuffer[runCount] != runBuffer[runCount - 1]) {
+ out.write(BYTE_MAX - (runCount - 1));
+ out.write(runBuffer[runCount - 1]);
+ runBuffer[0] = runBuffer[runCount];
+ runCount = 1;
+ isSequence = NOT_IDENTIFY_SEQUENCE;
+ break;
+ }
+ runCount++;
+ break;
+ case NOT_IN_SEQUENCE:
+ if (runBuffer[runCount] == runBuffer[runCount - 1]) {
+ isSequence = START_SEQUENCE;
+ }
+ runCount++;
+ break;
+ case START_SEQUENCE:
+ if (runBuffer[runCount] == runBuffer[runCount - 1]) {
+ out.write(runCount - 3);
+ out.write(runBuffer, 0, runCount - 2);
+ runBuffer[0] = runBuffer[runCount];
+ runBuffer[1] = runBuffer[runCount];
+ runBuffer[2] = runBuffer[runCount];
+ runCount = 3;
+ isSequence = IN_SEQUENCE;
+ break;
+ } else {
+ isSequence = NOT_IN_SEQUENCE;
+ runCount++;
+ break;
+ }
+ }
+ }
+ }
+
+
+ /**
+ * @see java.io.OutputStream#write(byte[])
+ * @param b the data.
+ * @exception IOException if an I/O error occurs.
+ */
+ public void write(byte[] b)
+ throws IOException {
+
+ for (int i = 0; i < b.length; i++) {
+ this.write(b[i]);
+ }
+ }
+
+
+ /**
+ * @see java.io.OutputStream#write(byte[], int, int)
+ * @param b the data.
+ * @param off the start offset in the data.
+ * @param len the number of bytes to write.
+ * @exception IOException if an I/O error occurs. In particular,
+ * an <code>IOException</code> is thrown if the output
+ * stream is closed.
+ */
+ public void write(byte[] b, int off, int len)
+ throws IOException {
+
+ for (int i = 0; i < len; i++) {
+ this.write(b[off + i]);
+ }
+ }
+
+
+ /**
+ * Flushes the the stream and writes out the trailer, but, unlike close(),
+ * without closing the stream.
+ *
+ * @exception IOException if an I/O error occurs.
+ */
+ public void finalizeStream()
+ throws IOException {
+ switch (isSequence) {
+ case IN_SEQUENCE:
+ out.write(BYTE_MAX - (runCount - 1));
+ out.write(runBuffer[runCount - 1]);
+ break;
+ default:
+ out.write(runCount - 1);
+ out.write(runBuffer, 0, runCount);
+ }
+
+ out.write(END_OF_DATA);
+
+ flush();
+ if (out instanceof Finalizable) {
+ ((Finalizable) out).finalizeStream();
+ }
+ }
+
+
+ /**
+ * Closes the stream.
+ *
+ * @exception IOException if an I/O error occurs.
+ */
+ public void close()
+ throws IOException {
+ finalizeStream();
+ super.close();
+ }
+
+}
+