# proc-macro2-impersonated
> Adapted from [`proc-macro2`](https://github.com/alexcrichton/proc-macro2)
> Removed wrap proc-macro for correct span outside rust sources
> Not use in proc-macro context if you don't know what you do
[![Build Status](https://api.travis-ci.com/botika/proc-macro2-impersonated.svg?branch=master)](https://travis-ci.com/botika/proc-macro2-impersonated)
[![Latest Version](https://img.shields.io/crates/v/proc-macro2-impersonated.svg)](https://crates.io/crates/proc-macro2-impersonated)
[![Rust Documentation](https://img.shields.io/badge/api-rustdoc-blue.svg)](https://docs.rs/proc-macro2-impersonated)
A wrapper around the procedural macro API of the compiler's `proc_macro` crate.
This library serves two purposes:
- **Bring proc-macro-like functionality to other contexts like build.rs and
main.rs.** Types from `proc_macro` are entirely specific to procedural macros
and cannot ever exist in code outside of a procedural macro. Meanwhile
`proc_macro2` types may exist anywhere including non-macro code. By developing
foundational libraries like [syn] and [quote] against `proc_macro2` rather
than `proc_macro`, the procedural macro ecosystem becomes easily applicable to
many other use cases and we avoid reimplementing non-macro equivalents of
those libraries.
- **Make procedural macros unit testable.** As a consequence of being specific
to procedural macros, nothing that uses `proc_macro` can be executed from a
unit test. In order for helper libraries or components of a macro to be
testable in isolation, they must be implemented using `proc_macro2`.
[syn]: https://github.com/botika/syn-impersonated
[quote]: https://github.com/botika/quote-impersonated
## Usage
```toml
[dependencies]
proc-macro2-impersonated = "1.0"
```
#### 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 crate by you, as defined in the Apache-2.0 license, shall
be dual licensed as above, without any additional terms or conditions.