-
Notifications
You must be signed in to change notification settings - Fork 41
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #870 from ScorexFoundation/restructure-part5
Avoid use of Java Reflection (restructure part 5)
- Loading branch information
Showing
395 changed files
with
3,855 additions
and
3,579 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,4 @@ | ||
|
||
import scala.language.experimental.macros | ||
import scala.reflect.ClassTag | ||
|
||
package object scalan { | ||
|
74 changes: 74 additions & 0 deletions
74
common/src/main/scala/scalan/reflection/CommonReflection.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
package scalan.reflection | ||
|
||
import scala.collection.compat.immutable.ArraySeq | ||
import scala.collection.mutable | ||
import scala.collection.immutable | ||
|
||
/** Reflection metadata and global dictionaries to access it. | ||
* For each class of this module that needs reflection metadata, | ||
* we register a class entry with the necessary information. | ||
* Only information that is needed at runtime is registered. | ||
*/ | ||
object CommonReflection { | ||
/** Descriptors of classes. */ | ||
val classes = mutable.HashMap.empty[Class[_], SRClass[_]] | ||
|
||
/** Registers a class entry in the map of classes. | ||
* | ||
* @tparam T the type of the class to be registered | ||
* @param clazz the class to be registered | ||
* @param constructors the constructors of the class | ||
* @param fields the fields of the class | ||
* @param methods the methods of the class (represented as a map of method names and argument types to the corresponding RMethod instances) | ||
*/ | ||
def registerClassEntry[T](clazz: Class[T], | ||
constructors: Seq[SRConstructor[_]] = ArraySeq.empty, | ||
fields: Map[String, SRField] = Map.empty, | ||
methods: Map[(String, Seq[Class[_]]), RMethod] = Map.empty): Unit = classes.synchronized { | ||
classes.put(clazz, new SRClass(clazz, constructors, fields, methods)) | ||
} | ||
|
||
registerClassEntry(classOf[Boolean]) | ||
|
||
registerClassEntry(classOf[Byte]) | ||
|
||
registerClassEntry(classOf[Short]) | ||
|
||
registerClassEntry(classOf[Int]) | ||
|
||
registerClassEntry(classOf[Long]) | ||
|
||
registerClassEntry(classOf[Product2[_, _]]) | ||
|
||
registerClassEntry(classOf[immutable.$colon$colon[_]], | ||
constructors = Array( | ||
mkConstructor(Array(classOf[java.lang.Object], classOf[immutable.List[_]])) { args => | ||
new immutable.$colon$colon(args(0).asInstanceOf[java.lang.Object], args(1).asInstanceOf[immutable.List[_]]) | ||
} | ||
) | ||
) | ||
|
||
{ val clazz = classOf[scala.Option[_]] | ||
registerClassEntry(clazz, | ||
methods = Map( | ||
mkMethod(clazz, "filter", Array(classOf[scala.Function1[_,_]])) { (obj, args) => | ||
obj.asInstanceOf[Option[Any]].filter(args(0).asInstanceOf[Any => Boolean]) | ||
}, | ||
mkMethod(clazz, "map", Array(classOf[scala.Function1[_,_]])) { (obj, args) => | ||
obj.asInstanceOf[Option[Any]].map(args(0).asInstanceOf[Any => Any]) | ||
} | ||
) | ||
) | ||
} | ||
|
||
{ val clazz = classOf[scala.Some[_]] | ||
registerClassEntry(clazz, | ||
constructors = Array( | ||
mkConstructor(Array(classOf[java.lang.Object])) { args => | ||
new scala.Some(args(0).asInstanceOf[java.lang.Object]) | ||
} | ||
) | ||
) | ||
} | ||
|
||
} |
Oops, something went wrong.