support binary
This commit is contained in:
@@ -134,26 +134,26 @@ public class Socket extends Emitter {
|
||||
* @return a reference to this object.
|
||||
*/
|
||||
@Override
|
||||
public Emitter emit(final String event, final Object... arguments) {
|
||||
public Emitter emit(final String event, final Object... args) {
|
||||
EventThread.exec(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
if (events.containsKey(event)) {
|
||||
Socket.super.emit(event, arguments);
|
||||
Socket.super.emit(event, args);
|
||||
return;
|
||||
}
|
||||
|
||||
List<Object> args = new ArrayList<Object>(arguments.length + 1);
|
||||
args.add(event);
|
||||
args.addAll(Arrays.asList(arguments));
|
||||
JSONArray _args = new JSONArray(args);
|
||||
List<Object> _args = new ArrayList<Object>(args.length + 1);
|
||||
_args.add(event);
|
||||
_args.addAll(Arrays.asList(args));
|
||||
JSONArray jsonArgs = new JSONArray(_args);
|
||||
int parserType = Parser.EVENT;
|
||||
if (HasBinaryData.hasBinary(_args)) { parserType = Parser.BINARY_EVENT; }
|
||||
Packet packet = new Packet(parserType, _args);
|
||||
if (HasBinaryData.hasBinary(jsonArgs)) { parserType = Parser.BINARY_EVENT; }
|
||||
Packet packet = new Packet(parserType, jsonArgs);
|
||||
|
||||
if (args.get(args.size() - 1) instanceof Ack) {
|
||||
if (_args.get(_args.size() - 1) instanceof Ack) {
|
||||
logger.fine(String.format("emitting packet with ack id %d", Socket.this.ids));
|
||||
Socket.this.acks.put(Socket.this.ids, (Ack)args.remove(args.size() - 1));
|
||||
Socket.this.acks.put(Socket.this.ids, (Ack)_args.remove(_args.size() - 1));
|
||||
packet.id = Socket.this.ids++;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user