summaryrefslogtreecommitdiff
path: root/utils/vrad_launcher
diff options
context:
space:
mode:
authorFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
committerFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
commit3bf9df6b2785fa6d951086978a3e66f49427166a (patch)
tree2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /utils/vrad_launcher
downloadarchived-source-engine-2018-hl2-src-master.tar.xz
archived-source-engine-2018-hl2-src-master.zip
Diffstat (limited to 'utils/vrad_launcher')
-rw-r--r--utils/vrad_launcher/stdafx.cpp15
-rw-r--r--utils/vrad_launcher/stdafx.h32
-rw-r--r--utils/vrad_launcher/vrad_launcher.cpp145
-rw-r--r--utils/vrad_launcher/vrad_launcher.vpc54
4 files changed, 246 insertions, 0 deletions
diff --git a/utils/vrad_launcher/stdafx.cpp b/utils/vrad_launcher/stdafx.cpp
new file mode 100644
index 0000000..983b8ba
--- /dev/null
+++ b/utils/vrad_launcher/stdafx.cpp
@@ -0,0 +1,15 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+// stdafx.cpp : source file that includes just the standard includes
+// vrad_launcher.pch will be the pre-compiled header
+// stdafx.obj will contain the pre-compiled type information
+
+#include "stdafx.h"
+
+// TODO: reference any additional headers you need in STDAFX.H
+// and not in this file
diff --git a/utils/vrad_launcher/stdafx.h b/utils/vrad_launcher/stdafx.h
new file mode 100644
index 0000000..36daff0
--- /dev/null
+++ b/utils/vrad_launcher/stdafx.h
@@ -0,0 +1,32 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+// stdafx.h : include file for standard system include files,
+// or project specific include files that are used frequently, but
+// are changed infrequently
+//
+
+#if !defined(AFX_STDAFX_H__4A047C84_94D7_4563_A08C_35E52A52AECC__INCLUDED_)
+#define AFX_STDAFX_H__4A047C84_94D7_4563_A08C_35E52A52AECC__INCLUDED_
+
+#if _MSC_VER > 1000
+#pragma once
+#endif // _MSC_VER > 1000
+
+#define WIN32_LEAN_AND_MEAN // Exclude rarely-used stuff from Windows headers
+
+#include <windows.h>
+#include <stdio.h>
+#include "interface.h"
+#include "ivraddll.h"
+
+// TODO: reference additional headers your program requires here
+
+//{{AFX_INSERT_LOCATION}}
+// Microsoft Visual C++ will insert additional declarations immediately before the previous line.
+
+#endif // !defined(AFX_STDAFX_H__4A047C84_94D7_4563_A08C_35E52A52AECC__INCLUDED_)
diff --git a/utils/vrad_launcher/vrad_launcher.cpp b/utils/vrad_launcher/vrad_launcher.cpp
new file mode 100644
index 0000000..a4d3183
--- /dev/null
+++ b/utils/vrad_launcher/vrad_launcher.cpp
@@ -0,0 +1,145 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+// vrad_launcher.cpp : Defines the entry point for the console application.
+//
+
+#include "stdafx.h"
+#include <direct.h>
+#include "tier1/strtools.h"
+#include "tier0/icommandline.h"
+
+
+char* GetLastErrorString()
+{
+ static char err[2048];
+
+ LPVOID lpMsgBuf;
+ FormatMessage(
+ FORMAT_MESSAGE_ALLOCATE_BUFFER |
+ FORMAT_MESSAGE_FROM_SYSTEM |
+ FORMAT_MESSAGE_IGNORE_INSERTS,
+ NULL,
+ GetLastError(),
+ MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
+ (LPTSTR) &lpMsgBuf,
+ 0,
+ NULL
+ );
+
+ strncpy( err, (char*)lpMsgBuf, sizeof( err ) );
+ LocalFree( lpMsgBuf );
+
+ err[ sizeof( err ) - 1 ] = 0;
+
+ return err;
+}
+
+
+void MakeFullPath( const char *pIn, char *pOut, int outLen )
+{
+ if ( pIn[0] == '/' || pIn[0] == '\\' || pIn[1] == ':' )
+ {
+ // It's already a full path.
+ Q_strncpy( pOut, pIn, outLen );
+ }
+ else
+ {
+ _getcwd( pOut, outLen );
+ Q_strncat( pOut, "\\", outLen, COPY_ALL_CHARACTERS );
+ Q_strncat( pOut, pIn, outLen, COPY_ALL_CHARACTERS );
+ }
+}
+
+int main(int argc, char* argv[])
+{
+ char dllName[512];
+
+ CommandLine()->CreateCmdLine( argc, argv );
+
+ // check whether they used the -both switch. If this is specified, vrad will be run
+ // twice, once with -hdr and once without
+ int both_arg=0;
+ for(int arg=1;arg<argc;arg++)
+ if (Q_stricmp(argv[arg],"-both")==0)
+ {
+ both_arg=arg;
+ }
+
+ char fullPath[512], redirectFilename[512];
+ MakeFullPath( argv[0], fullPath, sizeof( fullPath ) );
+ Q_StripFilename( fullPath );
+ Q_snprintf( redirectFilename, sizeof( redirectFilename ), "%s\\%s", fullPath, "vrad.redirect" );
+
+ // First, look for vrad.redirect and load the dll specified in there if possible.
+ CSysModule *pModule = NULL;
+ FILE *fp = fopen( redirectFilename, "rt" );
+ if ( fp )
+ {
+ if ( fgets( dllName, sizeof( dllName ), fp ) )
+ {
+ char *pEnd = strstr( dllName, "\n" );
+ if ( pEnd )
+ *pEnd = 0;
+
+ pModule = Sys_LoadModule( dllName );
+ if ( pModule )
+ printf( "Loaded alternate VRAD DLL (%s) specified in vrad.redirect.\n", dllName );
+ else
+ printf( "Can't find '%s' specified in vrad.redirect.\n", dllName );
+ }
+
+ fclose( fp );
+ }
+
+ int returnValue = 0;
+
+ for(int mode=0;mode<2;mode++)
+ {
+ if (mode && (! both_arg))
+ continue;
+
+
+ // If it didn't load the module above, then use the
+ if ( !pModule )
+ {
+ strcpy( dllName, "vrad_dll.dll" );
+ pModule = Sys_LoadModule( dllName );
+ }
+
+ if( !pModule )
+ {
+ printf( "vrad_launcher error: can't load %s\n%s", dllName, GetLastErrorString() );
+ return 1;
+ }
+
+ CreateInterfaceFn fn = Sys_GetFactory( pModule );
+ if( !fn )
+ {
+ printf( "vrad_launcher error: can't get factory from vrad_dll.dll\n" );
+ Sys_UnloadModule( pModule );
+ return 2;
+ }
+
+ int retCode = 0;
+ IVRadDLL *pDLL = (IVRadDLL*)fn( VRAD_INTERFACE_VERSION, &retCode );
+ if( !pDLL )
+ {
+ printf( "vrad_launcher error: can't get IVRadDLL interface from vrad_dll.dll\n" );
+ Sys_UnloadModule( pModule );
+ return 3;
+ }
+
+ if (both_arg)
+ strcpy(argv[both_arg],(mode)?"-hdr":"-ldr");
+ returnValue = pDLL->main( argc, argv );
+ Sys_UnloadModule( pModule );
+ pModule=0;
+ }
+ return returnValue;
+}
+
diff --git a/utils/vrad_launcher/vrad_launcher.vpc b/utils/vrad_launcher/vrad_launcher.vpc
new file mode 100644
index 0000000..6c1e7b2
--- /dev/null
+++ b/utils/vrad_launcher/vrad_launcher.vpc
@@ -0,0 +1,54 @@
+//-----------------------------------------------------------------------------
+// VRAD_LAUNCHER.VPC
+//
+// Project Script
+//-----------------------------------------------------------------------------
+
+$Macro SRCDIR "..\.."
+$Macro OUTBINDIR "$SRCDIR\..\game\bin"
+$Macro OUTBINNAME "vrad"
+
+$Include "$SRCDIR\vpc_scripts\source_exe_con_base.vpc"
+
+$Configuration
+{
+ $Compiler
+ {
+ $Create/UsePrecompiledHeader "Use Precompiled Header (/Yu)"
+ $PrecompiledHeaderFile "$(IntDir)/vrad_launcher.pch"
+ }
+
+ $Linker [$WIN32]
+ {
+ $EnableLargeAddresses "Support Addresses Larger Than 2 Gigabytes (/LARGEADDRESSAWARE)"
+ }
+}
+
+$Project "Vrad_launcher"
+{
+ $Folder "Source Files"
+ {
+ -$File "$SRCDIR\public\tier0\memoverride.cpp"
+
+ $File "vrad_launcher.cpp"
+
+ $File "StdAfx.cpp"
+ {
+ $Configuration
+ {
+ $Compiler
+ {
+ $Create/UsePrecompiledHeader "Create Precompiled Header (/Yc)"
+ }
+ }
+ }
+
+ }
+
+ $Folder "Header Files"
+ {
+ $File "$SRCDIR\public\tier1\interface.h"
+ $File "$SRCDIR\public\ivraddll.h"
+ $File "StdAfx.h"
+ }
+}