@@ -22,8 +22,8 @@ sealed trait Tuple extends Product {
22
22
runtime.Tuples .toIArray(this )
23
23
24
24
/** Return a copy of `this` tuple with an element appended */
25
- inline def :* [This >: this .type <: Tuple , L ] (x : L ): Append [ This , L ] =
26
- runtime.Tuples .append(x, this ).asInstanceOf [Append [ This , L ] ]
25
+ inline def :* [This >: this .type <: Tuple , L ] (x : L ): This :* L =
26
+ runtime.Tuples .append(x, this ).asInstanceOf [This :* L ]
27
27
28
28
/** Return a new tuple by prepending the element to `this` tuple.
29
29
* This operation is O(this.size)
@@ -58,8 +58,8 @@ sealed trait Tuple extends Product {
58
58
/** Return a new tuple by concatenating `this` tuple with `that` tuple.
59
59
* This operation is O(this.size + that.size)
60
60
*/
61
- inline def ++ [This >: this .type <: Tuple ](that : Tuple ): Concat [ This , that.type ] =
62
- runtime.Tuples .concat(this , that).asInstanceOf [Concat [ This , that.type ] ]
61
+ inline def ++ [This >: this .type <: Tuple ](that : Tuple ): This ++ that.type =
62
+ runtime.Tuples .concat(this , that).asInstanceOf [This ++ that.type ]
63
63
64
64
/** Return the size (or arity) of the tuple */
65
65
inline def size [This >: this .type <: Tuple ]: Size [This ] =
@@ -118,6 +118,9 @@ object Tuple {
118
118
case x *: xs => x *: Append [xs, Y ]
119
119
}
120
120
121
+ /** An infix shorthand for `Append[X, Y]` */
122
+ infix type :* [X <: Tuple , Y ] = Append [X , Y ]
123
+
121
124
/** Type of the head of a tuple */
122
125
type Head [X <: Tuple ] = X match {
123
126
case x *: _ => x
@@ -147,6 +150,9 @@ object Tuple {
147
150
case x1 *: xs1 => x1 *: Concat [xs1, Y ]
148
151
}
149
152
153
+ /** An infix shorthand for `Concat[X, Y]` */
154
+ infix type ++ [X <: Tuple , + Y <: Tuple ] = Concat [X , Y ]
155
+
150
156
/** Type of the element at position N in the tuple X */
151
157
type Elem [X <: Tuple , N <: Int ] = X match {
152
158
case x *: xs =>
0 commit comments