- Add skill CCMD to return player's current skill, while also being able to set skill for next game.

* Fixes #332.
This commit is contained in:
Mitchell Richters 2021-07-20 18:50:46 +10:00
parent 77630dcbc7
commit 33845c4a23
10 changed files with 88 additions and 0 deletions

View file

@ -495,3 +495,59 @@ CCMD(endofgame)
STAT_Update(true); STAT_Update(true);
ChangeLevel(nullptr, -1); ChangeLevel(nullptr, -1);
} }
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
CCMD(skill)
{
if (gamestate == GS_LEVEL)
{
auto argsCount = argv.argc();
if (argsCount < 2)
{
auto currentSkill = gi->GetCurrentSkill();
if (currentSkill >= 0)
{
Printf("Current skill is %d (%s)\n", currentSkill, GStrings.localize(gSkillNames[currentSkill]));
}
else if (currentSkill == -1)
{
Printf("Current skill is not set (%d)\n");
}
else if (currentSkill == -2)
{
Printf("This game has no skill settings.\n");
}
else
{
Printf("Current skill is an unknown/unsupported value (%d)\n");
}
}
else if (argsCount == 2)
{
auto newSkill = atoi(argv[1]);
if (newSkill >= 0 and newSkill < MAXSKILLS)
{
g_nextskill = newSkill;
Printf("Skill will be changed for next game.\n");
}
else
{
Printf("Please specify a skill level between 0 and %d\n", MAXSKILLS - 1);
}
}
else if (argsCount > 2)
{
Printf(PRINT_BOLD, "skill <newskill>: returns the current skill level, and optionally sets the skill level for the next game.\n");
}
}
else
{
Printf("Currently not in a game.\n");
}
}

View file

@ -121,6 +121,7 @@ struct GameInterface
virtual bool GetGeoEffect(GeoEffect* eff, int viewsector) { return false; } virtual bool GetGeoEffect(GeoEffect* eff, int viewsector) { return false; }
virtual int Voxelize(int sprnum) { return -1; } virtual int Voxelize(int sprnum) { return -1; }
virtual void AddExcludedEpisode(FString episode) {} virtual void AddExcludedEpisode(FString episode) {}
virtual int GetCurrentSkill() { return -1; }
virtual FString statFPS() virtual FString statFPS()
{ {

View file

@ -241,6 +241,12 @@ void GameInterface::NextLevel(MapRecord *map, int skill)
NewLevel(map, skill, false); NewLevel(map, skill, false);
} }
int GameInterface::GetCurrentSkill()
{
return gGameOptions.nDifficulty;
}
void GameInterface::Ticker() void GameInterface::Ticker()
{ {
for (int i = connecthead; i >= 0; i = connectpoint2[i]) for (int i = connecthead; i >= 0; i = connectpoint2[i])

View file

@ -149,6 +149,7 @@ struct GameInterface : public ::GameInterface
void EnterPortal(spritetype* viewer, int type) override; void EnterPortal(spritetype* viewer, int type) override;
void LeavePortal(spritetype* viewer, int type) override; void LeavePortal(spritetype* viewer, int type) override;
void LoadGameTextures() override; void LoadGameTextures() override;
int GetCurrentSkill() override;
GameStats getStats() override; GameStats getStats() override;
}; };

View file

@ -68,6 +68,7 @@ struct GameInterface : public ::GameInterface
void LeavePortal(spritetype* viewer, int type) override; void LeavePortal(spritetype* viewer, int type) override;
bool GetGeoEffect(GeoEffect* eff, int viewsector) override; bool GetGeoEffect(GeoEffect* eff, int viewsector) override;
void AddExcludedEpisode(FString episode) override; void AddExcludedEpisode(FString episode) override;
int GetCurrentSkill() override;
}; };

View file

@ -272,6 +272,11 @@ void GameInterface::loadPalette()
genspriteremaps(); genspriteremaps();
} }
int GameInterface::GetCurrentSkill()
{
return ud.player_skill - 1;
}
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
// //
// set up the game module's state // set up the game module's state

View file

@ -248,6 +248,7 @@ struct GameInterface : public ::GameInterface
int chaseCamY(binangle ang) { return -ang.bsin() / 12; } int chaseCamY(binangle ang) { return -ang.bsin() / 12; }
int chaseCamZ(fixedhoriz horiz) { return horiz.asq16() / 384; } int chaseCamZ(fixedhoriz horiz) { return horiz.asq16() / 384; }
void processSprites(spritetype* tsprite, int& spritesortcnt, int viewx, int viewy, int viewz, binangle viewang, double smoothRatio) override; void processSprites(spritetype* tsprite, int& spritesortcnt, int viewx, int viewy, int viewz, binangle viewang, double smoothRatio) override;
int GetCurrentSkill() override;
::GameStats getStats() override; ::GameStats getStats() override;
}; };

View file

@ -141,6 +141,11 @@ void GameInterface::NewGame(MapRecord *map, int skill, bool frommenu)
gameaction = ga_level; gameaction = ga_level;
} }
int GameInterface::GetCurrentSkill()
{
return -2;
}
int selectedlevelnew; int selectedlevelnew;
DEFINE_ACTION_FUNCTION(DMapScreen, SetNextLevel) DEFINE_ACTION_FUNCTION(DMapScreen, SetNextLevel)

View file

@ -580,6 +580,17 @@ void GameInterface::NewGame(MapRecord *map, int skill, bool)
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
int GameInterface::GetCurrentSkill()
{
return Skill;
}
//---------------------------------------------------------------------------
//
//
//
//---------------------------------------------------------------------------
void GameInterface::Ticker(void) void GameInterface::Ticker(void)
{ {
int i; int i;

View file

@ -2274,6 +2274,7 @@ struct GameInterface : public ::GameInterface
void LeavePortal(spritetype* viewer, int type) override; void LeavePortal(spritetype* viewer, int type) override;
int Voxelize(int sprnum); int Voxelize(int sprnum);
void ExitFromMenu() override; void ExitFromMenu() override;
int GetCurrentSkill() override;
GameStats getStats() override; GameStats getStats() override;