All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.univocity.parsers.common.TextWritingException Maven / Gradle / Ivy

/*******************************************************************************
 * 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.common;

/**
 * Exception type used provide information about any issue that might happen while writing to a given output.
 *
 * 

It generally provides location and data information in case of a writing failure. * * @author uniVocity Software Pty Ltd - [email protected] */ public class TextWritingException extends AbstractException { private static final long serialVersionUID = 7198462597717255519L; private final long recordCount; private final Object[] recordData; private final String recordCharacters; /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error * @param recordCount the number of records written until the error occurred * @param row the input row that was being written when the error occurred * @param recordCharacters the characters already written to the output record. * @param cause the cause of the error */ private TextWritingException(String message, long recordCount, Object[] row, String recordCharacters, Throwable cause) { super(message, cause); this.recordCount = recordCount; this.recordData = row; this.recordCharacters = recordCharacters; } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error * @param recordCount the number of records written until the error occurred * @param recordCharacters the characters already written to the output record. * @param cause the cause of the error */ public TextWritingException(String message, long recordCount, String recordCharacters, Throwable cause) { this(message, recordCount, null, recordCharacters, cause); } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error * @param recordCount the number of records written until the error occurred * @param row the input row that was being written when the error occurred * @param cause the cause of the error */ public TextWritingException(String message, long recordCount, Object[] row, Throwable cause) { this(message, recordCount, row, null, cause); } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error */ public TextWritingException(String message) { this(message, 0, null, null, null); } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param cause the cause of the error */ public TextWritingException(Throwable cause) { this(cause != null ? cause.getMessage() : null, 0, null, null, cause); } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error * @param line index of the line being written to the output when the error occurred * @param row the input row that was being written when the error occurred */ public TextWritingException(String message, long line, Object[] row) { this(message, line, row, null); } /** * Creates a new exception with information about an error that occurred when writing data to some output. * * @param message message with details about the error * @param line index of the line being written to the output when the error occurred * @param recordCharacters the characters already written to the output record. */ public TextWritingException(String message, long line, String recordCharacters) { this(message, line, null, recordCharacters, null); } /** * Returns the number of records written before the exception occurred. * * @return the number of records written before the exception occurred. */ public long getRecordCount() { return recordCount; } /** * Returns the data that failed to be written * * @return the data that failed to be written */ public Object[] getRecordData() { return restrictContent(recordData); } /** * Returns the character data that failed to be written * * @return the character data that failed to be written */ public String getRecordCharacters() { if(errorContentLength == 0){ return null; } return recordCharacters; } @Override protected String getDetails() { String details = ""; details = printIfNotEmpty(details, "recordCount", recordCount); details = printIfNotEmpty(details, "recordData", restrictContent(recordData)); details = printIfNotEmpty(details, "recordCharacters", restrictContent(recordCharacters)); return details; } @Override protected String getErrorDescription() { return "Error writing data"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy