public class PacketLineIn extends Object
This class is not thread safe and may issue multiple reads to the underlying stream for each method call made.
This class performs no buffering on its own. This makes it suitable to interleave reads performed by this class with reads performed directly against the underlying InputStream.
Modifier and Type | Class and Description |
---|---|
static class |
PacketLineIn.InputOverLimitIOException
IOException thrown by read when the configured input limit is exceeded.
|
Modifier and Type | Field and Description |
---|---|
static String |
DELIM
Magic return from
readString() when a delim packet is found. |
static String |
END
Magic return from
readString() when a flush packet is found. |
Constructor and Description |
---|
PacketLineIn(InputStream in)
Create a new packet line reader.
|
PacketLineIn(InputStream in,
long limit)
Create a new packet line reader.
|
Modifier and Type | Method and Description |
---|---|
String |
readString()
Read a single UTF-8 encoded string packet from the input stream.
|
String |
readStringRaw()
Read a single UTF-8 encoded string packet from the input stream.
|
public static final String END
readString()
when a flush packet is found.public static final String DELIM
readString()
when a delim packet is found.public PacketLineIn(InputStream in)
in
- the input stream to consume.public PacketLineIn(InputStream in, long limit)
in
- the input stream to consume.limit
- bytes to read from the input; unlimited if set to 0.public String readString() throws IOException
If the string ends with an LF, it will be removed before returning the
value to the caller. If this automatic trimming behavior is not desired,
use readStringRaw()
instead.
END
if the string was the magic flush
packet, DELIM
if the string was the magic DELIM
packet.IOException
- the stream cannot be read.public String readStringRaw() throws IOException
Unlike readString()
a trailing LF will be retained.
END
if the string was the magic flush
packet.IOException
- the stream cannot be read.Copyright © 2019 Eclipse JGit Project. All rights reserved.