2015-05-21 10:45:38 -05:00
|
|
|
% Advanced Linking
|
2015-03-25 17:35:51 -05:00
|
|
|
|
2015-05-21 10:45:38 -05:00
|
|
|
The common cases of linking with Rust have been covered earlier in this book,
|
|
|
|
but supporting the range of linking possibilities made available by other
|
|
|
|
languages is important for Rust to achieve seamless interaction with native
|
|
|
|
libraries.
|
|
|
|
|
|
|
|
# Link args
|
|
|
|
|
|
|
|
There is one other way to tell `rustc` how to customize linking, and that is via
|
2015-03-25 17:35:51 -05:00
|
|
|
the `link_args` attribute. This attribute is applied to `extern` blocks and
|
|
|
|
specifies raw flags which need to get passed to the linker when producing an
|
|
|
|
artifact. An example usage would be:
|
|
|
|
|
|
|
|
``` no_run
|
|
|
|
#![feature(link_args)]
|
|
|
|
|
|
|
|
#[link_args = "-foo -bar -baz"]
|
|
|
|
extern {}
|
|
|
|
# fn main() {}
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that this feature is currently hidden behind the `feature(link_args)` gate
|
2015-05-21 10:45:38 -05:00
|
|
|
because this is not a sanctioned way of performing linking. Right now `rustc`
|
2015-03-25 17:35:51 -05:00
|
|
|
shells out to the system linker, so it makes sense to provide extra command line
|
2015-05-21 10:45:38 -05:00
|
|
|
arguments, but this will not always be the case. In the future `rustc` may use
|
2015-06-25 18:29:23 -05:00
|
|
|
LLVM directly to link native libraries, in which case `link_args` will have no
|
2015-03-25 17:35:51 -05:00
|
|
|
meaning.
|
|
|
|
|
|
|
|
It is highly recommended to *not* use this attribute, and rather use the more
|
|
|
|
formal `#[link(...)]` attribute on `extern` blocks instead.
|
|
|
|
|