diff options
author | Den Shabalin <den.shabalin@gmail.com> | 2013-09-02 16:01:38 +0200 |
---|---|---|
committer | Den Shabalin <den.shabalin@gmail.com> | 2013-09-05 20:42:09 +0200 |
commit | 1352fea1c4ecfa0fd66ff1d5ad6e0ee437b1a59f (patch) | |
tree | c66d11c9b21a29a7601fedb4d8ad163dad0fa5cf /src/reflect/scala/reflect/internal/TreeGen.scala | |
parent | 73a4f172c3b4f2c7d8bf9936898f031d09899cef (diff) | |
download | scala-1352fea1c4ecfa0fd66ff1d5ad6e0ee437b1a59f.tar.gz scala-1352fea1c4ecfa0fd66ff1d5ad6e0ee437b1a59f.tar.bz2 scala-1352fea1c4ecfa0fd66ff1d5ad6e0ee437b1a59f.zip |
first-class early def splicing and extraction support
Diffstat (limited to 'src/reflect/scala/reflect/internal/TreeGen.scala')
-rw-r--r-- | src/reflect/scala/reflect/internal/TreeGen.scala | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/reflect/scala/reflect/internal/TreeGen.scala b/src/reflect/scala/reflect/internal/TreeGen.scala index 648c921eb7..66345b7d0b 100644 --- a/src/reflect/scala/reflect/internal/TreeGen.scala +++ b/src/reflect/scala/reflect/internal/TreeGen.scala @@ -14,7 +14,8 @@ abstract class TreeGen extends macros.TreeBuilder { def rootScalaDot(name: Name) = Select(rootId(nme.scala_) setSymbol ScalaPackage, name) def scalaDot(name: Name) = Select(Ident(nme.scala_) setSymbol ScalaPackage, name) def scalaAnnotationDot(name: Name) = Select(scalaDot(nme.annotation), name) - def scalaAnyRefConstr = scalaDot(tpnme.AnyRef) setSymbol AnyRefClass // used in ide + def scalaAnyRefConstrRaw = scalaDot(tpnme.AnyRef) + def scalaAnyRefConstr = scalaAnyRefConstrRaw setSymbol AnyRefClass // used in ide def scalaFunctionConstr(argtpes: List[Tree], restpe: Tree, abstractFun: Boolean = false): Tree = { val cls = if (abstractFun) @@ -380,6 +381,17 @@ abstract class TreeGen extends macros.TreeBuilder { global.Template(parents, self, gvdefs ::: fieldDefs ::: constr ++: etdefs ::: rest) } + def mkParents(ownerMods: Modifiers, parents: List[Tree], parentPos: Position = NoPosition) = + if (ownerMods.isCase) parents ::: List(scalaDot(tpnme.Product), scalaDot(tpnme.Serializable)) + else if (parents.isEmpty) atPos(parentPos)(scalaAnyRefConstrRaw) :: Nil + else parents + + def mkClassDef(mods: Modifiers, name: TypeName, tparams: List[TypeDef], templ: Template): ClassDef = { + val isInterface = mods.isTrait && (templ.body forall treeInfo.isInterfaceMember) + val mods1 = if (isInterface) (mods | Flags.INTERFACE) else mods + ClassDef(mods1, name, tparams, templ) + } + /** Create positioned tree representing an object creation <new parents { stats } * @param npos the position of the new * @param cpos the position of the anonymous class starting with parents |