entry_windows.odin 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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 global
  11. dll_forward_reason = DLL_Forward_Reason(fdwReason)
  12. switch dll_forward_reason {
  13. case .Process_Attach:
  14. #force_no_inline _startup_runtime()
  15. intrinsics.__entry_point()
  16. case .Process_Detach:
  17. #force_no_inline _cleanup_runtime()
  18. case .Thread_Attach:
  19. break
  20. case .Thread_Detach:
  21. break
  22. }
  23. return true
  24. }
  25. } else when !ODIN_TEST && !ODIN_NO_ENTRY_POINT {
  26. when ODIN_ARCH == .i386 || ODIN_NO_CRT {
  27. @(link_name="mainCRTStartup", linkage="strong", require)
  28. mainCRTStartup :: proc "system" () -> i32 {
  29. context = default_context()
  30. #force_no_inline _startup_runtime()
  31. intrinsics.__entry_point()
  32. #force_no_inline _cleanup_runtime()
  33. return 0
  34. }
  35. } else {
  36. @(link_name="main", linkage="strong", require)
  37. main :: proc "c" (argc: i32, argv: [^]cstring) -> i32 {
  38. args__ = argv[:argc]
  39. context = default_context()
  40. #force_no_inline _startup_runtime()
  41. intrinsics.__entry_point()
  42. #force_no_inline _cleanup_runtime()
  43. return 0
  44. }
  45. }
  46. }