mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
lots of Windows fixes and cross compilation for Windows
This commit is contained in:
parent
e71213ba4f
commit
99a9a6572a
@ -412,7 +412,84 @@ string _STR_TMP(const char *fmt, ...) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn (c &V) cc_windows_cross() {
|
||||||
|
if !c.out_name.ends_with('.exe') {
|
||||||
|
c.out_name = c.out_name + '.exe'
|
||||||
|
}
|
||||||
|
mut args := '-o $c.out_name -w -L. '
|
||||||
|
// -I flags
|
||||||
|
for flag in c.table.flags {
|
||||||
|
if !flag.starts_with('-l') {
|
||||||
|
args += flag
|
||||||
|
args += ' '
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mut libs := ''
|
||||||
|
if c.pref.build_mode == DEFAULT_MODE {
|
||||||
|
libs = '$TmpPath/vlib/builtin.o'
|
||||||
|
if !os.file_exists(libs) {
|
||||||
|
println('`builtin.o` not found')
|
||||||
|
exit(1)
|
||||||
|
}
|
||||||
|
for imp in c.table.imports {
|
||||||
|
libs += ' $TmpPath/vlib/${imp}.o'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
args += ' $c.out_name_c '
|
||||||
|
// -l flags (libs)
|
||||||
|
for flag in c.table.flags {
|
||||||
|
if flag.starts_with('-l') {
|
||||||
|
args += flag
|
||||||
|
args += ' '
|
||||||
|
}
|
||||||
|
}
|
||||||
|
println('Cross compiling for Windows...')
|
||||||
|
winroot := '$TmpPath/winroot'
|
||||||
|
if !os.dir_exists(winroot) {
|
||||||
|
winroot_url := 'https://github.com/vlang/v/releases/download/v0.1.10/winroot.zip'
|
||||||
|
println('"$winroot" not found. Download it from $winroot_url and save in $TmpPath')
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
}
|
||||||
|
mut obj_name := c.out_name
|
||||||
|
obj_name = obj_name.replace('.exe', '')
|
||||||
|
obj_name = obj_name.replace('.o.o', '.o')
|
||||||
|
mut include := '-I $winroot/include '
|
||||||
|
cmd := 'clang -o $obj_name -w $include -m32 -c -target x86_64-win32 $TmpPath/$c.out_name_c'
|
||||||
|
if c.pref.show_c_cmd {
|
||||||
|
println(cmd)
|
||||||
|
}
|
||||||
|
if os.system(cmd) != 0 {
|
||||||
|
println('Cross compilation for Windows failed. Make sure you have clang installed.')
|
||||||
|
exit(1)
|
||||||
|
}
|
||||||
|
if c.pref.build_mode != BUILD {
|
||||||
|
link_cmd := 'lld-link $obj_name $winroot/lib/libcmt.lib ' +
|
||||||
|
'$winroot/lib/libucrt.lib $winroot/lib/kernel32.lib $winroot/lib/libvcruntime.lib ' +
|
||||||
|
'$winroot/lib/uuid.lib'
|
||||||
|
if c.pref.show_c_cmd {
|
||||||
|
println(link_cmd)
|
||||||
|
}
|
||||||
|
|
||||||
|
if os.system(link_cmd) != 0 {
|
||||||
|
println('Cross compilation for Windows failed. Make sure you have lld linker installed.')
|
||||||
|
exit(1)
|
||||||
|
}
|
||||||
|
// os.rm(obj_name)
|
||||||
|
}
|
||||||
|
println('Done!')
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
fn (v mut V) cc() {
|
fn (v mut V) cc() {
|
||||||
|
// Cross compiling for Windows
|
||||||
|
if v.os == WINDOWS {
|
||||||
|
$if !windows {
|
||||||
|
v.cc_windows_cross()
|
||||||
|
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 := ['-w', '-march=native']// arguments for the C compiler
|
mut a := ['-w', '-march=native']// arguments for the C compiler
|
||||||
@ -530,7 +607,7 @@ mut args := ''
|
|||||||
'$sysroot/lib/x86_64-linux-gnu/libm-2.28.a ' +
|
'$sysroot/lib/x86_64-linux-gnu/libm-2.28.a ' +
|
||||||
'/usr/lib/x86_64-linux-gnu/crti.o ' +
|
'/usr/lib/x86_64-linux-gnu/crti.o ' +
|
||||||
obj_file +
|
obj_file +
|
||||||
' /usr/lib/x86_64-linux-gnu/libv.so ' +
|
' /usr/lib/x86_64-linux-gnu/libc.so ' +
|
||||||
'/usr/lib/x86_64-linux-gnu/crtn.o')
|
'/usr/lib/x86_64-linux-gnu/crtn.o')
|
||||||
println(ress)
|
println(ress)
|
||||||
if ress.contains('error:') {
|
if ress.contains('error:') {
|
||||||
@ -569,7 +646,7 @@ fn (v &V) v_files_from_dir(dir string) []string {
|
|||||||
if file.ends_with('_lin.v') && v.os != LINUX {
|
if file.ends_with('_lin.v') && v.os != LINUX {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if file.ends_with('_mav.v') && v.os != MAC {
|
if file.ends_with('_mac.v') && v.os != MAC {
|
||||||
lin_file := file.replace('_mav.v', '_lin.v')
|
lin_file := file.replace('_mav.v', '_lin.v')
|
||||||
// println('lin_file="$lin_file"')
|
// println('lin_file="$lin_file"')
|
||||||
// If there are both _mav.v and _lin.v, don't use _mav.v
|
// If there are both _mav.v and _lin.v, don't use _mav.v
|
||||||
|
@ -810,7 +810,8 @@ fn (p mut Parser) get_type() string {
|
|||||||
// "typ" not found? try "pkg__typ"
|
// "typ" not found? try "pkg__typ"
|
||||||
if t.name == '' && !p.builtin_pkg {
|
if t.name == '' && !p.builtin_pkg {
|
||||||
// && !p.first_run() {
|
// && !p.first_run() {
|
||||||
if !typ.contains('array_') && p.pkg != 'main' && !typ.contains('__') {
|
if !typ.contains('array_') && p.pkg != 'main' && !typ.contains('__') &&
|
||||||
|
!typ.starts_with('[') {
|
||||||
typ = p.prepend_pkg(typ)
|
typ = p.prepend_pkg(typ)
|
||||||
}
|
}
|
||||||
t = p.table.find_type(typ)
|
t = p.table.find_type(typ)
|
||||||
|
56
vlib/os/os.v
56
vlib/os/os.v
@ -6,11 +6,24 @@ module os
|
|||||||
|
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <unistd.h>
|
//#include <unistd.h>
|
||||||
#include <dirent.h>
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
//#include <execinfo.h> // for backtrace_symbols_fd
|
//#include <execinfo.h> // for backtrace_symbols_fd
|
||||||
|
|
||||||
|
/*
|
||||||
|
struct dirent {
|
||||||
|
d_ino int
|
||||||
|
d_off int
|
||||||
|
d_reclen u16
|
||||||
|
d_type byte
|
||||||
|
d_name [256]byte
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct C.dirent {
|
||||||
|
d_name byteptr
|
||||||
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
args = []string
|
args = []string
|
||||||
MAX_PATH = 4096
|
MAX_PATH = 4096
|
||||||
@ -20,6 +33,10 @@ const (
|
|||||||
FILE_ATTRIBUTE_DIRECTORY = 16 // Windows
|
FILE_ATTRIBUTE_DIRECTORY = 16 // Windows
|
||||||
)
|
)
|
||||||
|
|
||||||
|
import const (
|
||||||
|
INVALID_FILE_ATTRIBUTES
|
||||||
|
)
|
||||||
|
|
||||||
struct FILE {
|
struct FILE {
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,10 +67,10 @@ struct C.DIR {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct C.dirent {
|
//struct C.dirent {
|
||||||
d_name byteptr
|
//d_name byteptr
|
||||||
|
|
||||||
}
|
//}
|
||||||
|
|
||||||
struct C.sigaction {
|
struct C.sigaction {
|
||||||
mut:
|
mut:
|
||||||
@ -302,15 +319,22 @@ pub fn file_exists(path string) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn dir_exists(path string) bool {
|
pub fn dir_exists(path string) bool {
|
||||||
dir := C.opendir(path.cstr())
|
$if windows {
|
||||||
res := !isnil(dir)
|
attr := int(C.GetFileAttributes(path.cstr()))
|
||||||
if res {
|
println('ATTR =$attr')
|
||||||
C.closedir(dir)
|
return attr == FILE_ATTRIBUTE_DIRECTORY
|
||||||
}
|
}
|
||||||
return res
|
$else {
|
||||||
|
dir := C.opendir(path.cstr())
|
||||||
|
res := !isnil(dir)
|
||||||
|
if res {
|
||||||
|
C.closedir(dir)
|
||||||
|
}
|
||||||
|
return res
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// `mkdir` creates a new directory with the specified path.
|
// mkdir creates a new directory with the specified path.
|
||||||
pub fn mkdir(path string) {
|
pub fn mkdir(path string) {
|
||||||
$if windows {
|
$if windows {
|
||||||
path = path.replace('/', '\\')
|
path = path.replace('/', '\\')
|
||||||
@ -321,7 +345,7 @@ pub fn mkdir(path string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// `rm` removes file in `path`.
|
// rm removes file in `path`.
|
||||||
pub fn rm(path string) {
|
pub fn rm(path string) {
|
||||||
$if windows {
|
$if windows {
|
||||||
// os.system2('del /f $path')
|
// os.system2('del /f $path')
|
||||||
@ -530,6 +554,11 @@ pub fn getwd() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn ls(path string) []string {
|
pub fn ls(path string) []string {
|
||||||
|
$if windows {
|
||||||
|
return []string
|
||||||
|
}
|
||||||
|
$else {
|
||||||
|
|
||||||
mut res := []string
|
mut res := []string
|
||||||
dir := C.opendir(path.str)
|
dir := C.opendir(path.str)
|
||||||
if isnil(dir) {
|
if isnil(dir) {
|
||||||
@ -550,6 +579,7 @@ pub fn ls(path string) []string {
|
|||||||
}
|
}
|
||||||
C.closedir(dir)
|
C.closedir(dir)
|
||||||
return res
|
return res
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn log(s string) {
|
fn log(s string) {
|
||||||
|
3
vlib/os/os_mac.v
Normal file
3
vlib/os/os_mac.v
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
module os
|
||||||
|
|
||||||
|
#include <dirent.h>
|
@ -1,140 +0,0 @@
|
|||||||
module os
|
|
||||||
|
|
||||||
// Ref - https://docs.microsoft.com/en-us/windows/desktop/winprog/windows-data-types
|
|
||||||
|
|
||||||
type BOOL bool
|
|
||||||
type BOOLEAN BOOL
|
|
||||||
|
|
||||||
// A byte (8 bits)
|
|
||||||
type BYTE u8
|
|
||||||
|
|
||||||
// An 8-bit Windows (ANSI) character.
|
|
||||||
type CHAR u8
|
|
||||||
|
|
||||||
// An 16-bit Windows character.
|
|
||||||
type WCHAR u16
|
|
||||||
|
|
||||||
// A 32-bit signed integer. The range is -2147483648 through 2147483647 decimal.
|
|
||||||
type INT i32
|
|
||||||
|
|
||||||
// A signed integer type for pointer precision.
|
|
||||||
type INT_PTR INT*
|
|
||||||
|
|
||||||
// A pointer to an INT (INT32).
|
|
||||||
type PINT INT*
|
|
||||||
|
|
||||||
// A 8-bit signed integer.
|
|
||||||
type INT8 i8
|
|
||||||
|
|
||||||
// // A pointer to an INT8.
|
|
||||||
type PINT8 INT8*
|
|
||||||
|
|
||||||
// A 16-bit signed integer.
|
|
||||||
type INT16 i16
|
|
||||||
|
|
||||||
// // A pointer to an INT16.
|
|
||||||
type PINT16 INT16*
|
|
||||||
|
|
||||||
// A 32-bit signed integer.
|
|
||||||
type INT32 i32
|
|
||||||
|
|
||||||
// A pointer to an INT32.
|
|
||||||
type PINT32 INT32*
|
|
||||||
|
|
||||||
// A 64-bit signed integer.
|
|
||||||
type INT64 i64
|
|
||||||
|
|
||||||
// A pointer to an INT64.
|
|
||||||
type PINT64 INT64*
|
|
||||||
|
|
||||||
// An unsigned INT. The range is 0 through 4294967295 decimal.
|
|
||||||
type UINT u32
|
|
||||||
|
|
||||||
// An unsigned INT_PTR.
|
|
||||||
type UINT_PTR UINT*
|
|
||||||
|
|
||||||
// An unsigned INT8.
|
|
||||||
type UINT8 u8
|
|
||||||
|
|
||||||
// An unsigned INT16.
|
|
||||||
type UINT16 u16
|
|
||||||
|
|
||||||
// An unsigned INT32.
|
|
||||||
type UINT32 u32
|
|
||||||
|
|
||||||
// An unsigned INT64.
|
|
||||||
type UINT64 u64
|
|
||||||
|
|
||||||
// A 16-bit unsigned integer. The range is 0 through 65535 decimal.
|
|
||||||
type WORD u16
|
|
||||||
|
|
||||||
// A pointer to an WORD.
|
|
||||||
type LPWORD WORD*
|
|
||||||
|
|
||||||
// A 32-bit unsigned integer. The range is 0 through 4294967295 decimal.
|
|
||||||
type DWORD u32
|
|
||||||
|
|
||||||
// A pointer to an DWORD.
|
|
||||||
type DWORD_PTR DWORD*
|
|
||||||
type LPDWORD DWORD*
|
|
||||||
|
|
||||||
// A 64-bit unsigned integer. The range is 0 through 18446744073709551615 decimal.
|
|
||||||
type DWORDLONG u64
|
|
||||||
type PDWORDLONG DWORDLONG*
|
|
||||||
|
|
||||||
// A 32-bit unsigned integer.
|
|
||||||
type DWORD32 u32
|
|
||||||
type PDWORD32 DWORD32*
|
|
||||||
|
|
||||||
// A 64-bit unsigned integer.
|
|
||||||
type DWORD64 u64
|
|
||||||
type PDWORD64 DWORD64*
|
|
||||||
|
|
||||||
// A floating-point variable.
|
|
||||||
type FLOAT f32
|
|
||||||
type FLOAT64 f64
|
|
||||||
type PFLOAT FLOAT*
|
|
||||||
|
|
||||||
// A 32-bit signed integer. The range is 2147483648 through 2147483647 decimal.
|
|
||||||
type LONG i32
|
|
||||||
type LONG_PTR LONG*
|
|
||||||
type LPLONG LONG*
|
|
||||||
|
|
||||||
// A 64-bit signed integer. The range is 9223372036854775808 through 9223372036854775807 decimal.
|
|
||||||
type LONGLONG i64
|
|
||||||
type LONG32 i32
|
|
||||||
type LONG64 i64
|
|
||||||
|
|
||||||
// A pointer to a BOOL.
|
|
||||||
type LPBOOL BOOL*
|
|
||||||
|
|
||||||
// A pointer to a BYTE.
|
|
||||||
type LPBYTE BYTE*
|
|
||||||
|
|
||||||
// An 8-bit Windows (ANSI) character. For more information, see Character Sets Used By Fonts.
|
|
||||||
type LPCSTR CHAR*
|
|
||||||
|
|
||||||
// A 16-bit Unicode character. For more information, see Character Sets Used By Fonts.
|
|
||||||
type LPWSTR WCHAR*
|
|
||||||
|
|
||||||
// A pointer to an CHAR.
|
|
||||||
type PCHAR CHAR*
|
|
||||||
|
|
||||||
// A pointer to an BYTE.
|
|
||||||
type PBYTE BYTE*
|
|
||||||
|
|
||||||
//
|
|
||||||
// Descriptor
|
|
||||||
//
|
|
||||||
|
|
||||||
// A handle to an object.
|
|
||||||
type HANDLE C.HANDLE // voidptr?
|
|
||||||
|
|
||||||
// A pointer to a HANDLE.
|
|
||||||
type PHANDLE *HANDLE
|
|
||||||
|
|
||||||
// A handle to a registry key.
|
|
||||||
type HKEY HANDLE
|
|
||||||
|
|
||||||
// A pointer to a HKEY.
|
|
||||||
type PHKEY *HKEY
|
|
@ -303,7 +303,12 @@ pub fn sleep(seconds int) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn usleep(n int) {
|
pub fn usleep(n int) {
|
||||||
|
$if windows {
|
||||||
|
//C._usleep(n)
|
||||||
|
}
|
||||||
|
$else {
|
||||||
C.usleep(n)
|
C.usleep(n)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn sleep_ms(n int) {
|
pub fn sleep_ms(n int) {
|
||||||
|
Loading…
Reference in New Issue
Block a user