CodeGen API分析
CodeGen API分析
作為使用命令行界面的替代方法,開發人員可以使用核心CodeGen環境編寫自定義工具或實用程序來生成代碼,從而將CodeGen更緊密地集成到開發環境中。
為了實現這一點,CodeGen提供了一個.NET API,開發人員可以直接對其進行編碼以生成代碼。CodeGen API中的主要類有:
?CodeGen.Engine.CodeGenTaskSet
?CodeGen.Engine.CodeGenTask
?CodeGen.Engine.CodeGenerator
CodeGen API Example
這是使用codegen API的一個非常簡單的示例。此代碼段基本上與使用命令行相
同:
codegen -s CUSTOMER -t DataClass -r –v
下面是示例代碼:
;;Create a new task set
data taskset = new CodeGenTaskSet()
taskset.LoggingLevel = LoggingLevel.Verbose
;;Create a task and define what it shold do
data task = new CodeGenTask()
task.Structures.Add(“CUSTOMER”)
task.Templates.Add(“DataClass”)
task.ReplaceFiles = true
;;Add the task to the task set
taskset.Tasks.Add(task)
;;Create a code generator and tell it about the task set
data generator = new CodeGenerator(taskset)
;;Generate the code
generator.GenerateCode()
;;Did it work?
if (taskset.Complete) then
;;Good to go
else
;;Something failed!
當執行此代碼時,不會看到任何事情發生,因為codegen API沒有實現任何
UI。但是,如果想查看作為其處理的任務集生成的消息,可以針對其中一個注冊
一個事件處理程序方法taskset.Messages.CollectionChanged或者
task.Messages.CollectionChanged并在消息生成時監視/報告這些消息。例如,如果
在控制臺應用程序中,可以將消息記錄到標準輸出,如下所示:
lambda messageFromTaskSet(sender, e)
begin
if (e.Action==NotifyCollectionChangedAction.Add)
begin
data message, String
foreach message in e.NewItems
if (message!=^null)
Console.WriteLine(message)
end
end
;;Listen for messages from the taskset as it processes
taskset.Messages.CollectionChanged += messageFromTaskSet
總結
以上是生活随笔為你收集整理的CodeGen API分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CodeGen字段循环Field Loo
- 下一篇: CodeGen融合核心扩展定制文件