Implement disc limit break (crescendo)

This commit is contained in:
Melledy
2025-10-29 23:03:23 -07:00
parent 08520493ed
commit ebc48ab955
3 changed files with 71 additions and 3 deletions

View File

@@ -0,0 +1,40 @@
package emu.nebula.server.handlers;
import emu.nebula.net.NetHandler;
import emu.nebula.net.NetMsgId;
import emu.nebula.proto.DiscLimitBreak.DiscLimitBreakReq;
import emu.nebula.proto.DiscLimitBreak.DiscLimitBreakResp;
import emu.nebula.net.HandlerId;
import emu.nebula.net.GameSession;
@HandlerId(NetMsgId.disc_limit_break_req)
public class HandlerDiscLimitBreakReq extends NetHandler {
@Override
public byte[] handle(GameSession session, byte[] message) throws Exception {
// Parse request
var req = DiscLimitBreakReq.parseFrom(message);
// Get character
var disc = session.getPlayer().getCharacters().getDiscById(req.getId());
if (disc == null) {
return this.encodeMsg(NetMsgId.disc_limit_break_failed_ack);
}
// Limit break
var change = disc.limitBreak(req.getQty());
if (change == null) {
return this.encodeMsg(NetMsgId.disc_limit_break_failed_ack);
}
// Create response
var rsp = DiscLimitBreakResp.newInstance()
.setStar(disc.getStar())
.setChange(null);
return this.encodeMsg(NetMsgId.disc_limit_break_succeed_ack, rsp);
}
}

View File

@@ -23,7 +23,7 @@ public class HandlerDiscStrengthenReq extends NetHandler {
return this.encodeMsg(NetMsgId.disc_strengthen_failed_ack);
}
// Upgrade character
// Level up disc
var params = ItemParamMap.fromItemInfos(req.getItems());
var change = disc.upgrade(params);
@@ -33,9 +33,9 @@ public class HandlerDiscStrengthenReq extends NetHandler {
// Create response
var rsp = DiscStrengthenResp.newInstance()
.setChange(change.toProto())
.setLevel(disc.getLevel())
.setExp(disc.getExp());
.setExp(disc.getExp())
.setChange(change.toProto());
return this.encodeMsg(NetMsgId.disc_strengthen_succeed_ack, rsp);
}