ViewVC Help
View File | Revision Log | View Changeset | Root Listing
root/Oni2/Daodan/src/Daodan.c
(Generate patch)

Comparing Daodan/src/Daodan.c (file contents):
Revision 273 by rossy, Tue Mar 17 09:55:12 2009 UTC vs.
Revision 990 by alloc, Wed Apr 2 00:48:54 2014 UTC

# Line 1 | Line 1
1 + #include <windows.h>
2 + #include <string.h>
3 + #include <stdio.h>
4 + #include <time.h>
5 +
6   #include "Daodan.h"
7   #include "Daodan_Patch.h"
8   #include "Daodan_Utility.h"
9 + #include "Daodan_Cheater.h"
10 + #include "Daodan_BSL.h"
11 + #include "Daodan_Console.h"
12 + #include "Daodan_Config.h"
13 + #include "patches/Patches.h"
14 + #include "bink-proxy.h"
15 + #include "_Version.h"
16  
17   #include "Oni.h"
18 < #include "BFW_Utility.h"
18 >
19 > #include "Oni_GL.h"
20  
21   HMODULE DDrDLLModule;
22   HMODULE DDrONiModule;
23  
24 < bool DDrPatch_Init()
24 > void __cdecl DDrMain(int argc, char* argv[])
25   {
26 <        // Font texture cache doubled
27 <        DDrPatch_Byte ((void*)0x00400000 + 0x00020ea7, 0x20);
28 <        DDrPatch_Byte ((void*)0x00400000 + 0x00020f4a, 0x40);
29 <        
30 <        // Now supports textures up to 512x512
31 <        DDrPatch_Byte ((void*)0x00400000 + 0x00005251, 0x10);
19 <        
20 <        // Non-"_Final" levels are now valid
21 <        DDrPatch_Byte ((void*)0x00400000 + 0x000206a8, 0x01);
22 <        
23 <        // Pathfinding grid cache size x8
24 <        DDrPatch_Byte ((void*)0x00400000 + 0x0010b03b, 0x20);
25 <        DDrPatch_Byte ((void*)0x00400000 + 0x0010b04c, 0x20);
26 <        
27 <        // Projectile awareness fixed
28 <        DDrPatch_Byte ((void*)0x00400000 + 0x0009c07c, 0x6c);
29 <        DDrPatch_Byte ((void*)0x00400000 + 0x0009c080, 0x70);
30 <        DDrPatch_Byte ((void*)0x00400000 + 0x0009c084, 0x74);
31 <        DDrPatch_Byte ((void*)0x00400000 + 0x0009c110, 0x6c);
32 <        
33 <        // Forced DirectInput (for Windows NT)
34 <        DDrPatch_Byte ((void*)0x00400000 + 0x00002e6d, 0xeb);
35 <        
36 <        // Makes wp_fadetime actually have a function
37 <        const char fadetime_patch[] = { 0x66, 0x8B, 0x1D, 0xC4, 0x7D, 0x62, 0x00, 0x66, 0x89, 0x5E, 0x46, 0x5B, 0x5E, 0x83, 0xC4, 0x14, 0xC3 };
38 <        DDrPatch_Const((void*)0x00400000 + 0x0011a889, fadetime_patch);
39 <        DDrPatch_Byte ((void*)0x00400000 + 0x0011a560, 31);
40 <        
41 <        // Sets the fadetime to 4800 by default
42 <        DDrPatch_Int16((void*)0x00400000 + 0x0011ab0e, 0x12c0);
43 <        
44 <        // Hackish fix for Konoko not kicking guns
45 <        const char kickgun_patch[] = { 0x00, 0x05, 0x00, 0x00, 0x00, 0xC7, 0x05, 0x1C, 0xC9, 0x5E, 0x00, 0x70, 0xB8, 0x43, 0x00, 0xC7, 0x05, 0x20, 0xC9, 0x5E, 0x00, 0x20, 0xBE, 0x43 };
46 <        DDrPatch_Const((void*)0x00400000 + 0x000dc420, kickgun_patch);
47 <        
48 <        // Cooldown timer exploit fix ^_^
49 <        const char cooldown_patch[] = { 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90 };
50 <        DDrPatch_Const((void*)0x00400000 + 0x0011a825, cooldown_patch);
51 <        
52 < //      const char throwtest_patch[] = { 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90 };
53 < //      DDrPatch_Const((void*)0x00400000 + 0x000dc190, throwtest_patch);
54 <        
55 <        return true;
56 < }
26 >        time_t rawtime;
27 >        struct tm* timeinfo;
28 >        char buffer[80];
29 >        time(&rawtime);
30 >        timeinfo = localtime(&rawtime);
31 >        strftime(buffer, 80, "Daodan: %Y-%m-%d %H:%M:%S", timeinfo);
32  
33 < void DDrMain(int argc, char* argv[])
34 < {
60 <        DDrPatch_Init();
61 <        
62 <        // Safe startup message printer
63 <        DDrPatch_MakeJump(UUrStartupMessage, DDrStartupMessage);
33 >        DDrStartupMessage("Daodan: Daodan v."DAODAN_VERSION_STRING" attached!");
34 >        DDrStartupMessage(buffer);
35          
36 +        DDrConfig(argc, argv);
37 +
38 +        if(GetKeyState(VK_SHIFT) & 0x8000) {
39 +                DDrStartupMessage("Daodan: Shift");
40 +                guitest(DDrONiModule);
41 +        }
42 +
43 +        DD_Patch_Init();
44 +
45 +        BinkProxyInit();
46 +
47          ONiMain(argc, argv);
48   }
49 <
49 > /*
50 > void DDrWrongExe()
51 > {
52 >        switch (MessageBox(NULL, "This version of the Daodan DLL is incompatible with your Oni.exe.\n"
53 >                "Click OK for more information. To continue using Oni without the patch, replace the downloaded binkw32.dll with the original.", "Daodan", MB_OKCANCEL | MB_ICONERROR))
54 >        {
55 >                case IDOK:
56 >                        {
57 >                                STARTUPINFO si;
58 >                                PROCESS_INFORMATION pi;
59 >                                FillMemory(&si, 0, sizeof(si));
60 >                                FillMemory(&pi, 0, sizeof(pi));
61 >                                si.cb = sizeof(si);
62 >                                if (!CreateProcess(NULL, "cmd /c \"start http://wiki.oni2.net/Daodan_DLL\"", NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi))
63 >                                        MessageBox(NULL, "", "", 0);
64 >                                CloseHandle(pi.hProcess);
65 >                                CloseHandle(pi.hThread);
66 >                        }
67 >                default:
68 >                        ExitProcess(0);
69 >        }
70 > }
71 > */
72   BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpReserved)
73   {
74          switch (fdwReason)
# Line 73 | Line 77 | BOOL WINAPI DllMain(HINSTANCE hinstDLL,
77                          DDrDLLModule = hinstDLL;
78                          DDrONiModule = GetModuleHandle(NULL);
79                          
80 <                        DDrPatch_MakeCall((void*)0x00400000 + 0x0010fb49, DDrMain);
81 <                        
80 >                        if (*(uint32_t*)(OniExe + 0x0011acd0) == 0x09d36852)
81 >                                DDrPatch_MakeCall((void*)(OniExe + 0x0010fb49), (void*)DDrMain);
82 >                        else
83 >                                ExitProcess(0);
84                          break;
85          }
86          return TRUE;

Diff Legend

Removed lines
+ Added lines
< Changed lines (old)
> Changed lines (new)