summaryrefslogtreecommitdiff
path: root/test/files/run/t8199.scala
blob: 50994159ed5083f6558b8b7daf0cd7bcc983ebf3 (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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
class reallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongname {
object obj0
object obj01
object obj012
object obj0123
object obj01234
object obj012345
object obj0123456
object obj01234567
object obj012345678
object obj0123456789
object obj01234567890
class cls0
class cls01
class cls012
class cls0123
class cls01234
class cls012345
class cls0123456
class cls01234567
class cls012345678
class cls0123456789
class cls01234567890
trait trt0 { def x = Test.checkCallerImplClassName() }
trait trt01 { def x = Test.checkCallerImplClassName() }
trait trt012 { def x = Test.checkCallerImplClassName() }
trait trt0123 { def x = Test.checkCallerImplClassName() }
trait trt01234 { def x = Test.checkCallerImplClassName() }
trait trt012345 { def x = Test.checkCallerImplClassName() }
trait trt0123456 { def x = Test.checkCallerImplClassName() }
trait trt01234567 { def x = Test.checkCallerImplClassName() }
trait trt012345678 { def x = Test.checkCallerImplClassName() }
trait trt0123456789 { def x = Test.checkCallerImplClassName() }
trait trt01234567890 { def x = Test.checkCallerImplClassName() }
}

object Test extends App {
  def check(c: Class[_]) {
    checkClassName(c.getName)
  }
  def checkClassName(name: String) {
    val defaultMaxClassFileLength = 255
    assert((name + ".class").length <= defaultMaxClassFileLength, name)
  }
  def checkCallerImplClassName() {
    val name = Thread.currentThread.getStackTrace.apply(2).getClassName
    assert(name.contains("$class"))
    Test.checkClassName(name)
  }

  val c = new reallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongname
  import c._

  check(obj0.getClass)
  check(obj01.getClass)
  check(obj012.getClass)
  check(obj0123.getClass)
  check(obj01234.getClass)
  check(obj012345.getClass)
  check(obj0123456.getClass)
  check(obj01234567.getClass)
  check(obj012345678.getClass)
  check(obj0123456789.getClass)
  check(obj01234567890.getClass)

  check(classOf[cls0])
  check(classOf[cls01])
  check(classOf[cls012])
  check(classOf[cls0123])
  check(classOf[cls01234])
  check(classOf[cls012345])
  check(classOf[cls0123456])
  check(classOf[cls01234567])
  check(classOf[cls012345678])
  check(classOf[cls0123456789])
  check(classOf[cls01234567890])

  // interface facets
  check(classOf[trt0])
  check(classOf[trt01])
  check(classOf[trt012])
  check(classOf[trt0123])
  check(classOf[trt01234])
  check(classOf[trt012345])
  check(classOf[trt0123456])
  check(classOf[trt01234567])
  check(classOf[trt012345678])
  check(classOf[trt0123456789])
  check(classOf[trt01234567890])

  // impl classes are harder to find the names of to test!
  (new trt0 {}).x
  (new trt01 {}).x
  (new trt012 {}).x
  (new trt0123 {}).x
  (new trt01234 {}).x
  (new trt012345 {}).x
  (new trt0123456 {}).x
  (new trt01234567 {}).x
  (new trt012345678 {}).x
  (new trt0123456789 {}).x
  (new trt01234567890 {}).x
}

// filename too long: reallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongnamereallylongname$obj012345$.class