mirror of
https://github.com/OpenFusionProject/OpenFusion.git
synced 2024-11-22 13:30:06 +00:00
Fix academy nano missions not going into the 0th slot
This commit is contained in:
parent
772f80188e
commit
a1a5815f1f
@ -684,7 +684,7 @@ void lairUnlockCommand(std::string full, std::vector<std::string>& args, CNSocke
|
|||||||
}
|
}
|
||||||
|
|
||||||
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, taskResp);
|
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, taskResp);
|
||||||
MissionManager::startTask(plr, taskID, false);
|
MissionManager::startTask(plr, taskID);
|
||||||
taskResp.iTaskNum = taskID;
|
taskResp.iTaskNum = taskID;
|
||||||
taskResp.iRemainTime = 0;
|
taskResp.iRemainTime = 0;
|
||||||
sock->sendPacket((void*)&taskResp, P_FE2CL_REP_PC_TASK_START_SUCC, sizeof(sP_FE2CL_REP_PC_TASK_START_SUCC));
|
sock->sendPacket((void*)&taskResp, P_FE2CL_REP_PC_TASK_START_SUCC, sizeof(sP_FE2CL_REP_PC_TASK_START_SUCC));
|
||||||
|
@ -18,14 +18,16 @@ void MissionManager::init() {
|
|||||||
REGISTER_SHARD_PACKET(P_CL2FE_REQ_PC_TASK_STOP, quitMission);
|
REGISTER_SHARD_PACKET(P_CL2FE_REQ_PC_TASK_STOP, quitMission);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MissionManager::startTask(Player* plr, int TaskID, bool NanoMission) {
|
bool MissionManager::startTask(Player* plr, int TaskID) {
|
||||||
if (MissionManager::Tasks.find(TaskID) == MissionManager::Tasks.end()) {
|
if (MissionManager::Tasks.find(TaskID) == MissionManager::Tasks.end()) {
|
||||||
std::cout << "[WARN] Player submitted unknown task!?" << std::endl;
|
std::cout << "[WARN] Player submitted unknown task!?" << std::endl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// client freaks out if nano mission isn't sent first after reloging, so it's easiest to set it here
|
TaskData& task = *MissionManager::Tasks[TaskID];
|
||||||
if (NanoMission && plr->tasks[0] != 0) {
|
|
||||||
|
// client freaks out if nano mission isn't sent first after relogging, so it's easiest to set it here
|
||||||
|
if (task["m_iSTNanoID"] != 0 && plr->tasks[0] != 0) {
|
||||||
// lets move task0 to different spot
|
// lets move task0 to different spot
|
||||||
int moveToSlot = 1;
|
int moveToSlot = 1;
|
||||||
for (; moveToSlot < ACTIVE_MISSION_COUNT; moveToSlot++)
|
for (; moveToSlot < ACTIVE_MISSION_COUNT; moveToSlot++)
|
||||||
@ -40,7 +42,6 @@ bool MissionManager::startTask(Player* plr, int TaskID, bool NanoMission) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TaskData& task = *MissionManager::Tasks[TaskID];
|
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < ACTIVE_MISSION_COUNT; i++) {
|
for (i = 0; i < ACTIVE_MISSION_COUNT; i++) {
|
||||||
if (plr->tasks[i] == 0) {
|
if (plr->tasks[i] == 0) {
|
||||||
@ -67,7 +68,7 @@ void MissionManager::taskStart(CNSocket* sock, CNPacketData* data) {
|
|||||||
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, response);
|
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, response);
|
||||||
Player *plr = PlayerManager::getPlayer(sock);
|
Player *plr = PlayerManager::getPlayer(sock);
|
||||||
|
|
||||||
if (!startTask(plr, missionData->iTaskNum, false)) {
|
if (!startTask(plr, missionData->iTaskNum)) {
|
||||||
// TODO: TASK_FAIL?
|
// TODO: TASK_FAIL?
|
||||||
response.iTaskNum = missionData->iTaskNum;
|
response.iTaskNum = missionData->iTaskNum;
|
||||||
sock->sendPacket((void*)&response, P_FE2CL_REP_PC_TASK_START_SUCC, sizeof(sP_FE2CL_REP_PC_TASK_START_SUCC));
|
sock->sendPacket((void*)&response, P_FE2CL_REP_PC_TASK_START_SUCC, sizeof(sP_FE2CL_REP_PC_TASK_START_SUCC));
|
||||||
@ -486,7 +487,7 @@ void MissionManager::updateFusionMatter(CNSocket* sock, int fusion) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// start the nano mission
|
// start the nano mission
|
||||||
startTask(plr, AvatarGrowth[plr->level]["m_iNanoQuestTaskID"], true);
|
startTask(plr, AvatarGrowth[plr->level]["m_iNanoQuestTaskID"]);
|
||||||
|
|
||||||
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, response);
|
INITSTRUCT(sP_FE2CL_REP_PC_TASK_START_SUCC, response);
|
||||||
response.iTaskNum = AvatarGrowth[plr->level]["m_iNanoQuestTaskID"];
|
response.iTaskNum = AvatarGrowth[plr->level]["m_iNanoQuestTaskID"];
|
||||||
|
@ -41,7 +41,7 @@ namespace MissionManager {
|
|||||||
extern nlohmann::json AvatarGrowth[37];
|
extern nlohmann::json AvatarGrowth[37];
|
||||||
void init();
|
void init();
|
||||||
|
|
||||||
bool startTask(Player* plr, int TaskID, bool NanoMission);
|
bool startTask(Player* plr, int TaskID);
|
||||||
void taskStart(CNSocket* sock, CNPacketData* data);
|
void taskStart(CNSocket* sock, CNPacketData* data);
|
||||||
void taskEnd(CNSocket* sock, CNPacketData* data);
|
void taskEnd(CNSocket* sock, CNPacketData* data);
|
||||||
void setMission(CNSocket* sock, CNPacketData* data);
|
void setMission(CNSocket* sock, CNPacketData* data);
|
||||||
|
Loading…
Reference in New Issue
Block a user