
org.protempa.dest.table.TableDestination Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of protempa-framework Show documentation
Show all versions of protempa-framework Show documentation
Protempa Framework is the core of Protempa.
package org.protempa.dest.table;
import java.io.BufferedWriter;
import java.util.HashSet;
import java.util.Set;
import org.apache.commons.lang3.ArrayUtils;
import org.protempa.DataSource;
import org.protempa.KnowledgeSource;
import org.protempa.KnowledgeSourceReadException;
import org.protempa.dest.AbstractDestination;
import org.protempa.dest.GetSupportedPropositionIdsException;
import org.protempa.dest.QueryResultsHandlerInitException;
import org.protempa.dest.QueryResultsHandlerProcessingException;
import org.protempa.query.QueryMode;
import org.protempa.query.Query;
/*
* #%L
* Protempa Framework
* %%
* Copyright (C) 2012 - 2013 Emory University
* %%
* 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.
* #L%
*/
/**
*
* @author Andrew Post
*/
public final class TableDestination extends AbstractDestination {
private final boolean headerWritten;
private final TableColumnSpec[] columnSpecs;
private final String[] rowPropositionIds;
private final char columnDelimiter;
private final BufferedWriter out;
public TableDestination(BufferedWriter out, char columnDelimiter,
String[] rowPropositionIds, TableColumnSpec[] columnSpecs,
boolean headerWritten) {
this.out = out;
this.columnDelimiter = columnDelimiter;
this.rowPropositionIds = rowPropositionIds.clone();
this.columnSpecs = columnSpecs.clone();
this.headerWritten = headerWritten;
}
public String[] getRowPropositionIds() {
return this.rowPropositionIds.clone();
}
public char getColumnDelimiter() {
return this.columnDelimiter;
}
public TableColumnSpec[] getColumnSpecs() {
return this.columnSpecs.clone();
}
public boolean isHeaderWritten() {
return this.headerWritten;
}
@Override
public TableQueryResultsHandler getQueryResultsHandler(Query query, DataSource dataSource, KnowledgeSource knowledgeSource) throws QueryResultsHandlerInitException {
if (query.getQueryMode() == QueryMode.UPDATE) {
throw new QueryResultsHandlerInitException("Update mode not supported");
}
return new TableQueryResultsHandler(this.out, this.columnDelimiter,
this.rowPropositionIds, this.columnSpecs, this.headerWritten,
knowledgeSource);
}
/**
* Infers a list of propositions to populate all of the specified columns.
*
* @return an array of proposition id {@link String}s.
*/
@Override
public String[] getSupportedPropositionIds(DataSource dataSource, KnowledgeSource knowledgeSource) throws GetSupportedPropositionIdsException {
Set result = new HashSet<>();
org.arp.javautil.arrays.Arrays.addAll(result, this.rowPropositionIds);
for (TableColumnSpec columnSpec : this.columnSpecs) {
String[] inferredPropIds;
try {
inferredPropIds = columnSpec.getInferredPropositionIds(knowledgeSource, this.rowPropositionIds);
} catch (KnowledgeSourceReadException ex) {
throw new GetSupportedPropositionIdsException("Error getting proposition ids needed", ex);
}
org.arp.javautil.arrays.Arrays.addAll(result, inferredPropIds);
}
return result.toArray(new String[result.size()]);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy