Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Situations when Manifest not available

def bar[T: Manifest](a: Array[T]) = Array.ofDim[T](3)

class Foo

bar(Array(new Foo))  //Array[Foo] = Array(null, null, null)

Manifests seem to exist implicitly for arbitrary types, as shown above.

Since we have a context bound, this implies that there will be some types for which there is no implicit Manifest - what are they?

like image 892
Luigi Plinge Avatar asked Nov 18 '11 23:11

Luigi Plinge


2 Answers

A Manifest has to be "carried" from the point where the concrete type last appears in the source code, all the way through type parameters to the place where it is required.

But everything has a manifest.

like image 73
Daniel C. Sobral Avatar answered Nov 03 '22 01:11

Daniel C. Sobral


I'm not sure that your deduction is correct. I haven't seen types for which there is no manifest, but I have seen situations where the type inferencer doesn't seem able to provide one.

Specifically in nesting inference situations like this:

scala> def bar[T: Manifest](a: Array[T]) = Array.ofDim[T](3)
bar: [T](a: Array[T])(implicit evidence$1: Manifest[T])Array[T]

scala> def bar2[T](a: Array[T]) = bar(a)
<console>:8: error: No Manifest available for T.
   def bar2[T](a: Array[T]) = bar(a)
                                ^

It seems that unless the manifest is 'passed around' it isn't available at the lower level - so that we can say

scala> def bar2[T: Manifest](a: Array[T]) = bar(a)
bar2: [T](a: Array[T])(implicit evidence$1: Manifest[T])Array[T]

or

scala> def bar2[T](a: Array[T])(implicit m: Manifest[T]) = bar(a)
bar2: [T](a: Array[T])(implicit m: Manifest[T])Array[T]

However quite why this is the behaviour I don't know.

like image 44
Duncan McGregor Avatar answered Nov 03 '22 03:11

Duncan McGregor