EMMA Coverage Report (generated Wed Jun 28 22:15:27 PDT 2006)
[all classes][org.apache.derby.iapi.services.classfile]

COVERAGE SUMMARY FOR SOURCE FILE [ClassFormatOutput.java]

nameclass, %method, %block, %line, %
ClassFormatOutput.java100% (1/1)89%  (8/9)64%  (50/78)86%  (18/21)

COVERAGE BREAKDOWN BY CLASS AND METHOD

nameclass, %method, %block, %line, %
     
class ClassFormatOutput100% (1/1)89%  (8/9)64%  (50/78)86%  (18/21)
ClassFormatOutput (): void 100% (1/1)100% (4/4)100% (2/2)
ClassFormatOutput (int): void 100% (1/1)100% (7/7)100% (2/2)
getData (): byte [] 100% (1/1)100% (5/5)100% (1/1)
limit (String, int, int): void 0%   (0/1)0%   (0/20)0%   (0/1)
putU1 (int): void 100% (1/1)64%  (7/11)75%  (3/4)
putU2 (String, int): void 100% (1/1)75%  (12/16)80%  (4/5)
putU2 (int): void 100% (1/1)100% (5/5)100% (2/2)
putU4 (int): void 100% (1/1)100% (4/4)100% (2/2)
writeTo (OutputStream): void 100% (1/1)100% (6/6)100% (2/2)

1/*
2 
3   Derby - Class org.apache.derby.iapi.services.classfile.ClassFormatOutput
4 
5   Copyright 2000, 2004 The Apache Software Foundation or its licensors, as applicable.
6 
7   Licensed under the Apache License, Version 2.0 (the "License");
8   you may not use this file except in compliance with the License.
9   You may obtain a copy of the License at
10 
11      http://www.apache.org/licenses/LICENSE-2.0
12 
13   Unless required by applicable law or agreed to in writing, software
14   distributed under the License is distributed on an "AS IS" BASIS,
15   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16   See the License for the specific language governing permissions and
17   limitations under the License.
18 
19 */
20 
21package org.apache.derby.iapi.services.classfile;
22 
23import org.apache.derby.iapi.services.io.AccessibleByteArrayOutputStream;
24import java.io.DataOutputStream;
25import java.io.IOException;
26import java.io.OutputStream;
27 
28 
29/** A wrapper around DataOutputStream to provide input functions in terms
30    of the types defined on pages 83 of the Java Virtual Machine spec.
31 
32        For this types use these methods of DataOutputStream
33        <UL>
34        <LI>float - writeFloat
35        <LI>long - writeLong
36        <LI>double - writeDouble
37        <LI>UTF/String - writeUTF
38        <LI>U1Array - write(byte[])
39        </UL>
40 */
41 
42public final class ClassFormatOutput extends DataOutputStream {
43 
44        public ClassFormatOutput() {
45                this(512);
46        }
47 
48        public ClassFormatOutput(int size) {
49                this(new AccessibleByteArrayOutputStream(size));
50        }
51        public ClassFormatOutput(java.io.OutputStream stream) {
52                super(stream);
53        }
54        public void putU1(int i) throws IOException {
55                // ensure the format of the class file is not
56                // corrupted by writing an incorrect, truncated value.
57                if (i > 255)
58                        ClassFormatOutput.limit("U1", 255, i);
59                write(i);
60        }
61        public void putU2(int i) throws IOException {
62                putU2("U2", i);
63 
64        }
65        public void putU2(String limit, int i) throws IOException {
66                
67                // ensure the format of the class file is not
68                // corrupted by writing an incorrect, truncated value.
69                if (i > 65535)
70                        ClassFormatOutput.limit(limit, 65535, i);
71                write(i >> 8);
72                write(i);
73        }
74        public void putU4(int i) throws IOException {
75                writeInt(i);
76        }
77 
78        public void writeTo(OutputStream outTo) throws IOException {
79                ((AccessibleByteArrayOutputStream) out).writeTo(outTo);
80        }
81 
82        /**
83                Get a reference to the data array the class data is being built
84                in. No copy is made.
85        */
86        public byte[] getData() {
87                return ((AccessibleByteArrayOutputStream) out).getInternalByteArray();
88        }
89 
90        /**
91         * Throw an ClassFormatError if a limit of the Java class file format is reached.
92         * @param name Terse limit description from JVM spec.
93         * @param limit What the limit is.
94         * @param value What the value for the current class is
95         * @throws IOException Thrown when limit is exceeded.
96         */
97        static void limit(String name, int limit, int value)
98                throws IOException
99        {
100                throw new IOException(name + "(" + value + " > " + limit + ")");
101        }
102}

[all classes][org.apache.derby.iapi.services.classfile]
EMMA 2.0.5312 (C) Vladimir Roubtsov