Browse Source

Compiler compiles for x86 (doesn't work properly)

Ginger Bill 8 years ago
parent
commit
35c102137f
9 changed files with 208 additions and 161 deletions
  1. 28 10
      core/_preload.odin
  2. 2 2
      core/fmt.odin
  3. 99 99
      core/sys/windows.odin
  4. 3 1
      misc/shell.bat
  5. 17 8
      src/check_expr.cpp
  6. 0 4
      src/checker.cpp
  7. 54 37
      src/ir.cpp
  8. 3 0
      src/ir_opt.cpp
  9. 2 0
      src/ir_print.cpp

+ 28 - 10
core/_preload.odin

@@ -17,7 +17,7 @@ import (
 // Local Variables:    snake_case
 // Local Variables:    snake_case
 // Constant Variables: SCREAMING_SNAKE_CASE
 // Constant Variables: SCREAMING_SNAKE_CASE
 
 
-// IMPORTANT NOTE(bill): `type_info` & `type_info_val` cannot be used within a
+// IMPORTANT NOTE(bill): `type_info` cannot be used within a
 // #shared_global_scope due to  the internals of the compiler.
 // #shared_global_scope due to  the internals of the compiler.
 // This could change at a later date if the all these data structures are
 // This could change at a later date if the all these data structures are
 // implemented within the compiler rather than in this "preload" file
 // implemented within the compiler rather than in this "preload" file
@@ -407,24 +407,42 @@ proc __string_decode_rune(s: string) -> (rune, int) #inline {
 
 
 
 
 proc __mem_set(data: rawptr, value: i32, len: int) -> rawptr {
 proc __mem_set(data: rawptr, value: i32, len: int) -> rawptr {
-	foreign __llvm_core proc llvm_memset_64bit(dst: rawptr, val: u8, len: int, align: i32, is_volatile: bool) #link_name "llvm.memset.p0i8.i64";
-	llvm_memset_64bit(data, u8(value), len, 1, false);
-	return data;
+	when size_of(rawptr) == 8 {
+		foreign __llvm_core proc llvm_memset_64bit(dst: rawptr, val: u8, len: int, align: i32, is_volatile: bool) #link_name "llvm.memset.p0i8.i64";
+		llvm_memset_64bit(data, u8(value), len, 1, false);
+		return data;
+	} else {
+		foreign __llvm_core proc llvm_memset_32bit(dst: rawptr, val: u8, len: int, align: i32, is_volatile: bool) #link_name "llvm.memset.p0i8.i32";
+		llvm_memset_32bit(data, u8(value), len, 1, false);
+		return data;
+	}
 }
 }
 proc __mem_zero(data: rawptr, len: int) -> rawptr {
 proc __mem_zero(data: rawptr, len: int) -> rawptr {
 	return __mem_set(data, 0, len);
 	return __mem_set(data, 0, len);
 }
 }
 proc __mem_copy(dst, src: rawptr, len: int) -> rawptr {
 proc __mem_copy(dst, src: rawptr, len: int) -> rawptr {
 	// NOTE(bill): This _must_ be implemented like C's memmove
 	// NOTE(bill): This _must_ be implemented like C's memmove
-	foreign __llvm_core proc llvm_memmove_64bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memmove.p0i8.p0i8.i64";
-	llvm_memmove_64bit(dst, src, len, 1, false);
-	return dst;
+	when size_of(rawptr) == 8 {
+		foreign __llvm_core proc llvm_memmove_64bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memmove.p0i8.p0i8.i64";
+		llvm_memmove_64bit(dst, src, len, 1, false);
+		return dst;
+	} else {
+		foreign __llvm_core proc llvm_memmove_32bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memmove.p0i8.p0i8.i32";
+		llvm_memmove_32bit(dst, src, len, 1, false);
+		return dst;
+	}
 }
 }
 proc __mem_copy_non_overlapping(dst, src: rawptr, len: int) -> rawptr {
 proc __mem_copy_non_overlapping(dst, src: rawptr, len: int) -> rawptr {
 	// NOTE(bill): This _must_ be implemented like C's memcpy
 	// NOTE(bill): This _must_ be implemented like C's memcpy
-	foreign __llvm_core proc llvm_memcpy_64bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memcpy.p0i8.p0i8.i64";
-	llvm_memcpy_64bit(dst, src, len, 1, false);
-	return dst;
+	when size_of(rawptr) == 8 {
+		foreign __llvm_core proc llvm_memcpy_64bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memcpy.p0i8.p0i8.i64";
+		llvm_memcpy_64bit(dst, src, len, 1, false);
+		return dst;
+	} else {
+		foreign __llvm_core proc llvm_memcpy_32bit(dst, src: rawptr, len: int, align: i32, is_volatile: bool) #link_name "llvm.memcpy.p0i8.p0i8.i32";
+		llvm_memcpy_32bit(dst, src, len, 1, false);
+		return dst;
+	}
 }
 }
 
 
 proc __mem_compare(a, b: ^u8, n: int) -> int {
 proc __mem_compare(a, b: ^u8, n: int) -> int {

+ 2 - 2
core/fmt.odin

@@ -1087,6 +1087,7 @@ proc sbprintf(b: ^StringBuffer, fmt: string, args: ..any) -> string {
 		was_prev_index = false;
 		was_prev_index = false;
 		fi: FmtInfo;
 		fi: FmtInfo;
 	)
 	)
+
 	for var i = 0; i < end; /**/ {
 	for var i = 0; i < end; /**/ {
 		fi = FmtInfo{buf = b, good_arg_index = true};
 		fi = FmtInfo{buf = b, good_arg_index = true};
 
 
@@ -1104,8 +1105,7 @@ proc sbprintf(b: ^StringBuffer, fmt: string, args: ..any) -> string {
 		// Process a "verb"
 		// Process a "verb"
 		i++;
 		i++;
 
 
-	prefix_loop:
-		for ; i < end; i++ {
+		prefix_loop: for ; i < end; i++ {
 			match fmt[i] {
 			match fmt[i] {
 			case '+':
 			case '+':
 				fi.plus = true;
 				fi.plus = true;

+ 99 - 99
core/sys/windows.odin

@@ -285,164 +285,164 @@ const (
 )
 )
 
 
 foreign kernel32 {
 foreign kernel32 {
-	proc get_last_error     () -> i32                                                                                       #cc_c #link_name "GetLastError";
-	proc exit_process       (exit_code: u32)                                                                                #cc_c #link_name "ExitProcess";
-	proc get_module_handle_a(module_name: ^u8) -> Hinstance                                                                 #cc_c #link_name "GetModuleHandleA";
-	proc sleep(ms: i32) -> i32                                                                                              #cc_c #link_name "Sleep";
-	proc query_performance_frequency(result: ^i64) -> i32                                                                   #cc_c #link_name "QueryPerformanceFrequency";
-	proc query_performance_counter  (result: ^i64) -> i32                                                                   #cc_c #link_name "QueryPerformanceCounter";
-	proc output_debug_string_a(c_str: ^u8)                                                                                  #cc_c #link_name "OutputDebugStringA";
-
-	proc get_command_line_a    () -> ^u8                                                                                    #cc_c #link_name "GetCommandLineA";
-	proc get_command_line_w    () -> ^u16                                                                                   #cc_c #link_name "GetCommandLineW";
-	proc get_system_metrics    (index: i32) -> i32                                                                          #cc_c #link_name "GetSystemMetrics";
-	proc get_current_thread_id () -> u32                                                                                    #cc_c #link_name "GetCurrentThreadId";
-
-	proc get_system_time_as_file_time(system_time_as_file_time: ^Filetime)                                                  #cc_c #link_name "GetSystemTimeAsFileTime";
-	proc file_time_to_local_file_time(file_time: ^Filetime, local_file_time: ^Filetime) -> Bool                             #cc_c #link_name "FileTimeToLocalFileTime";
-	proc file_time_to_system_time    (file_time: ^Filetime, system_time: ^Systemtime) -> Bool                               #cc_c #link_name "FileTimeToSystemTime";
-	proc system_time_to_file_time    (system_time: ^Systemtime, file_time: ^Filetime) -> Bool                               #cc_c #link_name "SystemTimeToFileTime";
-
-	proc close_handle  (h: Handle) -> i32                                                                                   #cc_c #link_name "CloseHandle";
-	proc get_std_handle(h: i32) -> Handle                                                                                   #cc_c #link_name "GetStdHandle";
+	proc get_last_error     () -> i32                                                                                       #cc_std #link_name "GetLastError";
+	proc exit_process       (exit_code: u32)                                                                                #cc_std #link_name "ExitProcess";
+	proc get_module_handle_a(module_name: ^u8) -> Hinstance                                                                 #cc_std #link_name "GetModuleHandleA";
+	proc sleep(ms: i32) -> i32                                                                                              #cc_std #link_name "Sleep";
+	proc query_performance_frequency(result: ^i64) -> i32                                                                   #cc_std #link_name "QueryPerformanceFrequency";
+	proc query_performance_counter  (result: ^i64) -> i32                                                                   #cc_std #link_name "QueryPerformanceCounter";
+	proc output_debug_string_a(c_str: ^u8)                                                                                  #cc_std #link_name "OutputDebugStringA";
+
+	proc get_command_line_a    () -> ^u8                                                                                    #cc_std #link_name "GetCommandLineA";
+	proc get_command_line_w    () -> ^u16                                                                                   #cc_std #link_name "GetCommandLineW";
+	proc get_system_metrics    (index: i32) -> i32                                                                          #cc_std #link_name "GetSystemMetrics";
+	proc get_current_thread_id () -> u32                                                                                    #cc_std #link_name "GetCurrentThreadId";
+
+	proc get_system_time_as_file_time(system_time_as_file_time: ^Filetime)                                                  #cc_std #link_name "GetSystemTimeAsFileTime";
+	proc file_time_to_local_file_time(file_time: ^Filetime, local_file_time: ^Filetime) -> Bool                             #cc_std #link_name "FileTimeToLocalFileTime";
+	proc file_time_to_system_time    (file_time: ^Filetime, system_time: ^Systemtime) -> Bool                               #cc_std #link_name "FileTimeToSystemTime";
+	proc system_time_to_file_time    (system_time: ^Systemtime, file_time: ^Filetime) -> Bool                               #cc_std #link_name "SystemTimeToFileTime";
+
+	proc close_handle  (h: Handle) -> i32                                                                                   #cc_std #link_name "CloseHandle";
+	proc get_std_handle(h: i32) -> Handle                                                                                   #cc_std #link_name "GetStdHandle";
 	proc create_file_a (filename: ^u8, desired_access, share_mode: u32,
 	proc create_file_a (filename: ^u8, desired_access, share_mode: u32,
 	                       security: rawptr,
 	                       security: rawptr,
-	                       creation, flags_and_attribs: u32, template_file: Handle) -> Handle                               #cc_c #link_name "CreateFileA";
-	proc read_file (h: Handle, buf: rawptr, to_read: u32, bytes_read: ^i32, overlapped: rawptr) -> Bool                     #cc_c #link_name "ReadFile";
-	proc write_file(h: Handle, buf: rawptr, len: i32, written_result: ^i32, overlapped: rawptr) -> Bool                     #cc_c #link_name "WriteFile";
+	                       creation, flags_and_attribs: u32, template_file: Handle) -> Handle                               #cc_std #link_name "CreateFileA";
+	proc read_file (h: Handle, buf: rawptr, to_read: u32, bytes_read: ^i32, overlapped: rawptr) -> Bool                     #cc_std #link_name "ReadFile";
+	proc write_file(h: Handle, buf: rawptr, len: i32, written_result: ^i32, overlapped: rawptr) -> Bool                     #cc_std #link_name "WriteFile";
 
 
-	proc get_file_size_ex              (file_handle: Handle, file_size: ^i64) -> Bool                                       #cc_c #link_name "GetFileSizeEx";
-	proc get_file_attributes_a         (filename: ^u8) -> u32                                                               #cc_c #link_name "GetFileAttributesA";
-	proc get_file_attributes_ex_a      (filename: ^u8, info_level_id: GET_FILEEX_INFO_LEVELS, file_info: rawptr) -> Bool    #cc_c #link_name "GetFileAttributesExA";
-	proc get_file_information_by_handle(file_handle: Handle, file_info: ^ByHandleFileInformation) -> Bool                   #cc_c #link_name "GetFileInformationByHandle";
+	proc get_file_size_ex              (file_handle: Handle, file_size: ^i64) -> Bool                                       #cc_std #link_name "GetFileSizeEx";
+	proc get_file_attributes_a         (filename: ^u8) -> u32                                                               #cc_std #link_name "GetFileAttributesA";
+	proc get_file_attributes_ex_a      (filename: ^u8, info_level_id: GET_FILEEX_INFO_LEVELS, file_info: rawptr) -> Bool    #cc_std #link_name "GetFileAttributesExA";
+	proc get_file_information_by_handle(file_handle: Handle, file_info: ^ByHandleFileInformation) -> Bool                   #cc_std #link_name "GetFileInformationByHandle";
 
 
-	proc get_file_type   (file_handle: Handle) -> u32                                                                       #cc_c #link_name "GetFileType";
-	proc set_file_pointer(file_handle: Handle, distance_to_move: i32, distance_to_move_high: ^i32, move_method: u32) -> u32 #cc_c #link_name "SetFilePointer";
+	proc get_file_type   (file_handle: Handle) -> u32                                                                       #cc_std #link_name "GetFileType";
+	proc set_file_pointer(file_handle: Handle, distance_to_move: i32, distance_to_move_high: ^i32, move_method: u32) -> u32 #cc_std #link_name "SetFilePointer";
 
 
-	proc set_handle_information(obj: Handle, mask, flags: u32) -> Bool                                                      #cc_c #link_name "SetHandleInformation";
+	proc set_handle_information(obj: Handle, mask, flags: u32) -> Bool                                                      #cc_std #link_name "SetHandleInformation";
 
 
-	proc find_first_file_a(file_name : ^u8, data : ^FindData) -> Handle                                                     #cc_c #link_name "FindFirstFileA";
-	proc find_next_file_a (file : Handle, data : ^FindData) -> Bool                                                         #cc_c #link_name "FindNextFileA";
-	proc find_close       (file : Handle) -> Bool                                                                           #cc_c #link_name "FindClose";
+	proc find_first_file_a(file_name : ^u8, data : ^FindData) -> Handle                                                     #cc_std #link_name "FindFirstFileA";
+	proc find_next_file_a (file : Handle, data : ^FindData) -> Bool                                                         #cc_std #link_name "FindNextFileA";
+	proc find_close       (file : Handle) -> Bool                                                                           #cc_std #link_name "FindClose";
 
 
 
 
-	proc heap_alloc      (h: Handle, flags: u32, bytes: int) -> rawptr                                                      #cc_c #link_name "HeapAlloc";
-	proc heap_realloc    (h: Handle, flags: u32, memory: rawptr, bytes: int) -> rawptr                                      #cc_c #link_name "HeapReAlloc";
-	proc heap_free       (h: Handle, flags: u32, memory: rawptr) -> Bool                                                    #cc_c #link_name "HeapFree";
-	proc get_process_heap() -> Handle                                                                                       #cc_c #link_name "GetProcessHeap";
+	proc heap_alloc      (h: Handle, flags: u32, bytes: int) -> rawptr                                                      #cc_std #link_name "HeapAlloc";
+	proc heap_realloc    (h: Handle, flags: u32, memory: rawptr, bytes: int) -> rawptr                                      #cc_std #link_name "HeapReAlloc";
+	proc heap_free       (h: Handle, flags: u32, memory: rawptr) -> Bool                                                    #cc_std #link_name "HeapFree";
+	proc get_process_heap() -> Handle                                                                                       #cc_std #link_name "GetProcessHeap";
 
 
 
 
-	proc create_semaphore_a    (attributes: ^Security_Attributes, initial_count, maximum_count: i32, name: ^u8) -> Handle   #cc_c #link_name "CreateSemaphoreA";
-	proc release_semaphore     (semaphore: Handle, release_count: i32, previous_count: ^i32) -> Bool                        #cc_c #link_name "ReleaseSemaphore";
-	proc wait_for_single_object(handle: Handle, milliseconds: u32) -> u32                                                   #cc_c #link_name "WaitForSingleObject";
+	proc create_semaphore_a    (attributes: ^Security_Attributes, initial_count, maximum_count: i32, name: ^u8) -> Handle   #cc_std #link_name "CreateSemaphoreA";
+	proc release_semaphore     (semaphore: Handle, release_count: i32, previous_count: ^i32) -> Bool                        #cc_std #link_name "ReleaseSemaphore";
+	proc wait_for_single_object(handle: Handle, milliseconds: u32) -> u32                                                   #cc_std #link_name "WaitForSingleObject";
 
 
 
 
-	proc interlocked_compare_exchange  (dst: ^i32, exchange, comparand: i32) -> i32                                         #cc_c #link_name "InterlockedCompareExchange";
-	proc interlocked_exchange          (dst: ^i32, desired: i32) -> i32                                                     #cc_c #link_name "InterlockedExchange";
-	proc interlocked_exchange_add      (dst: ^i32, desired: i32) -> i32                                                     #cc_c #link_name "InterlockedExchangeAdd";
-	proc interlocked_and               (dst: ^i32, desired: i32) -> i32                                                     #cc_c #link_name "InterlockedAnd";
-	proc interlocked_or                (dst: ^i32, desired: i32) -> i32                                                     #cc_c #link_name "InterlockedOr";
+	proc interlocked_compare_exchange  (dst: ^i32, exchange, comparand: i32) -> i32                                         #cc_std #link_name "InterlockedCompareExchange";
+	proc interlocked_exchange          (dst: ^i32, desired: i32) -> i32                                                     #cc_std #link_name "InterlockedExchange";
+	proc interlocked_exchange_add      (dst: ^i32, desired: i32) -> i32                                                     #cc_std #link_name "InterlockedExchangeAdd";
+	proc interlocked_and               (dst: ^i32, desired: i32) -> i32                                                     #cc_std #link_name "InterlockedAnd";
+	proc interlocked_or                (dst: ^i32, desired: i32) -> i32                                                     #cc_std #link_name "InterlockedOr";
 
 
-	proc interlocked_compare_exchange64(dst: ^i64, exchange, comparand: i64) -> i64                                         #cc_c #link_name "InterlockedCompareExchange64";
-	proc interlocked_exchange64        (dst: ^i64, desired: i64) -> i64                                                     #cc_c #link_name "InterlockedExchange64";
-	proc interlocked_exchange_add64    (dst: ^i64, desired: i64) -> i64                                                     #cc_c #link_name "InterlockedExchangeAdd64";
-	proc interlocked_and64             (dst: ^i64, desired: i64) -> i64                                                     #cc_c #link_name "InterlockedAnd64";
-	proc interlocked_or64              (dst: ^i64, desired: i64) -> i64                                                     #cc_c #link_name "InterlockedOr64";
+	proc interlocked_compare_exchange64(dst: ^i64, exchange, comparand: i64) -> i64                                         #cc_std #link_name "InterlockedCompareExchange64";
+	proc interlocked_exchange64        (dst: ^i64, desired: i64) -> i64                                                     #cc_std #link_name "InterlockedExchange64";
+	proc interlocked_exchange_add64    (dst: ^i64, desired: i64) -> i64                                                     #cc_std #link_name "InterlockedExchangeAdd64";
+	proc interlocked_and64             (dst: ^i64, desired: i64) -> i64                                                     #cc_std #link_name "InterlockedAnd64";
+	proc interlocked_or64              (dst: ^i64, desired: i64) -> i64                                                     #cc_std #link_name "InterlockedOr64";
 
 
-	proc mm_pause          ()                                                                                               #cc_c #link_name "_mm_pause";
-	proc read_write_barrier()                                                                                               #cc_c #link_name "ReadWriteBarrier";
-	proc write_barrier     ()                                                                                               #cc_c #link_name "WriteBarrier";
-	proc read_barrier      ()                                                                                               #cc_c #link_name "ReadBarrier";
+	proc mm_pause          ()                                                                                               #cc_std #link_name "_mm_pause";
+	proc read_write_barrier()                                                                                               #cc_std #link_name "ReadWriteBarrier";
+	proc write_barrier     ()                                                                                               #cc_std #link_name "WriteBarrier";
+	proc read_barrier      ()                                                                                               #cc_std #link_name "ReadBarrier";
 
 
 
 
-	proc load_library_a  (c_str: ^u8) -> Hmodule                                                                            #cc_c #link_name "LoadLibraryA";
-	proc free_library    (h: Hmodule)                                                                                       #cc_c #link_name "FreeLibrary";
-	proc get_proc_address(h: Hmodule, c_str: ^u8) -> Proc                                                                   #cc_c #link_name "GetProcAddress";
+	proc load_library_a  (c_str: ^u8) -> Hmodule                                                                            #cc_std #link_name "LoadLibraryA";
+	proc free_library    (h: Hmodule)                                                                                       #cc_std #link_name "FreeLibrary";
+	proc get_proc_address(h: Hmodule, c_str: ^u8) -> Proc                                                                   #cc_std #link_name "GetProcAddress";
 
 
 }
 }
 
 
 foreign user32 {
 foreign user32 {
-	proc get_desktop_window   () -> Hwnd                                                                    #cc_c #link_name "GetDesktopWindow";
-	proc show_cursor          (show : Bool)                                                                 #cc_c #link_name "ShowCursor";
-	proc get_cursor_pos       (p: ^Point) -> i32                                                            #cc_c #link_name "GetCursorPos";
-	proc screen_to_client     (h: Hwnd, p: ^Point) -> i32                                                   #cc_c #link_name "ScreenToClient";
-	proc post_quit_message    (exit_code: i32)                                                              #cc_c #link_name "PostQuitMessage";
-	proc set_window_text_a    (hwnd: Hwnd, c_string: ^u8) -> Bool                                           #cc_c #link_name "SetWindowTextA";
-	proc register_class_ex_a  (wc: ^WndClassExA) -> i16                                                     #cc_c #link_name "RegisterClassExA";
+	proc get_desktop_window   () -> Hwnd                                                                    #cc_std #link_name "GetDesktopWindow";
+	proc show_cursor          (show : Bool)                                                                 #cc_std #link_name "ShowCursor";
+	proc get_cursor_pos       (p: ^Point) -> i32                                                            #cc_std #link_name "GetCursorPos";
+	proc screen_to_client     (h: Hwnd, p: ^Point) -> i32                                                   #cc_std #link_name "ScreenToClient";
+	proc post_quit_message    (exit_code: i32)                                                              #cc_std #link_name "PostQuitMessage";
+	proc set_window_text_a    (hwnd: Hwnd, c_string: ^u8) -> Bool                                           #cc_std #link_name "SetWindowTextA";
+	proc register_class_ex_a  (wc: ^WndClassExA) -> i16                                                     #cc_std #link_name "RegisterClassExA";
 
 
 	proc create_window_ex_a   (ex_style: u32,
 	proc create_window_ex_a   (ex_style: u32,
                                class_name, title: ^u8,
                                class_name, title: ^u8,
                                style: u32,
                                style: u32,
                                x, y, w, h: i32,
                                x, y, w, h: i32,
                                parent: Hwnd, menu: Hmenu, instance: Hinstance,
                                parent: Hwnd, menu: Hmenu, instance: Hinstance,
-                               param: rawptr) -> Hwnd                                                       #cc_c #link_name "CreateWindowExA";
+                               param: rawptr) -> Hwnd                                                       #cc_std #link_name "CreateWindowExA";
 
 
-	proc show_window          (hwnd: Hwnd, cmd_show: i32) -> Bool                                           #cc_c #link_name "ShowWindow";
-	proc translate_message    (msg: ^Msg) -> Bool                                                           #cc_c #link_name "TranslateMessage";
-	proc dispatch_message_a   (msg: ^Msg) -> Lresult                                                        #cc_c #link_name "DispatchMessageA";
-	proc update_window        (hwnd: Hwnd) -> Bool                                                          #cc_c #link_name "UpdateWindow";
-	proc get_message_a        (msg: ^Msg, hwnd: Hwnd, msg_filter_min, msg_filter_max : u32) -> Bool         #cc_c #link_name "GetMessageA";
+	proc show_window          (hwnd: Hwnd, cmd_show: i32) -> Bool                                           #cc_std #link_name "ShowWindow";
+	proc translate_message    (msg: ^Msg) -> Bool                                                           #cc_std #link_name "TranslateMessage";
+	proc dispatch_message_a   (msg: ^Msg) -> Lresult                                                        #cc_std #link_name "DispatchMessageA";
+	proc update_window        (hwnd: Hwnd) -> Bool                                                          #cc_std #link_name "UpdateWindow";
+	proc get_message_a        (msg: ^Msg, hwnd: Hwnd, msg_filter_min, msg_filter_max : u32) -> Bool         #cc_std #link_name "GetMessageA";
 	proc peek_message_a       (msg: ^Msg, hwnd: Hwnd,
 	proc peek_message_a       (msg: ^Msg, hwnd: Hwnd,
-	                           msg_filter_min, msg_filter_max, remove_msg: u32) -> Bool                     #cc_c #link_name "PeekMessageA";
+	                           msg_filter_min, msg_filter_max, remove_msg: u32) -> Bool                     #cc_std #link_name "PeekMessageA";
 
 
 
 
-	proc post_message         (hwnd: Hwnd, msg, wparam, lparam : u32) -> Bool                               #cc_c #link_name "PostMessageA";
+	proc post_message         (hwnd: Hwnd, msg, wparam, lparam : u32) -> Bool                               #cc_std #link_name "PostMessageA";
 
 
-	proc def_window_proc_a    (hwnd: Hwnd, msg: u32, wparam: Wparam, lparam: Lparam) -> Lresult             #cc_c #link_name "DefWindowProcA";
+	proc def_window_proc_a    (hwnd: Hwnd, msg: u32, wparam: Wparam, lparam: Lparam) -> Lresult             #cc_std #link_name "DefWindowProcA";
 
 
-	proc adjust_window_rect   (rect: ^Rect, style: u32, menu: Bool) -> Bool                                 #cc_c #link_name "AdjustWindowRect";
-	proc get_active_window    () -> Hwnd                                                                    #cc_c #link_name "GetActiveWindow";
+	proc adjust_window_rect   (rect: ^Rect, style: u32, menu: Bool) -> Bool                                 #cc_std #link_name "AdjustWindowRect";
+	proc get_active_window    () -> Hwnd                                                                    #cc_std #link_name "GetActiveWindow";
 
 
-	proc destroy_window       (wnd: Hwnd) -> Bool                                                           #cc_c #link_name "DestroyWindow";
-	proc describe_pixel_format(dc: Hdc, pixel_format: i32, bytes : u32, pfd: ^PixelFormatDescriptor) -> i32 #cc_c #link_name "DescribePixelFormat";
+	proc destroy_window       (wnd: Hwnd) -> Bool                                                           #cc_std #link_name "DestroyWindow";
+	proc describe_pixel_format(dc: Hdc, pixel_format: i32, bytes : u32, pfd: ^PixelFormatDescriptor) -> i32 #cc_std #link_name "DescribePixelFormat";
 
 
-	proc get_monitor_info_a   (monitor: Hmonitor, mi: ^MonitorInfo) -> Bool                                 #cc_c #link_name "GetMonitorInfoA";
-	proc monitor_from_window  (wnd: Hwnd, flags : u32) -> Hmonitor                                          #cc_c #link_name "MonitorFromWindow";
+	proc get_monitor_info_a   (monitor: Hmonitor, mi: ^MonitorInfo) -> Bool                                 #cc_std #link_name "GetMonitorInfoA";
+	proc monitor_from_window  (wnd: Hwnd, flags : u32) -> Hmonitor                                          #cc_std #link_name "MonitorFromWindow";
 
 
-	proc set_window_pos       (wnd: Hwnd, wndInsertAfter: Hwnd, x, y, width, height: i32, flags: u32)       #cc_c #link_name "SetWindowPos";
+	proc set_window_pos       (wnd: Hwnd, wndInsertAfter: Hwnd, x, y, width, height: i32, flags: u32)       #cc_std #link_name "SetWindowPos";
 
 
-	proc get_window_placement (wnd: Hwnd, wndpl: ^WindowPlacement) -> Bool                                  #cc_c #link_name "GetWindowPlacement";
-	proc set_window_placement (wnd: Hwnd, wndpl: ^WindowPlacement) -> Bool                                  #cc_c #link_name "SetWindowPlacement";
-	proc get_window_rect      (wnd: Hwnd, rect: ^Rect) -> Bool                                              #cc_c #link_name "GetWindowRect";
+	proc get_window_placement (wnd: Hwnd, wndpl: ^WindowPlacement) -> Bool                                  #cc_std #link_name "GetWindowPlacement";
+	proc set_window_placement (wnd: Hwnd, wndpl: ^WindowPlacement) -> Bool                                  #cc_std #link_name "SetWindowPlacement";
+	proc get_window_rect      (wnd: Hwnd, rect: ^Rect) -> Bool                                              #cc_std #link_name "GetWindowRect";
 
 
-	proc get_window_long_ptr_a(wnd: Hwnd, index: i32) -> i64                                                #cc_c #link_name "GetWindowLongPtrA";
-	proc set_window_long_ptr_a(wnd: Hwnd, index: i32, new: i64) -> i64                                      #cc_c #link_name "SetWindowLongPtrA";
+	proc get_window_long_ptr_a(wnd: Hwnd, index: i32) -> i64                                                #cc_std #link_name "GetWindowLongPtrA";
+	proc set_window_long_ptr_a(wnd: Hwnd, index: i32, new: i64) -> i64                                      #cc_std #link_name "SetWindowLongPtrA";
 
 
-	proc get_window_text      (wnd: Hwnd, str: ^u8, maxCount: i32) -> i32                                   #cc_c #link_name "GetWindowText";
+	proc get_window_text      (wnd: Hwnd, str: ^u8, maxCount: i32) -> i32                                   #cc_std #link_name "GetWindowText";
 
 
-	proc get_client_rect (hwnd: Hwnd, rect: ^Rect) -> Bool                                                  #cc_c #link_name "GetClientRect";
+	proc get_client_rect (hwnd: Hwnd, rect: ^Rect) -> Bool                                                  #cc_std #link_name "GetClientRect";
 
 
-	proc get_dc             (h: Hwnd) -> Hdc                                                                #cc_c #link_name "GetDC";
-	proc release_dc         (wnd: Hwnd, hdc: Hdc) -> i32                                                    #cc_c #link_name "ReleaseDC";
+	proc get_dc             (h: Hwnd) -> Hdc                                                                #cc_std #link_name "GetDC";
+	proc release_dc         (wnd: Hwnd, hdc: Hdc) -> i32                                                    #cc_std #link_name "ReleaseDC";
 
 
-	proc map_virtual_key(scancode : u32, map_type : u32) -> u32                                             #cc_c #link_name "MapVirtualKeyA";
+	proc map_virtual_key(scancode : u32, map_type : u32) -> u32                                             #cc_std #link_name "MapVirtualKeyA";
 
 
-	proc get_key_state      (v_key: i32) -> i16                                                             #cc_c #link_name "GetKeyState";
-	proc get_async_key_state(v_key: i32) -> i16                                                             #cc_c #link_name "GetAsyncKeyState";
+	proc get_key_state      (v_key: i32) -> i16                                                             #cc_std #link_name "GetKeyState";
+	proc get_async_key_state(v_key: i32) -> i16                                                             #cc_std #link_name "GetAsyncKeyState";
 }
 }
 
 
 foreign gdi32 {
 foreign gdi32 {
-	proc get_stock_object(fn_object: i32) -> Hgdiobj                                           #cc_c #link_name "GetStockObject";
+	proc get_stock_object(fn_object: i32) -> Hgdiobj                                           #cc_std #link_name "GetStockObject";
 
 
 	proc stretch_dibits( hdc: Hdc,
 	proc stretch_dibits( hdc: Hdc,
 	                        x_dst, y_dst, width_dst, height_dst: i32,
 	                        x_dst, y_dst, width_dst, height_dst: i32,
 	                        x_src, y_src, width_src, header_src: i32,
 	                        x_src, y_src, width_src, header_src: i32,
 	                        bits: rawptr, bits_info: ^BitmapInfo,
 	                        bits: rawptr, bits_info: ^BitmapInfo,
 	                        usage: u32,
 	                        usage: u32,
-	                        rop: u32) -> i32                                                   #cc_c #link_name "StretchDIBits";
+	                        rop: u32) -> i32                                                   #cc_std #link_name "StretchDIBits";
 
 
-	proc set_pixel_format   (hdc: Hdc, pixel_format: i32, pfd: ^PixelFormatDescriptor) -> Bool #cc_c #link_name "SetPixelFormat";
-	proc choose_pixel_format(hdc: Hdc, pfd: ^PixelFormatDescriptor) -> i32                     #cc_c #link_name "ChoosePixelFormat";
-	proc swap_buffers       (hdc: Hdc) -> Bool                                                 #cc_c #link_name "SwapBuffers";
+	proc set_pixel_format   (hdc: Hdc, pixel_format: i32, pfd: ^PixelFormatDescriptor) -> Bool #cc_std #link_name "SetPixelFormat";
+	proc choose_pixel_format(hdc: Hdc, pfd: ^PixelFormatDescriptor) -> i32                     #cc_std #link_name "ChoosePixelFormat";
+	proc swap_buffers       (hdc: Hdc) -> Bool                                                 #cc_std #link_name "SwapBuffers";
 
 
 }
 }
 
 
 foreign shell32 {
 foreign shell32 {
-	proc command_line_to_argv_w(cmd_list: ^u16, num_args: ^i32) -> ^^u16 #cc_c #link_name "CommandLineToArgvW";
+	proc command_line_to_argv_w(cmd_list: ^u16, num_args: ^i32) -> ^^u16 #cc_std #link_name "CommandLineToArgvW";
 }
 }
 
 
 foreign winmm {
 foreign winmm {
-	proc time_get_time() -> u32 #cc_c #link_name "timeGetTime";
+	proc time_get_time() -> u32 #cc_std #link_name "timeGetTime";
 }
 }
 
 
 
 

+ 3 - 1
misc/shell.bat

@@ -1,6 +1,8 @@
 @echo off
 @echo off
 
 
-call "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" x64 1> NUL
+rem call "C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\vcvarsall.bat" x86 1> NUL
+call "C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\vcvarsall.bat" x64 1> NUL
+rem call "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" x64 1> NUL
 rem call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvarsall.bat" x86 1> NUL
 rem call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvarsall.bat" x86 1> NUL
 set _NO_DEBUG_HEAP=1
 set _NO_DEBUG_HEAP=1
 
 

+ 17 - 8
src/check_expr.cpp

@@ -1276,9 +1276,14 @@ Type *type_to_abi_compat_param_type(gbAllocator a, Type *original_type) {
 		// SEE: https://msdn.microsoft.com/en-us/library/zthk2dkh.aspx
 		// SEE: https://msdn.microsoft.com/en-us/library/zthk2dkh.aspx
 		Type *bt = core_type(original_type);
 		Type *bt = core_type(original_type);
 		switch (bt->kind) {
 		switch (bt->kind) {
-		// Okay to pass by value
+		// Okay to pass by value (usually)
 		// Especially the only Odin types
 		// Especially the only Odin types
-		case Type_Basic:   break;
+		case Type_Basic: {
+			i64 sz = bt->Basic.size;
+			if (sz > 8 && build_context.word_size < 8) {
+				new_type = make_type_pointer(a, original_type);
+			}
+		} break;
 		case Type_Pointer: break;
 		case Type_Pointer: break;
 		case Type_Proc:    break; // NOTE(bill): Just a pointer
 		case Type_Proc:    break; // NOTE(bill): Just a pointer
 
 
@@ -1306,12 +1311,18 @@ Type *type_to_abi_compat_param_type(gbAllocator a, Type *original_type) {
 			}
 			}
 		} break;
 		} break;
 		}
 		}
-	} else if (build_context.ODIN_OS == "linux") {
+	} else if (build_context.ODIN_OS == "linux" ||
+	           build_context.ODIN_OS == "osx") {
 		Type *bt = core_type(original_type);
 		Type *bt = core_type(original_type);
 		switch (bt->kind) {
 		switch (bt->kind) {
-		// Okay to pass by value
+		// Okay to pass by value (usually)
 		// Especially the only Odin types
 		// Especially the only Odin types
-		case Type_Basic:   break;
+		case Type_Basic: {
+			i64 sz = bt->Basic.size;
+			if (sz > 8 && build_context.word_size < 8) {
+				new_type = make_type_pointer(a, original_type);
+			}
+		} break;
 		case Type_Pointer: break;
 		case Type_Pointer: break;
 		case Type_Proc:    break; // NOTE(bill): Just a pointer
 		case Type_Proc:    break; // NOTE(bill): Just a pointer
 
 
@@ -1735,9 +1746,7 @@ void check_map_type(Checker *c, Type *type, AstNode *node) {
 
 
 	{
 	{
 		// NOTE(bill): The preload types may have not been set yet
 		// NOTE(bill): The preload types may have not been set yet
-		if (t_map_key == NULL) {
-			init_preload(c);
-		}
+		init_preload(c);
 		GB_ASSERT(t_map_key != NULL);
 		GB_ASSERT(t_map_key != NULL);
 
 
 		Type *entry_type = make_type_struct(a);
 		Type *entry_type = make_type_struct(a);

+ 0 - 4
src/checker.cpp

@@ -1206,10 +1206,6 @@ Entity *find_core_entity(Checker *c, String name) {
 }
 }
 
 
 void init_preload(Checker *c) {
 void init_preload(Checker *c) {
-	if (c->done_preload) {
-		return;
-	}
-
 	if (t_type_info == NULL) {
 	if (t_type_info == NULL) {
 		Entity *type_info_entity = find_core_entity(c, str_lit("TypeInfo"));
 		Entity *type_info_entity = find_core_entity(c, str_lit("TypeInfo"));
 
 

+ 54 - 37
src/ir.cpp

@@ -198,7 +198,7 @@ struct irProcedure {
 		irValue *true_value;                                          \
 		irValue *true_value;                                          \
 		irValue *false_value;                                         \
 		irValue *false_value;                                         \
 	})                                                                \
 	})                                                                \
-	IR_INSTR_KIND(Phi, struct { Array<irValue *> edges; Type *type; })    \
+	IR_INSTR_KIND(Phi, struct { Array<irValue *> edges; Type *type; })\
 	IR_INSTR_KIND(Unreachable, i32)                                   \
 	IR_INSTR_KIND(Unreachable, i32)                                   \
 	IR_INSTR_KIND(UnaryOp, struct {                                   \
 	IR_INSTR_KIND(UnaryOp, struct {                                   \
 		Type *    type;                                               \
 		Type *    type;                                               \
@@ -218,26 +218,26 @@ struct irProcedure {
 		isize     arg_count;                                          \
 		isize     arg_count;                                          \
 	})                                                                \
 	})                                                                \
 	IR_INSTR_KIND(StartupRuntime, i32)                                \
 	IR_INSTR_KIND(StartupRuntime, i32)                                \
-	IR_INSTR_KIND(BoundsCheck, struct {                               \
-		TokenPos pos;                                                 \
-		irValue *index;                                               \
-		irValue *len;                                                 \
-	})                                                                \
-	IR_INSTR_KIND(SliceBoundsCheck, struct {                          \
-		TokenPos pos;                                                 \
-		irValue *low;                                                 \
-		irValue *high;                                                \
-		irValue *max;                                                 \
-		bool     is_substring;                                        \
+	IR_INSTR_KIND(DebugDeclare, struct {                              \
+		irDebugInfo *debug_info;                                      \
+		AstNode *    expr;                                            \
+		Entity *     entity;                                          \
+		bool         is_addr;                                         \
+		irValue *    value;                                           \
 	})                                                                \
 	})                                                                \
-	IR_INSTR_KIND(DebugDeclare, struct { \
-		irDebugInfo *debug_info; \
-		AstNode *    expr; \
-		Entity *     entity; \
-		bool         is_addr; \
-		irValue *    value; \
-	}) \
 
 
+// 	IR_INSTR_KIND(BoundsCheck, struct {                               \
+// 		TokenPos pos;                                                 \
+// 		irValue *index;                                               \
+// 		irValue *len;                                                 \
+// 	})                                                                \
+// 	IR_INSTR_KIND(SliceBoundsCheck, struct {                          \
+// 		TokenPos pos;                                                 \
+// 		irValue *low;                                                 \
+// 		irValue *high;                                                \
+// 		irValue *max;                                                 \
+// 		bool     is_substring;                                        \
+// 	})                                                                \
 
 
 
 
 #define IR_CONV_KINDS \
 #define IR_CONV_KINDS \
@@ -1011,22 +1011,6 @@ irValue *ir_instr_comment(irProcedure *p, String text) {
 	return v;
 	return v;
 }
 }
 
 
-irValue *ir_instr_bounds_check(irProcedure *p, TokenPos pos, irValue *index, irValue *len) {
-	irValue *v = ir_alloc_instr(p, irInstr_BoundsCheck);
-	v->Instr.BoundsCheck.pos   = pos;
-	v->Instr.BoundsCheck.index = index;
-	v->Instr.BoundsCheck.len   = len;
-	return v;
-}
-irValue *ir_instr_slice_bounds_check(irProcedure *p, TokenPos pos, irValue *low, irValue *high, irValue *max, bool is_substring) {
-	irValue *v = ir_alloc_instr(p, irInstr_SliceBoundsCheck);
-	v->Instr.SliceBoundsCheck.pos  = pos;
-	v->Instr.SliceBoundsCheck.low  = low;
-	v->Instr.SliceBoundsCheck.high = high;
-	v->Instr.SliceBoundsCheck.max  = max;
-	v->Instr.SliceBoundsCheck.is_substring = is_substring;
-	return v;
-}
 irValue *ir_instr_debug_declare(irProcedure *p, irDebugInfo *debug_info, AstNode *expr, Entity *entity, bool is_addr, irValue *value) {
 irValue *ir_instr_debug_declare(irProcedure *p, irDebugInfo *debug_info, AstNode *expr, Entity *entity, bool is_addr, irValue *value) {
 	irValue *v = ir_alloc_instr(p, irInstr_DebugDeclare);
 	irValue *v = ir_alloc_instr(p, irInstr_DebugDeclare);
 	v->Instr.DebugDeclare.debug_info = debug_info;
 	v->Instr.DebugDeclare.debug_info = debug_info;
@@ -3443,7 +3427,21 @@ void ir_emit_bounds_check(irProcedure *proc, Token token, irValue *index, irValu
 	index = ir_emit_conv(proc, index, t_int);
 	index = ir_emit_conv(proc, index, t_int);
 	len = ir_emit_conv(proc, len, t_int);
 	len = ir_emit_conv(proc, len, t_int);
 
 
-	ir_emit(proc, ir_instr_bounds_check(proc, token.pos, index, len));
+	gbAllocator a = proc->module->allocator;
+	irValue *file = ir_find_or_add_entity_string(proc->module, token.pos.file);
+	irValue *line = ir_const_int(a, token.pos.line);
+	irValue *column = ir_const_int(a, token.pos.column);
+
+	irValue **args = gb_alloc_array(a, irValue *, 5);
+	args[0] = file;
+	args[1] = line;
+	args[2] = column;
+	args[3] = index;
+	args[4] = len;
+
+	ir_emit_global_call(proc, "__bounds_check_error", args, 5);
+
+	// ir_emit(proc, ir_instr_bounds_check(proc, token.pos, index, len));
 }
 }
 
 
 void ir_emit_slice_bounds_check(irProcedure *proc, Token token, irValue *low, irValue *high, irValue *max, bool is_substring) {
 void ir_emit_slice_bounds_check(irProcedure *proc, Token token, irValue *low, irValue *high, irValue *max, bool is_substring) {
@@ -3451,10 +3449,29 @@ void ir_emit_slice_bounds_check(irProcedure *proc, Token token, irValue *low, ir
 		return;
 		return;
 	}
 	}
 
 
+	gbAllocator a = proc->module->allocator;
+	irValue *file = ir_find_or_add_entity_string(proc->module, token.pos.file);
+	irValue *line = ir_const_int(a, token.pos.line);
+	irValue *column = ir_const_int(a, token.pos.column);
 	low  = ir_emit_conv(proc, low,  t_int);
 	low  = ir_emit_conv(proc, low,  t_int);
 	high = ir_emit_conv(proc, high, t_int);
 	high = ir_emit_conv(proc, high, t_int);
 
 
-	ir_emit(proc, ir_instr_slice_bounds_check(proc, token.pos, low, high, max, is_substring));
+	irValue **args = gb_alloc_array(a, irValue *, 6);
+	args[0] = file;
+	args[1] = line;
+	args[2] = column;
+	args[3] = low;
+	args[4] = high;
+	args[5] = max;
+
+	if (is_substring) {
+		ir_emit_global_call(proc, "__substring_expr_error", args, 5);
+	} else {
+		ir_emit_global_call(proc, "__slice_expr_error", args, 6);
+	}
+
+
+	// ir_emit(proc, ir_instr_slice_bounds_check(proc, token.pos, low, high, max, is_substring));
 }
 }
 
 
 
 

+ 3 - 0
src/ir_opt.cpp

@@ -80,6 +80,8 @@ void ir_opt_add_operands(Array<irValue *> *ops, irInstr *i) {
 		// break;
 		// break;
 	case irInstr_StartupRuntime:
 	case irInstr_StartupRuntime:
 		break;
 		break;
+
+	#if 0
 	case irInstr_BoundsCheck:
 	case irInstr_BoundsCheck:
 		array_add(ops, i->BoundsCheck.index);
 		array_add(ops, i->BoundsCheck.index);
 		array_add(ops, i->BoundsCheck.len);
 		array_add(ops, i->BoundsCheck.len);
@@ -88,6 +90,7 @@ void ir_opt_add_operands(Array<irValue *> *ops, irInstr *i) {
 		array_add(ops, i->SliceBoundsCheck.low);
 		array_add(ops, i->SliceBoundsCheck.low);
 		array_add(ops, i->SliceBoundsCheck.high);
 		array_add(ops, i->SliceBoundsCheck.high);
 		break;
 		break;
+	#endif
 	}
 	}
 }
 }
 
 

+ 2 - 0
src/ir_print.cpp

@@ -1391,6 +1391,7 @@ void ir_print_instr(irFileBuffer *f, irModule *m, irValue *value) {
 	// 	ir_fprintf(f, "\n");
 	// 	ir_fprintf(f, "\n");
 	// } break;
 	// } break;
 
 
+	#if 0
 	case irInstr_BoundsCheck: {
 	case irInstr_BoundsCheck: {
 		irInstrBoundsCheck *bc = &instr->BoundsCheck;
 		irInstrBoundsCheck *bc = &instr->BoundsCheck;
 		ir_fprintf(f, "call void ");
 		ir_fprintf(f, "call void ");
@@ -1462,6 +1463,7 @@ void ir_print_instr(irFileBuffer *f, irModule *m, irValue *value) {
 
 
 		ir_fprintf(f, ")\n");
 		ir_fprintf(f, ")\n");
 	} break;
 	} break;
+	#endif
 
 
 	case irInstr_DebugDeclare: {
 	case irInstr_DebugDeclare: {
 		/* irInstrDebugDeclare *dd = &instr->DebugDeclare;
 		/* irInstrDebugDeclare *dd = &instr->DebugDeclare;