org.dbflute.helper.token.file.FileMakingOption Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dbflute-runtime Show documentation
Show all versions of dbflute-runtime Show documentation
The runtime library of DBFlute
/*
* Copyright 2014-2023 the original author or authors.
*
* 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 org.dbflute.helper.token.file;
import java.util.List;
/**
* The option of file-making.
*
* e.g. TSV, UTF-8, with header
* new FileMakingOption().delimitateByTab().encodeAsUTF8().headerInfo(columnNameList)
*
* @author jflute
*/
public class FileMakingOption {
// ===================================================================================
// Attribute
// =========
/** The delimiter of data. (Required) */
protected String _delimiter;
/** The encoding for the file. (Required) */
protected String _encoding;
/** The line separator for the file. (NotRequired) */
protected String _lineSeparator;
/** Does it quote values minimally? (NotRequired) */
protected boolean _quoteMinimally;
/** Does it suppress value count check? (NotRequired) */
protected boolean _suppressValueCountCheck;
/** Does it write line separator first? (for appending) (NotRequired) */
protected boolean _writeLineSeparatorFirst;
/** The header info of file-making. (NotRequired) */
protected FileMakingHeaderInfo _headerInfo;
// ===================================================================================
// Easy-to-Use
// ===========
/**
* Delimitate by Comma.
* @return this. (NotNull)
*/
public FileMakingOption delimitateByComma() {
_delimiter = ",";
return this;
}
/**
* Delimitate by Tab.
* @return this. (NotNull)
*/
public FileMakingOption delimitateByTab() {
_delimiter = "\t";
return this;
}
/**
* Encode file as UTF-8.
* @return this. (NotNull)
*/
public FileMakingOption encodeAsUTF8() {
_encoding = "UTF-8";
return this;
}
/**
* Encode file as Windows-31J.
* @return this. (NotNull)
*/
public FileMakingOption encodeAsWindows31J() {
_encoding = "Windows-31J";
return this;
}
/**
* Separate line by CR + LF.
* @return this. (NotNull)
*/
public FileMakingOption separateByCrLf() {
_lineSeparator = "\r\n";
return this;
}
/**
* Separate line by LF.
* @return this. (NotNull)
*/
public FileMakingOption separateByLf() {
_lineSeparator = "\n";
return this;
}
/**
* Quote values minimally (if it needs).
* @return this. (NotNull)
*/
public FileMakingOption quoteMinimally() {
_quoteMinimally = true;
return this;
}
/**
* Suppress the value count check. (compare with header's column count)
* @return this. (NotNull)
*/
public FileMakingOption suppressValueCountCheck() {
_suppressValueCountCheck = true;
return this;
}
/**
* Write line separator first. (for appending)
* @param lineSeparatorFirst Does it write line separator first?
* @return this. (NotNull)
*/
public FileMakingOption writeLineSeparatorFirst(boolean lineSeparatorFirst) {
_writeLineSeparatorFirst = lineSeparatorFirst;
return this;
}
/**
* Set the header info with the list of column name.
* @param columnNameList The list of column name. (NullAllowed: means no header)
* @return this. (NotNull)
*/
public FileMakingOption headerInfo(List columnNameList) {
if (columnNameList != null) {
final FileMakingHeaderInfo headerInfo = new FileMakingHeaderInfo();
headerInfo.acceptColumnNameList(columnNameList);
_headerInfo = headerInfo;
} else {
_headerInfo = null;
}
return this;
}
// ===================================================================================
// Basic Override
// ==============
@Override
public String toString() {
return "{" + _delimiter + ", " + _encoding + ", " + _quoteMinimally + ", " + _headerInfo + "}";
}
// ===================================================================================
// Accessor
// ========
public String getDelimiter() {
return _delimiter;
}
public void setDelimiter(String delimiter) {
_delimiter = delimiter;
}
public String getEncoding() {
return _encoding;
}
public void setEncoding(String encoding) {
_encoding = encoding;
}
public String getLineSeparator() {
return _lineSeparator;
}
public void setLineSeparator(String lineSeparator) {
_lineSeparator = lineSeparator;
}
public boolean isQuoteMinimally() {
return _quoteMinimally;
}
public boolean isSuppressValueCountCheck() {
return _suppressValueCountCheck;
}
public boolean isWriteLineSeparatorFirst() {
return _writeLineSeparatorFirst;
}
public FileMakingHeaderInfo getFileMakingHeaderInfo() {
return _headerInfo;
}
public void setFileMakingHeaderInfo(FileMakingHeaderInfo headerInfo) {
_headerInfo = headerInfo;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy