aboutsummaryrefslogtreecommitdiffstats
path: root/docs/design/intro.xml
blob: f05c42f134844e98fd85033c24eb5a7bcd59223b (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
<?xml version="1.0" standalone="no"?>

<!-- Overview -->

<document>
    <header>
        <title>FOP Design</title>
        <subtitle>Design Approach to FOP</subtitle>
        <authors>
            <person name="Keiron Liddle" email="keiron@aftexsw.com"/>
        </authors>
    </header>

    <body>
<s1 title="Introduction">
<p>
<note><p>
The information here is still in the early stage, some information
may be wrong or misleading. In general there is not a broad enough
input and it is lacking in depth of information.
</p></note>
The information here describes the design and architecture details for FOP.
Currently this is part of a redesign process for some of the core parts of
FOP.
  </p>
  <p>
The redesign is mainly focusing on some particular process involved
with the layout process when converting the FO tree into the Area Tree.
  </p>
<s2 title="Aims">
  <p>
The main aim for FOP is to comply with the spec and to be able to
process files of any size.
   </p>
  <p>
In achieving this aim we need to understand the problem and break it
into small problems that can be solved.
   </p>
  <p>
<ul>
<li>use SAX as input</li>
<li>process FO elements ASAP</li>
<li>dispose of unused memory, keep memory minimal</li>
<li>layout handles floats, footnotes and keeps in a simple straight forward way</li>
<li>id references are kept simple</li>
<li>pages are rendered ASAP, can be cached until resolved</li>
<li>renderers are totally responsible for their output format</li>
<li>output is sent to a stream</li>
</ul>
   </p>
</s2>
  </s1>

    </body>
</document>