Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rust-unofficial/patterns
A catalogue of Rust design patterns, anti-patterns and idioms
https://github.com/rust-unofficial/patterns
antipatterns idioms patterns reference rust rust-lang
Last synced: 5 days ago
JSON representation
A catalogue of Rust design patterns, anti-patterns and idioms
- Host: GitHub
- URL: https://github.com/rust-unofficial/patterns
- Owner: rust-unofficial
- License: mpl-2.0
- Created: 2015-10-15T02:10:14.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2024-10-17T01:12:16.000Z (3 months ago)
- Last Synced: 2024-10-29T15:04:58.756Z (3 months ago)
- Topics: antipatterns, idioms, patterns, reference, rust, rust-lang
- Language: Handlebars
- Homepage: https://rust-unofficial.github.io/patterns/
- Size: 5.03 MB
- Stars: 8,103
- Watchers: 194
- Forks: 374
- Open Issues: 76
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - rust-unofficial/patterns - A catalogue of Rust design patterns, anti-patterns and idioms (Handlebars)
- awesome-rust - Rust Design Patterns
- awesome-rust-cn - Rust Design Patterns
- StarryDivineSky - rust-unofficial/patterns
README
# Rust Design Patterns
An open source book about design patterns and idioms in the Rust programming
language that you can read [here](https://rust-unofficial.github.io/patterns/).You can also download the book in PDF format from
[this link](https://rust-unofficial.github.io/patterns/rust-design-patterns.pdf).## Contributing
You are missing content in this repository that can be helpful for others, and
you are eager to explain it? Awesome! We are always happy about new
contributions (e.g. elaboration or corrections on certain topics) to this
project.You can check the
[Umbrella issue](https://github.com/rust-unofficial/patterns/issues/116) for all
the patterns, anti-patterns, and idioms that could be added.We suggest reading our [Contribution guide](./CONTRIBUTING.md) to get more
information on how contributing to this repository works.## Building with mdbook
This book is built with [mdbook](https://rust-lang.github.io/mdBook/). You can
install it by running `cargo install mdbook`.### Additional dependencies
- `cargo install mdbook-last-changed` for date changes in the footer
- `cargo install mdbook-pandoc` for rendering the book to PDF
- `cargo install mdbook-i18n-helpers` for translation and i8n support
#### Texlive
```sh
# Source the .env file to get the PANDOC_VERSION
. ./.envsudo apt-get update
sudo apt-get install -y texlive texlive-latex-extra texlive-luatex texlive-lang-cjk librsvg2-bin fonts-noto
curl -LsSf https://github.com/jgm/pandoc/releases/download/$PANDOC_VERSION/pandoc-$PANDOC_VERSION-linux-amd64.tar.gz | tar zxf -
```### Building the book
If you want to build it locally you can run one of these two commands in the
root directory of the repository:- `mdbook build`
Builds static html pages as output and place them in the `/book` directory by
default.- `mdbook serve`
Serves the book at `http://localhost:3000` (port is changeable, take a look at
the terminal output to be sure) and reloads the browser when a change occurs.## License
The content of this repository is licensed under **MPL-2.0**; see
[LICENSE](./LICENSE).