blob: c7905ea763b5ccf62d0d41848e050f059f1748c6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
/*
* Copyright 2006 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* $Id$ */
package org.apache.fop.render.afp.modca;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Iterator;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* This is the base class for all data stream objects. Page objects are
* responsible for building and generating the binary datastream in an
* AFP format.
*
*/
public abstract class AbstractAFPObject {
/**
* Static logging instance
*/
protected static final Log log = LogFactory.getLog("org.apache.fop.render.afp.modca");
/**
* DataStream objects must implement the writeDataStream()
* method to write its data to the given OutputStream
* @param os The outputsteam stream
* @throws java.io.IOException
*/
public abstract void writeDataStream(OutputStream os) throws IOException;
/**
* Help method to write a set of AFPObjects to the AFP datastream.
* @afpObjects a list of AFPObjects
* @param os The stream to write to
* @throws java.io.IOException
*/
protected void writeObjectList(List afpObjects, OutputStream os)
throws IOException {
for (Iterator it = afpObjects.iterator(); it.hasNext(); ) {
((AbstractAFPObject)it.next()).writeDataStream(os);
}
}
}
|