mirror of
				https://github.com/vlang/v.git
				synced 2023-08-10 21:13:21 +03:00 
			
		
		
		
	Prevent people on platforms that arent 'windows' from being able to build with msvc
This commit is contained in:
		 Emily Hudson
					Emily Hudson
				
			
				
					committed by
					
						 Alexander Medvednikov
						Alexander Medvednikov
					
				
			
			
				
	
			
			
			 Alexander Medvednikov
						Alexander Medvednikov
					
				
			
						parent
						
							15a42f1f35
						
					
				
				
					commit
					decdd8be9f
				
			| @@ -210,6 +210,11 @@ fn main() { | |||||||
| } | } | ||||||
|  |  | ||||||
| fn (v mut V) compile() { | fn (v mut V) compile() { | ||||||
|  | 	// Emily: Stop people on linux from being able to build with msvc | ||||||
|  | 	if os.user_os() != 'windows' && v.os == .msvc { | ||||||
|  | 		panic('Cannot build with msvc on ${os.user_os()}') | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	mut cgen := v.cgen | 	mut cgen := v.cgen | ||||||
| 	cgen.genln('// Generated by V') | 	cgen.genln('// Generated by V') | ||||||
| 	v.add_v_files_to_compile() | 	v.add_v_files_to_compile() | ||||||
| @@ -754,6 +759,7 @@ fn (v mut V) cc() { | |||||||
| 			return | 			return | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 	 | ||||||
| 	linux_host := os.user_os() == 'linux' | 	linux_host := os.user_os() == 'linux' | ||||||
| 	v.log('cc() isprod=$v.pref.is_prod outname=$v.out_name') | 	v.log('cc() isprod=$v.pref.is_prod outname=$v.out_name') | ||||||
| 	mut a := [v.pref.cflags, '-std=gnu11', '-w'] // arguments for the C compiler | 	mut a := [v.pref.cflags, '-std=gnu11', '-w'] // arguments for the C compiler | ||||||
|   | |||||||
| @@ -30,6 +30,7 @@ const ( | |||||||
| 
 | 
 | ||||||
| // Given a root key look for one of the subkeys in 'versions' and get the path  | // Given a root key look for one of the subkeys in 'versions' and get the path  | ||||||
| fn find_windows_kit_internal(key RegKey, versions []string) ?string { | fn find_windows_kit_internal(key RegKey, versions []string) ?string { | ||||||
|  | 	$if windows { | ||||||
| 		for version in versions { | 		for version in versions { | ||||||
| 			required_bytes := 0 // TODO mut | 			required_bytes := 0 // TODO mut | ||||||
| 			result := C.RegQueryValueExW(key, version.to_wide(), 0, 0, 0, &required_bytes) | 			result := C.RegQueryValueExW(key, version.to_wide(), 0, 0, 0, &required_bytes) | ||||||
| @@ -61,6 +62,7 @@ fn find_windows_kit_internal(key RegKey, versions []string) ?string { | |||||||
| 
 | 
 | ||||||
| 			return string_from_wide(value) | 			return string_from_wide(value) | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| 	return error('windows kit not found') | 	return error('windows kit not found') | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -75,6 +77,7 @@ struct WindowsKit { | |||||||
| 
 | 
 | ||||||
| // Try and find the root key for installed windows kits | // Try and find the root key for installed windows kits | ||||||
| fn find_windows_kit_root() ?WindowsKit { | fn find_windows_kit_root() ?WindowsKit { | ||||||
|  | 	$if windows { | ||||||
| 		root_key := RegKey(0) | 		root_key := RegKey(0) | ||||||
| 		rc := C.RegOpenKeyExA( | 		rc := C.RegOpenKeyExA( | ||||||
| 			HKEY_LOCAL_MACHINE, 'SOFTWARE\\Microsoft\\Windows Kits\\Installed Roots', 0, KEY_QUERY_VALUE | KEY_WOW64_32KEY | KEY_ENUMERATE_SUB_KEYS, &root_key) | 			HKEY_LOCAL_MACHINE, 'SOFTWARE\\Microsoft\\Windows Kits\\Installed Roots', 0, KEY_QUERY_VALUE | KEY_WOW64_32KEY | KEY_ENUMERATE_SUB_KEYS, &root_key) | ||||||
| @@ -120,6 +123,8 @@ fn find_windows_kit_root() ?WindowsKit { | |||||||
| 			shared_include_path: kit_include_highest + '\\shared' | 			shared_include_path: kit_include_highest + '\\shared' | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 	return error('Host OS does not support funding a windows kit') | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| struct VsInstallation { | struct VsInstallation { | ||||||
| 	include_path string | 	include_path string | ||||||
| @@ -128,6 +133,9 @@ struct VsInstallation { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn find_vs() ?VsInstallation { | fn find_vs() ?VsInstallation { | ||||||
|  | 	$if !windows { | ||||||
|  | 		return error('Host OS does not support finding a Vs installation') | ||||||
|  | 	} | ||||||
| 	// Emily: | 	// Emily: | ||||||
| 	// VSWhere is guaranteed to be installed at this location now | 	// VSWhere is guaranteed to be installed at this location now | ||||||
| 	// If its not there then end user needs to update their visual studio  | 	// If its not there then end user needs to update their visual studio  | ||||||
| @@ -192,23 +200,28 @@ fn find_msvc() ?MsvcResult { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	$else { | 	$else { | ||||||
| 		panic('Cannot find msvc on this platform') | 		panic('Cannot find msvc on this OS') | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub fn (v mut V) cc_msvc() {  | pub fn (v mut V) cc_msvc() {  | ||||||
| 	r := find_msvc() or { | 	r := find_msvc() or { | ||||||
| 		println('Could not find MSVC') |  | ||||||
| 		 |  | ||||||
| 		// TODO: code reuse | 		// TODO: code reuse | ||||||
| 		if !v.pref.is_debug && v.out_name_c != 'v.c' && v.out_name_c != 'v_macos.c' { | 		if !v.pref.is_debug && v.out_name_c != 'v.c' && v.out_name_c != 'v_macos.c' { | ||||||
| 			os.rm('.$v.out_name_c') | 			os.rm('.$v.out_name_c') | ||||||
| 		} | 		} | ||||||
| 		return | 		panic('Cannot find MSVC on this OS.') | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	out_name_obj := v.out_name_c + '.obj' | ||||||
|  | 
 | ||||||
| 	// Default arguments | 	// Default arguments | ||||||
| 	mut a := ['-w', '/volatile:ms', '/D_UNICODE', '/DUNICODE'] | 
 | ||||||
|  | 	// volatile:ms enables atomic volatile (gcc _Atomic) | ||||||
|  | 	// -w: no warnings | ||||||
|  | 	// 2 unicode defines | ||||||
|  | 	// /Fo sets the object file name - needed so we can clean up after ourselves properly | ||||||
|  | 	mut a := ['-w', '/volatile:ms', '/D_UNICODE', '/DUNICODE', '/Fo$out_name_obj'] | ||||||
| 
 | 
 | ||||||
| 	if v.pref.is_prod { | 	if v.pref.is_prod { | ||||||
| 		a << '/O2' | 		a << '/O2' | ||||||
| @@ -219,7 +232,6 @@ pub fn (v mut V) cc_msvc() { | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if v.pref.is_so { | 	if v.pref.is_so { | ||||||
| 		// Dont think we have to do anything for this |  | ||||||
| 		if !v.out_name.ends_with('.dll') { | 		if !v.out_name.ends_with('.dll') { | ||||||
| 			v.out_name = v.out_name + '.dll' | 			v.out_name = v.out_name + '.dll' | ||||||
| 		} | 		} | ||||||
| @@ -258,6 +270,9 @@ pub fn (v mut V) cc_msvc() { | |||||||
| 	//a << '"$TmpPath/$v.out_name_c"' | 	//a << '"$TmpPath/$v.out_name_c"' | ||||||
| 	a << '".$v.out_name_c"' | 	a << '".$v.out_name_c"' | ||||||
| 
 | 
 | ||||||
|  | 	// Emily: | ||||||
|  | 	// Not all of these are needed (but the compiler should discard them if they are not used) | ||||||
|  | 	// these are the defaults used by msbuild and visual studio | ||||||
| 	mut real_libs :=  [ | 	mut real_libs :=  [ | ||||||
| 		'kernel32.lib', | 		'kernel32.lib', | ||||||
| 		'user32.lib', | 		'user32.lib', | ||||||
| @@ -287,6 +302,10 @@ pub fn (v mut V) cc_msvc() { | |||||||
| 		if f.starts_with('-l') { | 		if f.starts_with('-l') { | ||||||
| 			lib_base := f.right(2).trim_space() | 			lib_base := f.right(2).trim_space() | ||||||
| 
 | 
 | ||||||
|  | 			if lib_base.ends_with('.dll') { | ||||||
|  | 				panic('MSVC cannot link against a dll (`#flag -l $lib_base`)') | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
| 			// MSVC has no method of linking against a .dll | 			// MSVC has no method of linking against a .dll | ||||||
| 			// TODO: we should look for .defs aswell | 			// TODO: we should look for .defs aswell | ||||||
| 			lib_lib := lib_base + '.lib' | 			lib_lib := lib_base + '.lib' | ||||||
| @@ -307,11 +326,9 @@ pub fn (v mut V) cc_msvc() { | |||||||
| 	// Include the base paths | 	// Include the base paths | ||||||
| 	a << '-I "$r.ucrt_include_path" -I "$r.vs_include_path" -I "$r.um_include_path" -I "$r.shared_include_path"' | 	a << '-I "$r.ucrt_include_path" -I "$r.vs_include_path" -I "$r.um_include_path" -I "$r.shared_include_path"' | ||||||
| 
 | 
 | ||||||
| 	// Msvc also doesnt have atomic |  | ||||||
| 	// TODO: dont rely on gcc's _Atomic semantics! |  | ||||||
| 	a << other_flags | 	a << other_flags | ||||||
| 
 | 
 | ||||||
| 	// TODO: libs will need to be actually handled properly | 	// Libs are passed to cl.exe which passes them to the linker | ||||||
| 	a << real_libs.join(' ') | 	a << real_libs.join(' ') | ||||||
| 
 | 
 | ||||||
| 	a << '/link' | 	a << '/link' | ||||||
| @@ -350,6 +367,7 @@ pub fn (v mut V) cc_msvc() { | |||||||
| 
 | 
 | ||||||
| 	if !v.pref.is_debug && v.out_name_c != 'v.c' && v.out_name_c != 'v_macos.c' { | 	if !v.pref.is_debug && v.out_name_c != 'v.c' && v.out_name_c != 'v_macos.c' { | ||||||
| 		os.rm('.$v.out_name_c') | 		os.rm('.$v.out_name_c') | ||||||
|  | 		os.rm('$out_name_obj') | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| module main |  | ||||||
|  |  | ||||||
| fn (v mut V) cc_msvc() {  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fn build_thirdparty_obj_file_with_msvc(flag string) { |  | ||||||
|   |  | ||||||
| }  |  | ||||||
		Reference in New Issue
	
	Block a user