Repository: camel
Updated Branches:
  refs/heads/master e9091d3fc -> bde5691a8


CAMEL-11379: Optimise - core type converters to be invoked faster


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

Branch: refs/heads/master
Commit: cfd4e02db7981c9e65e69e6874731ce33e30ee61
Parents: e9091d3
Author: Claus Ibsen <davscl...@apache.org>
Authored: Thu Jun 29 14:06:02 2017 +0200
Committer: Claus Ibsen <davscl...@apache.org>
Committed: Thu Jun 29 14:06:02 2017 +0200

----------------------------------------------------------------------
 .../converter/ObjectConverterOptimised.java     |  8 ----
 .../TimePatternConverterOptimised.java          | 42 ++++++++++++++++++++
 .../impl/converter/OptimisedTypeConverter.java  |  8 +++-
 3 files changed, 49 insertions(+), 9 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/camel/blob/cfd4e02d/camel-core/src/main/java/org/apache/camel/converter/ObjectConverterOptimised.java
----------------------------------------------------------------------
diff --git 
a/camel-core/src/main/java/org/apache/camel/converter/ObjectConverterOptimised.java
 
b/camel-core/src/main/java/org/apache/camel/converter/ObjectConverterOptimised.java
index 149ca7a..dfbb7d5 100644
--- 
a/camel-core/src/main/java/org/apache/camel/converter/ObjectConverterOptimised.java
+++ 
b/camel-core/src/main/java/org/apache/camel/converter/ObjectConverterOptimised.java
@@ -47,14 +47,6 @@ public final class ObjectConverterOptimised {
             return null;
         }
 
-        // special for String -> long where we support time patterns
-        if (type == long.class || type == Long.class) {
-            Class fromType = value.getClass();
-            if (fromType == String.class) {
-                return TimePatternConverter.toMilliSeconds(value.toString());
-            }
-        }
-
         if (type == boolean.class || type == Boolean.class) {
             return ObjectConverter.toBoolean(value);
         } else if (type == int.class || type == Integer.class) {

http://git-wip-us.apache.org/repos/asf/camel/blob/cfd4e02d/camel-core/src/main/java/org/apache/camel/converter/TimePatternConverterOptimised.java
----------------------------------------------------------------------
diff --git 
a/camel-core/src/main/java/org/apache/camel/converter/TimePatternConverterOptimised.java
 
b/camel-core/src/main/java/org/apache/camel/converter/TimePatternConverterOptimised.java
new file mode 100644
index 0000000..bb45a40
--- /dev/null
+++ 
b/camel-core/src/main/java/org/apache/camel/converter/TimePatternConverterOptimised.java
@@ -0,0 +1,42 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.camel.converter;
+
+import org.apache.camel.Exchange;
+
+/**
+ * Optimised {@link TimePatternConverter}
+ */
+public final class TimePatternConverterOptimised {
+
+    private TimePatternConverterOptimised() {
+    }
+
+    public static Object convertTo(final Class<?> type, final Exchange 
exchange, final Object value) throws Exception {
+        // special for String -> long where we support time patterns
+        if (type == long.class || type == Long.class) {
+            Class fromType = value.getClass();
+            if (fromType == String.class) {
+                return TimePatternConverter.toMilliSeconds(value.toString());
+            }
+        }
+
+        // no optimised type converter found
+        return null;
+    }
+
+}

http://git-wip-us.apache.org/repos/asf/camel/blob/cfd4e02d/camel-core/src/main/java/org/apache/camel/impl/converter/OptimisedTypeConverter.java
----------------------------------------------------------------------
diff --git 
a/camel-core/src/main/java/org/apache/camel/impl/converter/OptimisedTypeConverter.java
 
b/camel-core/src/main/java/org/apache/camel/impl/converter/OptimisedTypeConverter.java
index 9280793..df774f8 100644
--- 
a/camel-core/src/main/java/org/apache/camel/impl/converter/OptimisedTypeConverter.java
+++ 
b/camel-core/src/main/java/org/apache/camel/impl/converter/OptimisedTypeConverter.java
@@ -22,6 +22,7 @@ import org.apache.camel.Exchange;
 import org.apache.camel.converter.IOConverterOptimised;
 import org.apache.camel.converter.NIOConverterOptimised;
 import org.apache.camel.converter.ObjectConverterOptimised;
+import org.apache.camel.converter.TimePatternConverterOptimised;
 
 /**
  * Optimised type converter for performing the most common conversions using 
the type converters
@@ -52,7 +53,12 @@ public class OptimisedTypeConverter {
         Object answer;
 
         // use the optimised type converters and use them in the most commonly 
used order
-        answer = ObjectConverterOptimised.convertTo(type, exchange, value);
+
+        // we need time pattern first as it can do a special String -> long 
conversion which should happen first
+        answer = TimePatternConverterOptimised.convertTo(type, exchange, 
value);
+        if (answer == null) {
+            answer = ObjectConverterOptimised.convertTo(type, exchange, value);
+        }
         if (answer == null) {
             answer = IOConverterOptimised.convertTo(type, exchange, value);
         }

Reply via email to