summaryrefslogtreecommitdiffstats
path: root/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/PropertyDocumentProcessor.java
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/PropertyDocumentProcessor.java63
1 files changed, 63 insertions, 0 deletions
diff --git a/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/PropertyDocumentProcessor.java b/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/PropertyDocumentProcessor.java
new file mode 100644
index 0000000000..0a0ff9ceeb
--- /dev/null
+++ b/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/PropertyDocumentProcessor.java
@@ -0,0 +1,63 @@
+package org.apache.tuscany.sca.domain.search.impl;
+
+import java.lang.reflect.Array;
+
+import org.apache.lucene.document.Field;
+import org.apache.tuscany.sca.assembly.Property;
+import org.apache.tuscany.sca.domain.search.DocumentMap;
+import org.apache.tuscany.sca.domain.search.DocumentProcessor;
+import org.apache.tuscany.sca.domain.search.DocumentProcessorsMap;
+
+public class PropertyDocumentProcessor implements DocumentProcessor {
+
+ public Document process(DocumentProcessorsMap processors,
+ DocumentMap documents, Object object, Document doc, String parent) {
+
+ if (object instanceof Property) {
+ Property property = (Property) object;
+ String name = property.getName();
+
+ if (name != null && name.length() > 0) {
+
+ if (doc == null) {
+ doc = documents.get(name);
+ }
+
+ Object value = property.getValue();
+
+ if (value.getClass().isArray()) {
+ int arraySize = Array.getLength(value);
+
+ for (int i = 0; i < arraySize; i++) {
+ Object arrayValue = Array.get(value, i);
+
+ doc.add(new Field(SearchFields.VALUE_FIELD, arrayValue.toString(),
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ } else {
+
+ doc.add(new Field(SearchFields.VALUE_FIELD, value.toString(),
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ return doc == null ? FAKE_DOCUMENT : doc;
+
+ } else {
+ return FAKE_DOCUMENT;
+ }
+
+ }
+
+ throw new IllegalArgumentException();
+
+ }
+
+ public Object getDocumentKey(Object object) {
+ // TODO Auto-generated method stub
+ return null;
+ }
+
+}