CodeDom生成类文件
仅供个人学习
需要先引入System.CodeDom nuget包
using CodeGenerate.Entities;
using System;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Collections.Generic;
using System.Reflection;
using System.Text; namespace CodeGenerate
{
public class GenerateCS
{
/// <summary>
/// 生成的类里面只有字段
/// </summary>
/// <param name="namespaceName"></param>
/// <param name="className"></param>
/// <param name="classType"></param>
/// <param name=""></param>
public static void FieldGenerate(string namespaceName, string className, TypeAttributes classType, string FileName, List<ClassFieldInfo> classInfos)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = namespaceName; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration(className); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = classType;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件名称
string outputFile = FileName; //添加字段
foreach (ClassFieldInfo item in classInfos)
{
CodeMemberField field = new CodeMemberField(item.FieldType, item.FiledName);
field.Attributes = item.FiledMemberAttributes;
field.Comments.Add(new CodeCommentStatement(item.FieldComments));
//field.InitExpression = new CodeFieldReferenceExpression(new CodeTypeReferenceExpression("System.Int64"), "12 * 1024 * 1024");
field.InitExpression = new CodeFieldReferenceExpression(null, item.FileValue);
Customerclass.Members.Add(field);
} //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
} public static void PropertiesGenerate(string namespaceName, string className, TypeAttributes classType, string FileName, List<ClassPropertyInfo> classInfos)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = namespaceName; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration(className); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = classType;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件名称
string outputFile = FileName; foreach(ClassPropertyInfo item in classInfos)
{
CodeMemberProperty property = new CodeMemberProperty();
property.Attributes = item.PropertyMemberAttributes;
property.Name = item.PropertyName;
property.HasGet = item.IsHaveGet;
property.HasSet = item.IsHaveSet;
property.Type = new CodeTypeReference(item.PropertyType);
property.Comments.Add(new CodeCommentStatement(item.PropertyComments));
//property.GetStatements.Add(new CodeMethodReturnStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id")));
//property.SetStatements.Add(new CodeAssignStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id"), new CodePropertySetValueReferenceExpression()));
Customerclass.Members.Add(property);
} //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
}
}
}
static void Generate(Dictionary<string, string> dic)
{
CodeCompileUnit unit = new CodeCompileUnit(); //准备必要的命名空间(这个是指要生成的类的空间)
CodeNamespace sampleNamespace = new CodeNamespace(); //导入必要的命名空间
//sampleNamespace.Imports.Add(new CodeNamespaceImport("System")); //设置命名空间的名称
sampleNamespace.Name = "FiiiChain.Consensus"; //准备要生成的类的定义
CodeTypeDeclaration Customerclass = new CodeTypeDeclaration("BlockSetting"); //指定这是一个Class
Customerclass.IsClass = true;
Customerclass.TypeAttributes = TypeAttributes.Public;
//Customerclass.Attributes = MemberAttributes.Public | MemberAttributes.Const; //把这个类放在这个命名空间下
sampleNamespace.Types.Add(Customerclass); //把该命名空间加入到编译器单元的命名空间集合中
unit.Namespaces.Add(sampleNamespace); //这是输出文件
string outputFile = "BlockSetting.cs"; //添加字段
foreach (KeyValuePair<string, string> item in dic)
{
CodeMemberField field = new CodeMemberField(typeof(long), item.Key);
field.Attributes = MemberAttributes.Public | MemberAttributes.Const;
//field.Comments.Add(new CodeCommentStatement("Max block size is 12 MB"));
//field.InitExpression = new CodeFieldReferenceExpression(new CodeTypeReferenceExpression("System.Int64"), "12 * 1024 * 1024");
field.InitExpression = new CodeFieldReferenceExpression(null, item.Value);
Customerclass.Members.Add(field);
}
//添加属性 CodeMemberProperty property = new CodeMemberProperty();
property.Attributes = MemberAttributes.Public | MemberAttributes.Final;
property.Name = "Id";
property.HasGet = true;
property.HasSet = true;
property.Type = new CodeTypeReference(typeof(System.String));
property.Comments.Add(new CodeCommentStatement("这是Id属性"));
//property.GetStatements.Add(new CodeMethodReturnStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id1")));
//property.SetStatements.Add(new CodeAssignStatement(new CodeFieldReferenceExpression(new CodeThisReferenceExpression(), "_Id2"), new CodePropertySetValueReferenceExpression()));
Customerclass.Members.Add(property); //添加方法(使用CodeMemberMethod)--此处略 //添加构造器(使用CodeConstructor) --此处略 //添加程序入口点(使用CodeEntryPointMethod) --此处略 //添加事件(使用CodeMemberEvent) --此处略 //添加特征(使用 CodeAttributeDeclaration)
Customerclass.CustomAttributes.Add(new CodeAttributeDeclaration(new CodeTypeReference(typeof(SerializableAttribute)))); //生成代码
CodeDomProvider provider = CodeDomProvider.CreateProvider("CSharp");
CodeGeneratorOptions options = new CodeGeneratorOptions();
options.BracingStyle = "C";
options.BlankLinesBetweenMembers = true;
using (System.IO.StreamWriter sw = new System.IO.StreamWriter(outputFile))
{
provider.GenerateCodeFromCompileUnit(unit, sw, options);
}
}
参考文章:http://www.cnblogs.com/xszjk/articles/6414099.html
CodeDom生成类文件的更多相关文章
- Mybatis逆向工程生成类文件
首先,我们需要建好相关文件夹目录: 然后,编写执行脚本 generator.xml : 1 <?xml version="1.0" encoding="UTF-8& ...
- C# wsdl.exe 生成类文件
wsdl.exe D:\XXX\demand\demand.\wsdl\XXX.wsdl /\wsdl\class 在 vs tools:Developer Command Prompt For VS ...
- T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll
生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 ,一定要自已新建,把T4代码复制进去,好多人因为用我现成的T4报错(原因不明) 点击添加文 ...
- 使用 xsd.exe 命令工具将 xsd 架构生成 类(CS) 文件
vs自带命令行工具 命令:xsd xml文件路径 C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC>xsd d:Scheme.xml ...
- 使用CodeSmith快速生成映射文件和映射类
一 CodeSmith简介 本文以表自动生成NHibernate的映射文件和映射类的实例来说明一下本软件的使用方法. CodeSmith是一种基于模板的代码生成工具,其使用类似于ASP.NET的语法来 ...
- 命令行下使用javah命令生成.h文件,出现“错误: 无法访问android.app.Activity 找不到android.app.Activity的类文件”的解决方法
在学习NDK中,当我在项目的bin/classes目录下使用javah命令生成头文件时,出现了“错误: 无法访问android.app.Activity 找不到android.app.Activity ...
- php中soap的使用实例以及生成WSDL文件,提供自动生成WSDL文件的类库——SoapDiscovery.class.php类
1. web service普及: Webservice soap wsdl区别之个人见解 Web Service实现业务诉求: Web Service是真正“办事”的那个,提供一种办事接口的统称. ...
- 通过MyEclipse生成Hibernate类文件和hbm.xml文件,或者annotation文件
1. 前言 很多人都在使用myEclipse,很多公司也都使用hibernate框架,老版本的hibernate中,由于没有annotation,我们需要写两个文件来维护表与对象的关系,写一个类, ...
- T4 模板自动生成带注释的实体类文件
T4 模板自动生成带注释的实体类文件 - 只需要一个 SqlSugar.dll 生成实体就是这么简单,只要建一个T4文件和 文件夹里面放一个DLL. 使用T4模板教程 步骤1 创建T4模板 如果你没有 ...
随机推荐
- Google推荐的15条HTML 5代码军规----来看看你知道几个,我一个都不知道。。。
Google规范的原文链接大家可以访问:http://google-styleguide.googlecode.com/svn/trunk/htmlcssguide.xml 1.协议头: 建议在指向图 ...
- 20155213 2016-2017-2 《Java程序设计》第五周学习总结
20155213 2016-2017-2 <Java程序设计>第五周学习总结 教材学习内容总结 Java中所有错误都会被打包为对象,运用try.catch,可以在错误发生时显示友好的错误信 ...
- Mysql查看建表语句以及修改引擎
更多内容推荐微信公众号,欢迎关注: 1 查看系统支持的存储引擎 show engines; 2 查看表使用的存储引擎 两种方法: a.show table status from db_name wh ...
- windows环境cmd下执行jar
项目目录结构 一,在pom.xml文件里添加配置 <build> <plugins> <plugin> <groupId>org.apache.mave ...
- python进阶之类常用魔法方法和魔法属性
前言 前面我们总结过了python的关键字.运算符.内置函数.语法糖等与python魔法方法之间的关系,现在我们更细一点,看看python的面向对象编程有哪些常用的魔法属性和魔法方法. 魔法属性 对于 ...
- aarch64_c1
CBFlib-0.9.5.15-3.fc26.aarch64.rpm 2017-02-06 06:55 393K fedora Mirroring Project CBFlib-devel-0.9.5 ...
- C#中HttpWebRequest的GetRequestStream执行的效率太低,甚至偶尔死掉
为了提高httpwebrequest的执行效率,查到了一些如下设置 request.ServicePoint.Expect100Continue = false; request.ServicePoi ...
- avalonJS-源码阅读(一)
写angularJS源码阅读系列的时候,写的太垃圾了.一个月后看,真心不忍直视,以后有机会的话得重写.这次写avalonJS,希望能在代码架构层面多些一点,少上源码.多写思路. avalon暴露句柄方 ...
- http://s22.app1105796624.qqopenapp.com/
http://s22.app1105796624.qqopenapp.com/ http://121.43.114.69/xiyou/app/js/ac_tx.js http://hiyouba.co ...
- Java 并发--线程创建
随着处理器的多核化,为提高处理器的资源利用率应用程序的并发变应运而生了.现在的操作系统是多任务操作系统,多线程是实现多任务的一种方式. 进程是指一个内存中运行的应用程序,每个进程都有自己独立的内存空间 ...