[][src]Struct rustc_target::spec::Target

pub struct Target {
    pub llvm_target: String,
    pub target_endian: String,
    pub target_pointer_width: String,
    pub target_c_int_width: String,
    pub target_os: String,
    pub target_env: String,
    pub target_vendor: String,
    pub arch: String,
    pub data_layout: String,
    pub linker_flavor: LinkerFlavor,
    pub options: TargetOptions,
}

Everything rustc knows about how to compile for a specific target.

Every field here must be specified, and has no default value.

Fields

llvm_target: String

Target triple to pass to LLVM.

target_endian: String

String to use as the target_endian cfg variable.

target_pointer_width: String

String to use as the target_pointer_width cfg variable.

target_c_int_width: String

Width of c_int type

target_os: String

OS name to use for conditional compilation.

target_env: String

Environment name to use for conditional compilation.

target_vendor: String

Vendor name to use for conditional compilation.

arch: String

Architecture to use for ABI considerations. Valid options include: "x86", "x86_64", "arm", "aarch64", "mips", "powerpc", "powerpc64", and others.

data_layout: String

Data layout to pass to LLVM.

linker_flavor: LinkerFlavor

Linker flavor

options: TargetOptions

Optional settings with defaults.

Methods

impl Target[src]

pub fn adjust_abi(&self, abi: Abi) -> Abi[src]

Given a function ABI, turn it into the correct ABI for this target.

pub fn min_atomic_width(&self) -> u64[src]

Minimum integer size in bits that this target can perform atomic operations on.

pub fn max_atomic_width(&self) -> u64[src]

Maximum integer size in bits that this target can perform atomic operations on.

pub fn is_abi_supported(&self, abi: Abi) -> bool[src]

pub fn from_json(obj: Json) -> TargetResult[src]

Loads a target descriptor from a JSON object.

pub fn search(target_triple: &TargetTriple) -> Result<Target, String>[src]

Search RUST_TARGET_PATH for a JSON file specifying the given target triple. Note that it could also just be a bare filename already, so also check for that. If one of the hardcoded targets we know about, just return it directly.

The error string could come from any of the APIs called, including filesystem access and JSON decoding.

Trait Implementations

impl HasTargetSpec for Target[src]

impl Clone for Target[src]

impl PartialEq<Target> for Target[src]

impl Debug for Target[src]

impl ToJson for Target[src]

Auto Trait Implementations

impl Unpin for Target

impl Sync for Target

impl Send for Target

impl UnwindSafe for Target

impl RefUnwindSafe for Target

Blanket Implementations

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Erased for T[src]

impl<E> SpecializationError for E[src]