/*
* Copyright: (c) 2004-2011 Mayo Foundation for Medical Education and
* Research (MFMER). All rights reserved. MAYO, MAYO CLINIC, and the
* triple-shield Mayo logo are trademarks and service marks of MFMER.
*
* Except as contained in the copyright notice above, or as used to identify
* MFMER as the author of this software, the trade names, trademarks, service
* marks, or product names of the copyright holder shall not be used in
* advertising, promotion or otherwise in connection with this software without
* prior written authorization of the copyright holder.
*
* Licensed 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.
*/
package edu.mayo.cts2.framework.filter.directory;
import java.util.Collection;
import java.util.HashSet;
import java.util.Set;
import com.google.common.collect.Iterables;
import edu.mayo.cts2.framework.model.core.types.SetOperator;
import edu.mayo.cts2.framework.model.directory.DirectoryResult;
/**
* The Class AbstractNonLazyDirectoryBuilder.
*
* @param <T> the generic type
* @author <a href="mailto:kevin.peterson@mayo.edu">Kevin Peterson</a>
*/
public abstract class AbstractNonLazyDirectoryBuilder<T> extends AbstractDirectoryBuilder<T> {
/**
* Process set operation.
*
* @param i1 the i1
* @param i2 the i2
* @param setOperator the set operator
* @return the collection
*/
protected Collection<T> processSetOperation(final DirectoryBuilder<T> i1,
final DirectoryBuilder<T> i2, final SetOperator setOperator) {
Set<T> set1 = new HashSet<T>();
Set<T> set2 = new HashSet<T>();
DirectoryResult<T> result1 = i1.resolve();
DirectoryResult<T> result2 = i2.resolve();
Iterables.addAll(set1, result1.getEntries());
Iterables.addAll(set2, result2.getEntries());
switch (setOperator) {
case UNION: {
set1.addAll(set2);
return set1;
}
case INTERSECT: {
set1.retainAll(set2);
return set1;
}
case SUBTRACT: {
set1.removeAll(set2);
return set1;
}
}
return set1;
}
}