# genco
[](https://github.com/udoprog/genco)
[](https://crates.io/crates/genco)
[](https://docs.rs/genco)
[](https://github.com/udoprog/genco/actions?query=branch%3Amain)
A whitespace-aware quasiquoter for beautiful code generation.
Central to genco are the [quote!] and [quote_in!] procedural macros which
ease the construction of [token streams].
This project solves the following language-specific concerns:
* **Imports** — Generates and groups [import statements] as they are used.
So you only import what you use, with no redundancy. We also do our best
to [solve namespace conflicts].
* **String Quoting** — genco knows how to [quote strings]. And can even
[interpolate] values *into* the quoted string if it's supported by the
language.
* **Structural Indentation** — The quoter relies on intuitive
[whitespace detection] to structurally sort out spacings and indentation.
Allowing genco to generate beautiful readable code with minimal effort.
This is also a requirement for generating correctly behaving code in
languages like Python where [indentation is meaningful].
* **Language Customization** — Building support for new languages is a
piece of cake with the help of the [impl_lang!] macro.
To support line changes during [whitespace detection], we depend on the
nightly [`proc_macro_span` feature]. On stable we can only detect column
changes.
*Until this is stabilized* and you want fully functional whitespace
detection you must build and run projects using genco with a `nightly`
compiler. This is important for whitespace-sensitive languages like python.
You can try the difference between:
```bash
cargo run --example rust
```
And:
```bash
cargo +nightly run --example rust
```
[`proc_macro_span` feature]: https://github.com/rust-lang/rust/issues/54725
## Supported Languages
The following are languages which have built-in support in genco.
* [🦀 Rust][rust]
[Example][rust-example]
* [☕ Java][java]
[Example][java-example]
* [🎼 C#][c#]
[Example][c#-example]
* [🐿️ Go][go]
[Example][go-example]
* [🎯 Dart][dart]
[Example][dart-example]
* [🌐 JavaScript][js]
[Example][js-example]
* [🇨 C][c]
[Example][c-example]
* [🐍 Python][python]
[Example][python-example]
**Requires a `nightly` compiler**
Is your favorite language missing? [Open an issue!]
You can run one of the examples by:
```bash
cargo +nightly run --example rust
```
## Rust Example
The following is a simple program producing Rust code to stdout with custom
configuration:
```rust
use genco::prelude::*;
let hash_map = rust::import("std::collections", "HashMap");
let tokens: rust::Tokens = quote! {
fn main() {
let mut m = $hash_map::new();
m.insert(1u32, 2u32);
}
};
println!("{}", tokens.to_file_string()?);
```
This would produce:
```rust,no_test
use std::collections::HashMap;
fn main() {
let mut m = HashMap::new();
m.insert(1u32, 2u32);
}
```
[c-example]: https://github.com/udoprog/genco/blob/master/examples/c.rs
[c]: https://docs.rs/genco/latest/genco/lang/c/index.html
[c#-example]: https://github.com/udoprog/genco/blob/master/examples/csharp.rs
[c#]: https://docs.rs/genco/latest/genco/lang/csharp/index.html
[dart-example]: https://github.com/udoprog/genco/blob/master/examples/dart.rs
[dart]: https://docs.rs/genco/latest/genco/lang/dart/index.html
[go-example]: https://github.com/udoprog/genco/blob/master/examples/go.rs
[go]: https://docs.rs/genco/latest/genco/lang/go/index.html
[impl_lang!]: https://docs.rs/genco/latest/genco/macro.impl_lang.html
[import statements]: https://docs.rs/genco/latest/genco/macro.quote.html#imports
[indentation is meaningful]: https://docs.python.org/3/faq/design.html#why-does-python-use-indentation-for-grouping-of-statements
[interpolate]: https://docs.rs/genco/latest/genco/macro.quote.html#quoted-string-interpolation
[java-example]: https://github.com/udoprog/genco/blob/master/examples/java.rs
[java]: https://docs.rs/genco/latest/genco/lang/java/index.html
[js-example]: https://github.com/udoprog/genco/blob/master/examples/js.rs
[js]: https://docs.rs/genco/latest/genco/lang/js/index.html
[Open an issue!]: https://github.com/udoprog/genco/issues/new
[python-example]: https://github.com/udoprog/genco/blob/master/examples/python.rs
[python]: https://docs.rs/genco/latest/genco/lang/python/index.html
[quote strings]: https://docs.rs/genco/latest/genco/macro.quote.html#string-quoting
[quote_in!]: https://docs.rs/genco/latest/genco/macro.quote_in.html
[quote!]: https://docs.rs/genco/latest/genco/macro.quote.html
[quoted()]: https://docs.rs/genco/latest/genco/tokens/fn.quoted.html
[rust-example]: https://github.com/udoprog/genco/blob/master/examples/rust.rs
[rust]: https://docs.rs/genco/latest/genco/lang/rust/index.html
[solve namespace conflicts]: https://docs.rs/genco/latest/genco/lang/csharp/fn.import.html
[token streams]: https://docs.rs/genco/latest/genco/tokens/struct.Tokens.html
[whitespace detection]: https://docs.rs/genco/latest/genco/macro.quote.html#whitespace-detection