Project

General

Profile

Download (4.05 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
* Copyright (C) 2007 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/
9
package eu.etaxonomy.cdm.io.dwca.in;
10

    
11
import java.util.ArrayList;
12
import java.util.List;
13
import java.util.Map;
14
import java.util.Set;
15

    
16
import org.apache.log4j.Logger;
17

    
18
import eu.etaxonomy.cdm.io.dwca.TermUri;
19
import eu.etaxonomy.cdm.io.stream.StreamImportBase;
20
import eu.etaxonomy.cdm.io.stream.StreamImportConfiguratorBase;
21
import eu.etaxonomy.cdm.io.stream.StreamImportStateBase;
22
import eu.etaxonomy.cdm.model.common.CdmBase;
23
import eu.etaxonomy.cdm.model.common.IdentifiableEntity;
24
import eu.etaxonomy.cdm.model.reference.Reference;
25

    
26

    
27
/**
28
 * @author a.mueller
29
 *
30
 */
31
public class StreamPartitioner<ITEM extends IConverterInput>  implements INamespaceReader<IReader<MappedCdmBase>>{
32
	private static final Logger logger = Logger.getLogger(StreamPartitioner.class);
33

    
34
	private final int partitionSize;
35
	private final LookAheadStream<ITEM> inStream;
36
	private final IPartitionableConverter converter;
37
	private final StreamImportStateBase<StreamImportConfiguratorBase, StreamImportBase> state;
38
	private ConcatenatingReader<MappedCdmBase> outStream;
39

    
40
	public StreamPartitioner(INamespaceReader<ITEM> input, IPartitionableConverter converter, StreamImportStateBase state, Integer size){
41
		 this.inStream = new LookAheadStream<ITEM>(input);
42
		 this.converter = converter;
43
		 this.partitionSize = size;
44
		 this.state = state;
45
		 initNewOutStream();
46
	}
47

    
48

    
49
	private void initNewOutStream(){
50
		outStream = new ConcatenatingReader<MappedCdmBase>();
51
	}
52

    
53
	@Override
54
    public boolean hasNext() {
55
		if (this.outStream.hasNext()){
56
			return true;
57
		}else{
58
			return inStream.hasNext();  //TODO what, if converter returns no ouput for inStream.hasNext() ??
59
			//but be aware that requesting the next object from the next partition crosses the transactional borders
60
		}
61
	}
62

    
63
	@Override
64
	public IReader<MappedCdmBase> read() {
65
		logger.debug("Start partitioner read");
66
		handleNextPartition();
67
		IReader<MappedCdmBase> result = this.outStream;
68

    
69
		initNewOutStream();
70
		logger.debug("End partitioner read");
71
		return result;
72
	}
73

    
74
	private void handleNextPartition(){
75
	    List<ITEM> lookaheadArray = new ArrayList<ITEM>();
76
		while (this.inStream.hasNextLookAhead(partitionSize)){
77
			lookaheadArray.add(this.inStream.readLookAhead());
78
		}
79

    
80
		IReader<ITEM> lookaheadStream = new ListReader<ITEM>(lookaheadArray);
81

    
82
		Map<String, Set<String>> foreignKeys = converter.getPartitionForeignKeys(lookaheadStream);
83
		IImportMapping mapping = state.getMapping();
84
		InMemoryMapping partialMapping = mapping.getPartialMapping(foreignKeys);
85
		Reference sourceRef = state.getCurrentIO().getReferenceService().find(state.getConfig().getSourceRefUuid());
86
		partialMapping.putMapping(TermUri.CDM_SOURCE_REFERENCE.toString(), state.getConfig().getSourceRefUuid().toString(), sourceRef);
87

    
88
		state.loadRelatedObjects(partialMapping);
89

    
90
		while (inStream.isLookingAhead() && inStream.hasNext()){
91
			IReader<MappedCdmBase> resultReader = converter.map(inStream.read());
92
			List<MappedCdmBase> resultList = new ArrayList<MappedCdmBase>();  //maybe better let converter return list from the beginning
93
			while (resultReader.hasNext()){
94
				MappedCdmBase item = resultReader.read();
95
				resultList.add(item);
96
				addItemToRelatedObjects(item);
97
			}
98
			outStream.add(new ListReader<MappedCdmBase>(resultList));
99
		}
100

    
101
		return;
102

    
103
	}
104

    
105

    
106
	/**
107
	 * Add new items to the local mapping
108
	 * @param item
109
	 */
110
	private void addItemToRelatedObjects(MappedCdmBase<IdentifiableEntity> item) {
111
		CdmBase cdmBase = item.getCdmBase();
112
		if (cdmBase.getId() == 0){
113
			if (cdmBase.isInstanceOf(IdentifiableEntity.class)){
114
			    Set<String> requiredSourceNamespaces = converter.requiredSourceNamespaces();
115
				if (requiredSourceNamespaces.contains(item.getNamespace())){
116
					state.addRelatedObject(item.getNamespace(), item.getSourceId(),  item.getCdmBase());
117
				}
118
			}
119
		}
120
	}
121

    
122

    
123
	@Override
124
	public TermUri getTerm() {
125
		return inStream.getTerm();
126
	}
127

    
128

    
129
}
(37-37/37)