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>) -> &mut Self

Passes an argument directly to the linker.

When the linker is not ld-like such as when using a compiler as a linker, the argument is prepended by -Wl,.

source

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

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 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 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 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)

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 Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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 Twhere 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 Twhere 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