This commit is contained in:
Olivier Gagnon 2021-09-21 20:39:25 -04:00
parent 0c932dd4d1
commit dc518e7032
3 changed files with 52 additions and 48 deletions

@ -2354,7 +2354,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("write", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port.write(data);
@ -2421,7 +2421,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("tryWrite", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port.tryWrite(data);
@ -2442,7 +2442,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("read", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port.read();
@ -2489,7 +2489,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("peek", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port.peek();
@ -2506,7 +2506,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("clear", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port.clear();
@ -2542,7 +2542,7 @@ function NetscriptFunctions(workerScript) {
);
}
var port = NetscriptPorts[port - 1];
if (port == null || !(port instanceof NetscriptPort)) {
if (port == null || !(port instanceof Object)) {
throw makeRuntimeErrorMsg("getPortHandle", `Could not find port: ${port}. This is a bug. Report to dev.`);
}
return port;

@ -1,51 +1,55 @@
import { Settings } from "./Settings/Settings";
export class NetscriptPort {
data: any[] = [];
interface IPort {}
export function NetscriptPort(): IPort {
const data: any[] = [];
return {
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
write(data: any): any {
this.data.push(data);
if (this.data.length > Settings.MaxPortCapacity) {
return this.data.shift();
write: (value: any): any => {
data.push(value);
if (data.length > Settings.MaxPortCapacity) {
return data.shift();
}
return null;
}
},
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
tryWrite(data: any): boolean {
if (this.data.length >= Settings.MaxPortCapacity) {
tryWrite: (value: any): boolean => {
if (data.length >= Settings.MaxPortCapacity) {
return false;
}
this.data.push(data);
data.push(value);
return true;
}
},
read(): any {
if (this.data.length === 0) {
read: (): any => {
if (data.length === 0) {
return "NULL PORT DATA";
}
return this.data.shift();
}
return data.shift();
},
peek(): any {
if (this.data.length === 0) {
peek: (): any => {
if (data.length === 0) {
return "NULL PORT DATA";
} else {
const foo = this.data.slice();
const foo = data.slice();
return foo[0];
}
}
},
full(): boolean {
return this.data.length == Settings.MaxPortCapacity;
}
full: (): boolean => {
return data.length == Settings.MaxPortCapacity;
},
empty(): boolean {
return this.data.length === 0;
}
empty: (): boolean => {
return data.length === 0;
},
clear(): void {
this.data.length = 0;
}
clear: (): void => {
data.length = 0;
},
};
}

@ -35,7 +35,7 @@ import { simple as walksimple } from "acorn-walk";
// Netscript Ports are instantiated here
export const NetscriptPorts = [];
for (var i = 0; i < CONSTANTS.NumNetscriptPorts; ++i) {
NetscriptPorts.push(new NetscriptPort());
NetscriptPorts.push(NetscriptPort());
}
export function prestigeWorkerScripts() {