Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Scala Macro Tools
提交
83a835c8
S
Scala Macro Tools
项目概览
梦境迷离
/
Scala Macro Tools
上一次同步 1 年多
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
Scala Macro Tools
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
83a835c8
编写于
8月 04, 2021
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactor
上级
011e058b
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
25 addition
and
31 deletion
+25
-31
src/main/scala/io/github/dreamylost/macros/AbstractMacroProcessor.scala
.../io/github/dreamylost/macros/AbstractMacroProcessor.scala
+14
-21
src/main/scala/io/github/dreamylost/macros/applyMacro.scala
src/main/scala/io/github/dreamylost/macros/applyMacro.scala
+1
-1
src/main/scala/io/github/dreamylost/macros/builderMacro.scala
...main/scala/io/github/dreamylost/macros/builderMacro.scala
+9
-8
src/main/scala/io/github/dreamylost/macros/jsonMacro.scala
src/main/scala/io/github/dreamylost/macros/jsonMacro.scala
+1
-1
未找到文件。
src/main/scala/io/github/dreamylost/macros/AbstractMacroProcessor.scala
浏览文件 @
83a835c8
...
...
@@ -22,6 +22,8 @@
package
io.github.dreamylost.macros
import
scala.reflect.macros.whitebox
import
java.time.ZonedDateTime
import
java.time.format.DateTimeFormatter
/**
*
...
...
@@ -85,7 +87,7 @@ abstract class AbstractMacroProcessor(val c: whitebox.Context) {
def
printTree
(
force
:
Boolean
,
resTree
:
Tree
)
:
Unit
=
{
c
.
info
(
c
.
enclosingPosition
,
"\n###### Expanded macro ######\n"
+
resTree
.
toString
()
+
"\n###### Expanded macro
######\n"
,
s
"\n###### Time: ${ZonedDateTime.now().format(DateTimeFormatter.ISO_ZONED_DATE_TIME)} Expanded macro start ######\n"
+
resTree
.
toString
()
+
"\n###### Expanded macro end
######\n"
,
force
=
force
)
}
...
...
@@ -201,32 +203,23 @@ abstract class AbstractMacroProcessor(val c: whitebox.Context) {
}
/**
* Modify companion object
s
.
* Modify companion object
or object
.
*
* @param compDeclOpt
* @param codeBlock
* @param codeBlock
s
* @param className
* @return
*/
def
modifiedCompanion
(
def
appendModuleBody
(
compDeclOpt
:
Option
[
ModuleDef
],
codeBlock
:
Tree
,
className
:
TypeName
)
:
Tree
=
{
compDeclOpt
map
{
compDecl
=>
val
q
"$mods object $obj extends ..$bases { ..$body }"
=
compDecl
val
o
=
q
"""
$mods object $obj extends ..$bases {
..$body
..$codeBlock
}
"""
c
.
info
(
c
.
enclosingPosition
,
s
"modifiedCompanion className: $className, exists obj: $o"
,
force
=
true
)
o
}
getOrElse
{
// Create a companion object with the builder
val
o
=
q
"object ${className.toTermName} { ..$codeBlock }"
c
.
info
(
c
.
enclosingPosition
,
s
"modifiedCompanion className: $className, new obj: $o"
,
force
=
true
)
o
codeBlocks
:
List
[
Tree
],
className
:
TypeName
)
:
Tree
=
{
compDeclOpt
.
fold
(
q
"object ${className.toTermName} { ..$codeBlocks }"
)
{
compDecl
=>
c
.
info
(
c
.
enclosingPosition
,
s
"appendModuleBody className: $className, exists obj: $compDecl"
,
force
=
true
)
val
ModuleDef
(
mods
,
name
,
impl
)
=
compDecl
val
Template
(
parents
,
self
,
body
)
=
impl
val
newImpl
=
Template
(
parents
,
self
,
body
++
codeBlocks
)
ModuleDef
(
mods
,
name
,
newImpl
)
}
}
...
...
src/main/scala/io/github/dreamylost/macros/applyMacro.scala
浏览文件 @
83a835c8
...
...
@@ -46,7 +46,7 @@ object applyMacro {
override
def
createCustomExpr
(
classDecl
:
ClassDef
,
compDeclOpt
:
Option
[
ModuleDef
]
=
None
)
:
Any
=
{
val
classDefinition
=
mapToClassDeclInfo
(
classDecl
)
val
apply
=
getApplyMethodWithCurrying
(
classDefinition
.
className
,
classDefinition
.
classParamss
,
classDefinition
.
classTypeParams
)
val
compDecl
=
modifiedCompanion
(
compDeclOpt
,
apply
,
classDefinition
.
className
)
val
compDecl
=
appendModuleBody
(
compDeclOpt
,
List
(
apply
)
,
classDefinition
.
className
)
c
.
Expr
(
q
"""
$classDecl
...
...
src/main/scala/io/github/dreamylost/macros/builderMacro.scala
浏览文件 @
83a835c8
...
...
@@ -58,31 +58,32 @@ object builderMacro {
valDefMapTo
(
field
.
asInstanceOf
[
ValDef
])
}
private
def
getBuilderClassAndMethod
(
typeName
:
TypeName
,
fieldss
:
List
[
List
[
Tree
]],
classTypeParams
:
List
[
Tree
],
isCase
:
Boolean
)
:
Tree
=
{
private
def
getBuilderClassAndMethod
(
typeName
:
TypeName
,
fieldss
:
List
[
List
[
Tree
]],
classTypeParams
:
List
[
Tree
],
isCase
:
Boolean
)
:
List
[
Tree
]
=
{
val
fields
=
fieldss
.
flatten
val
builderClassName
=
getBuilderClassName
(
typeName
)
val
builderFieldMethods
=
fields
.
map
(
f
=>
getFieldSetMethod
(
typeName
,
f
,
classTypeParams
))
val
builderFieldDefinitions
=
fields
.
map
(
f
=>
getFieldDefinition
(
f
))
val
returnTypeParams
=
extractClassTypeParamsTypeName
(
classTypeParams
)
q
""
"
def builder[..$classTypeParams](): $builderClassName[..$returnTypeParams] = new $builderClassName()
class $builderClassName[..$classTypeParams] {
val
builderMethod
=
q
"def builder[..$classTypeParams](): $builderClassName[..$returnTypeParams] = new $builderClassName()
"
val
buulderClass
=
q
"""
class $builderClassName[..$classTypeParams] {
..$builderFieldDefinitions
..$builderFieldMethods
def build(): $typeName[..$returnTypeParams] = ${getConstructorWithCurrying(typeName, fieldss, isCase)}
}
"""
}
"""
List
(
builderMethod
,
buulderClass
)
}
override
def
createCustomExpr
(
classDecl
:
ClassDef
,
compDeclOpt
:
Option
[
ModuleDef
]
=
None
)
:
Any
=
{
val
classDefinition
=
mapToClassDeclInfo
(
classDecl
)
val
builder
=
getBuilderClassAndMethod
(
classDefinition
.
className
,
classDefinition
.
classParamss
,
classDefinition
.
classTypeParams
,
isCaseClass
(
classDecl
))
val
compDecl
=
modifiedCompanion
(
compDeclOpt
,
builder
,
classDefinition
.
className
)
val
compDecl
=
appendModuleBody
(
compDeclOpt
,
builder
,
classDefinition
.
className
)
// Return both the class and companion object declarations
c
.
Expr
(
q
"""
...
...
src/main/scala/io/github/dreamylost/macros/jsonMacro.scala
浏览文件 @
83a835c8
...
...
@@ -56,7 +56,7 @@ object jsonMacro {
override
def
createCustomExpr
(
classDecl
:
c.universe.ClassDef
,
compDeclOpt
:
Option
[
c.universe.ModuleDef
])
:
Any
=
{
val
classDefinition
=
mapToClassDeclInfo
(
classDecl
)
val
format
=
jsonFormatter
(
classDefinition
.
className
,
classDefinition
.
classParamss
.
flatten
)
val
compDecl
=
modifiedCompanion
(
compDeclOpt
,
format
,
classDefinition
.
className
)
val
compDecl
=
appendModuleBody
(
compDeclOpt
,
List
(
format
)
,
classDefinition
.
className
)
// Return both the class and companion object declarations
c
.
Expr
(
q
"""
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录