olabusayoT commented on a change in pull request #273: WIP: Add User Defined 
Functions Capability
URL: https://github.com/apache/incubator-daffodil/pull/273#discussion_r333669489
 
 

 ##########
 File path: 
daffodil-core/src/main/scala/org/apache/daffodil/dpath/Expression.scala
 ##########
 @@ -1870,6 +1871,47 @@ case class FunctionCallExpression(functionQNameString: 
String, expressions: List
       case (RefQName(_, "unsignedByte", XSD), args) =>
         XSConverterExpr(functionQNameString, functionQName, args, 
NodeInfo.UnsignedByte)
 
+      case (RefQName(Some(_), _, _), args) => {
+        val namespace = functionQName.namespace.toString()
+        val fName = functionQName.local
+
+        lazy val udfservice = {
+          val a = UDFService
+          a.warnings.map { w => SDW(WarnID.UserDefinedFunction, w) }
+          val allErrors = a.errors.mkString("\n\n")
+          SDE(s"Function unknown: fname[${fName}] 
fnamespace[${namespace}].\n$allErrors")
+          a
+        }
+
+        val fcObject = udfservice.udfs.lookupFunctionClass(namespace, fName)
+
+        if (fcObject == null) {
+          SDE("Function not found: fname[%s] fnamespace[%s]. Currently 
registered UDFs:\n%s", fName, namespace, udfservice.allFunctionClasses)
+        }
+
+        val fcClassType = fcObject.getClass
+
+        val paramTypesReturnTypeTuple: Array[(Array[Class[_]], Class[_])] = 
fcClassType.getMethods.collect {
+          case p if p.getName == "evaluate" => (p.getParameterTypes, 
p.getReturnType)
+        }
+
+        if (paramTypesReturnTypeTuple.isEmpty) {
+          SDE("Missing evaluate method for function provided: name[%s] 
namespace[%s]", fName, namespace)
+        }
+
+        if (paramTypesReturnTypeTuple.length > 1) {
+          SDE("Only one evaluate method allowed per function class: name[%s] 
namespace[%s]", fName, namespace)
+        }
+
+        val paramTypes: Array[Class[_]] = paramTypesReturnTypeTuple.head._1
+        val retType: Class[_] = paramTypesReturnTypeTuple.head._2
+
 
 Review comment:
   So there's no restriction on the number of param types currently. The 
restriction is really on the number of the evaluate functions found. So in the 
case of no arg type, there would be a tuple returned of an Empty List and 
whatever the return type is. 
   
   There is also a restriction on having no return type, as I can't really see 
any advantage to supporting the void class. Thoughts?

----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
 
For queries about this service, please contact Infrastructure at:
[email protected]


With regards,
Apache Git Services

Reply via email to