/** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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 org.apache.metamodel.csv; import org.apache.metamodel.DataContext; import org.apache.metamodel.factory.DataContextFactory; import org.apache.metamodel.factory.DataContextProperties; import org.apache.metamodel.factory.ResourceFactoryRegistry; import org.apache.metamodel.util.FileHelper; import org.apache.metamodel.util.Resource; public class CsvDataContextFactory implements DataContextFactory { public static final String PROPERTY_TYPE = "csv"; @Override public boolean accepts(DataContextProperties properties, ResourceFactoryRegistry resourceFactoryRegistry) { return PROPERTY_TYPE.equals(properties.getDataContextType()); } @Override public DataContext create(DataContextProperties properties, ResourceFactoryRegistry resourceFactoryRegistry) { assert accepts(properties, resourceFactoryRegistry); final Resource resource = resourceFactoryRegistry.createResource(properties.getResourceProperties()); final int columnNameLineNumber = getInt(properties.getColumnNameLineNumber(), CsvConfiguration.DEFAULT_COLUMN_NAME_LINE); final String encoding = getString(properties.getEncoding(), FileHelper.DEFAULT_ENCODING); final char separatorChar = getChar(properties.getSeparatorChar(), CsvConfiguration.DEFAULT_SEPARATOR_CHAR); final char quoteChar = getChar(properties.getQuoteChar(), CsvConfiguration.DEFAULT_QUOTE_CHAR); final char escapeChar = getChar(properties.getEscapeChar(), CsvConfiguration.DEFAULT_ESCAPE_CHAR); final boolean failOnInconsistentRowLength = getBoolean(properties.isFailOnInconsistentRowLength(), false); final boolean multilineValuesEnabled = getBoolean(properties.isMultilineValuesEnabled(), true); final CsvConfiguration configuration = new CsvConfiguration(columnNameLineNumber, encoding, separatorChar, quoteChar, escapeChar, failOnInconsistentRowLength, multilineValuesEnabled); return new CsvDataContext(resource, configuration); } private String getString(String value, String ifNull) { return value == null ? ifNull : value; } private int getInt(Integer value, int ifNull) { return value == null ? ifNull : value; } private boolean getBoolean(Boolean value, boolean ifNull) { return value == null ? ifNull : value; } private char getChar(Character value, char ifNull) { return value == null ? ifNull : value; } }