Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/deniszykov/t4-templates-unity3d
T4 Text Template Processor for Unity3D
https://github.com/deniszykov/t4-templates-unity3d
t4 unity unity-asset unity-editor unity3d unity3d-plugin
Last synced: 3 months ago
JSON representation
T4 Text Template Processor for Unity3D
- Host: GitHub
- URL: https://github.com/deniszykov/t4-templates-unity3d
- Owner: deniszykov
- License: other
- Created: 2016-05-22T08:20:01.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-10-05T16:08:09.000Z (over 2 years ago)
- Last Synced: 2024-04-29T00:43:20.055Z (9 months ago)
- Topics: t4, unity, unity-asset, unity-editor, unity3d, unity3d-plugin
- Language: C#
- Size: 3.63 MB
- Stars: 88
- Watchers: 5
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-unity-open-source-on-github - t4-templates-unity3d - T4 Text Template Processor (Editor Utility)
README
# Introduction
This Unity [editor extension](https://assetstore.unity.com/packages/tools/utilities/t4-code-generation-63294) provides [T4 text templates](https://msdn.microsoft.com/en-US/library/bb126445.aspx) processor.
T4 template is a mixture of text blocks and control logic that can generate a text file. The control logic is written as fragments of program code in C#.
The generated file can be text of any kind, such as resource file, source code or web page.T4 template example:
```csharpThe date and time now is: <#= DateTime.Now #>
```
## Use cases
* Source code generation
* [Project resources catalogization](GameDevWare.TextTransform.Unity/Assets/Editor/GameDevWare.TextTransform/Examples/FileList_Example.tt)
* [Resource loading/reading code generation](GameDevWare.TextTransform.Unity/Assets/Editor/GameDevWare.TextTransform/Examples/ResourceAsyncLoad_Example.tt)
* [Code generation by DSL](GameDevWare.TextTransform.Unity/Assets/Editor/GameDevWare.TextTransform/Examples/DSL_Example.tt)
* Code generation for ORM (BLToolkit for example)
* [Embedding environment information into project's build](GameDevWare.TextTransform.Unity/Assets/Editor/GameDevWare.TextTransform/Examples/EnvironmentInfo_Example.tt)
## How to use
Create or copy file with **.tt** extension. Select this file in Project window (Window -> Project), then in Inspector window (Window -> Inspector) setup T4 template's parameters. Click "Generate" button.
Inspector window for T4 template contains following parameters:
* **Output Type** - type of generated file
* **Text** - normal template's output. It corresponds to "Design-time T4 text templates" in Microsoft's terminology.
* **Text Generator** - generator-class which can generate content when TransformText() is called. It corresponds to "Run time T4 text templates" in Microsoft's terminology.
* **Output Path** - path to generated file. If not specified, generated file will have file name of template and file extension from *output* directive.
* **Auto-Gen Triggers** - list of events which trigger auto-generation.
* **Code Compilation** - after each code compilation
* **Asset Changes** - after watched assets are changed, look for **Assets to Watch**
* **Auto-Gen Delay (Ms)** - delay before triggered auto-generation starts
* **Assets to Watch** - list of assets and folders which trigger auto-generation## Details
T4 template can use *hostspecific=true* [property](https://msdn.microsoft.com/en-us/library/bb126478.aspx#Anchor_4) to access *Host.ResolvePath* method, which maps path relatively to template's location.By default *UnityEngine.dll* and *UnityEditor.dll* assemblies are referenced in all templates.
You can reference project's assemblies *Assembly-CSharp* and *Assembly-CSharp-firstpass* by adding **assembly** [directive](https://msdn.microsoft.com/en-us/library/bb126478.aspx#Anchor_3):
```xml
<#@ assembly name="Assembly-CSharp" #>
<#@ assembly name="Assembly-CSharp-firstpass" #>
```
### Target Runtime
The template always uses the current runtime and core libraries of Unity Editor.### Language Version
You could specify C# language version with `language=` directive.
List of available language versions:
* language="C#v3.5" - C# version 3.5.
* language="C#" - C# up to version 6, depending on Unity Editor's version.
* language="C#/Unity" - C# version based on Roslyn shipped with Unity Editor.
* unspecified - It is currently the equivalent of "C#/Unity".[MSBuild Macros](https://msdn.microsoft.com/en-US/library/c02as0cs.aspx) are not available.
You can run template generation from your code with **UnityTemplateGenerator.RunForTemplate(templatePath)** call.
## Version 2.0.0
there is some breaking changes due renaming in this version## Version 1.0.7
fixed missing 's' in project name 'TextTran_S_form', files, namespaces, folders has been renamed.
executable name of tools has been changed to 'GameDevWare.TextTransform.exe' new NuGet package will be published## Contacts
Please send any questions at [email protected]## License
[Asset Store Terms of Service and EULA](LICENSE.md)