1
0
Fork 0

bug fixes

This commit is contained in:
iTNTPiston 2022-06-19 06:00:37 -07:00
parent 57603a9242
commit e06c1b5b16
8 changed files with 412 additions and 24 deletions

View file

@ -293,6 +293,9 @@ module.exports = function (webpackEnv) {
],
},
resolve: {
// fallback: {
// buffer: require.resolve("buffer/")
// },
// This allows you to set a fallback for where webpack should look for modules.
// We placed these paths second because we want `node_modules` to "win"
// if there are any conflicts. This matches Node resolution mechanism.
@ -321,6 +324,11 @@ module.exports = function (webpackEnv) {
...(modules.webpackAliases || {}),
},
plugins: [
// Work around for Buffer is undefined:
// https://github.com/webpack/changelog-v5/issues/10
// new webpack.ProvidePlugin({
// Buffer: ['buffer', 'Buffer'],
// }),
// Prevents users from importing files from outside of src/ (or node_modules/).
// This often causes confusion because we only process files within src/ with babel.
// To fix this, we prevent you from importing files out of src/ -- if you'd like to,

81
package-lock.json generated
View file

@ -24,6 +24,7 @@
"babel-preset-react-app": "^10.0.1",
"bfj": "^7.0.2",
"browserslist": "^4.18.1",
"buffer": "^6.0.3",
"camelcase": "^6.2.1",
"case-sensitive-paths-webpack-plugin": "^2.4.0",
"clsx": "^1.1.1",
@ -5001,6 +5002,25 @@
"resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
"integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
},
"node_modules/base64-js": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
"integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
"funding": [
{
"type": "github",
"url": "https://github.com/sponsors/feross"
},
{
"type": "patreon",
"url": "https://www.patreon.com/feross"
},
{
"type": "consulting",
"url": "https://feross.org/support"
}
]
},
"node_modules/batch": {
"version": "0.6.1",
"resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz",
@ -5173,6 +5193,29 @@
"node-int64": "^0.4.0"
}
},
"node_modules/buffer": {
"version": "6.0.3",
"resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
"integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
"funding": [
{
"type": "github",
"url": "https://github.com/sponsors/feross"
},
{
"type": "patreon",
"url": "https://www.patreon.com/feross"
},
{
"type": "consulting",
"url": "https://feross.org/support"
}
],
"dependencies": {
"base64-js": "^1.3.1",
"ieee754": "^1.2.1"
}
},
"node_modules/buffer-from": {
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
@ -8466,6 +8509,25 @@
"node": ">=4"
}
},
"node_modules/ieee754": {
"version": "1.2.1",
"resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
"integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
"funding": [
{
"type": "github",
"url": "https://github.com/sponsors/feross"
},
{
"type": "patreon",
"url": "https://www.patreon.com/feross"
},
{
"type": "consulting",
"url": "https://feross.org/support"
}
]
},
"node_modules/ignore": {
"version": "5.2.0",
"resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz",
@ -19657,6 +19719,11 @@
"resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
"integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="
},
"base64-js": {
"version": "1.5.1",
"resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
"integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA=="
},
"batch": {
"version": "0.6.1",
"resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz",
@ -19793,6 +19860,15 @@
"node-int64": "^0.4.0"
}
},
"buffer": {
"version": "6.0.3",
"resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
"integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
"requires": {
"base64-js": "^1.3.1",
"ieee754": "^1.2.1"
}
},
"buffer-from": {
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
@ -22161,6 +22237,11 @@
"harmony-reflect": "^1.4.6"
}
},
"ieee754": {
"version": "1.2.1",
"resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
"integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA=="
},
"ignore": {
"version": "5.2.0",
"resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz",

View file

@ -20,6 +20,7 @@
"babel-preset-react-app": "^10.0.1",
"bfj": "^7.0.2",
"browserslist": "^4.18.1",
"buffer": "^6.0.3",
"camelcase": "^6.2.1",
"case-sensitive-paths-webpack-plugin": "^2.4.0",
"clsx": "^1.1.1",

View file

@ -9,6 +9,9 @@ import { ItemStack as ISC } from './components/ItemStack';
import { ItemStack, ItemType } from 'core/ItemStack';
import { DisplayPane } from 'surfaces/DisplayPane';
import { Item } from 'core/Item';
import { deserialzeCommands, serializeCommands } from 'core/serialize';
const Buffer = require("buffer/").Buffer;
export const App: React.FC = () => {
const [commands, setCommands] = useState<Command[]>([
@ -62,6 +65,14 @@ export const App: React.FC = () => {
}
}, [commands, displayIndex]);
// useEffect(()=>{
// const encoded = serializeCommands(commands);
// console.log(encoded);
// const deserialized = deserialzeCommands(encoded);
// console.log(deserialized);
// window.location.hash = "#"+encoded;
// }, [commands]);
return (
<div className='Calamity'
@ -107,7 +118,7 @@ export const App: React.FC = () => {
</ul>
</div>
{displayIndex >= 0 && displayIndex < commands.length &&
<DisplayPane
displayIndex={displayIndex}
command={commands[displayIndex].getDisplayString()}
@ -119,6 +130,9 @@ export const App: React.FC = () => {
setCommands(arrCopy);
}}/>
}
{
contextMenuShowing && <div style={{
position: "absolute",
@ -157,6 +171,9 @@ export const App: React.FC = () => {
<CommandItem error onClick={()=>{
if(confirm("Delete?")){
setCommands(commands.filter((_,i)=>i!==contextIndex));
if(displayIndex >= commands.length){
setDisplayIndex(commands.length-1);
}
setContextMenuShowing(false);
setContextIndex(-1);
}

View file

@ -1,17 +1,31 @@
import { Inventory } from "./Inventory";
import { Item } from "./Item";
import { ItemStack } from "./ItemStack";
import { Item, ItemIds } from "./Item";
import { ItemStack, ItemType } from "./ItemStack";
const Buffer = require("buffer/").Buffer;
export interface Command {
execute(inv: Inventory): void,
getDisplayString(): string,
fromBuffer(buf: Buffer): number,
toBuffer(): Buffer,
}
export class CommandNothing implements Command {
static Op = 0x0;
constructor(){
}
fromBuffer(buf: Buffer): number {
return 0;
}
toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1);
buf.writeInt8(CommandNothing.Op);
return buf;
}
execute(inv: Inventory): void {
}
@ -22,10 +36,47 @@ export class CommandNothing implements Command {
}
export class CommandInitialize implements Command {
static Op = 0x1;
private stacks: ItemStack[]
constructor(stacks: ItemStack[]){
this.stacks = stacks;
}
public fromBuffer(buf: Buffer): number {
let read = 0;
const size = buf.readUInt16LE();
read+=2;
const stacks: ItemStack[] = [];
for(let i=0;i<size;i++){
const count = buf.readInt16LE(read);
read+=2;
const id = buf.readInt8(read);
read++;
for(const item in ItemIds){
if(ItemIds[item as Item] === id){
stacks.push({item: item as Item, count});
}
}
}
this.stacks = stacks;
return read;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(3*this.stacks.length+5);
let write = 0;
buf.writeUInt8(CommandInitialize.Op);
write++;
buf.writeInt16LE(this.stacks.length, write);
write+=2;
this.stacks.forEach(({item,count})=>{
console.log(count);
buf.writeInt16LE(count&0xffff, write);
write+=2;
buf.writeInt8(ItemIds[item], write);
write++;
});
return buf;
}
public execute(inv: Inventory): void {
inv.init(this.stacks);
}
@ -37,13 +88,25 @@ export class CommandInitialize implements Command {
})
return parts.join(" ");
}
}
export class CommandBreakSlots implements Command {
static Op = 0x2;
private numToBreak: number;
constructor(numToBreak: number){
this.numToBreak = numToBreak;
}
public fromBuffer(buf: Buffer): number {
this.numToBreak = buf.readInt16LE();
return 2;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(3);
buf.writeUInt8(CommandBreakSlots.Op);
buf.writeInt16LE(this.numToBreak, 1);
return buf;
}
public execute(inv: Inventory): void {
inv.addBrokenSlots(this.numToBreak);
}
@ -53,6 +116,15 @@ export class CommandBreakSlots implements Command {
}
export class CommandSave implements Command {
static Op = 0x3;
public fromBuffer(buf: Buffer): number {
return 0;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1);
buf.writeInt8(CommandSave.Op);
return buf;
}
public execute(inv: Inventory): void {
inv.save();
}
@ -62,6 +134,15 @@ export class CommandSave implements Command {
}
export class CommandReload implements Command {
static Op = 0x4;
public fromBuffer(buf: Buffer): number {
return 0;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1);
buf.writeInt8(CommandReload.Op);
return buf;
}
public execute(inv: Inventory): void {
inv.reload();
}
@ -71,6 +152,15 @@ export class CommandReload implements Command {
}
export class CommandSortKey implements Command {
static Op = 0x5;
public fromBuffer(buf: Buffer): number {
return 0;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1);
buf.writeInt8(CommandSortKey.Op);
return buf;
}
public execute(inv: Inventory): void {
inv.sortKey();
}
@ -80,6 +170,15 @@ export class CommandSortKey implements Command {
}
export class CommandSortMaterial implements Command {
static Op = 0x6;
public fromBuffer(buf: Buffer): number {
return 0;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1);
buf.writeInt8(CommandSortMaterial.Op);
return buf;
}
public execute(inv: Inventory): void {
inv.sortMaterial();
}
@ -88,55 +187,155 @@ export class CommandSortMaterial implements Command {
}
}
const Verbs = ["?", "Remove", "Drop", "Sell", "Eat", "Cook", "Get", "Add", "Pickup"];
const VerbToId = {
"Remove" : 1,
"Drop": 2,
"Sell": 3,
"Eat": 4,
"Cook": 5,
"Get": 6,
"Add": 7,
"Pickup": 8
}
export class CommandRemoveMaterial implements Command {
private verb: string;
static Op = 0x7;
private verb: number;
private count: number;
private item: Item;
private slot: number;
constructor(verb: string, count: number, item: Item, slot: number){
this.verb = verb;
this.verb = VerbToId[verb as keyof typeof VerbToId] || 0;
this.count = count;
this.item = item;
this.slot = slot;
}
public fromBuffer(buf: Buffer): number {
let read = 0;
this.count = buf.readInt16LE(read);
read+=2;
const id = buf.readInt8(read);
read+=1;
for(const item in ItemIds){
if(ItemIds[item as Item] === id){
this.item = item as Item;
}
}
this.slot = buf.readInt16LE(read);
read+=2;
this.verb = buf.readInt8(read);
read++;
return read;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1+2+1+2+1);
let write = 0;
buf.writeInt8(CommandRemoveMaterial.Op);
write++;
buf.writeInt16LE(this.count, write);
write+=2;
buf.writeInt8(ItemIds[this.item], write);
write++;
buf.writeInt16LE(this.slot, write);
write+=2;
buf.writeInt8(this.verb, write);
return buf;
}
public execute(inv: Inventory): void {
inv.remove(this.item, this.count, this.slot);
}
public getDisplayString(): string {
return `${this.verb} ${this.count} ${this.item} From Slot ${this.slot+1}`;
return `${Verbs[this.verb]} ${this.count} ${this.item} From Slot ${this.slot+1}`;
}
}
export class CommandRemoveUnstackableMaterial implements Command {
private verb: string;
static Op = 0x8;
private verb: number;
private item: Item;
private slot: number;
constructor(verb: string,item: Item, slot: number){
this.verb = verb;
this.verb = VerbToId[verb as keyof typeof VerbToId] || 0;;
this.item = item;
this.slot = slot;
}
public fromBuffer(buf: Buffer): number {
let read = 0;
const id = buf.readInt8(read);
read+=1;
for(const item in ItemIds){
if(ItemIds[item as Item] === id){
this.item = item as Item;
}
}
this.slot = buf.readInt16LE(read);
read+=2;
this.verb = buf.readInt8(read);
read++;
return read;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1+1+2+1);
let write = 0;
buf.writeInt8(CommandRemoveUnstackableMaterial.Op);
write++;
buf.writeInt8(ItemIds[this.item], write);
write++;
buf.writeInt16LE(this.slot, write);
write+=2;
buf.writeInt8(this.verb, write);
return buf;
}
public execute(inv: Inventory): void {
inv.remove(this.item, 1, this.slot);
}
public getDisplayString(): string {
return `${this.verb} ${this.item} From Slot ${this.slot+1}`;
return `${Verbs[this.verb]} ${this.item} From Slot ${this.slot+1}`;
}
}
export class CommandAddMaterial implements Command {
private verb: string;
static Op = 0x9;
private verb: number;
private count: number;
private item: Item;
constructor(verb: string, count: number, item: Item){
this.verb = verb;
this.verb = VerbToId[verb as keyof typeof VerbToId] || 0;
this.count = count;
this.item = item;
}
public fromBuffer(buf: Buffer): number {
let read = 0;
const id = buf.readInt8(read);
read+=1;
for(const item in ItemIds){
if(ItemIds[item as Item] === id){
this.item = item as Item;
}
}
this.count = buf.readInt16LE(read);
read+=2;
this.verb = buf.readInt8(read);
read++;
return read;
}
public toBuffer(): Buffer {
const buf: Buffer = Buffer.alloc(1+1+2+1);
let write = 0;
buf.writeInt8(CommandAddMaterial.Op);
write++;
buf.writeInt8(ItemIds[this.item], write);
write++;
buf.writeInt16LE(this.count, write);
write+=2;
buf.writeInt8(this.verb, write);
return buf;
}
public execute(inv: Inventory): void {
inv.add(this.item, this.count);
}
public getDisplayString(): string {
return `${this.verb} ${this.count} ${this.item}`;
return `${Verbs[this.verb]} ${this.count} ${this.item}`;
}
}

View file

@ -34,8 +34,8 @@ export class Inventory {
}
public init(stacks: ItemStack[]) {
this.savedSlots = [...stacks];
this.slots = [...stacks];
this.savedSlots = [...stacks.map((stack)=>({...stack}))];
this.slots = [...stacks.map((stack)=>({...stack}))];
}
public addBrokenSlots(num: number) {

View file

@ -33,6 +33,23 @@ export const ItemIds = {
[Item.SpiritOrb]: 0x02,
[Item.Diamond]: 0x10,
[Item.Lotus]: 0x11,
[Item.SilentPrincess]: 0x12,
[Item.Honey]: 0x13,
[Item.Acorn]: 0x14,
[Item.FaroshScale]: 0x15,
[Item.FaroshClaw]: 0x16,
[Item.FaroshHorn]: 0x17,
[Item.HeartyBass]: 0x18,
[Item.Beetle]: 0x19,
[Item.Opal]: 0x1a,
[Item.Tail]: 0x1b,
[Item.Spring]: 0x1c,
[Item.Shaft]: 0x1d,
[Item.Core]: 0x1e,
[Item.Wood]: 0x1f,
[Item.SpeedFood]: 0x40,
}
export const itemToType = (item: Item): ItemType => {

65
src/core/serialize.ts Normal file
View file

@ -0,0 +1,65 @@
import { Command, CommandAddMaterial, CommandBreakSlots, CommandInitialize, CommandNothing, CommandReload, CommandRemoveMaterial, CommandRemoveUnstackableMaterial, CommandSave, CommandSortKey, CommandSortMaterial } from "./Command";
import { Item } from "./Item";
const Buffer = require("buffer/").Buffer;
export const serializeCommands = (commands: Command[]): string => {
const sizeBuf: Buffer = Buffer.alloc(4);
sizeBuf.writeInt32LE(commands.length);
const commandBuffers = commands.map(c=>c.toBuffer());
const allBufs = Buffer.concat([sizeBuf, ...commandBuffers]);
console.log(allBufs);
return allBufs.toString("base64");
}
export const deserialzeCommands = (base64str: string): Command[] => {
const buf: Buffer = Buffer.from(base64str, "base64");
const size = buf.readInt32LE();
let off = 4;
const commands: Command[] = [];
for(let i=0;i<size;i++){
const op = buf.readUInt8(off);
off++;
let command: Command | undefined = undefined;
switch(op){
case CommandNothing.Op:
command = new CommandNothing();
break;
case CommandInitialize.Op:
command = new CommandInitialize([]);
break;
case CommandBreakSlots.Op:
command = new CommandBreakSlots(0);
break;
case CommandSave.Op:
command = new CommandSave();
break;
case CommandReload.Op:
command = new CommandReload();
break;
case CommandSortKey.Op:
command = new CommandSortKey();
break;
case CommandSortMaterial.Op:
command = new CommandSortMaterial();
break;
case CommandRemoveMaterial.Op:
command = new CommandRemoveMaterial("",0,Item.Slate,0);
break;
case CommandRemoveUnstackableMaterial.Op:
command = new CommandRemoveUnstackableMaterial("", Item.Slate, 0);
break;
case CommandAddMaterial.Op:
command = new CommandAddMaterial("",0,Item.Slate);
break;
}
if(command){
off += command.fromBuffer(buf.slice(off));
commands.push(command);
}else{
console.error("invalid opcode: "+op);
}
}
return commands;
}