Removed vastly inferior variant of accessing argc/argv in WinMain()

This commit is contained in:
Willi Schinmeyer 2012-05-17 14:14:34 +02:00
parent 54238f9bf1
commit 561bf99a84

View file

@ -56,8 +56,6 @@ char** g_argv;
// used in Release Builds to suppress the Console // used in Release Builds to suppress the Console
#if defined(_WIN32) #if defined(_WIN32)
// contains __getmainargs()
//#include <internal.h>
#include <winbase.h> #include <winbase.h>
int main(int argc, char* argv[]); int main(int argc, char* argv[]);
@ -68,45 +66,8 @@ int CALLBACK WinMain(
__in LPSTR lpCmdLine, __in LPSTR lpCmdLine,
__in int nCmdShow __in int nCmdShow
){ ){
if(false) {
// while this works, it's not exactly nice
__argc = 3;
// load msvcrt.dll - we need an internal function from it
HMODULE crtlib = LoadLibrary("msvcrt.dll");
if(crtlib == NULL) {
// do error handling here?
return 0;
}
// retrieve pointer to function
struct fake_startupinfo {
int newmode;
};
typedef int(*GetMainArgsPtr)(int*, char***, char***, int, fake_startupinfo*);
GetMainArgsPtr __getmainargs = (GetMainArgsPtr) GetProcAddress(crtlib, "__getmainargs");
if(__getmainargs == NULL){
FreeLibrary(crtlib);
return 0;
}
fake_startupinfo startinfo;
startinfo.newmode = 0; //this sets _newmode - what does that do?
int argc;
char** argv;
char** envp;
int argret = __getmainargs(&argc, &argv, &envp, 0, &startinfo); //0: no wildcard expanding
FreeLibrary(crtlib);
if(argret < 0) {
// might want to handle this error here?
return 0;
}
return main(argc, argv);
}
else {
// This, on the other hand, seems very nice - but just like the first version I'm not sure it always works.
return main(__argc, __argv); return main(__argc, __argv);
} }
}
#endif #endif