Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jeffcampbellmakesgames/Genesis
A general purpose code generator library for Unity
https://github.com/jeffcampbellmakesgames/Genesis
Last synced: 3 months ago
JSON representation
A general purpose code generator library for Unity
- Host: GitHub
- URL: https://github.com/jeffcampbellmakesgames/Genesis
- Owner: jeffcampbellmakesgames
- License: mit
- Created: 2020-04-18T10:37:05.000Z (almost 5 years ago)
- Default Branch: develop
- Last Pushed: 2022-12-08T15:07:06.000Z (about 2 years ago)
- Last Synced: 2024-08-04T22:12:51.597Z (7 months ago)
- Language: C#
- Size: 56.6 MB
- Stars: 74
- Watchers: 5
- Forks: 8
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.MD
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
- awesome-unity-packages - Genesis
README
data:image/s3,"s3://crabby-images/331ef/331ef882032abd6ab1086f29cf5e055aed60930d" alt="Unit-Tests"
[data:image/s3,"s3://crabby-images/83c1c/83c1cd4c198a65251863bbd0364f130ba72f6f8c" alt="Genesis Continous Deployment"](https://github.com/jeffcampbellmakesgames/Genesis/actions/workflows/publish_releases.yml)![]()
[data:image/s3,"s3://crabby-images/fd432/fd43213bb59a161ac6c4afe58ccd16987c6acfd9" alt="License: MIT"](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/66c52/66c52d92e1db0bf64b47a1e0665db43604268c9a" alt="Twitter Follow"](https://twitter.com/stampyturtle)# Genesis
## About
Genesis is a general-purpose, plugin-extensible code generation framework for Unity.## Overview
Genesis is architected as a .Net Core console application that leverages Roslyn code analysis to inspect a target C# codebase and generate code files where developers can build custom code generators via an extensible plugin framework. While Genesis v2 is largely engine-agnostic, it has a first-class integration into the Unity game engine.
## Minimum Requirements
* Unity 2019.4.X
* **Scripting Runtime**: .Net 4.X
* **.Net Core Runtime**: 3.1.X
* **MSBuild**: MSBuild is required for the Roslyn parsing Genesis Requires. There are a few ways to ensure this is installed and I would recommend restarting your PC after performing any of these steps (see [here](https://docs.microsoft.com/en-us/visualstudio/msbuild/walkthrough-using-msbuild?view=vs-2022) for MS docs on installation).
* MSBuild is installed along with Visual Studio, so having VS installed accomplishes this requirement.
* Installing the .Net Core SDK v3.1 will ensure MSBuild is installed.
* Installing the Visual Studio Build Tools [here](https://docs.microsoft.com/en-us/visualstudio/msbuild/walkthrough-using-msbuild?view=vs-2022) will ensure MSBuild is available.## Installing Genesis
Using this library in your project can be done in three ways:### Install via OpenUPM
The package is available on the [openupm registry](https://openupm.com/). It's recommended to install it via [openupm-cli](https://github.com/openupm/openupm-cli).```
openupm add com.jeffcampbellmakesgames.Genesis
```### Install via GIT URL
Using the native Unity Package Manager introduced in 2017.2, you can add this library as a package by modifying your `manifest.json` file found at `/ProjectName/Packages/manifest.json` to include it as a dependency. See the example below on how to reference it.```
{
"dependencies": {
...
"com.jeffcampbellmakesgames.genesis" : "https://github.com/jeffcampbellmakesgames/genesis.git#release/stable",
...
}
}
```You will need to have Git installed and available in your system's PATH.
### Install via classic `.UnityPackage`
The latest release can be found [here](https://github.com/jeffcampbellmakesgames/Genesis/releases) as a UnityPackage file that can be downloaded and imported directly into your project's Assets folder.## Usage
To learn more about how to use JCMG Genesis, see the wiki [here](https://github.com/jeffcampbellmakesgames/Genesis/wiki/Usage) for more information.
## Support
If this is useful to you and/or you’d like to see future development and more tools in the future, please consider supporting it either by contributing to the Github projects (submitting bug reports or features and/or creating pull requests) or by buying me coffee using any of the links below. Every little bit helpsdata:image/s3,"s3://crabby-images/f3df2/f3df242083c02ed474f04d5622490904b8bc03bc" alt="![ko-fi"](https://ko-fi.com/I3I2W7GX)
## Contributing
For information on how to contribute and code style guidelines, please visit [here](CONTRIBUTING.md).