QTfrontend/campaign.cpp
changeset 15506 f315bb93db1f
parent 14633 c9d2a5a9f6ba
--- a/QTfrontend/campaign.cpp	Thu Nov 14 17:25:48 2019 +0100
+++ b/QTfrontend/campaign.cpp	Thu Nov 14 18:19:18 2019 +0100
@@ -57,25 +57,29 @@
     QSettings* teamfile = getCampTeamFile(campaignName, teamName);
     int progress = teamfile->value("Campaign " + campaignName + "/Progress", 0).toInt();
     int unlockedMissions = teamfile->value("Campaign " + campaignName + "/UnlockedMissions", 0).toInt();
-    // The CowardMode cheat unlocks all campaign missions,
-    // but as "punishment", none of them will be marked as completed.
+    QSettings campfile("physfs://Missions/Campaign/" + campaignName + "/campaign.ini", QSettings::IniFormat, 0);
+    campfile.setIniCodec("UTF-8");
+    int totalMissions = campfile.value("MissionNum", 1).toInt();
+    // The CowardMode cheat unlocks all campaign missions.
     // Added to make it easier to test campaigns.
     bool cheat = teamfile->value("Team/CowardMode", false).toBool();
-    if(cheat)
+    if(progress>0 && unlockedMissions==0)
     {
-        return false;
-    }
-    else if(progress>0 && unlockedMissions==0)
-    {
-        QSettings campfile("physfs://Missions/Campaign/" + campaignName + "/campaign.ini", QSettings::IniFormat, 0);
-        campfile.setIniCodec("UTF-8");
-        int totalMissions = campfile.value("MissionNum", 1).toInt();
-        return (progress > (progress - missionInList)) || (progress >= totalMissions);
+        int maxMission;
+        if(cheat)
+            maxMission = totalMissions - (missionInList + 1);
+        else
+            maxMission = progress - missionInList;
+        return (progress > maxMission) || (progress >= totalMissions);
     }
     else if(unlockedMissions>0)
     {
         int fileMissionId = missionInList + 1;
-        int actualMissionId = teamfile->value(QString("Campaign %1/Mission%2").arg(campaignName, QString::number(fileMissionId)), false).toInt();
+        int actualMissionId;
+        if(cheat)
+            actualMissionId = totalMissions - missionInList;
+        else
+            actualMissionId = teamfile->value(QString("Campaign %1/Mission%2").arg(campaignName, QString::number(fileMissionId)), false).toInt();
         return teamfile->value(QString("Campaign %1/Mission%2Won").arg(campaignName, QString::number(actualMissionId)), false).toBool();
     }
     else
@@ -87,8 +91,7 @@
 {
     QSettings* teamfile = getCampTeamFile(campaignName, teamName);
     bool won = teamfile->value("Campaign " + campaignName + "/Won", false).toBool();
-    bool cheat = teamfile->value("Team/CowardMode", false).toBool();
-    return won && !cheat;
+    return won;
 }
 
 QSettings* getCampMetaInfo()