entry_windows.odin 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #+private
  2. #+build windows
  3. #+no-instrumentation
  4. package runtime
  5. import "base:intrinsics"
  6. when ODIN_BUILD_MODE == .Dynamic {
  7. @(link_name="DllMain", linkage="strong", require)
  8. DllMain :: proc "system" (hinstDLL: rawptr, fdwReason: u32, lpReserved: rawptr) -> b32 {
  9. context = default_context()
  10. // Populate Windows DLL-specific globals
  11. dll_forward_reason = DLL_Forward_Reason(fdwReason)
  12. dll_instance = hinstDLL
  13. switch dll_forward_reason {
  14. case .Process_Attach:
  15. #force_no_inline _startup_runtime()
  16. intrinsics.__entry_point()
  17. case .Process_Detach:
  18. #force_no_inline _cleanup_runtime()
  19. case .Thread_Attach:
  20. break
  21. case .Thread_Detach:
  22. break
  23. }
  24. return true
  25. }
  26. } else when !ODIN_TEST && !ODIN_NO_ENTRY_POINT {
  27. when ODIN_ARCH == .i386 || ODIN_NO_CRT {
  28. @(link_name="mainCRTStartup", linkage="strong", require)
  29. mainCRTStartup :: proc "system" () -> i32 {
  30. context = default_context()
  31. #force_no_inline _startup_runtime()
  32. intrinsics.__entry_point()
  33. #force_no_inline _cleanup_runtime()
  34. return 0
  35. }
  36. } else {
  37. @(link_name="main", linkage="strong", require)
  38. main :: proc "c" (argc: i32, argv: [^]cstring) -> i32 {
  39. args__ = argv[:argc]
  40. context = default_context()
  41. #force_no_inline _startup_runtime()
  42. intrinsics.__entry_point()
  43. #force_no_inline _cleanup_runtime()
  44. return 0
  45. }
  46. }
  47. }