summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIulian Dragos <jaguarul@gmail.com>2008-12-17 14:09:49 +0000
committerIulian Dragos <jaguarul@gmail.com>2008-12-17 14:09:49 +0000
commitfef6bc4f30f7421851a414d92153a209699c8b97 (patch)
tree3dca462c7e4dc2ad541b940de4e93a504a8d757f
parentaf7c1282930008c6f69b87c93aa2d4460e2c4ff0 (diff)
downloadscala-fef6bc4f30f7421851a414d92153a209699c8b97.tar.gz
scala-fef6bc4f30f7421851a414d92153a209699c8b97.tar.bz2
scala-fef6bc4f30f7421851a414d92153a209699c8b97.zip
Fixed warnings.
-rw-r--r--src/compiler/scala/tools/nsc/backend/icode/Checkers.scala2
-rw-r--r--src/compiler/scala/tools/nsc/backend/icode/Opcodes.scala3
-rw-r--r--src/compiler/scala/tools/nsc/backend/icode/analysis/CopyPropagation.scala2
-rw-r--r--src/compiler/scala/tools/nsc/backend/icode/analysis/TypeFlowAnalysis.scala2
-rw-r--r--src/compiler/scala/tools/nsc/backend/msil/GenMSIL.scala2
5 files changed, 6 insertions, 5 deletions
diff --git a/src/compiler/scala/tools/nsc/backend/icode/Checkers.scala b/src/compiler/scala/tools/nsc/backend/icode/Checkers.scala
index dc435bd2e9..d04eb308f8 100644
--- a/src/compiler/scala/tools/nsc/backend/icode/Checkers.scala
+++ b/src/compiler/scala/tools/nsc/backend/icode/Checkers.scala
@@ -422,7 +422,7 @@ abstract class Checkers {
case CALL_METHOD(method, style) =>
style match {
- case Dynamic =>
+ case Dynamic | InvokeDynamic =>
checkStack(1 + method.info.paramTypes.length)
checkMethodArgs(method)
checkMethod(stack.pop, method)
diff --git a/src/compiler/scala/tools/nsc/backend/icode/Opcodes.scala b/src/compiler/scala/tools/nsc/backend/icode/Opcodes.scala
index 9b11c588d0..923481b1c4 100644
--- a/src/compiler/scala/tools/nsc/backend/icode/Opcodes.scala
+++ b/src/compiler/scala/tools/nsc/backend/icode/Opcodes.scala
@@ -314,7 +314,7 @@ trait Opcodes { self: ICodes =>
override def consumed = {
var result = method.tpe.paramTypes.length;
result = result + (style match {
- case Dynamic => 1
+ case Dynamic | InvokeDynamic => 1
case Static(true) => 1
case Static(false) => 0
case SuperCall(_) => 1
@@ -624,6 +624,7 @@ trait Opcodes { self: ICodes =>
/** Returns a string representation of this style. */
override def toString(): String = this match {
case Dynamic => "dynamic"
+ case InvokeDynamic => "invoke-dynamic"
case Static(false) => "static-class"
case Static(true) => "static-instance"
case SuperCall(mix) => "super(" + mix + ")"
diff --git a/src/compiler/scala/tools/nsc/backend/icode/analysis/CopyPropagation.scala b/src/compiler/scala/tools/nsc/backend/icode/analysis/CopyPropagation.scala
index 9b9b58c39b..0981d858c4 100644
--- a/src/compiler/scala/tools/nsc/backend/icode/analysis/CopyPropagation.scala
+++ b/src/compiler/scala/tools/nsc/backend/icode/analysis/CopyPropagation.scala
@@ -304,7 +304,7 @@ abstract class CopyPropagation {
out.stack = Unknown :: out.stack.drop(i.consumed)
case CALL_METHOD(method, style) => style match {
- case Dynamic =>
+ case Dynamic | InvokeDynamic =>
out = simulateCall(in, method, false)
case Static(onInstance) =>
diff --git a/src/compiler/scala/tools/nsc/backend/icode/analysis/TypeFlowAnalysis.scala b/src/compiler/scala/tools/nsc/backend/icode/analysis/TypeFlowAnalysis.scala
index 20e473f7b0..12c0dc7742 100644
--- a/src/compiler/scala/tools/nsc/backend/icode/analysis/TypeFlowAnalysis.scala
+++ b/src/compiler/scala/tools/nsc/backend/icode/analysis/TypeFlowAnalysis.scala
@@ -470,7 +470,7 @@ abstract class TypeFlowAnalysis {
}
case CALL_METHOD(method, style) => style match {
- case Dynamic =>
+ case Dynamic | InvokeDynamic =>
stack.pop(1 + method.info.paramTypes.length)
stack.push(toTypeKind(method.info.resultType))
diff --git a/src/compiler/scala/tools/nsc/backend/msil/GenMSIL.scala b/src/compiler/scala/tools/nsc/backend/msil/GenMSIL.scala
index dbabae1387..f1059516be 100644
--- a/src/compiler/scala/tools/nsc/backend/msil/GenMSIL.scala
+++ b/src/compiler/scala/tools/nsc/backend/msil/GenMSIL.scala
@@ -1468,7 +1468,7 @@ abstract class GenMSIL extends SubComponent {
if (doEmit) {
val methodInfo: MethodInfo = getMethod(msym)
- style match {
+ (style: @unchecked) match {
case SuperCall(_) =>
mcode.Emit(OpCodes.Call, methodInfo)
case Dynamic =>