GenCode_Egret.lua 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. local function genCode(handler)
  2. local settings = handler.project:GetSettings("Publish").codeGeneration
  3. local codePkgName = handler:ToFilename(handler.pkg.name); --convert chinese to pinyin, remove special chars etc.
  4. local exportCodePath = handler.exportCodePath..'/'..codePkgName
  5. local namespaceName = codePkgName
  6. local ns = 'fairygui'
  7. if settings.packageName~=nil and settings.packageName~='' then
  8. namespaceName = settings.packageName..'.'..namespaceName;
  9. end
  10. --CollectClasses(stripeMemeber, stripeClass, fguiNamespace)
  11. local classes = handler:CollectClasses(settings.ignoreNoname, settings.ignoreNoname, ns)
  12. handler:SetupCodeFolder(exportCodePath, "ts") --check if target folder exists, and delete old files
  13. local getMemberByName = settings.getMemberByName
  14. local classCnt = classes.Count
  15. local writer = CodeWriter.new({ blockFromNewLine=false, usingTabs=true })
  16. for i=0,classCnt-1 do
  17. local classInfo = classes[i]
  18. local members = classInfo.members
  19. writer:reset()
  20. writer:writeln('module %s', namespaceName)
  21. writer:startBlock()
  22. writer:writeln()
  23. writer:writeln('export class %s extends %s', classInfo.className, classInfo.superClassName)
  24. writer:startBlock()
  25. local memberCnt = members.Count
  26. for j=0,memberCnt-1 do
  27. local memberInfo = members[j]
  28. writer:writeln('public %s:%s;', memberInfo.varName, memberInfo.type)
  29. end
  30. writer:writeln('public static URL:string = "ui://%s%s";', handler.pkg.id, classInfo.resId)
  31. writer:writeln()
  32. writer:writeln('public static createInstance():%s', classInfo.className)
  33. writer:startBlock()
  34. writer:writeln('return <%s>(%s.UIPackage.createObject("%s", "%s"));', classInfo.className, ns, handler.pkg.name, classInfo.resName)
  35. writer:endBlock()
  36. writer:writeln()
  37. writer:writeln('protected constructFromXML(xml:any):void')
  38. writer:startBlock()
  39. writer:writeln('super.constructFromXML(xml);')
  40. writer:writeln()
  41. for j=0,memberCnt-1 do
  42. local memberInfo = members[j]
  43. if memberInfo.group==0 then
  44. if getMemberByName then
  45. writer:writeln('this.%s = <%s>(this.getChild("%s"));', memberInfo.varName, memberInfo.type, memberInfo.name)
  46. else
  47. writer:writeln('this.%s = <%s>(this.getChildAt(%s));', memberInfo.varName, memberInfo.type, memberInfo.index)
  48. end
  49. elseif memberInfo.group==1 then
  50. if getMemberByName then
  51. writer:writeln('this.%s = this.getController("%s");', memberInfo.varName, memberInfo.name)
  52. else
  53. writer:writeln('this.%s = this.getControllerAt(%s);', memberInfo.varName, memberInfo.index)
  54. end
  55. else
  56. if getMemberByName then
  57. writer:writeln('this.%s = this.getTransition("%s");', memberInfo.varName, memberInfo.name)
  58. else
  59. writer:writeln('this.%s = this.getTransitionAt(%s);', memberInfo.varName, memberInfo.index)
  60. end
  61. end
  62. end
  63. writer:endBlock()
  64. writer:endBlock() --class
  65. writer:endBlock() --namepsace
  66. writer:save(exportCodePath..'/'..classInfo.className..'.ts')
  67. end
  68. writer:reset()
  69. local binderName = codePkgName..'Binder'
  70. writer:writeln('module %s', namespaceName)
  71. writer:startBlock()
  72. writer:writeln()
  73. writer:writeln('export class %s', binderName)
  74. writer:startBlock()
  75. writer:writeln('public static bindAll():void')
  76. writer:startBlock()
  77. for i=0,classCnt-1 do
  78. local classInfo = classes[i]
  79. writer:writeln('%s.UIObjectFactory.setPackageItemExtension(%s.URL, %s);', ns, classInfo.className, classInfo.className)
  80. end
  81. writer:endBlock() --bindall
  82. writer:endBlock() --class
  83. writer:endBlock() --namespace
  84. writer:save(exportCodePath..'/'..binderName..'.ts')
  85. end
  86. return genCode