@colyseus/sdk 0.17.18 → 0.17.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/build/3rd_party/discord.cjs +1 -1
  2. package/build/3rd_party/discord.mjs +1 -1
  3. package/build/Auth.cjs +1 -1
  4. package/build/Auth.mjs +1 -1
  5. package/build/Client.cjs +3 -4
  6. package/build/Client.cjs.map +1 -1
  7. package/build/Client.mjs +2 -3
  8. package/build/Client.mjs.map +1 -1
  9. package/build/Connection.cjs +1 -1
  10. package/build/Connection.mjs +1 -1
  11. package/build/HTTP.cjs +1 -1
  12. package/build/HTTP.mjs +1 -1
  13. package/build/Room.cjs +20 -18
  14. package/build/Room.cjs.map +1 -1
  15. package/build/Room.mjs +8 -6
  16. package/build/Room.mjs.map +1 -1
  17. package/build/Storage.cjs +1 -1
  18. package/build/Storage.mjs +1 -1
  19. package/build/core/nanoevents.cjs +1 -1
  20. package/build/core/nanoevents.mjs +1 -1
  21. package/build/core/signal.cjs +1 -1
  22. package/build/core/signal.mjs +1 -1
  23. package/build/core/utils.cjs +1 -1
  24. package/build/core/utils.mjs +1 -1
  25. package/build/debug.cjs +1 -1
  26. package/build/debug.mjs +1 -1
  27. package/build/errors/Errors.cjs +1 -1
  28. package/build/errors/Errors.mjs +1 -1
  29. package/build/index.cjs +1 -1
  30. package/build/index.mjs +1 -1
  31. package/build/legacy.cjs +1 -1
  32. package/build/legacy.mjs +1 -1
  33. package/build/serializer/NoneSerializer.cjs +1 -1
  34. package/build/serializer/NoneSerializer.mjs +1 -1
  35. package/build/serializer/SchemaSerializer.cjs +1 -1
  36. package/build/serializer/SchemaSerializer.mjs +1 -1
  37. package/build/serializer/Serializer.cjs +1 -1
  38. package/build/serializer/Serializer.mjs +1 -1
  39. package/build/transport/H3Transport.cjs +1 -1
  40. package/build/transport/H3Transport.mjs +1 -1
  41. package/build/transport/WebSocketTransport.cjs +1 -1
  42. package/build/transport/WebSocketTransport.mjs +1 -1
  43. package/dist/colyseus-cocos-creator.js +23 -37
  44. package/dist/colyseus-cocos-creator.js.map +1 -1
  45. package/dist/colyseus.js +23 -37
  46. package/dist/colyseus.js.map +1 -1
  47. package/dist/debug.js +22 -45
  48. package/dist/debug.js.map +1 -1
  49. package/package.json +4 -4
  50. package/src/Client.ts +1 -3
  51. package/src/Room.ts +8 -5
  52. package/src/Protocol.ts +0 -25
@@ -3,7 +3,7 @@
3
3
  // This software is released under the MIT License.
4
4
  // https://opensource.org/license/MIT
5
5
  //
6
- // colyseus.js@0.17.18 - @colyseus/schema 4.0.4
6
+ // colyseus.js@0.17.20 - @colyseus/schema 4.0.5
7
7
  // THIS VERSION USES "XMLHttpRequest" INSTEAD OF "fetch" FOR COMPATIBILITY WITH COCOS CREATOR
8
8
  (function (global, factory) {
9
9
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
@@ -83,7 +83,7 @@
83
83
  };
84
84
 
85
85
  // packages/shared-types/src/Protocol.ts
86
- var Protocol$1 = {
86
+ var Protocol = {
87
87
  // Room-related (10~19)
88
88
  JOIN_ROOM: 10,
89
89
  ERROR: 11,
@@ -96,7 +96,7 @@
96
96
  ROOM_DATA_BYTES: 17,
97
97
  PING: 18
98
98
  };
99
- var ErrorCode$1 = {
99
+ var ErrorCode = {
100
100
  MATCHMAKE_NO_HANDLER: 520,
101
101
  MATCHMAKE_INVALID_CRITERIA: 521,
102
102
  MATCHMAKE_INVALID_ROOM_ID: 522,
@@ -3832,6 +3832,15 @@
3832
3832
  static is(type) {
3833
3833
  return typeof (type[Symbol.metadata]) === "object";
3834
3834
  }
3835
+ /**
3836
+ * Check if a value is an instance of Schema.
3837
+ * This method uses duck-typing to avoid issues with multiple @colyseus/schema versions.
3838
+ * @param obj Value to check
3839
+ * @returns true if the value is a Schema instance
3840
+ */
3841
+ static isSchema(obj) {
3842
+ return typeof obj?.assign === "function";
3843
+ }
3835
3844
  /**
3836
3845
  * Track property changes
3837
3846
  */
@@ -5036,13 +5045,13 @@
5036
5045
  // trigger onRemove on child structure.
5037
5046
  //
5038
5047
  if ((change.op & exports$1.OPERATION.DELETE) === exports$1.OPERATION.DELETE &&
5039
- change.previousValue instanceof Schema) {
5048
+ Schema.isSchema(change.previousValue)) {
5040
5049
  const deleteCallbacks = callbacks[change.previousValue[$refId]]?.[exports$1.OPERATION.DELETE];
5041
5050
  for (let i = deleteCallbacks?.length - 1; i >= 0; i--) {
5042
5051
  deleteCallbacks[i]();
5043
5052
  }
5044
5053
  }
5045
- if (ref instanceof Schema) {
5054
+ if (Schema.isSchema(ref)) {
5046
5055
  //
5047
5056
  // Handle schema instance
5048
5057
  //
@@ -5426,7 +5435,7 @@
5426
5435
  // trigger onRemove on child structure.
5427
5436
  //
5428
5437
  if ((change.op & exports$1.OPERATION.DELETE) === exports$1.OPERATION.DELETE &&
5429
- change.previousValue instanceof Schema) {
5438
+ Schema.isSchema(change.previousValue)) {
5430
5439
  const childRefId = change.previousValue[$refId];
5431
5440
  const deleteCallbacks = this.callbacks[childRefId]?.[exports$1.OPERATION.DELETE];
5432
5441
  if (deleteCallbacks) {
@@ -5435,7 +5444,7 @@
5435
5444
  }
5436
5445
  }
5437
5446
  }
5438
- if (ref instanceof Schema) {
5447
+ if (Schema.isSchema(ref)) {
5439
5448
  //
5440
5449
  // Handle Schema instance
5441
5450
  //
@@ -8387,32 +8396,6 @@
8387
8396
  }
8388
8397
  _Connection__offlineListener = new WeakMap();
8389
8398
 
8390
- // Use codes between 0~127 for lesser throughput (1 byte)
8391
- var Protocol;
8392
- (function (Protocol) {
8393
- // Room-related (10~19)
8394
- Protocol[Protocol["HANDSHAKE"] = 9] = "HANDSHAKE";
8395
- Protocol[Protocol["JOIN_ROOM"] = 10] = "JOIN_ROOM";
8396
- Protocol[Protocol["ERROR"] = 11] = "ERROR";
8397
- Protocol[Protocol["LEAVE_ROOM"] = 12] = "LEAVE_ROOM";
8398
- Protocol[Protocol["ROOM_DATA"] = 13] = "ROOM_DATA";
8399
- Protocol[Protocol["ROOM_STATE"] = 14] = "ROOM_STATE";
8400
- Protocol[Protocol["ROOM_STATE_PATCH"] = 15] = "ROOM_STATE_PATCH";
8401
- Protocol[Protocol["ROOM_DATA_SCHEMA"] = 16] = "ROOM_DATA_SCHEMA";
8402
- Protocol[Protocol["ROOM_DATA_BYTES"] = 17] = "ROOM_DATA_BYTES";
8403
- Protocol[Protocol["PING"] = 18] = "PING";
8404
- })(Protocol || (Protocol = {}));
8405
- var ErrorCode;
8406
- (function (ErrorCode) {
8407
- ErrorCode[ErrorCode["MATCHMAKE_NO_HANDLER"] = 520] = "MATCHMAKE_NO_HANDLER";
8408
- ErrorCode[ErrorCode["MATCHMAKE_INVALID_CRITERIA"] = 521] = "MATCHMAKE_INVALID_CRITERIA";
8409
- ErrorCode[ErrorCode["MATCHMAKE_INVALID_ROOM_ID"] = 522] = "MATCHMAKE_INVALID_ROOM_ID";
8410
- ErrorCode[ErrorCode["MATCHMAKE_UNHANDLED"] = 523] = "MATCHMAKE_UNHANDLED";
8411
- ErrorCode[ErrorCode["MATCHMAKE_EXPIRED"] = 524] = "MATCHMAKE_EXPIRED";
8412
- ErrorCode[ErrorCode["AUTH_FAILED"] = 525] = "AUTH_FAILED";
8413
- ErrorCode[ErrorCode["APPLICATION_ERROR"] = 526] = "APPLICATION_ERROR";
8414
- })(ErrorCode || (ErrorCode = {}));
8415
-
8416
8399
  const serializers = {};
8417
8400
  function registerSerializer(id, serializer) {
8418
8401
  serializers[id] = serializer;
@@ -8591,8 +8574,11 @@
8591
8574
  // msgpackr workaround: force buffer to be created.
8592
8575
  this.packr.encode(undefined);
8593
8576
  if (rootSchema) {
8594
- this.serializer = new (getSerializer("schema"));
8595
- this.serializer.state = new rootSchema();
8577
+ const serializer = new (getSerializer("schema"));
8578
+ this.serializer = serializer;
8579
+ const state = new rootSchema();
8580
+ serializer.state = state;
8581
+ serializer.decoder = new buildExports.Decoder(state);
8596
8582
  }
8597
8583
  this.onLeave(() => this.removeAllListeners());
8598
8584
  }
@@ -9603,9 +9589,9 @@
9603
9589
  exports.Client = Client;
9604
9590
  exports.CloseCode = CloseCode;
9605
9591
  exports.ColyseusSDK = ColyseusSDK;
9606
- exports.ErrorCode = ErrorCode$1;
9592
+ exports.ErrorCode = ErrorCode;
9607
9593
  exports.MatchMakeError = MatchMakeError;
9608
- exports.Protocol = Protocol$1;
9594
+ exports.Protocol = Protocol;
9609
9595
  exports.Room = Room;
9610
9596
  exports.SchemaSerializer = SchemaSerializer;
9611
9597
  exports.ServerError = ServerError;