mirror of
https://github.com/samsonjs/cpwebsocket.git
synced 2026-03-25 09:15:48 +00:00
Draft 76
This commit is contained in:
parent
e171f4ab46
commit
e3ca5ee0ac
1 changed files with 25 additions and 3 deletions
|
|
@ -2,6 +2,7 @@
|
||||||
// CPWebSocket.j
|
// CPWebSocket.j
|
||||||
//
|
//
|
||||||
// Copyright 2010 Sami Samhuri
|
// Copyright 2010 Sami Samhuri
|
||||||
|
// Additions Ignacio Cases
|
||||||
//
|
//
|
||||||
// MIT license
|
// MIT license
|
||||||
//
|
//
|
||||||
|
|
@ -39,15 +40,19 @@ CPWebSocketStateClosed = 3;
|
||||||
{
|
{
|
||||||
_ws.onopen = function() {
|
_ws.onopen = function() {
|
||||||
[delegate webSocketDidOpen: self];
|
[delegate webSocketDidOpen: self];
|
||||||
|
[[CPRunLoop currentRunLoop] limitDateForMode:CPDefaultRunLoopMode];
|
||||||
};
|
};
|
||||||
_ws.onclose = function(event) {
|
_ws.onclose = function(event) {
|
||||||
[delegate webSocketDidClose: self];
|
[delegate webSocketDidClose: self];
|
||||||
|
[[CPRunLoop currentRunLoop] limitDateForMode:CPDefaultRunLoopMode];
|
||||||
};
|
};
|
||||||
_ws.onmessage = function(event) {
|
_ws.onmessage = function(event) {
|
||||||
[delegate webSocket: self didReceiveMessage: event.data];
|
[delegate webSocket: self didReceiveMessage: event.data];
|
||||||
|
[[CPRunLoop currentRunLoop] limitDateForMode:CPDefaultRunLoopMode];
|
||||||
};
|
};
|
||||||
_ws.onerror = function(event) {
|
_ws.onerror = function(event) {
|
||||||
[delegate webSocketDidReceiveError: self];
|
[delegate webSocketDidReceiveError: self];
|
||||||
|
[[CPRunLoop currentRunLoop] limitDateForMode:CPDefaultRunLoopMode];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -56,9 +61,26 @@ CPWebSocketStateClosed = 3;
|
||||||
return _ws.URL;
|
return _ws.URL;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (CPNumber) state
|
// I. Cases: In Draft 76 the api is readyState instead of state
|
||||||
|
- (CPNumber) readyState
|
||||||
{
|
{
|
||||||
return _ws.state;
|
return _ws.readyState;
|
||||||
|
}
|
||||||
|
// I. Cases
|
||||||
|
- (CPString)state
|
||||||
|
{
|
||||||
|
var result;
|
||||||
|
|
||||||
|
if ([self readyState] == 0) {
|
||||||
|
result = @"CPWebSocketStateConnecting";
|
||||||
|
}else if ([self readyState] == 1) {
|
||||||
|
result = @"CPWebSocketStateOpen";
|
||||||
|
} else if ([self readyState] == 2) {
|
||||||
|
result = @"CPWebSocketStateClosing";
|
||||||
|
} else if ([self readyState] == 3) {
|
||||||
|
result = @"CPWebSocketStateClosed";
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
- (CPNumber) bytesBuffered
|
- (CPNumber) bytesBuffered
|
||||||
|
|
@ -71,7 +93,7 @@ CPWebSocketStateClosed = 3;
|
||||||
_ws.close();
|
_ws.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL) send: (CPString) data
|
- (BOOL) send: (JSObject) data
|
||||||
{
|
{
|
||||||
// TODO check the state, should not be CPWebSocketConnecting
|
// TODO check the state, should not be CPWebSocketConnecting
|
||||||
return _ws.send(data);
|
return _ws.send(data);
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue