#macro #file

pathsep

a small macro to enable easy path construction in other macro calls

2 releases

0.1.1 Nov 19, 2018
0.1.0 Oct 26, 2018

#1957 in Rust patterns

Download history 1/week @ 2024-07-20 9/week @ 2024-07-27 17/week @ 2024-08-03 4/week @ 2024-08-10 7/week @ 2024-08-24 7/week @ 2024-08-31 4/week @ 2024-09-07 7/week @ 2024-09-14 17/week @ 2024-09-21 23/week @ 2024-09-28 13/week @ 2024-10-05 10/week @ 2024-10-12 6/week @ 2024-10-19 63/week @ 2024-10-26 8/week @ 2024-11-02

87 downloads per month
Used in 2 crates

Apache-2.0/MIT

7KB

Get the path separator for your OS

When you want to include!(_) generated files, cargo will ask you to put them in $OUT_DIR. However, the "usual" way of

include!(concat!(env!("OUT_DIR"), "/somefile.rs"));

will fail on some windows systems, because they fail to understand the / path separator. This crate allows you to replace that with:

include!(join_path!(env!("OUT_DIR"), "somefile.rs"));

This will work on all operating systems. You can create paths starting with the separator by prepending / to the join_path! arguments:

join_path!(/ "usr", "local", "lib");

Usage

Add this to your Cargo.toml:

pathsep = "0.1"

Then you can use #[macro_use] extern crate pathsep; in your crate root. As of Rust 1.30, you can also omit the #[macro_use] and use pathsep::join_path; directly.

License

This code is licensed under the terms of the Apache License 2.0 or the MIT license, at your discretion.


lib.rs:

A small macro that gives us the path separator of the target system

This can be used in conjunction with include!(..) or include_str!(..) and concat!(..) to build paths.

Examples

#[macro_use] extern crate pathsep;

include!(concat!(env!("OUT_DIR"), path_separator!(), "generated.rs"));

The same can be more succinctly written as:

#[macro_use] extern crate pathsep;

include!(path_join!(env!("OUT_DIR"), "generated.rs"));

No runtime deps