Merge pull request #511 from nofficalfs/PR-Enhancement-EventDebuggerPatch
支持额外类型Content的Debugger
This commit is contained in:
commit
638ac38f21
20
game/game.js
20
game/game.js
|
@ -11297,10 +11297,11 @@
|
||||||
case "object":
|
case "object":
|
||||||
if(Array.isArray(item)){
|
if(Array.isArray(item)){
|
||||||
let lastEvent=null;
|
let lastEvent=null;
|
||||||
return (event,step,source,player,target,targets,card,cards,skill,forced,num,trigger,result,_status,lib,game,ui,get,ai)=>{
|
return function*(event,step,source,player,target,targets,card,cards,skill,forced,num,trigger,result,_status,lib,game,ui,get,ai){
|
||||||
if(step>=item.length) return event.finish();
|
if(step>=item.length) return event.finish();
|
||||||
var current=item[step];
|
var current=item[step];
|
||||||
lastEvent=current(event,{
|
if(typeof current!="function") throw new Error(`content ${step} of ${event.name} is not vaild: ${current}`);
|
||||||
|
var currentResult=current(event,{
|
||||||
event:event,
|
event:event,
|
||||||
step:step,
|
step:step,
|
||||||
source:source,
|
source:source,
|
||||||
|
@ -11315,11 +11316,14 @@
|
||||||
trigger:trigger,
|
trigger:trigger,
|
||||||
result:result
|
result:result
|
||||||
},(lastEvent&&("result" in lastEvent))?lastEvent.result:null);
|
},(lastEvent&&("result" in lastEvent))?lastEvent.result:null);
|
||||||
|
// TODO: use `event.debugger` to replace source
|
||||||
|
if(gnc.is.generator(currentResult)) lastEvent=yield* currentResult;
|
||||||
|
else lastEvent=currentResult;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
if(Symbol.iterator in item) return lib.init.parsex(Array.from(item));
|
if(Symbol.iterator in item) return lib.init.parsex(Array.from(item));
|
||||||
if("toString" in item) return lib.init.parsex(item.toString());
|
if(item.toString !== Object.prototype.toString) return lib.init.parsex(item.toString());
|
||||||
if("render" in item) {
|
if("render" in item) {
|
||||||
// TODO: Object Render Parse
|
// TODO: Object Render Parse
|
||||||
throw new Error("NYI: Object Render Parse");
|
throw new Error("NYI: Object Render Parse");
|
||||||
|
@ -11330,7 +11334,8 @@
|
||||||
case "function":
|
case "function":
|
||||||
if (gnc.is.generatorFunc(item)) {
|
if (gnc.is.generatorFunc(item)) {
|
||||||
let gen,lastEvent;
|
let gen,lastEvent;
|
||||||
return (event,step,source,player,target,targets,card,cards,skill,forced,num,trigger,result,_status,lib,game,ui,get,ai)=>{
|
return function*(event,step,source,player,target,targets,card,cards,skill,forced,num,trigger,result,_status,lib,game,ui,get,ai){
|
||||||
|
event.step=NaN;
|
||||||
if(!gen)gen=item(event,{
|
if(!gen)gen=item(event,{
|
||||||
event:event,
|
event:event,
|
||||||
step:step,
|
step:step,
|
||||||
|
@ -11348,7 +11353,12 @@
|
||||||
});
|
});
|
||||||
var res=gen.next((lastEvent&&("result" in lastEvent))?lastEvent.result:null);
|
var res=gen.next((lastEvent&&("result" in lastEvent))?lastEvent.result:null);
|
||||||
if(res.done) event.finish();
|
if(res.done) event.finish();
|
||||||
else lastEvent=res.value;
|
else {
|
||||||
|
var currentResult=res.value;
|
||||||
|
// TODO: use `event.debugger` to replace source
|
||||||
|
if(typeof currentResult=="function") yield currentResult;
|
||||||
|
else lastEvent=currentResult;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in New Issue