https://github.com/usagi/retrieve
https://github.com/usagi/retrieve
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/usagi/retrieve
- Owner: usagi
- License: mit
- Created: 2022-04-27T17:41:29.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-05-11T10:00:03.000Z (about 3 years ago)
- Last Synced: 2025-03-23T21:11:24.843Z (3 months ago)
- Language: Rust
- Size: 25.4 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
[![github]](https://github.com/usagi/retrieve) [![crates-io]](https://crates.io/crates/retrieve) [![docs-rs]](https://docs.rs/retrieve)
[](https://travis-ci.org/usagi/retrieve)[github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github
[crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust
[docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=# retrieve
`mod x` and `use x::*` pattern syntax sugar of the proc-macro attribute.
- `retrieve::`
- `mod_use` => `mod x; use x::*;` for a module internal.
- `pub_mod_use` => `pub mod x; use x::*` for a public nested modules.
- `mod_pub_use` => `mod x; pub use x::*` for a public flatten modules with separated source writting.
- `pub_mod_pub_use` => `pub x; pub use x::x` for a public nested modules with flatten alias in the root.I am tired of writing the `mod x; use x::*;` pattern over and over again for structured beatiful source code!😝 And I like the stylish attribute proc-macro style syntax sugars.💖
## Example: [examples/](examples/)
- src/
- main.rs
- x.rs ; Or it can move to x/mod.rs if you like module-name/mod.rs style.
- x/
- a.rs ; `crate::x::a::*`
- b.rs ; `crate::x::b::*`1. main.rs:
```rust
use retrieve::*;#[mod_pub_use(x)] // <-- here!; it's the same as `mod x; pub use x::*;`
fn main()
{
// `X` from x::X
let x = X {
a: 1,
b: 2
};// And it from '2. x.rs'; `.a()` from the trait of `x::a::A` and `.b()` from the trait of `x::b::B`
println!("{:?}", x.a() + x.b());
}
```2. x.rs:
```rust
use retrieve::*;#[mod_pub_use(a, b)] // <-- here!; it's the same as `mod a; pub use a::*;` and `mod b; pub use b::*;`
pub struct X
{
pub a: i32,
pub b: i32
}
```## for Debuggin
`retrieve` has `print` feature. It will be show a part of evaluated syntax:
eg. Run the example with `print` feature:
```sh
cargo run --example work_arround --features print
```Then, you will get something like it in the build messages:
```sh
Compiling retrieve v1.0.1 (C:\Users\usagi\tmp\retrieve)
[(proc-macro)retrieve::mod_pub_use+print]
mod x; pub use x::*;
fn main()
{ let x = X :: new(1) ; println! ("{:?} {:?}", x.a(), x.to_string()) ; }
[(proc-macro)retrieve::mod_pub_use+print]
mod a; pub use a::*;
mod new; pub use new::*;
mod _impl_already_traits; pub use _impl_already_traits::*;
pub struct X { a : i32 }
[(proc-macro)retrieve::mod_pub_use+print]
mod display; pub use display::*;
use super :: X ;
Finished dev [unoptimized + debuginfo] target(s) in 1.41s
Running `target\debug\examples\work_arround.exe`
1 "One!"
```## LICENSE
- [MIT](LICENSE.md)
## Author
- USAGI.NETWORK / Usagi Ito