pub struct GccLinker<'a> {
    cmd: Command,
    sess: &'a Session,
    target_cpu: &'a str,
    hinted_static: Option<bool>,
    is_ld: bool,
    is_gnu: bool,
}

Fields§

§cmd: Command§sess: &'a Session§target_cpu: &'a str§hinted_static: Option<bool>§is_ld: bool§is_gnu: bool

Implementations§

source§

impl<'a> GccLinker<'a>

source

fn linker_arg(&mut self, arg: impl AsRef<OsStr>)

source

fn linker_args(&mut self, args: &[impl AsRef<OsStr>])

source

fn takes_hints(&self) -> bool

source

fn hint_static(&mut self)

source

fn hint_dynamic(&mut self)

source

fn push_linker_plugin_lto_args(&mut self, plugin_path: Option<&OsStr>)

source

fn build_dylib(&mut self, out_filename: &Path)

Trait Implementations§

source§

impl<'a> Linker for GccLinker<'a>

source§

fn linker_args(&mut self, args: &[&OsStr], verbatim: bool)

Passes a series of arguments directly to the linker.

When the linker is ld-like, the arguments are simply appended to the command. When the linker is not ld-like such as when using a compiler as a linker, the arguments are joined by commas to form an argument that is then prepended with -Wl. In this situation, only a single argument is appended to the command to ensure that the order of the arguments is preserved by the compiler.

source§

fn cmd(&mut self) -> &mut Command

source§

fn set_output_kind(&mut self, output_kind: LinkOutputKind, out_filename: &Path)

source§

fn include_path(&mut self, path: &Path)

source§

fn framework_path(&mut self, path: &Path)

source§

fn output_filename(&mut self, path: &Path)

source§

fn add_object(&mut self, path: &Path)

source§

fn full_relro(&mut self)

source§

fn partial_relro(&mut self)

source§

fn no_relro(&mut self)

source§

fn gc_sections(&mut self, keep_metadata: bool)

source§

fn no_gc_sections(&mut self)

source§

fn optimize(&mut self)

source§

fn pgo_gen(&mut self)

source§

fn control_flow_guard(&mut self)

source§

fn ehcont_guard(&mut self)

source§

fn debuginfo(&mut self, strip: Strip, _: &[PathBuf])

source§

fn no_crt_objects(&mut self)

source§

fn no_default_libraries(&mut self)

source§

fn export_symbols( &mut self, tmpdir: &Path, crate_type: CrateType, symbols: &[String] )

source§

fn subsystem(&mut self, subsystem: &str)

source§

fn reset_per_library_state(&mut self)

source§

fn linker_plugin_lto(&mut self)

source§

fn add_eh_frame_header(&mut self)

source§

fn add_no_exec(&mut self)

source§

fn add_as_needed(&mut self)

source§

fn linker_arg(&mut self, arg: &OsStr, verbatim: bool)

Auto Trait Implementations§

§

impl<'a> !RefUnwindSafe for GccLinker<'a>

§

impl<'a> !Send for GccLinker<'a>

§

impl<'a> !Sync for GccLinker<'a>

§

impl<'a> Unpin for GccLinker<'a>

§

impl<'a> !UnwindSafe for GccLinker<'a>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 136 bytes