summaryrefslogtreecommitdiffstats
path: root/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java
diff options
context:
space:
mode:
authoradrianocrestani <adrianocrestani@13f79535-47bb-0310-9956-ffa450edef68>2009-06-06 09:18:42 +0000
committeradrianocrestani <adrianocrestani@13f79535-47bb-0310-9956-ffa450edef68>2009-06-06 09:18:42 +0000
commit8f34ff7c71819472d7b2f023b8ecb04da97d2655 (patch)
treeefe54ad5daf1f6aa176abab2641bfdf007f167d9 /branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java
parent6a9f8b2718697d444e4413166465cf2c5f1ef533 (diff)
-applying patch tuscany_2552_phillipe_ramalho_06_04_2009.patch from TUSCANY-2552
-adding domain-search to modules/pom.xml git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@782215 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to '')
-rw-r--r--branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java106
1 files changed, 106 insertions, 0 deletions
diff --git a/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java b/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java
new file mode 100644
index 0000000000..27e1e9b087
--- /dev/null
+++ b/branches/sca-java-1.x/modules/domain-search/src/main/java/org/apache/tuscany/sca/domain/search/impl/CompositeDocumentProcessor.java
@@ -0,0 +1,106 @@
+package org.apache.tuscany.sca.domain.search.impl;
+
+import javax.xml.namespace.QName;
+
+import org.apache.lucene.document.Field;
+import org.apache.tuscany.sca.assembly.Component;
+import org.apache.tuscany.sca.assembly.Composite;
+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 CompositeDocumentProcessor implements DocumentProcessor {
+
+ public Document process(DocumentProcessorsMap processors,
+ DocumentMap documents, Object object, Document doc, String parent) {
+
+ if (object instanceof Composite) {
+ Composite composite = (Composite) object;
+ String uri = composite.getURI();
+ QName name = composite.getName();
+
+ uri = (uri == null ? "" : uri) + (name == null ? "" : name.toString());
+
+ if (uri.length() == 0) {
+ uri = null;
+
+ } else if (doc == null) {
+ doc = documents.get(uri);
+ parent += DomainPathAnalyzer.PATH_SEPARATOR + SearchFields.COMPOSITE_FIELD + DomainPathAnalyzer.TYPE_SEPARATOR + uri;
+
+ }
+
+ for (Component component : composite.getComponents()) {
+
+
+ Document componentDoc = processors.process(processors,
+ documents, component, null, parent);
+
+ if (uri != null) {
+
+ componentDoc.add(new Field(SearchFields.PARENT_FIELD, parent,
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ }
+
+ if (uri != null) {
+
+ doc.add(new Field(SearchFields.COMPOSITE_FIELD, uri.toString(),
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ for (Composite include : composite.getIncludes()) {
+ Document compositeDoc = processors.process(processors,
+ documents, include, null, parent);
+
+ if (uri != null) {
+
+ compositeDoc.add(new Field(SearchFields.INCLUDEDBY_FIELD,
+ uri, Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ }
+
+ for (Component component : composite.getComponents()) {
+ Document componentDoc = processors.process(processors,
+ documents, component, null, parent);
+
+ if (uri != null) {
+
+ componentDoc.add(new Field(SearchFields.PARENT_FIELD, parent,
+ Field.Store.YES, Field.Index.ANALYZED));
+
+ }
+
+ }
+
+ return doc == null ? FAKE_DOCUMENT : doc;
+
+ }
+
+ throw new IllegalArgumentException();
+
+ }
+
+ public Object getDocumentKey(Object object) {
+
+ if (object instanceof Composite) {
+ Composite composite = (Composite) object;
+ String uri = composite.getURI();
+ QName name = composite.getName();
+
+ uri = (uri == null ? "" : uri) + (name == null ? "" : name.toString());
+
+ return uri.length() == 0 ? null : uri;
+
+ }
+
+ throw new IllegalArgumentException();
+
+ }
+
+}