当前位置: 首页>>代码示例>>C#>>正文


C# TypeBuilder.CreateAndAddType方法代码示例

本文整理汇总了C#中System.Reflection.Emit.TypeBuilder.CreateAndAddType方法的典型用法代码示例。如果您正苦于以下问题:C# TypeBuilder.CreateAndAddType方法的具体用法?C# TypeBuilder.CreateAndAddType怎么用?C# TypeBuilder.CreateAndAddType使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Reflection.Emit.TypeBuilder的用法示例。


在下文中一共展示了TypeBuilder.CreateAndAddType方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: EmitCodeAndGetExplorerItemTree

      public ExplorerItem EmitCodeAndGetExplorerItemTree(TypeBuilder dataContextTypeBuilder)
      {
         var query = SqlHelper.LoadSql("QueryTables.sql");
         var tables = connection.Query(query);

         var explorerItems = new List<ExplorerItem>();

         foreach (var group in tables.GroupBy(t => t.TableCatalog))
         {
            var databaseName = group.Key;

            var preparedTables = new List<TableData>();

            foreach (var table in group.OrderBy(t => t.TableName))
            {
               var unmodifiedTableName = (string)table.TableName;
               var tableName = cxInfo.GetTableName(unmodifiedTableName);

               var explorerItem = new ExplorerItem(tableName, ExplorerItemKind.QueryableObject, ExplorerIcon.Table)
               {
                  IsEnumerable = true,
                  Children = new List<ExplorerItem>(),
                  DragText = tableName,
                  SqlName = $"\"{unmodifiedTableName}\""
               };

               var tableData = PrepareTableEntity(cxInfo, moduleBuilder, connection, nameSpace, databaseName, unmodifiedTableName, explorerItem);
               preparedTables.Add(tableData);
            }

            // build the associations before the types are created
            BuildAssociations(connection, preparedTables);

            foreach (var tableData in preparedTables)
            {
               dataContextTypeBuilder.CreateAndAddType(tableData);
               explorerItems.Add(tableData.ExplorerItem);
            }
         }

         return new ExplorerItem("Tables", ExplorerItemKind.Category, ExplorerIcon.Table)
         {
            IsEnumerable = true,
            Children = explorerItems
         };
      }
开发者ID:henrik-m,项目名称:linqpad-postgresql-driver,代码行数:46,代码来源:PostgreSqlTablesProvider.cs


注:本文中的System.Reflection.Emit.TypeBuilder.CreateAndAddType方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。