revert change as it is still broken in mono
This commit is contained in:
parent
3aa03a719c
commit
3572f7297d
|
@ -13,17 +13,6 @@ namespace Ooui
|
|||
|
||||
protected readonly List<Message> queuedMessages = new List<Message> ();
|
||||
|
||||
protected readonly System.Threading.SemaphoreSlim slimSema=new System.Threading.SemaphoreSlim(0,1);
|
||||
|
||||
protected void LockQueue()
|
||||
{
|
||||
slimSema.Wait();
|
||||
}
|
||||
protected void UnlockQueue()
|
||||
{
|
||||
slimSema.Release();
|
||||
}
|
||||
|
||||
protected readonly bool disposeElementAfterSession;
|
||||
readonly Action<string, Exception> errorLogger;
|
||||
|
||||
|
@ -91,9 +80,9 @@ namespace Ooui
|
|||
|
||||
protected virtual void QueueMessage (Message message)
|
||||
{
|
||||
LockQueue();
|
||||
lock (queuedMessages) {
|
||||
QueueMessageLocked (message);
|
||||
UnlockQueue();
|
||||
}
|
||||
}
|
||||
|
||||
protected void Error (string message, Exception ex)
|
||||
|
|
|
@ -530,7 +530,7 @@ namespace Ooui
|
|||
// Create a new session and let it handle everything from here
|
||||
//
|
||||
try {
|
||||
var session = new WebSocketSession (this,element, disposeElementWhenDone, w, h, Error, serverToken);
|
||||
var session = new WebSocketSession (element, disposeElementWhenDone, w, h, Error, serverToken);
|
||||
listenerContext.StartWebSocketConnection(session.Opened,
|
||||
session.Arrived,
|
||||
session.Closed); }
|
||||
|
|
|
@ -24,11 +24,11 @@ namespace Ooui
|
|||
DateTime lastTransmitTime = DateTime.MinValue;
|
||||
readonly TimeSpan throttleInterval = TimeSpan.FromSeconds (1.0 / UI.MaxFps);
|
||||
|
||||
public WebSocketSession (UI ui,Element element, bool disposeElementAfterSession, double initialWidth, double initialHeight, Action<string, Exception> errorLogger, CancellationToken serverToken)
|
||||
public WebSocketSession (Element element, bool disposeElementAfterSession, double initialWidth, double initialHeight, Action<string, Exception> errorLogger, CancellationToken serverToken)
|
||||
: base (element, disposeElementAfterSession, initialWidth, initialHeight, errorLogger)
|
||||
{
|
||||
|
||||
this.ui = ui;
|
||||
|
||||
//
|
||||
// Create a new session cancellation token that will trigger
|
||||
// automatically if the server shutsdown or the session shutsdown.
|
||||
|
@ -92,7 +92,7 @@ namespace Ooui
|
|||
//
|
||||
var messagesToSend = new List<Message> ();
|
||||
|
||||
LockQueue();
|
||||
lock (queuedMessages) {
|
||||
messagesToSend.AddRange (queuedMessages);
|
||||
queuedMessages.Clear ();
|
||||
|
||||
|
@ -107,22 +107,9 @@ namespace Ooui
|
|||
//Console.WriteLine ("TRANSMIT " + json);
|
||||
sendMsg?.Invoke(WebSocketMessage.Create(json));
|
||||
//task = webSocket.SendAsync (outputBuffer, WebSocketMessageType.Text, true, token).ConfigureAwait (false);
|
||||
UnlockQueue();
|
||||
}
|
||||
|
||||
}
|
||||
catch ( System.AggregateException ex)
|
||||
{
|
||||
if(ex.ToString().Replace(" ","").ToLower().Contains("mutexisnotowned"))
|
||||
{
|
||||
if(ui.Verbose)
|
||||
Console.WriteLine("Mutex is not owned error, continue going");
|
||||
}else{
|
||||
Error ("Failed to send queued messages, aborting session", ex);
|
||||
element.MessageSent -= handleElementMessageSent;
|
||||
sessionCts.Cancel ();
|
||||
}
|
||||
_=ex;
|
||||
}
|
||||
catch (Exception ex) {
|
||||
Error ("Failed to send queued messages, aborting session", ex);
|
||||
element.MessageSent -= handleElementMessageSent;
|
||||
|
@ -135,7 +122,6 @@ namespace Ooui
|
|||
sendMsg = arg1;
|
||||
Init();
|
||||
}
|
||||
internal UI ui;
|
||||
|
||||
internal void Arrived(WebSocketMessage obj)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue