Fixed Qt GUI --help command line option when no window system is present (X11/wayland). There is now a pre-gui initialization sweep of command line options. Also added a --version command line option and a warning that the --no-gui option is not supported (should someone try to use it). Fixes issue #528.

This commit is contained in:
harry 2022-08-14 20:15:50 -04:00 committed by zeromus
parent 32bd9a7f49
commit 3eddaf8052
3 changed files with 25 additions and 5 deletions

View File

@ -642,6 +642,7 @@ static const char *DriverUsage =
static void ShowUsage(const char *prog) static void ShowUsage(const char *prog)
{ {
int i,j; int i,j;
FCEUD_Message("Starting " FCEU_NAME_AND_VERSION "...\n");
printf("\nUsage is as follows:\n%s <options> filename\n\n",prog); printf("\nUsage is as follows:\n%s <options> filename\n\n",prog);
puts(DriverUsage); puts(DriverUsage);
#ifdef _S9XLUA_H #ifdef _S9XLUA_H
@ -681,11 +682,9 @@ static void ShowUsage(const char *prog)
} }
int fceuWrapperInit( int argc, char *argv[] ) // Pre-GUI initialization.
int fceuWrapperPreInit( int argc, char *argv[] )
{ {
int opt, error;
std::string s;
for (int i=0; i<argc; i++) for (int i=0; i<argc; i++)
{ {
if ( (strcmp(argv[i], "--help") == 0) || (strcmp(argv[i],"-h") == 0) ) if ( (strcmp(argv[i], "--help") == 0) || (strcmp(argv[i],"-h") == 0) )
@ -693,7 +692,24 @@ int fceuWrapperInit( int argc, char *argv[] )
ShowUsage(argv[0]); ShowUsage(argv[0]);
exit(0); exit(0);
} }
else if ( strcmp(argv[i], "--no-gui") == 0)
{
printf("Error: Qt/SDL version does not support --no-gui option.\n");
exit(1);
} }
else if ( strcmp(argv[i], "--version") == 0)
{
printf("%i.%i.%i\n", FCEU_VERSION_MAJOR, FCEU_VERSION_MINOR, FCEU_VERSION_PATCH);
exit(0);
}
}
return 0;
}
int fceuWrapperInit( int argc, char *argv[] )
{
int opt, error;
std::string s;
FCEUD_Message("Starting " FCEU_NAME_AND_VERSION "...\n"); FCEUD_Message("Starting " FCEU_NAME_AND_VERSION "...\n");

View File

@ -30,6 +30,7 @@ int CloseGame(void);
int reloadLastGame(void); int reloadLastGame(void);
int LoadGameFromLua( const char *path ); int LoadGameFromLua( const char *path );
int fceuWrapperPreInit( int argc, char *argv[] );
int fceuWrapperInit( int argc, char *argv[] ); int fceuWrapperInit( int argc, char *argv[] );
int fceuWrapperMemoryCleanup( void ); int fceuWrapperMemoryCleanup( void );
int fceuWrapperClose( void ); int fceuWrapperClose( void );

View File

@ -95,7 +95,10 @@ static bool showSplashScreen(void)
int main( int argc, char *argv[] ) int main( int argc, char *argv[] )
{ {
int retval; int retval = 0;
fceuWrapperPreInit(argc, argv);
qInstallMessageHandler(MessageOutput); qInstallMessageHandler(MessageOutput);
QApplication app(argc, argv); QApplication app(argc, argv);