Author: tallison
Date: Thu Oct 23 15:46:09 2014
New Revision: 1633846

URL: http://svn.apache.org/r1633846
Log:
move pretty print metadata key sorter into standalone class, with added 
PrettyMetadataKeyComparator...argh

Added:
    
tika/trunk/tika-serialization/src/main/java/org/apache/tika/metadata/serialization/PrettyMetadataKeyComparator.java

Added: 
tika/trunk/tika-serialization/src/main/java/org/apache/tika/metadata/serialization/PrettyMetadataKeyComparator.java
URL: 
http://svn.apache.org/viewvc/tika/trunk/tika-serialization/src/main/java/org/apache/tika/metadata/serialization/PrettyMetadataKeyComparator.java?rev=1633846&view=auto
==============================================================================
--- 
tika/trunk/tika-serialization/src/main/java/org/apache/tika/metadata/serialization/PrettyMetadataKeyComparator.java
 (added)
+++ 
tika/trunk/tika-serialization/src/main/java/org/apache/tika/metadata/serialization/PrettyMetadataKeyComparator.java
 Thu Oct 23 15:46:09 2014
@@ -0,0 +1,44 @@
+package org.apache.tika.metadata.serialization;
+
+/*
+* 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.
+*/
+
+public class PrettyMetadataKeyComparator implements 
java.util.Comparator<String> {
+    @Override
+    public int compare(String s1, String s2) {
+        if (s1 == null) {
+            return 1;
+        } else if (s2 == null) {
+            return -1;
+        }
+
+        //this is stinky.  This should reference 
RecursiveParserWrapper.TIKA_CONTENT
+        //but that would require making core a dependency of serialization...
+        //do we want to do that?
+        if (s1.equals("tika:content")) {
+            if (s2.equals("tika:content")) {
+                return 0;
+            }
+            return 2;
+        } else if (s2.equals("tika:content")) {
+            return -2;
+        }
+        //do we want to lowercase?
+        return s1.compareTo(s2);
+    }
+}
+


Reply via email to