Packages

o

bloop.io

ClasspathHasher

object ClasspathHasher

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. ClasspathHasher
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  6. def containsMacroDefinition(classpath: Seq[File]): Task[Seq[(File, Boolean)]]
  7. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  8. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  9. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  10. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  11. def hash(classpath: Array[AbsolutePath], parallelUnits: Int, cancelCompilation: Promise[Unit], scheduler: Scheduler, logger: Logger, tracer: BraveTracer, serverOut: PrintStream): Task[Either[Unit, Vector[FileHash]]]

    Hash the classpath in parallel with Monix's task.

    Hash the classpath in parallel with Monix's task.

    The hashing works in two steps: first, we try to acquire the hash of a given entry. This "negotiation" step is required because we may be hashing other project's classpath concurrently and we want to minimize stalling and make as much progress as we can hashing. Those entries whose hashing couldn't be "acquired" are left to the second step, which blocks until the ongoing hashing finishes.

    This approach allows us to control how many concurrent tasks we spawn to new threads (and, therefore, how many threads we create in the io pool) and, at the same time, allows us to do as much progress without blocking.

    NOTE: When the task returned by this method is cancelled, the promise cancelCompilation will be completed and the returned value will be empty. The call-site needs to handle the case where cancellation happens.

    classpath

    The list of files to be hashed (if they exist).

    parallelUnits

    The amount of classpath entries we can hash at once.

    cancelCompilation

    A promise that will be completed if task is cancelled.

    scheduler

    The scheduler that should be used for internal Monix usage.

    logger

    The logger where every action will be logged.

    tracer

    A tracer to keep track of timings in Zipkin.

    returns

    A task returning an error if the task was cancelled or a complete list of hashes.

  12. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  13. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  16. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  17. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  18. def toString(): String
    Definition Classes
    AnyRef → Any
  19. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  20. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped