blob: eaf736c5b74f54e7676228d72bbe84ba41332830 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
/* NSC -- new Scala compiler
* Copyright 2005-2010 LAMP/EPFL
* @author Paul Phillips
*/
package scala.tools.nsc
package object interpreter {
/** Tracing */
def tracing[T](msg: String)(x: T): T = { println("(" + msg + ") " + x) ; x }
/** Frequency counter */
def freq[T](seq: Seq[T]) = seq groupBy identity mapValues (_.length)
/** null becomes "", otherwise identity */
def onull(s: String) = if (s == null) "" else s
/** Heuristically strip interpreter wrapper prefixes
* from an interpreter output string.
*/
def stripWrapperGunk(str: String): String = {
val wrapregex = """(line[0-9]+\$object[$.])?(\$iw[$.])*"""
str.replaceAll(wrapregex, "")
}
/** Class objects */
def classForName(name: String): Option[Class[_]] =
try Some(Class forName name)
catch { case _: ClassNotFoundException | _: SecurityException => None }
}
|