mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-10-23 02:03:14 +02:00
e0272ad4af
* Added new types for various file paths, all in the Paths folder. * TypeSafety and other helper functions related to these types * Added basic globbing support with * and ?. Currently only implemented for Script/Text, on nano and download terminal commands * Enforcing the new types throughout the codebase, plus whatever rewrites happened along the way * Server.textFiles is now a map * TextFile no longer uses a fn property, now it is filename * Added a shared ContentFile interface for shared functionality between TextFile and Script. * related to ContentFile change above, the player is now allowed to move a text file to a script file and vice versa. * File paths no longer conditionally start with slashes, and all directory names other than root have ending slashes. The player is still able to provide paths starting with / but this now indicates that the player is specifying an absolute path instead of one relative to root. * Singularized the MessageFilename and LiteratureName enums * Because they now only accept correct types, server.writeToXFile functions now always succeed (the only reasons they could fail before were invalid filepath). * Fix several issues with tab completion, which included pretty much a complete rewrite * Changed the autocomplete display options so there's less chance it clips outside the display area. * Turned CompletedProgramName into an enum. * Got rid of programsMetadata, and programs and DarkWebItems are now initialized immediately instead of relying on initializers called from the engine. * For any executable (program, cct, or script file) pathing can be used directly to execute without using the run command (previously the command had to start with ./ and it wasn't actually using pathing).
105 lines
3.4 KiB
TypeScript
105 lines
3.4 KiB
TypeScript
import React from "react";
|
|
import { GetServer, GetAllServers } from "../Server/AllServers";
|
|
import { Modal } from "../ui/React/Modal";
|
|
import { formatBigNumber } from "../ui/formatNumber";
|
|
|
|
import Table from "@mui/material/Table";
|
|
import TableBody from "@mui/material/TableBody";
|
|
import TableCell from "@mui/material/TableCell";
|
|
import TableContainer from "@mui/material/TableContainer";
|
|
import TableHead from "@mui/material/TableHead";
|
|
import TableRow from "@mui/material/TableRow";
|
|
import Typography from "@mui/material/Typography";
|
|
import Paper from "@mui/material/Paper";
|
|
import Accordion from "@mui/material/Accordion";
|
|
import AccordionSummary from "@mui/material/AccordionSummary";
|
|
import AccordionDetails from "@mui/material/AccordionDetails";
|
|
import ExpandMoreIcon from "@mui/icons-material/ExpandMore";
|
|
import { ServerName } from "../Types/strings";
|
|
import { allContentFiles } from "../Paths/ContentFile";
|
|
|
|
interface File {
|
|
name: string;
|
|
size: number;
|
|
}
|
|
|
|
function ServerAccordion(props: { hostname: ServerName }): React.ReactElement {
|
|
const server = GetServer(props.hostname);
|
|
if (server === null) throw new Error(`server '${props.hostname}' should not be null`);
|
|
let totalSize = 0;
|
|
const files: File[] = [];
|
|
for (const [path, file] of allContentFiles(server)) {
|
|
totalSize += file.content.length;
|
|
files.push({ name: path, size: file.content.length });
|
|
}
|
|
|
|
if (totalSize === 0) return <></>;
|
|
|
|
files.sort((a: File, b: File): number => b.size - a.size);
|
|
|
|
return (
|
|
<Accordion TransitionProps={{ unmountOnExit: true }}>
|
|
<AccordionSummary expandIcon={<ExpandMoreIcon />}>
|
|
<Typography>
|
|
{server.hostname} ({formatBigNumber(totalSize)}b)
|
|
</Typography>
|
|
</AccordionSummary>
|
|
<AccordionDetails>
|
|
<TableContainer component={Paper}>
|
|
<Table>
|
|
<TableHead>
|
|
<TableRow>
|
|
<TableCell>
|
|
<Typography>Filename</Typography>
|
|
</TableCell>
|
|
<TableCell align="right">
|
|
<Typography>Size</Typography>
|
|
</TableCell>
|
|
</TableRow>
|
|
</TableHead>
|
|
<TableBody>
|
|
{files.map((file: File) => (
|
|
<TableRow key={file.name}>
|
|
<TableCell component="th" scope="row">
|
|
<Typography>{file.name}</Typography>
|
|
</TableCell>
|
|
<TableCell align="right">
|
|
<Typography>{formatBigNumber(file.size)}b</Typography>
|
|
</TableCell>
|
|
</TableRow>
|
|
))}
|
|
</TableBody>
|
|
</Table>
|
|
</TableContainer>
|
|
<ul></ul>
|
|
</AccordionDetails>
|
|
</Accordion>
|
|
);
|
|
}
|
|
|
|
interface IProps {
|
|
open: boolean;
|
|
onClose: () => void;
|
|
}
|
|
|
|
export function FileDiagnosticModal(props: IProps): React.ReactElement {
|
|
const keys: string[] = [];
|
|
for (const key of GetAllServers()) {
|
|
keys.push(key.hostname);
|
|
}
|
|
|
|
return (
|
|
<Modal open={props.open} onClose={props.onClose}>
|
|
<>
|
|
<Typography>
|
|
Welcome to the file diagnostic! If your save file is really big it's likely because you have too many
|
|
text/scripts. This tool can help you narrow down where they are.
|
|
</Typography>
|
|
{keys.map((hostname: string) => (
|
|
<ServerAccordion key={hostname} hostname={hostname} />
|
|
))}
|
|
</>
|
|
</Modal>
|
|
);
|
|
}
|