mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2025-01-01 19:07:36 +01:00
Fixed bug with Terminal parsing changes. Stock's otlkMag is now capped at 50 to prevent forecast from going above 100% or below 0%
This commit is contained in:
parent
5ac10f17f8
commit
dc63b14476
@ -511,11 +511,17 @@ export let CONSTANTS: IMap<any> = {
|
||||
LatestUpdate:
|
||||
`
|
||||
v0.43.1
|
||||
* Terminal changes:
|
||||
** Quoted arguments are now properly parsed. (e.g. run f.script "this is one argument" will be correctly parsed)
|
||||
** Errors are now shown in red text
|
||||
** 'unalias' command now has a different format and no longer needs the quotations
|
||||
|
||||
* Added two new Bladeburner skills for increasing money and experience gain
|
||||
* Made some minor adjustments to Bladeburner UI
|
||||
* Corporation "Smart Factories" and "Smart Storage" upgrades have slightly lower price multipliers
|
||||
* Added 6 new Coding Contract problems
|
||||
* Updated documentation with list of all Coding Contract problems
|
||||
* Bug Fix: A Stock Forecast should no longer go above 1 (i.e. 100%)
|
||||
`
|
||||
|
||||
}
|
||||
|
@ -640,6 +640,7 @@ function processStockPrices(numCycles=1) {
|
||||
} else {
|
||||
stock.otlkMag -= otlkMagChange;
|
||||
}
|
||||
if (stock.otlkMag > 50) { stock.otlkMag = 50; } // Cap so the "forecast" is between 0 and 100
|
||||
if (stock.otlkMag < 0) {
|
||||
stock.otlkMag *= -1;
|
||||
stock.b = !stock.b;
|
||||
|
@ -60,6 +60,12 @@ function postNetburnerText() {
|
||||
post("Bitburner v" + CONSTANTS.Version);
|
||||
}
|
||||
|
||||
// Helper function that checks if an argument (which is a string) is a valid number
|
||||
function isNumber(str) {
|
||||
if (typeof str != "string") { return false; } // Only process strings
|
||||
return !isNaN(str) && !isNaN(parseFloat(str));
|
||||
}
|
||||
|
||||
//Defines key commands in terminal
|
||||
$(document).keydown(function(event) {
|
||||
//Terminal
|
||||
@ -803,12 +809,6 @@ let Terminal = {
|
||||
},
|
||||
|
||||
parseCommandArguments : function(command) {
|
||||
// Helper function that checks if an argument (which is a string) is a valid number
|
||||
function isNumber(str) {
|
||||
if (typeof str != "string") { return false; } // Only process strings
|
||||
return !isNaN(str) && !isNaN(parseFloat(str));
|
||||
}
|
||||
|
||||
// This will be used to keep track of whether we're in a quote. This is for situations
|
||||
// like the alias command:
|
||||
// alias run="run NUKE.exe"
|
||||
@ -1370,7 +1370,7 @@ let Terminal = {
|
||||
break;
|
||||
case "run":
|
||||
//Run a program or a script
|
||||
if (commandArray.length !== 2) {
|
||||
if (commandArray.length < 2) {
|
||||
postError("Incorrect number of arguments. Usage: run [program/script] [-t] [num threads] [arg1] [arg2]...");
|
||||
} else {
|
||||
var executableName = commandArray[1];
|
||||
@ -1382,9 +1382,8 @@ let Terminal = {
|
||||
}
|
||||
|
||||
//Check if its a script or just a program/executable
|
||||
//Dont use isScriptFilename here because `executableName` includes the args too
|
||||
if (executableName.includes(".script") || executableName.includes(".js") || executableName.includes(".ns")) {
|
||||
Terminal.runScript(executableName);
|
||||
if (isScriptFilename(executableName)) {
|
||||
Terminal.runScript(commandArray);
|
||||
} else if (executableName.endsWith(".cct")) {
|
||||
Terminal.runContract(executableName);
|
||||
} else {
|
||||
@ -2158,59 +2157,31 @@ let Terminal = {
|
||||
programHandlers[programName](s, splitArgs);
|
||||
},
|
||||
|
||||
runScript: function(scriptName) {
|
||||
var server = Player.getCurrentServer();
|
||||
|
||||
var numThreads = 1;
|
||||
var args = [];
|
||||
var results = scriptName.split(" ");
|
||||
if (results.length <= 0) {
|
||||
post("This is a bug. Please contact developer");
|
||||
runScript: function(commandArray) {
|
||||
if (commandArray.length < 2) {
|
||||
dialogBoxCreate(`Bug encountered with Terminal.runScript(). Command array has a length of less than 2: ${commandArray}`);
|
||||
return;
|
||||
}
|
||||
scriptName = results[0];
|
||||
if (results.length > 1) {
|
||||
if (results.length >= 3 && results[1] == "-t") {
|
||||
numThreads = Math.round(Number(results[2]));
|
||||
|
||||
const server = Player.getCurrentServer();
|
||||
|
||||
let numThreads = 1;
|
||||
const args = [];
|
||||
const scriptName = commandArray[1];
|
||||
|
||||
if (commandArray.length > 2) {
|
||||
if (commandArray.length >= 4 && commandArray[2] == "-t") {
|
||||
numThreads = Math.round(parseFloat(commandArray[3]));
|
||||
if (isNaN(numThreads) || numThreads < 1) {
|
||||
post("Invalid number of threads specified. Number of threads must be greater than 0");
|
||||
postError("Invalid number of threads specified. Number of threads must be greater than 0");
|
||||
return;
|
||||
}
|
||||
for (var i = 3; i < results.length; ++i) {
|
||||
var arg = results[i];
|
||||
|
||||
//Forced string
|
||||
if ((arg.startsWith("'") && arg.endsWith("'")) ||
|
||||
(arg.startsWith('"') && arg.endsWith('"'))) {
|
||||
args.push(arg.slice(1, -1));
|
||||
continue;
|
||||
}
|
||||
//Number
|
||||
var tempNum = Number(arg);
|
||||
if (!isNaN(tempNum)) {
|
||||
args.push(tempNum);
|
||||
continue;
|
||||
}
|
||||
//Otherwise string
|
||||
args.push(arg);
|
||||
for (let i = 4; i < commandArray.length; ++i) {
|
||||
args.push(commandArray[i]);
|
||||
}
|
||||
} else {
|
||||
for (var i = 1; i < results.length; ++i) {
|
||||
var arg = results[i];
|
||||
|
||||
//Forced string
|
||||
if ((arg.startsWith("'") && arg.endsWith("'")) ||
|
||||
(arg.startsWith('"') && arg.endsWith('"'))) {
|
||||
args.push(arg.slice(1, -1));
|
||||
continue;
|
||||
}
|
||||
//Number
|
||||
var tempNum = Number(arg);
|
||||
if (!isNaN(tempNum)) {
|
||||
args.push(tempNum);
|
||||
continue;
|
||||
}
|
||||
//Otherwise string
|
||||
args.push(arg);
|
||||
for (let i = 2; i < commandArray.length; ++i) {
|
||||
args.push(commandArray[i])
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user