/*
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the
* Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that
* it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If
* not, see <http://www.gnu.org/licenses/>.
*/
package silentium.gameserver.network.loginserverpackets;
/**
* @author -Wooden-
*/
public abstract class LoginServerBasePacket
{
private final byte[] _decrypt;
private int _off;
public LoginServerBasePacket(byte[] decrypt)
{
_decrypt = decrypt;
_off = 1; // skip packet type id
}
public int readD()
{
int result = _decrypt[_off++] & 0xff;
result |= _decrypt[_off++] << 8 & 0xff00;
result |= _decrypt[_off++] << 0x10 & 0xff0000;
result |= _decrypt[_off++] << 0x18 & 0xff000000;
return result;
}
public int readC()
{
int result = _decrypt[_off++] & 0xff;
return result;
}
public int readH()
{
int result = _decrypt[_off++] & 0xff;
result |= _decrypt[_off++] << 8 & 0xff00;
return result;
}
public double readF()
{
long result = _decrypt[_off++] & 0xff;
result |= _decrypt[_off++] << 8 & 0xff00;
result |= _decrypt[_off++] << 0x10 & 0xff0000;
result |= _decrypt[_off++] << 0x18 & 0xff000000;
result |= _decrypt[_off++] << 0x20 & 0xff00000000l;
result |= _decrypt[_off++] << 0x28 & 0xff0000000000l;
result |= _decrypt[_off++] << 0x30 & 0xff000000000000l;
result |= _decrypt[_off++] << 0x38 & 0xff00000000000000l;
return Double.longBitsToDouble(result);
}
public String readS()
{
String result = null;
try
{
result = new String(_decrypt, _off, _decrypt.length - _off, "UTF-16LE");
result = result.substring(0, result.indexOf(0x00));
_off += result.length() * 2 + 2;
}
catch (Exception e)
{
e.printStackTrace();
}
return result;
}
public final byte[] readB(int length)
{
byte[] result = new byte[length];
for (int i = 0; i < length; i++)
{
result[i] = _decrypt[_off + i];
}
_off += length;
return result;
}
}