T4 Template Overview
T4 Template Overview
T4 Template的组成

指令区:为模板转换引擎提供指令,控制模板如何被处理
- template:模板相关的属性,debug是否可以调试;hostspecific设置为true时,为生成的模板类中添加Host属性
- output:生成输出文件类型
- assembly:模板引擎中引用的程序集
- import:模板引擎中导入的命名空间
- include:包含其他文件,在最终转换时,将这些引用的文件和当前文件进行合并
代码控制区
- 标准代码控制区,<#...#>包围的区域,包含标准的代码
- 表达式控制区,<#=...#>包围的区域,计算表达式的值,插入到最终输出文件中
- 类特性控制区,<#+...#>包围的区域,定义类、属性、方法等,主要用于帮助类或者帮助方法,可以其他代码区域引用这里定义的类和方法,该区域中包含的代码可以放在单独文件中,然后include到当前文件中
T4 工具方法
- Write,WriteLine:向模板中写入数据文本
- Error,在VS的Error Window面板显示错误
- Warning,在VS的Error Window面板显示警告
更多方法,请参考:http://msdn.microsoft.com/en-us/library/bb126474.aspx
Host属性:引用模板转换引擎的宿主
- Microsoft.VisualStudio.TextTemplating.ITextTemplatingEngineHost类型
- 使用Host.ResolvePath()引用相对于模板的路径
- 使用Host.LogErrors打印错误信息,如果宿主是VS的话,就是向Error Window打印错误警告信息
- 如果是在VS中使用,可以访问VS的API
建议的开发流程
- T4模板不是编写代码的理想环境(没有智能提示等)
- 首先在其他工程中实现模板需要的功能
- 将工程的代码迁移到T4模板中
如何Debug T4模板
- 首先建议采用上面说的开发流程,T4模板的Debug是用来解决迁移过程中出现的问题
- template指令设置debug="true“
- 添加断点
- 在模板文件中右键Debug T4 Template
T4 Template的三个组件

引擎

如何生成GeneratedTextTransformation

GeneratedTextTransformation运行

使用自定义的TextTransformation
GeneratedTextTransformation继承自TextTransformation,如果要使用另外一套方法集,可以定义继承自TextTransformation的类,然后在template指令的inherits属性指定为该类
宿主
- 加载引擎或者指令处理器需要的文本文件或者二进制文件,比如加载程序集、指令处理器代码文件,也可以读取文本文件,将它们的内容作为字符串返回
- 为引擎创建GeneratedTextTransformation类提供一组标准的程序集和命名空间
- 为引擎编译和执行GeneratedTextTransformation类提供AppDomain,使用独立的AppDomain是为保护宿主应用程序(VS)不受模板文件中错误的影响
- 将生成的结果写入输出文件
- 为生成的输出文件设置默认扩展名
- 处理文件转换过程中出现的错误,比如写入文件中,又比如VS将错误显示到Error Window中
- 为指令提供默认值,比如language默认值C#
自定义宿主
创建并运行自己的工程,引用Microsoft.VisualStudio.TextTemplating.11.0.dll和Microsoft.VisualStudio.TextTemplating.Interfaces.11.0.dll,主要是使用Engine的ProcessTemplate
更详细流程请参考官方文档:http://msdn.microsoft.com/en-us/library/bb126579.aspx
指令处理器
- 提供公共功能,访问外部资源或数据
- 引擎将指令转换为代码,添加到GeneratedTextTransformation中,比如Import指令最终添加为using代码语句
自定义指令处理器:
需要创建继承自DirectiveProcessor或者RequiresProvidesDirectiveProcessor的类,该类的重要接口如下
- bool IsDirectiveSupported(string directiveName)支持哪些指令,只有返回true的指令名称,才会进行下一步的处理
- void ProcessDirective (string directiveName, IDictionary<string, string> arguments)处理指令时,引擎调用这个方法,一般是将指令名称和参数保存下来为后面的操作做准备
- string[] GetReferencesForProcessingRun()返回模板需要的程序集名称
- string[] GetImportsForProcessingRun()返回模板需要的命名空间
- string GetClassCodeForProcessingRun()向GeneratedTextTransformation类中插入的实际代码,定义了公共功能如属性、方法等的代码
部署指令处理器
- Visual Studio Extension (VSIX)
- VSPackage
- 注册表
详细部署流程,请参考官方文档:http://msdn.microsoft.com/en-us/library/cc138364.aspx
参考文档和资料
http://msdn.microsoft.com/en-us/library/bb126445.aspx
http://www.cnblogs.com/artech/archive/2010/11/16/T4_Assembly_Locking_Debug.html
http://www.cnblogs.com/artech/archive/2010/10/23/1859529.html
http://www.hanselman.com/blog/T4TextTemplateTransformationToolkitCodeGenerationBestKeptVisualStudioSecret.aspx
T4 Template Overview的更多相关文章
- [转] How to generate multiple outputs from single T4 template (T4 输出多个文件)
本文转自:http://www.olegsych.com/2008/03/how-to-generate-multiple-outputs-from-single-t4-template/ Updat ...
- 用T4 Template生成代码
1 T4语法 T4的语法与ASP.NET的方式比较类似.主要包括指令.文本块.控制块. 1.1 指令 指令主要包括template, output, assembly, import, incl ...
- 把旧系统迁移到.Net Core 2.0 日记(9) -- T4 Template
想着用T4 Template 自动生成代码,省了功夫. 发现T4 Template 挺笨的. 我开始这样写是会报错的 <# var modualName = "CRM" ...
- 使用微软T4 template进行代码生成
使得软件工程高效开发的主要方法是复用.复用的宗旨是提高设计的内聚性,主要包括:函数,类,模式,组件,框架等等.而有些应用场景并都是可以直接拿来现成代码使用的,有时代码库的代码不是那么容易修改,或者根本 ...
- 【Reship】use of tangible T4 template engine
1.first of all 之前在 “使用T4模板生成代码 – 初探” 文章简单的使用了T4模板的生成功能,但对于一个模板生成多个实例文件,如何实现这个方式呢?无意发现一个解决方案 “Multipl ...
- t4 template multi file output
1.Manager.ttinclude <#@ assembly name="System.Core"#> <#@ assembly name="Sys ...
- CSharpGL(12)用T4模板生成CSSL及其renderer代码
CSharpGL(12)用T4模板生成CSSL及其renderer代码 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立 ...
- [转]Multiple outputs from T4 made easy
本文转自:http://damieng.com/blog/2009/01/22/multiple-outputs-from-t4-made-easy One of the things I wante ...
- T4 assembly
In a T4 template the executing assembly is not yours but one from the T4 engine. To access types fro ...
随机推荐
- Oracle 多表关联更新
drop table course; create table course ( id integer, teacherNo integer, teacherDesc ), teacherName ) ...
- 快速解读GC日志(转)
本文是 Plumbr 发行的 Java垃圾收集手册 的部分内容.文中将介绍GC日志的输出格式, 以及如何解读GC日志, 从中提取有用的信息.我们通过 -XX:+UseSerialGC 选项,指定JVM ...
- Lichee (六) 优化配置的微内核
我们的分析<Lichee(二) 在sun4i_crane平台下的编译 >的时候.竟然没有一个步骤是在配置内核 make ARCH=arm menuconfig 细致的读过的代码的会发现,在 ...
- 毕业后的第二份工作:进入国外 在新加坡工作 每月一次18K
--訪传智播客成都校区12.26就业班学员 杨洋 姓名:杨洋 毕业院校:重庆科技学院 专业:电子信息技术与project 就职公司:新电科技 岗位:Javaproject师 月薪:18K 上午.他刚去 ...
- 从头学起android<GridView网格视图.二十八.>
GridView基于组件的网络格所有的形式的组分的,例如:当制作专辑,所有的图片将在相同的尺寸在不同的显示格在孩子,是否能够依靠这个组件完成.此组件的继承结构参见例如下面: java.lang.Obj ...
- 线程同步synchronized
一Java规划共享多个线程之间数据的能力. 当线程以异步方式訪问共享数据时.有时候是不安全的或者不和逻辑的. 比方卖火车票.同一时刻一个线程在读取数据,另外一个线程在处理数据,当处理数据的线程没有等到 ...
- Unity插件之NGUI学习(6)—— 关于Widget怎样加入触发事件(触发OnClick)
NGUI中,Button本身就带有OnClick事件,可是Sprite,Label等( 也绑有Widget的)并没有触发事件,事实上NGUI的事件触发都必须加入Box Collider,并勾选Is T ...
- Spark集群搭建简配+它到底有多快?【单挑纯C/CPP/HADOOP】
最近耳闻Spark风生水起,这两天利用休息时间研究了一下,果然还是给人不少惊喜.可惜,笔者不善JAVA,只有PYTHON和SCALA接口.花了不少时间从零开始认识PYTHON和SCALA,不少时间答了 ...
- Windows下C语言的Socket编程例子(TCP和UDP)
原文:Windows下C语言的Socket编程例子(TCP和UDP) 刚刚学windows编程,所以想写学习笔记,这是一个简单的Socket程序例子,开发环境是vc6: 首先是TCP server端: ...
- 接口自动化测试:Thrift框架RPC协议客户端开发
import java.lang.Thread.State;import java.util.Iterator;import java.util.List; import org.apache.thr ...