diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-10-26 11:48:53 +1300 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-10-26 11:48:53 +1300 |
commit | 64aa76a78916310cfbc14ec3ae6083555b95a4a0 (patch) | |
tree | 3e8a3f7bdab0250f284aae5768c1f50ed3e7e811 /src/org/traccar/protocol/XexunFrameDecoder.java | |
parent | 511b1807da62c225afc70d45f6eb047382d242a9 (diff) | |
download | trackermap-server-64aa76a78916310cfbc14ec3ae6083555b95a4a0.tar.gz trackermap-server-64aa76a78916310cfbc14ec3ae6083555b95a4a0.tar.bz2 trackermap-server-64aa76a78916310cfbc14ec3ae6083555b95a4a0.zip |
Modify Xexun frame decoder
Diffstat (limited to 'src/org/traccar/protocol/XexunFrameDecoder.java')
-rw-r--r-- | src/org/traccar/protocol/XexunFrameDecoder.java | 32 |
1 files changed, 12 insertions, 20 deletions
diff --git a/src/org/traccar/protocol/XexunFrameDecoder.java b/src/org/traccar/protocol/XexunFrameDecoder.java index 60fa02696..b892fa346 100644 --- a/src/org/traccar/protocol/XexunFrameDecoder.java +++ b/src/org/traccar/protocol/XexunFrameDecoder.java @@ -20,47 +20,39 @@ import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.ChannelHandlerContext; import org.jboss.netty.handler.codec.frame.FrameDecoder; import org.traccar.helper.ChannelBufferTools; +import org.traccar.helper.StringFinder; public class XexunFrameDecoder extends FrameDecoder { @Override protected Object decode( - ChannelHandlerContext ctx, - Channel channel, - ChannelBuffer buf) throws Exception { + ChannelHandlerContext ctx, Channel channel, ChannelBuffer buf) throws Exception { - // Check minimum length - int length = buf.readableBytes(); - if (length < 80) { + if (buf.readableBytes() < 80) { return null; } - // Find start - Integer beginIndex = ChannelBufferTools.find(buf, buf.readerIndex(), "GPRMC"); - if (beginIndex == null) { - beginIndex = ChannelBufferTools.find(buf, buf.readerIndex(), "GNRMC"); - if (beginIndex == null) { + int beginIndex = buf.indexOf(buf.readerIndex(), buf.writerIndex(), new StringFinder("GPRMC")); + if (beginIndex == -1) { + beginIndex = buf.indexOf(buf.readerIndex(), buf.writerIndex(), new StringFinder("GNRMC")); + if (beginIndex == -1) { return null; } } - // Find identifier - Integer idIndex = ChannelBufferTools.find(buf, beginIndex, "imei:"); - if (idIndex == null) { + int identifierIndex = buf.indexOf(beginIndex, buf.writerIndex(), new StringFinder("imei:")); + if (identifierIndex == -1) { return null; } - // Find end - Integer endIndex = ChannelBufferTools.find(buf, idIndex, ","); - if (endIndex == null) { + int endIndex = buf.indexOf(identifierIndex, buf.writerIndex(), (byte) ','); + if (endIndex == -1) { return null; } - // Read buffer buf.skipBytes(beginIndex); - ChannelBuffer frame = buf.readBytes(endIndex - beginIndex + 1); - return frame; + return buf.readBytes(endIndex - beginIndex + 1); } } |