/** * The contents of this file are subject to the OpenMRS Public License * Version 1.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://license.openmrs.org * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * Copyright (C) OpenMRS, LLC. All Rights Reserved. */ package org.openmrs.report; import java.util.LinkedHashMap; import java.util.Map; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.openmrs.Cohort; import org.openmrs.api.CohortService; import org.openmrs.api.context.Context; import org.openmrs.cohort.CohortDefinition; /** * The logic that evaluates a {@link CohortDataSetDefinition} and produces a {@link CohortDataSet} * * @see CohortDataSetDefinition * @see CohortDataSet * @deprecated see reportingcompatibility module */ @Deprecated public class CohortDataSetProvider implements DataSetProvider { protected Log log = LogFactory.getLog(this.getClass()); public CohortDataSetProvider() { } /** * @see org.openmrs.report.DataSetProvider#canEvaluate(org.openmrs.report.DataSetDefinition) */ public boolean canEvaluate(DataSetDefinition dataSetDefinition) { return (dataSetDefinition instanceof CohortDataSetDefinition); } /** * @see org.openmrs.report.DataSetProvider#evaluate(DataSetDefinition, Cohort, * EvaluationContext) */ @SuppressWarnings("unchecked") public DataSet evaluate(DataSetDefinition dataSetDefinition, Cohort inputCohort, EvaluationContext evalContext) { CohortDataSetDefinition def = (CohortDataSetDefinition) dataSetDefinition; CohortDataSet data = new CohortDataSet(); data.setDefinition(def); data.setEvaluationContext(evalContext); data.setName(def.getName()); Map<String, Cohort> results = new LinkedHashMap<String, Cohort>(); CohortService cs = Context.getCohortService(); for (Map.Entry<String, CohortDefinition> e : def.getStrategies().entrySet()) { Cohort temp = cs.evaluate(e.getValue(), evalContext); if (inputCohort != null) temp = Cohort.intersect(temp, inputCohort); results.put(e.getKey(), temp); } data.setCohortData(results); return data; } }