Packages

p

breeze

macros

package macros

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

Type Members

  1. macro class arityize extends Annotation with StaticAnnotation

    An annotation for code generating up to 22 replicas a la Tuples.

    An annotation for code generating up to 22 replicas a la Tuples.

    Annotations
    @compileTimeOnly( ... )
  2. class expand extends Annotation with StaticAnnotation

    expand is a macro annotation that is kind of like @specialized, but it's more of a templating mechanism.

    expand is a macro annotation that is kind of like @specialized, but it's more of a templating mechanism. It is pretty... alpha in that the functionality is basically there, but it is now in the least bit battle tested. Don't ask much of it, and it will do fine, ask a lot, and well...

    Basically, expand takes a def with type arguments whose types are annotated with breeze.macros.expand.args and generates the cross product of all combinations. For example:

    @expand
    def foo[@expandArgs(Int, Double) T, @expandArgs(Int, Double) U](x: T, y: U) = x + y

    will generate

    def foo_T_Int_U_Int(x: Int, y: Int) = x + y
    def foo_T_Int_U_Double(x: Int, y: Double) = x + y
    def foo_T_Double_U_Int(x: Double, y: Int) = x + y
    def foo_T_Double_U_Double(x: Double, y: Double) = x + y

    The real power comes from breeze.macros.expand.sequence, which annotates an argument to the method to correlate with a type (the first argument to sequence) and then a sequence of trees which are inlined in place of references to the argument. For example:

    @expand
    def foo[@expandArgs(Int, Double) T](x: T, y: T)(implicit @sequence(T)({_ + _}, {_ * _}) op: XXX) = op(x,y)
    /* The type of op is unimportant, though giving it a "real" type is useful. */

    will generate

    def foo_T_Int(x: Int, y: Int) = x + y
    def foo_T_Double(x: Double, y: Double) = x * y

    See breeze.linalg.DenseVectorOps for a more complete example.

    Annotations
    @compileTimeOnly( ... )

Value Members

  1. macro def assert(condition: Boolean, message: String): Unit
  2. macro def assert(condition: Boolean): Unit
  3. macro def assume(condition: Boolean, message: String): Unit
  4. macro def assume(condition: Boolean): Unit
  5. macro def cforRange(r: Range)(body: (Int) ⇒ Unit): Unit
  6. macro def cforRange2(r1: Range, r2: Range)(body: (Int, Int) ⇒ Unit): Unit
  7. macro def require(condition: Boolean, message: String): Unit
  8. macro def require(condition: Boolean): Unit
  9. object AssertImpl
  10. object arityize
  11. object expand

Inherited from AnyRef

Inherited from Any

Ungrouped