Repository: spark
Updated Branches:
  refs/heads/branch-2.0 b2d0ed287 -> 9b145c664


[SPARK-17424] Fix unsound substitution bug in ScalaReflection.

## What changes were proposed in this pull request?

This method gets a type's primary constructor and fills in type parameters with 
concrete types. For example, `MapPartitions[T, U] -> MapPartitions[Int, 
String]`. This Substitution fails when the actual type args are empty because 
they are still unknown. Instead, when there are no resolved types to subsitute, 
this returns the original args with unresolved type parameters.
## How was this patch tested?

This doesn't affect substitutions where the type args are determined. This 
fixes our case where the actual type args are empty and our job runs 
successfully.

Author: Ryan Blue <[email protected]>

Closes #15062 from rdblue/SPARK-17424-fix-unsound-reflect-substitution.

(cherry picked from commit b23693390781a99ff9248ea07a22e68884ffc747)
Signed-off-by: Wenchen Fan <[email protected]>


Project: http://git-wip-us.apache.org/repos/asf/spark/repo
Commit: http://git-wip-us.apache.org/repos/asf/spark/commit/9b145c66
Tree: http://git-wip-us.apache.org/repos/asf/spark/tree/9b145c66
Diff: http://git-wip-us.apache.org/repos/asf/spark/diff/9b145c66

Branch: refs/heads/branch-2.0
Commit: 9b145c6644d832c55ca4ff5abfd2e00d0bf01d59
Parents: b2d0ed2
Author: Ryan Blue <[email protected]>
Authored: Fri May 12 20:38:36 2017 +0800
Committer: Wenchen Fan <[email protected]>
Committed: Fri May 12 20:39:43 2017 +0800

----------------------------------------------------------------------
 .../org/apache/spark/sql/catalyst/ScalaReflection.scala | 12 ++++++++++--
 1 file changed, 10 insertions(+), 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/spark/blob/9b145c66/sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/ScalaReflection.scala
----------------------------------------------------------------------
diff --git 
a/sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/ScalaReflection.scala
 
b/sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/ScalaReflection.scala
index dd36468..c10894f 100644
--- 
a/sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/ScalaReflection.scala
+++ 
b/sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/ScalaReflection.scala
@@ -797,8 +797,16 @@ trait ScalaReflection {
   def getConstructorParameters(tpe: Type): Seq[(String, Type)] = {
     val formalTypeArgs = tpe.typeSymbol.asClass.typeParams
     val TypeRef(_, _, actualTypeArgs) = tpe
-    constructParams(tpe).map { p =>
-      p.name.toString -> p.typeSignature.substituteTypes(formalTypeArgs, 
actualTypeArgs)
+    val params = constructParams(tpe)
+    // if there are type variables to fill in, do the substitution 
(SomeClass[T] -> SomeClass[Int])
+    if (actualTypeArgs.nonEmpty) {
+      params.map { p =>
+        p.name.toString -> p.typeSignature.substituteTypes(formalTypeArgs, 
actualTypeArgs)
+      }
+    } else {
+      params.map { p =>
+        p.name.toString -> p.typeSignature
+      }
     }
   }
 


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to