summaryrefslogblamecommitdiff
path: root/src/repl/scala/tools/nsc/interpreter/ReplStrings.scala
blob: 43da5c6f1204505699f760493281ef86f6803126 (plain) (tree)
1
2
3
4
5
6
7
8
9
                            
                                





                         
                                   

                   


















                                                                       
                                                                         
 
/* NSC -- new Scala compiler
 * Copyright 2005-2013 LAMP/EPFL
 * @author  Paul Phillips
 */

package scala.tools.nsc
package interpreter

import scala.reflect.internal.Chars

trait ReplStrings {
  /** Convert a string into code that can recreate the string.
   *  This requires replacing all special characters by escape
   *  codes. It does not add the surrounding " marks.  */
  def string2code(str: String): String = {
    val res = new StringBuilder
    for (c <- str) c match {
      case '"' | '\'' | '\\'  => res += '\\' ; res += c
      case _ if c.isControl   => res ++= Chars.char2uescape(c)
      case _                  => res += c
    }
    res.toString
  }

  def string2codeQuoted(str: String) =
    "\"" + string2code(str) + "\""

  def any2stringOf(x: Any, maxlen: Int) =
    "scala.runtime.ScalaRunTime.replStringOf(%s, %s)".format(x, maxlen)

  def words(s: String) = (s.trim split "\\s+" filterNot (_ == "")).toList
}