summaryrefslogtreecommitdiff
path: root/src/compiler/scala/tools/nsc/interpreter/Completion.scala
blob: 3436c6631efab89c467d41408552d6c2ec1b4881 (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/* NSC -- new Scala compiler
 * Copyright 2005-2011 LAMP/EPFL
 * @author Paul Phillips
 */

package scala.tools.nsc
package interpreter

import java.util.{ List => JList }

/** An implementation-agnostic completion interface which makes no
 *  reference to the jline classes.
 */
trait Completion {
  type ExecResult
  trait Instance {
    def complete(buffer: String, cursor: Int, candidates: JList[CharSequence]): Int
  }
  def resetVerbosity(): Unit
  def execute(line: String): Option[ExecResult]
  def completer(): Instance
}

object Completion {
  object Empty extends Completion {
    type ExecResult = Nothing
    object NullCompleter extends Instance {
      def complete(buffer: String, cursor: Int, candidates: JList[CharSequence]) = -1
    }
    def resetVerbosity() = ()
    def execute(line: String) = None
    def completer() = NullCompleter
  }
  def looksLikeInvocation(code: String) = (
        (code != null)
    &&  (code startsWith ".")
    && !(code == ".")
    && !(code startsWith "./")
    && !(code startsWith "..")
  )
  def looksLikePath(code: String) = (code != null) && (code.length >= 2) && (
    Set("/", "\\", "./", "../", "~/") exists (code startsWith _)
  )
  object Forwarder {
    def apply(forwardTo: () => Option[CompletionAware]): CompletionAware = new CompletionAware {
      def completions(verbosity: Int) = forwardTo() map (_ completions verbosity) getOrElse Nil
      override def follow(s: String) = forwardTo() flatMap (_ follow s)
    }
  }
}