node-insim
Version:
An InSim library for NodeJS with TypeScript support
100 lines (99 loc) • 4.16 kB
JavaScript
;
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.IR_HOS = void 0;
var decorators_1 = require("../decorators");
var lfspack_1 = require("../lfspack");
var base_1 = require("./base");
var enums_1 = require("./enums");
var structs_1 = require("./structs");
/**
* Hostlist (hosts connected to the Relay)
*/
var IR_HOS = /** @class */ (function (_super) {
__extends(IR_HOS, _super);
function IR_HOS() {
var _this = _super.apply(this, __spreadArray([], __read(arguments), false)) || this;
_this.SIZE_MULTIPLIER = 1;
/** 4 + NumHosts * 40 */
_this.Size = 4;
_this.Type = enums_1.PacketType.IRP_HOS;
/** As given in {@link IR_HLR} */
_this.ReqI = 0;
/** Number of hosts described in this packet */
_this.NumHosts = 0;
/** Host info for every host in the Relay. 1 to 6 of these in a {@link IR_HOS} */
_this.Info = [];
return _this;
}
IR_HOS.prototype.unpack = function (buffer) {
_super.prototype.unpack.call(this, buffer);
var hostInfoOffset = this.getFormatSize();
var hostInfoLength = new structs_1.HInfo().getFormatSize();
for (var i = 0; i < this.NumHosts; i++) {
var start = hostInfoOffset + hostInfoLength * i;
var hostInfoBuffer = (0, lfspack_1.copyBuffer)(buffer.slice(start, start + hostInfoLength));
this.Info.push(new structs_1.HInfo().unpack(hostInfoBuffer));
}
return this;
};
__decorate([
(0, decorators_1.byte)()
], IR_HOS.prototype, "Size", void 0);
__decorate([
(0, decorators_1.byte)()
], IR_HOS.prototype, "Type", void 0);
__decorate([
(0, decorators_1.byte)()
], IR_HOS.prototype, "ReqI", void 0);
__decorate([
(0, decorators_1.byte)()
], IR_HOS.prototype, "NumHosts", void 0);
return IR_HOS;
}(base_1.Packet));
exports.IR_HOS = IR_HOS;