Go to file
David Tolnay 39117c6eb5
Merge pull request #6 from dtolnay/links
Enable Cargo's overriding build scripts feature
2020-10-07 10:58:39 -07:00
.github/workflows Remove Travis configuration 2020-05-05 11:37:36 -07:00
src Rename Cargo features to libstdc++ and libc++ 2020-09-25 17:39:51 -04:00
.gitignore Implement build script 2020-01-24 14:41:39 -08:00
build.rs Rename Cargo features to libstdc++ and libc++ 2020-09-25 17:39:51 -04:00
Cargo.toml Enable Cargo's overriding build scripts feature 2020-10-07 10:55:41 -07:00
LICENSE-APACHE Dual mit OR apache license 2020-01-24 14:39:54 -08:00
LICENSE-MIT Dual mit OR apache license 2020-01-24 14:39:54 -08:00
README.md Rename Cargo features to libstdc++ and libc++ 2020-09-25 17:39:51 -04:00

-lstdc++ or -lc++

github crates.io docs.rs build status

This crate exists for the purpose of passing -lstdc++ or -lc++ to the linker, while making it possible for an application to make that choice on behalf of its library dependencies.

Without this crate, a library would need to:

  • pick one or the other to link, with no way for downstream applications to override the choice;
  • or link neither and require an explicit link flag provided by downstream applications even if they would be fine with a default choice;

neither of which are good experiences.


Options

An application or library that is fine with either of libstdc++ or libc++ being linked, whichever is the platform's default, should use:

[dependencies]
link-cplusplus = "1.0"

An application that wants a particular one or the other linked should use:

[dependencies]
link-cplusplus = { version = "1.0", features = ["libstdc++"] }

# or

link-cplusplus = { version = "1.0", features = ["libc++"] }

An application that wants to handle its own more complicated logic for link flags from its build script can make this crate do nothing by using:

[dependencies]
link-cplusplus = { version = "1.0", features = ["nothing"] }

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.