Skip to content

Commit

Permalink
New feature: poll external file for console commands
Browse files Browse the repository at this point in the history
The commit adds "-refreshfile" and "-refreshinterval" command-line
arguments. Every refreshinterval tics (or once a second if not
specified) a refreshfile is read and is evaluated if exists and not
empty. Then it is truncated.

This feature provides a facility for an external program to control
the game.
  • Loading branch information
kmeaw committed Feb 5, 2022
1 parent 751f859 commit c558c90
Showing 1 changed file with 40 additions and 0 deletions.
40 changes: 40 additions & 0 deletions src/common/console/c_console.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@
#include "g_input.h"
#include "c_commandbuffer.h"
#include "vm.h"
#include "m_argv.h"

#define LEFTMARGIN 8
#define RIGHTMARGIN 8
Expand Down Expand Up @@ -110,6 +111,9 @@ static int TopLine, InsertLine;

static void ClearConsole ();

static FString* RefreshFile;
static int RefreshInterval = 0;

struct GameAtExit
{
GameAtExit(FString str) : Command(str) {}
Expand Down Expand Up @@ -235,6 +239,8 @@ void C_InitConback(FTextureID fallback, bool tile, double brightness)
void C_InitConsole (int width, int height, bool ingame)
{
int cwidth, cheight;
const char *v;
int i;

vidactive = ingame;
if (CurrentConsoleFont != NULL)
Expand All @@ -250,6 +256,18 @@ void C_InitConsole (int width, int height, bool ingame)
CmdLine.ConCols = ConWidth / cwidth;

if (conbuffer == NULL) conbuffer = new FConsoleBuffer;

i = Args->CheckParm ("-refreshfile");
if (i > 0 && i < (int)Args->NumArgs() - 1)
{
RefreshFile = Args->GetArgList(i + 1);
RefreshInterval = TICRATE;
v = Args->CheckValue ("-refreshinterval");
if (v != NULL && (atoi(v) != 0))
{
RefreshInterval = atoi(v);
}
}
}

//==========================================================================
Expand Down Expand Up @@ -534,9 +552,31 @@ void C_NewModeAdjust ()
int consoletic = 0;
void C_Ticker()
{
FileReader fr;
static int lasttic = 0;
long filesize = 1;
consoletic++;

if (RefreshInterval > 0 && (consoletic % RefreshInterval) == 0)
{
if (fr.OpenFile (RefreshFile->GetChars()))
{
auto length = fr.GetLength();
fr.Close();

if (length > 0)
{
C_ExecFile (RefreshFile->GetChars());

// Truncate the file
FileWriter fw;
if (fw.Open (RefreshFile->GetChars())) {
fw.Close ();
}
}
}
}

if (lasttic == 0)
lasttic = consoletic - 1;

Expand Down

0 comments on commit c558c90

Please sign in to comment.