Commit 23ff98cf authored by chechunchi's avatar chechunchi

add penetrate but remain bug

parent 26ff2f20
...@@ -19,6 +19,7 @@ import MsgSelectChainAdapter from "./selectChain"; ...@@ -19,6 +19,7 @@ import MsgSelectChainAdapter from "./selectChain";
import MsgSelectEffectYnAdapter from "./selectEffectYn"; import MsgSelectEffectYnAdapter from "./selectEffectYn";
import MsgSelectPositionAdapter from "./selectPosition"; import MsgSelectPositionAdapter from "./selectPosition";
import MsgSelectOptionAdapter from "./selectOption"; import MsgSelectOptionAdapter from "./selectOption";
import { penetrate } from "./penetrate";
/* /*
* STOC GameMsg * STOC GameMsg
...@@ -41,8 +42,9 @@ export default class GameMsgAdapter implements StocAdapter { ...@@ -41,8 +42,9 @@ export default class GameMsgAdapter implements StocAdapter {
const func = dataView.getUint8(0); const func = dataView.getUint8(0);
const gameData = exData.slice(1); const gameData = exData.slice(1);
const gameMsg = new ygopro.StocGameMessage({}); let gameMsg: any = new ygopro.StocGameMessage({}).toObject();
if (!penetrate(func, gameMsg, gameData)) {
switch (func) { switch (func) {
case GAME_MSG.MSG_START: { case GAME_MSG.MSG_START: {
gameMsg.start = MsgStartAdapter(gameData); gameMsg.start = MsgStartAdapter(gameData);
...@@ -79,11 +81,12 @@ export default class GameMsgAdapter implements StocAdapter { ...@@ -79,11 +81,12 @@ export default class GameMsgAdapter implements StocAdapter {
break; break;
} }
case GAME_MSG.MSG_MOVE: { // case GAME_MSG.MSG_MOVE: {
gameMsg.move = MsgMoveAdapter(gameData); // // gameMsg.move = MsgMoveAdapter(gameData);
// gameMsg["move"] = MsgMoveAdapter(gameData);
break; //
} // break;
// }
case GAME_MSG.MSG_SELECT_CARD: { case GAME_MSG.MSG_SELECT_CARD: {
gameMsg.select_card = MsgSelectCardAdapter(gameData); gameMsg.select_card = MsgSelectCardAdapter(gameData);
...@@ -115,9 +118,10 @@ export default class GameMsgAdapter implements StocAdapter { ...@@ -115,9 +118,10 @@ export default class GameMsgAdapter implements StocAdapter {
break; break;
} }
} }
}
return new ygopro.YgoStocMsg({ return new ygopro.YgoStocMsg({
stoc_game_msg: gameMsg, stoc_game_msg: new ygopro.StocGameMessage(gameMsg),
}); });
} }
} }
{
"50": {
"protoType": "move",
"fields": [
{
"fieldName": "code",
"fieldType": "uint32"
},
{
"fieldName": "from",
"fieldType": "CardLocation"
},
{
"fieldName": "to",
"fieldType": "CardLocation"
},
{
"fieldName": "reason",
"fieldType": "uint8"
}
]
}
}
//! 透传协议
import PenetrateData from "./penetrate.json";
import { BufferReader } from "../../bufferIO";
export interface penetrateType {
protoType: string;
fields: {
fieldName: string;
fieldType: string;
}[];
}
const PenetrateConfig = _objToMap(PenetrateData);
export function penetrate(
msgKey: number,
gameMsg: any,
gameData: Uint8Array
): boolean {
const config = PenetrateConfig.get(msgKey.toString());
const reader = new BufferReader(gameData, true);
if (config) {
const protoType = config.protoType;
const fields = config.fields;
let obj: any = {};
for (let field of fields) {
obj[field.fieldName] = readField(reader, field.fieldType);
}
gameMsg[protoType] = obj;
}
return config ? true : false;
}
function _objToMap(obj: any): Map<string, penetrateType> {
let map = new Map();
for (let key of Object.keys(obj)) {
map.set(key, obj[key]);
}
return map;
}
function readField(reader: BufferReader, fieldType: string): any {
switch (fieldType) {
case "uint8": {
return reader.readUint8();
}
case "uint32": {
return reader.readUint32();
}
case "CardLocation": {
return reader.readCardLocation();
}
default: {
return undefined;
}
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment