com.univocity.parsers.fixed.FixedWidthWriterSettings Maven / Gradle / Ivy
Show all versions of univocity-parsers Show documentation
/*******************************************************************************
* Copyright 2014 uniVocity Software Pty Ltd
*
* 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 com.univocity.parsers.fixed;
import java.util.*;
import com.univocity.parsers.common.*;
/**
* This is the configuration class used by the Fixed-Width writer ({@link FixedWidthWriter})
*
* The FixedWidthWriterSettings provides all configuration options in {@link CommonWriterSettings} and currently does not require any additional setting.
*
*
The FixedWidthParserSettings requires a definition of the field lengths of each record in the input. This must provided using an instance of {@link FixedWidthFieldLengths}.
*
* @see com.univocity.parsers.fixed.FixedWidthWriter
* @see com.univocity.parsers.fixed.FixedWidthFormat
* @see com.univocity.parsers.fixed.FixedWidthFieldLengths
* @see com.univocity.parsers.common.CommonWriterSettings
*
* @author uniVocity Software Pty Ltd - [email protected]
*
*/
public class FixedWidthWriterSettings extends CommonWriterSettings {
private final FixedWidthFieldLengths fieldLengths;
/**
* You can only create an instance of this class by providing a definition of the field lengths of each record in the input.
* This must provided using an instance of {@link FixedWidthFieldLengths}.
* @param fieldLengths the instance of {@link FixedWidthFieldLengths} which provides the lengths of each field in the fixed-width records to be parsed
* @see com.univocity.parsers.fixed.FixedWidthFieldLengths
*/
public FixedWidthWriterSettings(FixedWidthFieldLengths fieldLengths) {
if (fieldLengths == null) {
throw new IllegalArgumentException("Field lengths cannot be null");
}
this.fieldLengths = fieldLengths;
String[] names = fieldLengths.getFieldNames();
if (names != null) {
setHeaders(names);
}
}
/**
* Returns the sequence of field lengths to be written to form a record.
* @return the sequence of field lengths to be written to form a record.
*/
int[] getFieldLengths() {
return fieldLengths.getFieldLengths();
}
/**
* Returns the default FixedWidthFormat configured to handle Fixed-Width outputs
* @return and instance of FixedWidthFormat configured to handle Fixed-Width outputs
*/
@Override
protected FixedWidthFormat createDefaultFormat() {
return new FixedWidthFormat();
}
@Override
protected void addConfiguration(Map out) {
super.addConfiguration(out);
out.put("Field lengths", fieldLengths);
}
}