Fixed bug and added compatibility for converting RunningScript offline dataMap to version v0.43.1

This commit is contained in:
danielyxie 2019-02-12 01:14:38 -08:00
parent 9137c24274
commit 8266492001
7 changed files with 26 additions and 10 deletions

File diff suppressed because one or more lines are too long

@ -22,6 +22,7 @@ import {gameOptionsBoxClose} from "../utils/GameOptions";
import {clearEventListeners} from "../utils/uiHelpers/clearEventListeners"; import {clearEventListeners} from "../utils/uiHelpers/clearEventListeners";
import {Reviver, Generic_toJSON, import {Reviver, Generic_toJSON,
Generic_fromJSON} from "../utils/JSONReviver"; Generic_fromJSON} from "../utils/JSONReviver";
import { convertTimeMsToTimeElapsedString } from "../utils/StringHelperFunctions";
import {createElement} from "../utils/uiHelpers/createElement"; import {createElement} from "../utils/uiHelpers/createElement";
import {createPopup} from "../utils/uiHelpers/createPopup"; import {createPopup} from "../utils/uiHelpers/createPopup";
import {createStatusText} from "./ui/createStatusText"; import {createStatusText} from "./ui/createStatusText";
@ -509,9 +510,11 @@ function loadImportedGame(saveObj, saveString) {
Player.lastUpdate = Engine._lastUpdate; Player.lastUpdate = Engine._lastUpdate;
Engine.start(); //Run main game loop and Scripts loop Engine.start(); //Run main game loop and Scripts loop
dialogBoxCreate("While you were offline, your scripts generated <span class='money-gold'>$" + const timeOfflineString = convertTimeMsToTimeElapsedString(time);
numeralWrapper.format(offlineProductionFromScripts, '0,0.00') + "</span> and your Hacknet Nodes generated <span class='money-gold'>$" + dialogBoxCreate(`Offline for ${timeOfflineString}. While you were offline, your scripts ` +
numeralWrapper.format(offlineProductionFromHacknetNodes, '0,0.00') + "</span>"); "generated <span class='money-gold'>" +
numeralWrapper.formatMoney(offlineProductionFromScripts) + "</span> and your Hacknet Nodes generated <span class='money-gold'>" +
numeralWrapper.formatMoney(offlineProductionFromHacknetNodes) + "</span>");
return true; return true;
} }

@ -812,6 +812,9 @@ function loadAllRunningScripts() {
} }
function scriptCalculateOfflineProduction(runningScriptObj) { function scriptCalculateOfflineProduction(runningScriptObj) {
console.log("Calculating offline production for: ");
console.log(runningScriptObj);
//The Player object stores the last update time from when we were online //The Player object stores the last update time from when we were online
var thisUpdate = new Date().getTime(); var thisUpdate = new Date().getTime();
var lastUpdate = Player.lastUpdate; var lastUpdate = Player.lastUpdate;

@ -1905,7 +1905,7 @@ let Terminal = {
} }
const scriptname = commandArray[1]; const scriptname = commandArray[1];
if (!scriptname.endsWith(".lit") && !isScriptFilename(scriptname) && !scriptname.endsWith(".txt")) { if (!scriptname.endsWith(".lit") && !isScriptFilename(scriptname) && !scriptname.endsWith(".txt")) {
postError("scp only works for .script, .txt, and .lit files"); postError("scp only works for scripts, text files (.txt), and literature files (.lit)");
return; return;
} }
const destServer = getServer(commandArray[2]); const destServer = getServer(commandArray[2]);

@ -1365,9 +1365,11 @@ const Engine = {
Player.lastUpdate = Engine._lastUpdate; Player.lastUpdate = Engine._lastUpdate;
Engine.start(); //Run main game loop and Scripts loop Engine.start(); //Run main game loop and Scripts loop
removeLoadingScreen(); removeLoadingScreen();
dialogBoxCreate("While you were offline, your scripts generated <span class='money-gold'>$" + const timeOfflineString = convertTimeMsToTimeElapsedString(time);
formatNumber(offlineProductionFromScripts, 2) + "</span> and your Hacknet Nodes generated <span class='money-gold'>$" + dialogBoxCreate(`Offline for ${timeOfflineString}. While you were offline, your scripts ` +
formatNumber(offlineProductionFromHacknetNodes, 2) + "</span>"); "generated <span class='money-gold'>" +
numeralWrapper.formatMoney(offlineProductionFromScripts) + "</span> and your Hacknet Nodes generated <span class='money-gold'>" +
numeralWrapper.formatMoney(offlineProductionFromHacknetNodes) + "</span>");
//Close main menu accordions for loaded game //Close main menu accordions for loaded game
var visibleMenuTabs = [terminal, createScript, activeScripts, stats, var visibleMenuTabs = [terminal, createScript, activeScripts, stats,
hacknetnodes, city, tutorial, options, dev]; hacknetnodes, city, tutorial, options, dev];

@ -15,7 +15,15 @@ function Reviver(key, value) {
if (typeof value === "object" && if (typeof value === "object" &&
typeof value.ctor === "string" && typeof value.ctor === "string" &&
typeof value.data !== "undefined") { typeof value.data !== "undefined") {
// Compatibility for version v0.43.1
// TODO Remove this eventually
if (value.ctor === "AllServersMap") {
console.log('Converting AllServersMap for v0.43.1');
return value.data;
}
ctor = Reviver.constructors[value.ctor] || window[value.ctor]; ctor = Reviver.constructors[value.ctor] || window[value.ctor];
if (typeof ctor === "function" && if (typeof ctor === "function" &&
typeof ctor.fromJSON === "function") { typeof ctor.fromJSON === "function") {
@ -45,7 +53,7 @@ function Generic_toJSON(ctorName, obj, keys) {
} }
data = {}; data = {};
for (index = 0; index < keys.length; ++index) { for (let index = 0; index < keys.length; ++index) {
key = keys[index]; key = keys[index];
data[key] = obj[key]; data[key] = obj[key];
} }

@ -39,7 +39,7 @@ function convertTimeMsToTimeElapsedString(time: number): string {
if (days > 0) {res += `${days} days `; } if (days > 0) {res += `${days} days `; }
if (hours > 0) {res += `${hours} hours `; } if (hours > 0) {res += `${hours} hours `; }
if (minutes > 0) {res += `${minutes} minutes `; } if (minutes > 0) {res += `${minutes} minutes `; }
res += `${seconds} seconds `; res += `${seconds} seconds`;
return res; return res;
} }