summaryrefslogtreecommitdiffstats
path: root/branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java
diff options
context:
space:
mode:
Diffstat (limited to 'branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java')
-rw-r--r--branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java59
1 files changed, 59 insertions, 0 deletions
diff --git a/branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java b/branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java
new file mode 100644
index 0000000000..5d01bec389
--- /dev/null
+++ b/branches/sca-java-1.5.1/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/BindingDocumentProcessor.java
@@ -0,0 +1,59 @@
+package org.apache.tuscany.sca.domain.search.impl;
+
+import org.apache.lucene.document.Field;
+import org.apache.tuscany.sca.assembly.Binding;
+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 BindingDocumentProcessor implements DocumentProcessor {
+
+ public Document process(DocumentProcessorsMap processors,
+ DocumentMap documents, Object object, Document document, String parent) {
+
+ if (object instanceof Binding) {
+ Binding binding = (Binding) object;
+ String uri = binding.getURI();
+
+ if (uri != null && uri.length() == 0) {
+ uri = null;
+ }
+
+ if (uri != null) {
+
+ if (document == null) {
+ document = documents.get(uri);
+ }
+
+ document.add(new Field(SearchFields.BINDING_FIELD, uri,
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ return document == null ? FAKE_DOCUMENT : document;
+
+ }
+
+ throw new IllegalArgumentException();
+
+ }
+
+ public Object getDocumentKey(Object obj) {
+
+ if (obj instanceof Binding) {
+ Binding binding = (Binding) obj;
+ String uri = binding.getURI();
+
+ if (uri != null && uri.length() == 0) {
+ return null;
+ }
+
+ return uri;
+
+ }
+
+ throw new IllegalArgumentException();
+
+ }
+
+}