mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2025-01-11 15:57:33 +01:00
Fixed bug and added compatibility for converting RunningScript offline dataMap to version v0.43.1
This commit is contained in:
parent
9137c24274
commit
8266492001
2
dist/engine.bundle.js
vendored
2
dist/engine.bundle.js
vendored
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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user