added forced target
This commit is contained in:
@@ -33,8 +33,12 @@ CUtlString Target_t::GetTriplet()
|
||||
triplet.AppendTail("-");
|
||||
if ( kernel == TARGET_KERNEL_UNKNOWN )
|
||||
triplet.AppendTail("unknown-unknown");
|
||||
if ( kernel == TARGET_KERNEL_LINUX )
|
||||
if ( kernel == TARGET_KERNEL_UNKNOWN_LINUX )
|
||||
triplet.AppendTail("unknown-linux");
|
||||
if ( kernel == TARGET_KERNEL_PC_LINUX )
|
||||
triplet.AppendTail("pc-linux");
|
||||
if ( kernel == TARGET_KERNEL_ALPINE_LINUX )
|
||||
triplet.AppendTail("alpine-linux");
|
||||
if ( kernel == TARGET_KERNEL_WINDOWS )
|
||||
triplet.AppendTail("pc-windows");
|
||||
if ( kernel == TARGET_KERNEL_DARWIN )
|
||||
@@ -60,33 +64,22 @@ CUtlString Target_t::GetTriplet()
|
||||
|
||||
const char *Target_t::GetExecutableFileFormat()
|
||||
{
|
||||
switch(kernel)
|
||||
if (kernel & TARGET_KERNEL_POSIX)
|
||||
return "";
|
||||
|
||||
if (kernel & TARGET_KERNEL_WINDOWS_DEVICES)
|
||||
{
|
||||
case TARGET_KERNEL_LINUX:
|
||||
case TARGET_KERNEL_ANDROID:
|
||||
case TARGET_KERNEL_DARWIN:
|
||||
case TARGET_KERNEL_IOS:
|
||||
return "%s";
|
||||
break;
|
||||
case TARGET_KERNEL_WINDOWS:
|
||||
return "%s.exe";
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
const char *Target_t::GetStaticLibraryFileFormat()
|
||||
{
|
||||
switch(kernel)
|
||||
{
|
||||
case TARGET_KERNEL_LINUX:
|
||||
case TARGET_KERNEL_ANDROID:
|
||||
case TARGET_KERNEL_DARWIN:
|
||||
case TARGET_KERNEL_IOS:
|
||||
return "lib%s.a";
|
||||
if (kernel & TARGET_KERNEL_POSIX)
|
||||
return "lib%s.a";
|
||||
|
||||
case TARGET_KERNEL_WINDOWS:
|
||||
if (kernel & TARGET_KERNEL_WINDOWS_DEVICES)
|
||||
{
|
||||
switch(abi)
|
||||
{
|
||||
@@ -96,25 +89,16 @@ const char *Target_t::GetStaticLibraryFileFormat()
|
||||
return "lib%s.a";
|
||||
}
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
const char *Target_t::GetDynamicLibraryFileFormat()
|
||||
{
|
||||
switch(kernel)
|
||||
{
|
||||
case TARGET_KERNEL_LINUX:
|
||||
case TARGET_KERNEL_ANDROID:
|
||||
if (kernel & TARGET_KERNEL_LINUX_DEVICES)
|
||||
return "lib%s.so";
|
||||
case TARGET_KERNEL_DARWIN:
|
||||
if (kernel & TARGET_KERNEL_APPLE_DEVICES)
|
||||
return "lib%s.dylib";
|
||||
if (kernel & TARGET_KERNEL_WINDOWS_DEVICES)
|
||||
return "lib%s.dylib";
|
||||
case TARGET_KERNEL_WINDOWS:
|
||||
return "%s.dll";
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
//----------------------------------------------------------------------------
|
||||
@@ -124,25 +108,19 @@ const char *Target_t::GetDynamicLibraryFileFormat()
|
||||
//----------------------------------------------------------------------------
|
||||
Target_t Target_t::HostTarget()
|
||||
{
|
||||
ETargetKernel kernel =
|
||||
ETargetKernel kernel = TARGET_KERNEL_UNDEFINED;
|
||||
#if defined(__linux__)
|
||||
TARGET_KERNEL_LINUX
|
||||
kernel = TARGET_KERNEL_LINUX;
|
||||
#elif defined(__APPLE__)
|
||||
TARGET_KERNEL_DARWIN
|
||||
kernel TARGET_KERNEL_DARWIN;
|
||||
#endif
|
||||
;
|
||||
// i have no idea how to get libc
|
||||
ETargetABI abi =
|
||||
TARGET_ABI_GNU
|
||||
;
|
||||
ETargetCPU cpu =
|
||||
ETargetCPU cpu = TARGET_CPU_UNDEFINED;
|
||||
#if defined(__x86_64__)
|
||||
TARGET_CPU_AMD64
|
||||
cpu = TARGET_CPU_AMD64;
|
||||
#endif
|
||||
#if defined(__i386__)
|
||||
TARGET_CPU_80386
|
||||
cpu = TARGET_CPU_80386;
|
||||
#endif
|
||||
;
|
||||
// POSIX doesn't know about these
|
||||
// use uname to get them
|
||||
#if defined(__i386__) && defined(POSIX)
|
||||
@@ -153,6 +131,18 @@ ETargetCPU cpu =
|
||||
if (!V_strcmp("i686", s_uname.machine))
|
||||
cpu = TARGET_CPU_80686;
|
||||
#endif
|
||||
ETargetABI abi = TARGET_ABI_GNU;
|
||||
|
||||
#ifdef FPC_ARCH
|
||||
cpu = CPUFromString(FPC_ARCH);
|
||||
#endif
|
||||
#ifdef FPC_OS
|
||||
kernel = KernelFromString(FPC_OS);
|
||||
#endif
|
||||
#ifdef FPC_ABI
|
||||
abi = ABIFromString(FPC_ABI);
|
||||
#endif
|
||||
|
||||
|
||||
return {
|
||||
.kernel = kernel,
|
||||
@@ -172,44 +162,16 @@ Target_t Target_t::DefaultTarget()
|
||||
CUtlString szArch = CommandLine()->ParamValue("-arch");
|
||||
CUtlString szAbi = CommandLine()->ParamValue("-abi");
|
||||
|
||||
ETargetKernel kernel = HostTarget().kernel;
|
||||
ETargetCPU cpu = HostTarget().cpu;
|
||||
ETargetABI abi = HostTarget().abi;
|
||||
ETargetKernel kernel = KernelFromString(szOS);
|
||||
ETargetCPU cpu = CPUFromString(szArch);
|
||||
ETargetABI abi = ABIFromString(szAbi);
|
||||
if (cpu == TARGET_CPU_UNDEFINED)
|
||||
cpu = HostTarget().cpu;
|
||||
if (kernel == TARGET_KERNEL_UNDEFINED)
|
||||
kernel = HostTarget().kernel;
|
||||
if (abi == TARGET_ABI_UNDEFINED)
|
||||
abi = HostTarget().abi;
|
||||
|
||||
if ( szArch == "x86_64" )
|
||||
cpu = TARGET_CPU_AMD64;
|
||||
else if ( szArch == "i386" )
|
||||
cpu = TARGET_CPU_80386;
|
||||
else if ( szArch == "i486" )
|
||||
cpu = TARGET_CPU_80486;
|
||||
else if ( szArch == "i586" )
|
||||
cpu = TARGET_CPU_80586;
|
||||
else if ( szArch == "i686" )
|
||||
cpu = TARGET_CPU_80686;
|
||||
else if ( szArch == "aarch64" )
|
||||
cpu = TARGET_CPU_AARCH64;
|
||||
else if ( szArch == "wasm32" )
|
||||
cpu = TARGET_CPU_WASM32;
|
||||
|
||||
if ( szOS == "unknown" )
|
||||
kernel = TARGET_KERNEL_UNKNOWN;
|
||||
else if ( szOS == "windows" )
|
||||
kernel = TARGET_KERNEL_WINDOWS;
|
||||
else if ( szOS == "linux" )
|
||||
kernel = TARGET_KERNEL_LINUX;
|
||||
else if ( szOS == "macos" )
|
||||
kernel = TARGET_KERNEL_DARWIN;
|
||||
else if ( szOS == "ios" )
|
||||
kernel = TARGET_KERNEL_IOS;
|
||||
else if ( szOS == "android" )
|
||||
kernel = TARGET_KERNEL_ANDROID;
|
||||
else if ( szOS != 0 )
|
||||
V_printf("Unknown OS: %s\n", szOS.GetString());
|
||||
|
||||
if ( szAbi == "gnu" )
|
||||
abi = TARGET_ABI_GNU;
|
||||
else if ( szAbi == "musl" )
|
||||
abi = TARGET_ABI_MUSL;
|
||||
|
||||
return {
|
||||
.kernel = kernel,
|
||||
@@ -218,3 +180,57 @@ Target_t Target_t::DefaultTarget()
|
||||
.optimization = TARGET_DEBUG,
|
||||
};
|
||||
}
|
||||
ETargetCPU Target_t::CPUFromString( const char *szName )
|
||||
{
|
||||
CUtlString szUtlName = szName;
|
||||
if ( szUtlName == "x86_64" )
|
||||
return TARGET_CPU_AMD64;
|
||||
else if ( szUtlName == "i386" )
|
||||
return TARGET_CPU_80386;
|
||||
else if ( szUtlName == "i486" )
|
||||
return TARGET_CPU_80486;
|
||||
else if ( szUtlName == "i586" )
|
||||
return TARGET_CPU_80586;
|
||||
else if ( szUtlName == "i686" )
|
||||
return TARGET_CPU_80686;
|
||||
else if ( szUtlName == "aarch64" )
|
||||
return TARGET_CPU_AARCH64;
|
||||
else if ( szUtlName == "wasm32" )
|
||||
return TARGET_CPU_WASM32;
|
||||
return TARGET_CPU_UNDEFINED;
|
||||
}
|
||||
|
||||
ETargetKernel Target_t::KernelFromString( const char *szName )
|
||||
{
|
||||
CUtlString szUtlName = szName;
|
||||
if ( szUtlName == "unknown" )
|
||||
return TARGET_KERNEL_UNKNOWN;
|
||||
else if ( szUtlName == "windows" )
|
||||
return TARGET_KERNEL_WINDOWS;
|
||||
else if ( szUtlName == "linux" )
|
||||
return TARGET_KERNEL_LINUX;
|
||||
else if ( szUtlName == "unknown-linux" )
|
||||
return TARGET_KERNEL_UNKNOWN_LINUX;
|
||||
else if ( szUtlName == "pc-linux" )
|
||||
return TARGET_KERNEL_PC_LINUX;
|
||||
else if ( szUtlName == "alpine-linux" )
|
||||
return TARGET_KERNEL_ALPINE_LINUX;
|
||||
else if ( szUtlName == "macos" )
|
||||
return TARGET_KERNEL_DARWIN;
|
||||
else if ( szUtlName == "ios" )
|
||||
return TARGET_KERNEL_IOS;
|
||||
else if ( szUtlName == "android" )
|
||||
return TARGET_KERNEL_ANDROID;
|
||||
return TARGET_KERNEL_UNDEFINED;
|
||||
}
|
||||
|
||||
ETargetABI Target_t::ABIFromString( const char *szName )
|
||||
{
|
||||
CUtlString szUtlName = szName;
|
||||
if ( szUtlName == "gnu" )
|
||||
return TARGET_ABI_GNU;
|
||||
else if ( szUtlName == "musl" )
|
||||
return TARGET_ABI_MUSL;
|
||||
return TARGET_ABI_UNDEFINED;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user