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 992 by alloc, Sat Apr 5 10:19:11 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"
6 < #include "BFW_Utility.h"
17 > #include "Oni/Oni.h"
18  
19   HMODULE DDrDLLModule;
20   HMODULE DDrONiModule;
21  
22 < bool DDrPatch_Init()
22 > void __cdecl DDrMain(int argc, char* argv[])
23   {
24 <        // Font texture cache doubled
25 <        DDrPatch_Byte ((void*)0x00400000 + 0x00020ea7, 0x20);
26 <        DDrPatch_Byte ((void*)0x00400000 + 0x00020f4a, 0x40);
27 <        
28 <        // Now supports textures up to 512x512
29 <        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 < }
24 >        time_t rawtime;
25 >        struct tm* timeinfo;
26 >        char buffer[80];
27 >        time(&rawtime);
28 >        timeinfo = localtime(&rawtime);
29 >        strftime(buffer, 80, "Daodan: %Y-%m-%d %H:%M:%S", timeinfo);
30  
31 < void DDrMain(int argc, char* argv[])
32 < {
60 <        DDrPatch_Init();
61 <        
62 <        // Safe startup message printer
63 <        DDrPatch_MakeJump(UUrStartupMessage, DDrStartupMessage);
31 >        DDrStartupMessage("Daodan: Daodan v."DAODAN_VERSION_STRING" attached!");
32 >        DDrStartupMessage(buffer);
33          
34 +        DDrConfig(argc, argv);
35 +
36 +        if(GetKeyState(VK_SHIFT) & 0x8000) {
37 +                DDrStartupMessage("Daodan: Shift");
38 +                guitest(DDrONiModule);
39 +        }
40 +
41 +        DD_Patch_Init();
42 +
43 +        BinkProxyInit();
44 +
45          ONiMain(argc, argv);
46   }
47 <
47 > /*
48 > void DDrWrongExe()
49 > {
50 >        switch (MessageBox(NULL, "This version of the Daodan DLL is incompatible with your Oni.exe.\n"
51 >                "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))
52 >        {
53 >                case IDOK:
54 >                        {
55 >                                STARTUPINFO si;
56 >                                PROCESS_INFORMATION pi;
57 >                                FillMemory(&si, 0, sizeof(si));
58 >                                FillMemory(&pi, 0, sizeof(pi));
59 >                                si.cb = sizeof(si);
60 >                                if (!CreateProcess(NULL, "cmd /c \"start http://wiki.oni2.net/Daodan_DLL\"", NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi))
61 >                                        MessageBox(NULL, "", "", 0);
62 >                                CloseHandle(pi.hProcess);
63 >                                CloseHandle(pi.hThread);
64 >                        }
65 >                default:
66 >                        ExitProcess(0);
67 >        }
68 > }
69 > */
70   BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpReserved)
71   {
72          switch (fdwReason)
# Line 73 | Line 75 | BOOL WINAPI DllMain(HINSTANCE hinstDLL,
75                          DDrDLLModule = hinstDLL;
76                          DDrONiModule = GetModuleHandle(NULL);
77                          
78 <                        DDrPatch_MakeCall((void*)0x00400000 + 0x0010fb49, DDrMain);
79 <                        
78 >                        if (*(uint32_t*)(OniExe + 0x0011acd0) == 0x09d36852)
79 >                                DDrPatch_MakeCall((void*)(OniExe + 0x0010fb49), (void*)DDrMain);
80 >                        else
81 >                                ExitProcess(0);
82                          break;
83          }
84          return TRUE;

Diff Legend

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