summaryrefslogblamecommitdiff
path: root/test/files/run/elidable.scala
blob: fed1c7b392922f62e6a071626b5796ab3dc80ddf (plain) (tree)
1
2
3
4
5
6
7
8
9
10


                   

                                    




                                                                                          


                            
                                                               





                                                           
                                                               


          

                                                               
                                                                             
                                                                       

 
             

                                                               
                                                                                
                                                                       









                                      
                                                                                                    
 
                                                       


                                                                                  


                                          



                                         
      





















                                                                      












                                                    














                                                                                                    











                                                     

   
import annotation._
import elidable._

// runs -Xelide-below WARNING or 900

object Fail {
  def fail(msg: String): Unit = throw new IllegalStateException(s"Expected failure: $msg")
}
import Fail.fail

trait T {
  @elidable(FINEST) def f1()
  @elidable(SEVERE) def f2()
  @elidable(FINEST) def f3() = fail("Should have been elided.")
  def f4()
}

class C extends T {
  def f1() = println("Good for me, I was not elided. C.f1")
  def f2() = println("Good for me, I was not elided. C.f2")
  @elidable(FINEST) def f4() = fail("Should have been elided.")
}

object O {
  @elidable(FINEST) def f1() = fail("Should have been elided.")
  @elidable(INFO) def f2() = fail("Should have been elided.")
  @elidable(SEVERE) def f3() = println("Good for me, I was not elided. O.f3")
  @elidable(INFO) def f4 = fail("Should have been elided (no parens).")
}

object Test {
  @elidable(FINEST) def f1() = fail("Should have been elided.")
  @elidable(INFO) def f2() = fail("Should have been elided.")
  @elidable(SEVERE) def f3() = println("Good for me, I was not elided. Test.f3")
  @elidable(INFO) def f4 = fail("Should have been elided (no parens).")

  @elidable(FINEST) def f5() = {}
  @elidable(FINEST) def f6() = true
  @elidable(FINEST) def f7() = 1:Byte
  @elidable(FINEST) def f8() = 1:Short
  @elidable(FINEST) def f9() = 1:Char
  @elidable(FINEST) def fa() = 1
  @elidable(FINEST) def fb() = 1l
  @elidable(FINEST) def fc() = 1.0f
  @elidable(FINEST) def fd() = 1.0
  @elidable(FINEST) def fe() = { fail("Should have been elided to empty string.") ; "hello, world" }

  /* variable elisions? see test/files/neg/t10068.scala
  @elidable(INFO) val goner1: Int      = { fail("Should have been elided.") ; 42 }
  @elidable(INFO) lazy val goner2: Int = { fail("Should have been elided.") ; 42 }
  @elidable(INFO) var goner3: Int      = { fail("Should have been elided.") ; 42 }
  @elidable(INFO) var goner4: Nothing  = _
  */

  def main(args: Array[String]): Unit = {
    f1()
    f2()
    f3()
    f4
    O.f1()
    O.f2()
    O.f3()
    O.f4

    val c = new C
    c.f1()
    c.f2()
    c.f3()
    c.f4()

    // make sure a return value is still available when eliding a call
    println(f5())
    println(f6())
    println(f7())
    println(f8())
    println(f9().toInt)
    println(fa())
    println(fb())
    println(fc())
    println(fd())
    println(fe())
    if (!fe().isEmpty) fail(s"Not empty: [${fe()}]")
/*
()
false
0
0
0
0
0
0.0
0.0
   // was: null
*/

    // this one won't show up in the output because a call to f1 is elidable when accessed through T
    (c:T).f1()

    // Test whether the method definitions are still available.
    List("Test", "Test$", "O", "O$", "C", "T") foreach { className =>
      List("f1", "f2", "f3", "f4") foreach { methodName =>
        Class.forName(className).getMethod(methodName)
      }
    }
    List("Test", "Test$") foreach { className =>
      List("f5", "f6", "f7", "f8", "f9", "fa", "fb", "fc", "fd", "fe") foreach { methodName =>
        Class.forName(className).getMethod(methodName)
      }
    }

    // variable elisions?
    /*
    assert(goner1 == 0)
    assert(goner2 == 0)
    assert(goner3 == 0)
    try assert(goner4 == null)
    catch {
      case _: NullPointerException => println("NPE")
      case _: NotImplementedError   => println("NIE")
    }
    */
  }
}