mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-11-08 08:43:53 +01:00
IPVGO: Provide API for getting game stats per opponent (#1255)
Give users access to wins, losses, stat bonuses, and favor gained
This commit is contained in:
parent
35c32e2871
commit
b53c35126e
@ -17,5 +17,7 @@ analysis: {
|
||||
getLiberties(): number[][];
|
||||
|
||||
getControlledEmptyNodes(): string[];
|
||||
|
||||
getStats(): Partial<Record<GoOpponent, SimpleOpponentStats>>;
|
||||
};
|
||||
```
|
||||
|
@ -16,7 +16,7 @@ export interface Go
|
||||
|
||||
| Property | Modifiers | Type | Description |
|
||||
| --- | --- | --- | --- |
|
||||
| [analysis](./bitburner.go.analysis.md) | | { getValidMoves(): boolean\[\]\[\]; getChains(): (number \| null)\[\]\[\]; getLiberties(): number\[\]\[\]; getControlledEmptyNodes(): string\[\]; } | Tools to analyze the IPvGO subnet. |
|
||||
| [analysis](./bitburner.go.analysis.md) | | { getValidMoves(): boolean\[\]\[\]; getChains(): (number \| null)\[\]\[\]; getLiberties(): number\[\]\[\]; getControlledEmptyNodes(): string\[\]; getStats(): Partial<Record<[GoOpponent](./bitburner.goopponent.md)<!-- -->, [SimpleOpponentStats](./bitburner.simpleopponentstats.md)<!-- -->>>; } | Tools to analyze the IPvGO subnet. |
|
||||
| [cheat](./bitburner.go.cheat.md) | | { getCheatSuccessChance(): number; removeRouter( x: number, y: number, ): Promise<{ type: "move" \| "pass" \| "gameOver"; x: number \| null; y: number \| null; }>; playTwoMoves( x1: number, y1: number, x2: number, y2: number, ): Promise<{ type: "move" \| "pass" \| "gameOver"; x: number \| null; y: number \| null; }>; repairOfflineNode( x: number, y: number, ): Promise<{ type: "move" \| "pass" \| "gameOver"; x: number \| null; y: number \| null; }>; destroyNode( x: number, y: number, ): Promise<{ type: "move" \| "pass" \| "gameOver"; x: number \| null; y: number \| null; }>; } | Illicit and dangerous IPvGO tools. Not for the faint of heart. Requires Bitnode 14.2 to use. |
|
||||
|
||||
## Methods
|
||||
|
@ -162,6 +162,7 @@
|
||||
| [PlayerRequirement](./bitburner.playerrequirement.md) | Structured interface to requirements for joining a faction or company. For fields with numerical value > 0, the player must have at least this value. For fields with numerical value <<!-- -->= 0, the player must have at most this value. For "not", the sub-condition must be failed instead of passed. For "someCondition", at least one sub-condition must be passed. |
|
||||
| [ReactNode](./bitburner.reactnode.md) | <p>A stand-in for the real React.ReactNode. A [ReactElement](./bitburner.reactelement.md) is rendered dynamically with React. number and string are displayed directly. boolean, null, and undefined are ignored and not rendered. An array of ReactNodes will display all members of that array sequentially.</p><p>Use React.createElement to make the ReactElement type, see [creating an element without jsx](https://react.dev/reference/react/createElement#creating-an-element-without-jsx) from the official React documentation.</p> |
|
||||
| [ScriptArg](./bitburner.scriptarg.md) | |
|
||||
| [SimpleOpponentStats](./bitburner.simpleopponentstats.md) | |
|
||||
| [SleeveBladeburnerTask](./bitburner.sleevebladeburnertask.md) | |
|
||||
| [SleeveClassTask](./bitburner.sleeveclasstask.md) | |
|
||||
| [SleeveCompanyTask](./bitburner.sleevecompanytask.md) | |
|
||||
|
20
markdown/bitburner.simpleopponentstats.md
Normal file
20
markdown/bitburner.simpleopponentstats.md
Normal file
@ -0,0 +1,20 @@
|
||||
<!-- Do not edit this file. It is automatically generated by API Documenter. -->
|
||||
|
||||
[Home](./index.md) > [bitburner](./bitburner.md) > [SimpleOpponentStats](./bitburner.simpleopponentstats.md)
|
||||
|
||||
## SimpleOpponentStats type
|
||||
|
||||
|
||||
**Signature:**
|
||||
|
||||
```typescript
|
||||
type SimpleOpponentStats = {
|
||||
wins: number;
|
||||
losses: number;
|
||||
winStreak: number;
|
||||
highestWinStreak: number;
|
||||
favor: number;
|
||||
bonusPercent: number;
|
||||
bonusDescription: string;
|
||||
};
|
||||
```
|
@ -79,3 +79,13 @@ export type OpponentStats = {
|
||||
highestWinStreak: number;
|
||||
favor: number;
|
||||
};
|
||||
|
||||
export type SimpleOpponentStats = {
|
||||
wins: number;
|
||||
losses: number;
|
||||
winStreak: number;
|
||||
highestWinStreak: number;
|
||||
favor: number;
|
||||
bonusPercent: number;
|
||||
bonusDescription: string;
|
||||
};
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { BoardState, Play } from "../Types";
|
||||
import { BoardState, Play, SimpleOpponentStats } from "../Types";
|
||||
|
||||
import { Player } from "@player";
|
||||
import { AugmentationName, GoColor, GoOpponent, GoPlayType, GoValidity } from "@enums";
|
||||
@ -11,8 +11,10 @@ import {
|
||||
getControlledSpace,
|
||||
simpleBoardFromBoard,
|
||||
} from "../boardAnalysis/boardAnalysis";
|
||||
import { getScore, resetWinstreak } from "../boardAnalysis/scoring";
|
||||
import { getOpponentStats, getScore, resetWinstreak } from "../boardAnalysis/scoring";
|
||||
import { WHRNG } from "../../Casino/RNG";
|
||||
import { getRecordKeys } from "../../Types/Record";
|
||||
import { CalculateEffect, getEffectTypeForFaction } from "./effect";
|
||||
|
||||
/**
|
||||
* Check the move based on the current settings
|
||||
@ -362,6 +364,30 @@ export function resetBoardState(
|
||||
return simpleBoardFromBoard(Go.currentGame.board);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve and clean up stats for each opponent played against
|
||||
*/
|
||||
export function getStats() {
|
||||
const statDetails: Partial<Record<GoOpponent, SimpleOpponentStats>> = {};
|
||||
for (const opponent of getRecordKeys(Go.stats)) {
|
||||
const details = getOpponentStats(opponent);
|
||||
const nodePower = getOpponentStats(opponent).nodePower;
|
||||
const effectPercent = (CalculateEffect(nodePower, opponent) - 1) * 100;
|
||||
const effectDescription = getEffectTypeForFaction(opponent);
|
||||
statDetails[opponent] = {
|
||||
wins: details.wins,
|
||||
losses: details.losses,
|
||||
winStreak: details.winStreak,
|
||||
highestWinStreak: details.highestWinStreak,
|
||||
favor: details.favor,
|
||||
bonusPercent: effectPercent,
|
||||
bonusDescription: effectDescription,
|
||||
};
|
||||
}
|
||||
|
||||
return statDetails;
|
||||
}
|
||||
|
||||
/** Validate singularity access by throwing an error if the player does not have access. */
|
||||
export function checkCheatApiAccess(error: (s: string) => void): void {
|
||||
const hasSourceFile = Player.sourceFileLvl(14) > 1;
|
||||
|
@ -260,6 +260,7 @@ const go = {
|
||||
getChains: 16,
|
||||
getLiberties: 16,
|
||||
getControlledEmptyNodes: 16,
|
||||
getStats: 0,
|
||||
},
|
||||
cheat: {
|
||||
getCheatSuccessChance: 1,
|
||||
|
@ -18,6 +18,7 @@ import {
|
||||
getGameState,
|
||||
getLiberties,
|
||||
getOpponentNextMove,
|
||||
getStats,
|
||||
getValidMoves,
|
||||
handlePassTurn,
|
||||
makePlayerMove,
|
||||
@ -85,6 +86,9 @@ export function NetscriptGo(): InternalAPI<NSGo> {
|
||||
getControlledEmptyNodes: () => () => {
|
||||
return getControlledEmptyNodes();
|
||||
},
|
||||
getStats: () => () => {
|
||||
return getStats();
|
||||
},
|
||||
},
|
||||
cheat: {
|
||||
getCheatSuccessChance: (ctx: NetscriptContext) => () => {
|
||||
|
33
src/ScriptEditor/NetscriptDefinitions.d.ts
vendored
33
src/ScriptEditor/NetscriptDefinitions.d.ts
vendored
@ -3949,6 +3949,17 @@ type GoOpponent =
|
||||
| "Illuminati"
|
||||
| "????????????";
|
||||
|
||||
/** @public */
|
||||
type SimpleOpponentStats = {
|
||||
wins: number;
|
||||
losses: number;
|
||||
winStreak: number;
|
||||
highestWinStreak: number;
|
||||
favor: number;
|
||||
bonusPercent: number;
|
||||
bonusDescription: string;
|
||||
};
|
||||
|
||||
/**
|
||||
* IPvGO api
|
||||
* @public
|
||||
@ -4167,6 +4178,28 @@ export interface Go {
|
||||
* (This is intentionally expensive; you can derive this info from just getBoardState() )
|
||||
*/
|
||||
getControlledEmptyNodes(): string[];
|
||||
|
||||
/**
|
||||
* Displays the game history, captured nodes, and gained bonuses for each opponent you have played against.
|
||||
*
|
||||
* The details are keyed by opponent name, in this structure:
|
||||
*
|
||||
* <pre lang="javascript">
|
||||
* {
|
||||
* <OpponentName>: {
|
||||
* wins: number,
|
||||
* losses: number,
|
||||
* winStreak: number,
|
||||
* highestWinStreak: number,
|
||||
* favor: number,
|
||||
* bonusPercent: number,
|
||||
* bonusDescription: string,
|
||||
* }
|
||||
* }
|
||||
* </pre>
|
||||
*
|
||||
*/
|
||||
getStats(): Partial<Record<GoOpponent, SimpleOpponentStats>>;
|
||||
};
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user