mockit.asm.methods.LineNumberTableWriter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jmockit Show documentation
Show all versions of jmockit Show documentation
JMockit is a Java toolkit for automated developer testing.
It contains mocking/faking APIs and a code coverage tool, supporting both JUnit and TestNG.
The mocking APIs allow all kinds of Java code, without testability restrictions, to be tested
in isolation from selected dependencies.
package mockit.asm.methods;
import javax.annotation.*;
import mockit.asm.constantPool.*;
import mockit.asm.controlFlow.*;
import mockit.asm.util.*;
/**
* Writes the bytecode for the "LineNumberTable" method code attribute.
*/
final class LineNumberTableWriter extends AttributeWriter
{
/**
* Number of entries in the LineNumberTable attribute.
*/
@Nonnegative private int lineNumberCount;
/**
* The LineNumberTable attribute.
*/
@Nullable private ByteVector lineNumbers;
LineNumberTableWriter(@Nonnull ConstantPoolGeneration cp) { super(cp); }
void addLineNumber(@Nonnegative int line, @Nonnull Label start) {
if (lineNumbers == null) {
setAttribute("LineNumberTable");
lineNumbers = new ByteVector();
}
lineNumberCount++;
lineNumbers.putShort(start.position);
lineNumbers.putShort(line);
}
boolean hasLineNumbers() { return lineNumbers != null; }
@Nonnegative @Override
public int getSize() { return lineNumbers == null ? 0 : 8 + lineNumbers.getLength(); }
@Override
public void put(@Nonnull ByteVector out) {
if (lineNumbers != null) {
put(out, 2 + lineNumbers.getLength());
out.putShort(lineNumberCount);
out.putByteVector(lineNumbers);
}
}
}