import scala.collection.jcl.Conversions import java.io.File import java.util.Collections import java.util.jar.{JarEntry,JarFile} object MethodCount { def getClassInformations(l:List[String]):List[Pair[String,Int]] = { def getInfo(n:String):Pair[String,Int] = try { (n, Class.forName(n).getDeclaredMethods.size) } catch { case _ => (n, -1) } def isClass(n:String):Boolean = n.endsWith(".class") && !n.matches("\\$\\$anonfun\\$") def getClassName(n:String):String = n.substring(0, n.length - 6).replace('/', '.') def getJarEntries(f:File):List[JarEntry] = Conversions.convertList(Collections.list((new JarFile(f)).entries)).toList def getFiles(l:List[String]):List[File] = l.map(new File(System.getProperty("scala.home"), _)).filter(_.exists) getFiles(l).map(getJarEntries).flatten(identity(_)).map(_.getName).filter(isClass).map(getClassName).map(getInfo) } def main(args:Array[String]):Unit = { val l:List[Pair[String,Int]] = getClassInformations(List("lib/scala-library.jar", "lib/scala-swing.jar")) Console.printf("total:\t%d\n", l.size) l.sort(_._2 > _._2).take(10).foreach((i) => Console.printf("%s:\t%d\n", i._1, i._2)) } }