Modified Ext.cs
This commit is contained in:
@@ -110,7 +110,7 @@ namespace WebSocketSharp
|
|||||||
private static ushort getCodeFrom (byte [] data)
|
private static ushort getCodeFrom (byte [] data)
|
||||||
{
|
{
|
||||||
return data.Length > 1
|
return data.Length > 1
|
||||||
? data.SubArray (0, 2).To<ushort> (ByteOrder.BIG)
|
? data.SubArray (0, 2).ToUInt16 (ByteOrder.BIG)
|
||||||
: (ushort) 0;
|
: (ushort) 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -138,6 +138,37 @@ namespace WebSocketSharp
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static byte [] readBytes (this Stream stream, byte [] buffer, int offset, int length)
|
||||||
|
{
|
||||||
|
var readLen = stream.Read (buffer, offset, length);
|
||||||
|
if (readLen < 1)
|
||||||
|
return buffer.SubArray (0, offset);
|
||||||
|
|
||||||
|
var tmpLen = 0;
|
||||||
|
while (readLen < length)
|
||||||
|
{
|
||||||
|
tmpLen = stream.Read (buffer, offset + readLen, length - readLen);
|
||||||
|
if (tmpLen < 1)
|
||||||
|
break;
|
||||||
|
|
||||||
|
readLen += tmpLen;
|
||||||
|
}
|
||||||
|
|
||||||
|
return readLen < length
|
||||||
|
? buffer.SubArray (0, offset + readLen)
|
||||||
|
: buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static bool readBytes (
|
||||||
|
this Stream stream, byte [] buffer, int offset, int length, Stream dest)
|
||||||
|
{
|
||||||
|
var bytes = stream.readBytes (buffer, offset, length);
|
||||||
|
var len = bytes.Length;
|
||||||
|
dest.Write (bytes, 0, len);
|
||||||
|
|
||||||
|
return len == offset + length;
|
||||||
|
}
|
||||||
|
|
||||||
private static void times (this ulong n, Action act)
|
private static void times (this ulong n, Action act)
|
||||||
{
|
{
|
||||||
for (ulong i = 0; i < n; i++)
|
for (ulong i = 0; i < n; i++)
|
||||||
@@ -152,7 +183,7 @@ namespace WebSocketSharp
|
|||||||
{
|
{
|
||||||
using (var buffer = new MemoryStream ())
|
using (var buffer = new MemoryStream ())
|
||||||
{
|
{
|
||||||
var tmp = code.ToByteArray (ByteOrder.BIG);
|
var tmp = code.ToByteArrayInternally (ByteOrder.BIG);
|
||||||
buffer.Write (tmp, 0, 2);
|
buffer.Write (tmp, 0, 2);
|
||||||
if (reason != null && reason.Length > 0)
|
if (reason != null && reason.Length > 0)
|
||||||
{
|
{
|
||||||
@@ -467,76 +498,63 @@ namespace WebSocketSharp
|
|||||||
: String.Format ("\"{0}\"", value.Replace ("\"", "\\\""));
|
: String.Format ("\"{0}\"", value.Replace ("\"", "\\\""));
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static byte [] ReadBytesInternal (this Stream stream, int length)
|
internal static byte [] ReadBytes (this Stream stream, int length)
|
||||||
{
|
{
|
||||||
var buffer = new byte [length];
|
return stream.readBytes (new byte [length], 0, length);
|
||||||
var readLen = stream.Read (buffer, 0, length);
|
|
||||||
if (readLen <= 0)
|
|
||||||
return new byte []{};
|
|
||||||
|
|
||||||
var tmpLen = 0;
|
|
||||||
while (readLen < length)
|
|
||||||
{
|
|
||||||
tmpLen = stream.Read (buffer, readLen, length - readLen);
|
|
||||||
if (tmpLen <= 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
readLen += tmpLen;
|
|
||||||
}
|
|
||||||
|
|
||||||
return readLen == length
|
|
||||||
? buffer
|
|
||||||
: buffer.SubArray (0, readLen);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static byte [] ReadBytesInternal (this Stream stream, long length, int bufferLength)
|
internal static byte [] ReadBytes (this Stream stream, long length, int bufferLength)
|
||||||
{
|
{
|
||||||
var count = length / bufferLength;
|
using (var result = new MemoryStream ())
|
||||||
var rem = length % bufferLength;
|
|
||||||
using (var readData = new MemoryStream ())
|
|
||||||
{
|
{
|
||||||
var readLen = 0;
|
var count = length / bufferLength;
|
||||||
var bufferLen = 0;
|
var rem = (int) (length % bufferLength);
|
||||||
var tmpLen = 0;
|
|
||||||
Func<byte [], bool> read = buffer =>
|
|
||||||
{
|
|
||||||
bufferLen = buffer.Length;
|
|
||||||
readLen = stream.Read (buffer, 0, bufferLen);
|
|
||||||
if (readLen <= 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
while (readLen < bufferLen)
|
var buffer = new byte [bufferLength];
|
||||||
{
|
var end = false;
|
||||||
tmpLen = stream.Read (buffer, readLen, bufferLen - readLen);
|
|
||||||
if (tmpLen <= 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
readLen += tmpLen;
|
|
||||||
}
|
|
||||||
|
|
||||||
readData.Write (buffer, 0, readLen);
|
|
||||||
return readLen == bufferLen;
|
|
||||||
};
|
|
||||||
|
|
||||||
var readBuffer = new byte [bufferLength];
|
|
||||||
var readEnd = false;
|
|
||||||
for (long i = 0; i < count; i++)
|
for (long i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
if (!read (readBuffer))
|
if (!stream.readBytes (buffer, 0, bufferLength, result))
|
||||||
{
|
{
|
||||||
readEnd = true;
|
end = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!readEnd && rem > 0)
|
if (!end && rem > 0)
|
||||||
read (new byte [rem]);
|
stream.readBytes (new byte [rem], 0, rem, result);
|
||||||
|
|
||||||
readData.Close ();
|
result.Close ();
|
||||||
return readData.ToArray ();
|
return result.ToArray ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal static void ReadBytesAsync (
|
||||||
|
this Stream stream, int length, Action<byte []> completed, Action<Exception> error)
|
||||||
|
{
|
||||||
|
var buffer = new byte [length];
|
||||||
|
AsyncCallback callback = ar =>
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
var readLen = stream.EndRead (ar);
|
||||||
|
var result = readLen < 1
|
||||||
|
? new byte []{}
|
||||||
|
: readLen < length
|
||||||
|
? stream.readBytes (buffer, readLen, length - readLen)
|
||||||
|
: buffer;
|
||||||
|
|
||||||
|
if (completed != null)
|
||||||
|
completed (result);
|
||||||
|
}
|
||||||
|
catch (Exception ex) {
|
||||||
|
if (error != null)
|
||||||
|
error (ex);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
stream.BeginRead (buffer, 0, length, callback, null);
|
||||||
|
}
|
||||||
|
|
||||||
internal static string RemovePrefix (this string value, params string [] prefixes)
|
internal static string RemovePrefix (this string value, params string [] prefixes)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@@ -607,6 +625,22 @@ namespace WebSocketSharp
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal static byte [] ToByteArrayInternally (this ushort value, ByteOrder order)
|
||||||
|
{
|
||||||
|
var buffer = BitConverter.GetBytes (value);
|
||||||
|
return order.IsHostOrder ()
|
||||||
|
? buffer
|
||||||
|
: buffer.Reverse ().ToArray ();
|
||||||
|
}
|
||||||
|
|
||||||
|
internal static byte [] ToByteArrayInternally (this ulong value, ByteOrder order)
|
||||||
|
{
|
||||||
|
var buffer = BitConverter.GetBytes (value);
|
||||||
|
return order.IsHostOrder ()
|
||||||
|
? buffer
|
||||||
|
: buffer.Reverse ().ToArray ();
|
||||||
|
}
|
||||||
|
|
||||||
internal static string ToCompressionExtension (this CompressionMethod method)
|
internal static string ToCompressionExtension (this CompressionMethod method)
|
||||||
{
|
{
|
||||||
return method != CompressionMethod.NONE
|
return method != CompressionMethod.NONE
|
||||||
@@ -623,6 +657,16 @@ namespace WebSocketSharp
|
|||||||
return CompressionMethod.NONE;
|
return CompressionMethod.NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal static ushort ToUInt16 (this byte [] src, ByteOrder srcOrder)
|
||||||
|
{
|
||||||
|
return BitConverter.ToUInt16 (src.ToHostOrder (srcOrder), 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal static ulong ToUInt64 (this byte [] src, ByteOrder srcOrder)
|
||||||
|
{
|
||||||
|
return BitConverter.ToUInt64 (src.ToHostOrder (srcOrder), 0);
|
||||||
|
}
|
||||||
|
|
||||||
internal static string TrimEndSlash (this string value)
|
internal static string TrimEndSlash (this string value)
|
||||||
{
|
{
|
||||||
value = value.TrimEnd ('/');
|
value = value.TrimEnd ('/');
|
||||||
@@ -1148,48 +1192,6 @@ namespace WebSocketSharp
|
|||||||
return uriString.Substring (0, p).IsPredefinedScheme ();
|
return uriString.Substring (0, p).IsPredefinedScheme ();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Reads a block of bytes from the specified <see cref="Stream"/>
|
|
||||||
/// and returns the read data in an array of <see cref="byte"/>.
|
|
||||||
/// </summary>
|
|
||||||
/// <returns>
|
|
||||||
/// An array of <see cref="byte"/> that receives the read data.
|
|
||||||
/// </returns>
|
|
||||||
/// <param name="stream">
|
|
||||||
/// A <see cref="Stream"/> that contains the data to read.
|
|
||||||
/// </param>
|
|
||||||
/// <param name="length">
|
|
||||||
/// An <see cref="int"/> that contains the number of bytes to read.
|
|
||||||
/// </param>
|
|
||||||
public static byte [] ReadBytes (this Stream stream, int length)
|
|
||||||
{
|
|
||||||
return stream == null || length < 1
|
|
||||||
? new byte []{}
|
|
||||||
: stream.ReadBytesInternal (length);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Reads a block of bytes from the specified <see cref="Stream"/>
|
|
||||||
/// and returns the read data in an array of <see cref="byte"/>.
|
|
||||||
/// </summary>
|
|
||||||
/// <returns>
|
|
||||||
/// An array of <see cref="byte"/> that receives the read data.
|
|
||||||
/// </returns>
|
|
||||||
/// <param name="stream">
|
|
||||||
/// A <see cref="Stream"/> that contains the data to read.
|
|
||||||
/// </param>
|
|
||||||
/// <param name="length">
|
|
||||||
/// A <see cref="long"/> that contains the number of bytes to read.
|
|
||||||
/// </param>
|
|
||||||
public static byte [] ReadBytes (this Stream stream, long length)
|
|
||||||
{
|
|
||||||
return stream == null || length < 1
|
|
||||||
? new byte []{}
|
|
||||||
: length > 1024
|
|
||||||
? stream.ReadBytesInternal (length, 1024)
|
|
||||||
: stream.ReadBytesInternal ((int) length);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Retrieves a sub-array from the specified <paramref name="array"/>.
|
/// Retrieves a sub-array from the specified <paramref name="array"/>.
|
||||||
/// A sub-array starts at the specified element position.
|
/// A sub-array starts at the specified element position.
|
||||||
@@ -1212,13 +1214,13 @@ namespace WebSocketSharp
|
|||||||
public static T [] SubArray<T> (this T [] array, int startIndex, int length)
|
public static T [] SubArray<T> (this T [] array, int startIndex, int length)
|
||||||
{
|
{
|
||||||
if (array == null || array.Length == 0)
|
if (array == null || array.Length == 0)
|
||||||
return new T [] {};
|
return new T []{};
|
||||||
|
|
||||||
if (startIndex < 0 || length <= 0)
|
if (startIndex < 0 || length <= 0)
|
||||||
return new T [] {};
|
return new T []{};
|
||||||
|
|
||||||
if (startIndex + length > array.Length)
|
if (startIndex + length > array.Length)
|
||||||
return new T [] {};
|
return new T []{};
|
||||||
|
|
||||||
if (startIndex == 0 && array.Length == length)
|
if (startIndex == 0 && array.Length == length)
|
||||||
return array;
|
return array;
|
||||||
|
@@ -88,7 +88,7 @@ namespace WebSocketSharp
|
|||||||
internal bool ContainsReservedCloseStatusCode {
|
internal bool ContainsReservedCloseStatusCode {
|
||||||
get {
|
get {
|
||||||
return ApplicationData.Length > 1
|
return ApplicationData.Length > 1
|
||||||
? ApplicationData.SubArray (0, 2).To<ushort> (ByteOrder.BIG).IsReserved ()
|
? ApplicationData.SubArray (0, 2).ToUInt16 (ByteOrder.BIG).IsReserved ()
|
||||||
: false;
|
: false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -330,7 +330,8 @@ namespace WebSocketSharp.Server
|
|||||||
}
|
}
|
||||||
|
|
||||||
_listening = false;
|
_listening = false;
|
||||||
_serviceHosts.Stop (((ushort) CloseStatusCode.SERVER_ERROR).ToByteArray (ByteOrder.BIG), true);
|
_serviceHosts.Stop (
|
||||||
|
((ushort) CloseStatusCode.SERVER_ERROR).ToByteArrayInternally (ByteOrder.BIG), true);
|
||||||
_listener.Abort ();
|
_listener.Abort ();
|
||||||
|
|
||||||
_state = ServerState.STOP;
|
_state = ServerState.STOP;
|
||||||
|
@@ -208,7 +208,8 @@ namespace WebSocketSharp.Server
|
|||||||
}
|
}
|
||||||
|
|
||||||
StopListener ();
|
StopListener ();
|
||||||
_serviceHosts.Stop (((ushort) CloseStatusCode.SERVER_ERROR).ToByteArray (ByteOrder.BIG), true);
|
_serviceHosts.Stop (
|
||||||
|
((ushort) CloseStatusCode.SERVER_ERROR).ToByteArrayInternally (ByteOrder.BIG), true);
|
||||||
|
|
||||||
_state = ServerState.STOP;
|
_state = ServerState.STOP;
|
||||||
}
|
}
|
||||||
|
@@ -467,7 +467,8 @@ namespace WebSocketSharp.Server
|
|||||||
}
|
}
|
||||||
|
|
||||||
StopListener ();
|
StopListener ();
|
||||||
_sessions.Stop (((ushort) CloseStatusCode.SERVER_ERROR).ToByteArray (ByteOrder.BIG), true);
|
_sessions.Stop (
|
||||||
|
((ushort) CloseStatusCode.SERVER_ERROR).ToByteArrayInternally (ByteOrder.BIG), true);
|
||||||
|
|
||||||
_state = ServerState.STOP;
|
_state = ServerState.STOP;
|
||||||
}
|
}
|
||||||
|
@@ -305,7 +305,7 @@ namespace WebSocketSharp.Server
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (host.Sessions.State == ServerState.START)
|
if (host.Sessions.State == ServerState.START)
|
||||||
host.Sessions.Stop (((ushort) CloseStatusCode.AWAY).ToByteArray (ByteOrder.BIG), true);
|
host.Sessions.Stop (((ushort) CloseStatusCode.AWAY).ToByteArrayInternally (ByteOrder.BIG), true);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@@ -1420,7 +1420,7 @@ namespace WebSocketSharp
|
|||||||
}
|
}
|
||||||
|
|
||||||
var send = _readyState == WebSocketState.OPEN && !code.IsReserved ();
|
var send = _readyState == WebSocketState.OPEN && !code.IsReserved ();
|
||||||
close (new PayloadData (code.ToByteArray (ByteOrder.BIG)), send, true);
|
close (new PayloadData (code.ToByteArrayInternally (ByteOrder.BIG)), send, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -1433,7 +1433,7 @@ namespace WebSocketSharp
|
|||||||
public void Close (CloseStatusCode code)
|
public void Close (CloseStatusCode code)
|
||||||
{
|
{
|
||||||
var send = _readyState == WebSocketState.OPEN && !code.IsReserved ();
|
var send = _readyState == WebSocketState.OPEN && !code.IsReserved ();
|
||||||
close (new PayloadData (((ushort) code).ToByteArray (ByteOrder.BIG)), send, true);
|
close (new PayloadData (((ushort) code).ToByteArrayInternally (ByteOrder.BIG)), send, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -1671,7 +1671,7 @@ namespace WebSocketSharp
|
|||||||
var msg = _readyState.CheckIfOpen () ??
|
var msg = _readyState.CheckIfOpen () ??
|
||||||
stream.CheckIfCanRead () ??
|
stream.CheckIfCanRead () ??
|
||||||
(length < 1 ? "'length' must be greater than 0." : null) ??
|
(length < 1 ? "'length' must be greater than 0." : null) ??
|
||||||
((readLen = (data = stream.ReadBytesInternal (length)).Length) == 0
|
((readLen = (data = stream.ReadBytes (length)).Length) == 0
|
||||||
? "A data cannot be read from 'stream'." : null);
|
? "A data cannot be read from 'stream'." : null);
|
||||||
|
|
||||||
if (msg != null)
|
if (msg != null)
|
||||||
@@ -1796,13 +1796,9 @@ namespace WebSocketSharp
|
|||||||
/// </param>
|
/// </param>
|
||||||
public void SendAsync (Stream stream, int length, bool dispose, Action completed)
|
public void SendAsync (Stream stream, int length, bool dispose, Action completed)
|
||||||
{
|
{
|
||||||
byte [] data = null;
|
|
||||||
int readLen = 0;
|
|
||||||
var msg = _readyState.CheckIfOpen () ??
|
var msg = _readyState.CheckIfOpen () ??
|
||||||
stream.CheckIfCanRead () ??
|
stream.CheckIfCanRead () ??
|
||||||
(length < 1 ? "'length' must be greater than 0." : null) ??
|
(length < 1 ? "'length' must be greater than 0." : null);
|
||||||
((readLen = (data = stream.ReadBytesInternal (length)).Length) == 0
|
|
||||||
? "A data cannot be read from 'stream'." : null);
|
|
||||||
|
|
||||||
if (msg != null)
|
if (msg != null)
|
||||||
{
|
{
|
||||||
@@ -1812,17 +1808,40 @@ namespace WebSocketSharp
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (readLen != length)
|
Action<byte []> result = data =>
|
||||||
_logger.Warn (String.Format (
|
{
|
||||||
"A data with 'length' cannot be read from 'stream'.\nexpected: {0} actual: {1}", length, readLen));
|
var readLen = data.Length;
|
||||||
|
if (readLen == 0)
|
||||||
|
{
|
||||||
|
var err = "A data cannot be read from 'stream'.";
|
||||||
|
_logger.Error (err);
|
||||||
|
error (err);
|
||||||
|
|
||||||
if (dispose)
|
return;
|
||||||
stream.Dispose ();
|
}
|
||||||
|
|
||||||
if (readLen <= FragmentLength)
|
if (readLen != length)
|
||||||
sendAsync (Opcode.BINARY, data, completed);
|
_logger.Warn (String.Format (
|
||||||
else
|
"A data with 'length' cannot be read from 'stream'.\nexpected: {0} actual: {1}",
|
||||||
sendAsync (Opcode.BINARY, new MemoryStream (data), completed);
|
length,
|
||||||
|
readLen));
|
||||||
|
|
||||||
|
if (dispose)
|
||||||
|
stream.Dispose ();
|
||||||
|
|
||||||
|
if (readLen <= FragmentLength)
|
||||||
|
sendAsync (Opcode.BINARY, data, completed);
|
||||||
|
else
|
||||||
|
sendAsync (Opcode.BINARY, new MemoryStream (data), completed);
|
||||||
|
};
|
||||||
|
|
||||||
|
Action<Exception> exception = ex =>
|
||||||
|
{
|
||||||
|
_logger.Fatal (ex.ToString ());
|
||||||
|
error ("An exception has occured.");
|
||||||
|
};
|
||||||
|
|
||||||
|
stream.ReadBytesAsync (length, result, exception);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@@ -87,8 +87,8 @@ namespace WebSocketSharp
|
|||||||
ExtPayloadLen = payloadLen < 126
|
ExtPayloadLen = payloadLen < 126
|
||||||
? new byte []{}
|
? new byte []{}
|
||||||
: payloadLen == 126
|
: payloadLen == 126
|
||||||
? ((ushort) dataLen).ToByteArray (ByteOrder.BIG)
|
? ((ushort) dataLen).ToByteArrayInternally (ByteOrder.BIG)
|
||||||
: dataLen.ToByteArray (ByteOrder.BIG);
|
: dataLen.ToByteArrayInternally (ByteOrder.BIG);
|
||||||
|
|
||||||
/* MaskingKey */
|
/* MaskingKey */
|
||||||
|
|
||||||
@@ -399,7 +399,7 @@ namespace WebSocketSharp
|
|||||||
: 8;
|
: 8;
|
||||||
|
|
||||||
var extPayloadLen = extLen > 0
|
var extPayloadLen = extLen > 0
|
||||||
? stream.ReadBytesInternal (extLen)
|
? stream.ReadBytes (extLen)
|
||||||
: new byte []{};
|
: new byte []{};
|
||||||
|
|
||||||
if (extLen > 0 && extPayloadLen.Length != extLen)
|
if (extLen > 0 && extPayloadLen.Length != extLen)
|
||||||
@@ -414,7 +414,7 @@ namespace WebSocketSharp
|
|||||||
|
|
||||||
var masked = mask == Mask.MASK;
|
var masked = mask == Mask.MASK;
|
||||||
var maskingKey = masked
|
var maskingKey = masked
|
||||||
? stream.ReadBytesInternal (4)
|
? stream.ReadBytes (4)
|
||||||
: new byte []{};
|
: new byte []{};
|
||||||
|
|
||||||
if (masked && maskingKey.Length != 4)
|
if (masked && maskingKey.Length != 4)
|
||||||
@@ -430,8 +430,8 @@ namespace WebSocketSharp
|
|||||||
ulong dataLen = payloadLen < 126
|
ulong dataLen = payloadLen < 126
|
||||||
? payloadLen
|
? payloadLen
|
||||||
: payloadLen == 126
|
: payloadLen == 126
|
||||||
? extPayloadLen.To<ushort> (ByteOrder.BIG)
|
? extPayloadLen.ToUInt16 (ByteOrder.BIG)
|
||||||
: extPayloadLen.To<ulong> (ByteOrder.BIG);
|
: extPayloadLen.ToUInt64 (ByteOrder.BIG);
|
||||||
|
|
||||||
byte [] data = null;
|
byte [] data = null;
|
||||||
if (dataLen > 0)
|
if (dataLen > 0)
|
||||||
@@ -442,9 +442,9 @@ namespace WebSocketSharp
|
|||||||
return CreateCloseFrame (Mask.UNMASK, code, code.GetMessage ());
|
return CreateCloseFrame (Mask.UNMASK, code, code.GetMessage ());
|
||||||
}
|
}
|
||||||
|
|
||||||
data = dataLen > 1024
|
data = payloadLen > 126
|
||||||
? stream.ReadBytesInternal ((long) dataLen, 1024)
|
? stream.ReadBytes ((long) dataLen, 1024)
|
||||||
: stream.ReadBytesInternal ((int) dataLen);
|
: stream.ReadBytes ((int) dataLen);
|
||||||
|
|
||||||
if (data.LongLength != (long) dataLen)
|
if (data.LongLength != (long) dataLen)
|
||||||
return CreateCloseFrame (
|
return CreateCloseFrame (
|
||||||
@@ -473,9 +473,9 @@ namespace WebSocketSharp
|
|||||||
{
|
{
|
||||||
var len = frame.ExtPayloadLen.Length;
|
var len = frame.ExtPayloadLen.Length;
|
||||||
var extPayloadLen = len == 2
|
var extPayloadLen = len == 2
|
||||||
? frame.ExtPayloadLen.To<ushort> (ByteOrder.BIG).ToString ()
|
? frame.ExtPayloadLen.ToUInt16 (ByteOrder.BIG).ToString ()
|
||||||
: len == 8
|
: len == 8
|
||||||
? frame.ExtPayloadLen.To<ulong> (ByteOrder.BIG).ToString ()
|
? frame.ExtPayloadLen.ToUInt64 (ByteOrder.BIG).ToString ()
|
||||||
: String.Empty;
|
: String.Empty;
|
||||||
|
|
||||||
var masked = frame.IsMasked;
|
var masked = frame.IsMasked;
|
||||||
@@ -584,7 +584,7 @@ namespace WebSocketSharp
|
|||||||
WsFrame frame = null;
|
WsFrame frame = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var header = stream.ReadBytesInternal (2);
|
var header = stream.ReadBytes (2);
|
||||||
frame = header.Length == 2
|
frame = header.Length == 2
|
||||||
? parse (header, stream, unmask)
|
? parse (header, stream, unmask)
|
||||||
: CreateCloseFrame (
|
: CreateCloseFrame (
|
||||||
@@ -672,7 +672,7 @@ namespace WebSocketSharp
|
|||||||
header = (header << 4) + (int) Opcode;
|
header = (header << 4) + (int) Opcode;
|
||||||
header = (header << 1) + (int) Mask;
|
header = (header << 1) + (int) Mask;
|
||||||
header = (header << 7) + (int) PayloadLen;
|
header = (header << 7) + (int) PayloadLen;
|
||||||
buffer.Write (((ushort) header).ToByteArray (ByteOrder.BIG), 0, 2);
|
buffer.Write (((ushort) header).ToByteArrayInternally (ByteOrder.BIG), 0, 2);
|
||||||
|
|
||||||
if (PayloadLen > 125)
|
if (PayloadLen > 125)
|
||||||
buffer.Write (ExtPayloadLen, 0, ExtPayloadLen.Length);
|
buffer.Write (ExtPayloadLen, 0, ExtPayloadLen.Length);
|
||||||
|
Reference in New Issue
Block a user