summaryrefslogtreecommitdiff
path: root/ThirdParty/CsvHelper-master/src/CsvHelper/BadDataException.cs
blob: 9aecd38c1a00c138977170f3845feca64641397e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Copyright 2009-2022 Josh Close
// This file is a part of CsvHelper and is dual licensed under MS-PL and Apache 2.0.
// See LICENSE.txt for details or visit http://www.opensource.org/licenses/ms-pl.html for MS-PL and http://opensource.org/licenses/Apache-2.0 for Apache 2.0.
// https://github.com/JoshClose/CsvHelper
using System;

namespace CsvHelper
{
	/// <summary>
	/// Represents errors that occur due to bad data.
	/// </summary>
	[Serializable]
	public class BadDataException : CsvHelperException
	{
		/// <summary>
		/// The full field unedited.
		/// </summary>
		public readonly string Field;

		/// <summary>
		/// The full row unedited.
		/// </summary>
		public readonly string RawRecord;

		/// <summary>
		/// Initializes a new instance of the <see cref="BadDataException"/> class.
		/// </summary>
		/// <param name="field">The full field unedited.</param>
		/// <param name="rawRecord">The full row unedited.</param>
		/// <param name="context">The reading context.</param>
		public BadDataException(string field, string rawRecord, CsvContext context) : base(context)
		{
			Field = field;
			RawRecord = rawRecord;
		}

		/// <summary>
		/// Initializes a new instance of the <see cref="BadDataException"/> class
		/// with a specified error message.
		/// </summary>
		/// <param name="field">The full field unedited.</param>
		/// <param name="rawRecord">The full row unedited.</param>
		/// <param name="context">The reading context.</param>
		/// <param name="message">The message that describes the error.</param>
		public BadDataException(string field, string rawRecord, CsvContext context, string message) : base(context, message)
		{
			Field = field;
			RawRecord = rawRecord;
		}

		/// <summary>
		/// Initializes a new instance of the <see cref="BadDataException"/> class
		/// with a specified error message and a reference to the inner exception that 
		/// is the cause of this exception.
		/// </summary>
		/// <param name="field">The full field unedited.</param>
		/// <param name="rawRecord">The full row unedited.</param>
		/// <param name="context">The reading context.</param>
		/// <param name="message">The error message that explains the reason for the exception.</param>
		/// <param name="innerException">The exception that is the cause of the current exception, or a null reference (Nothing in Visual Basic) if no inner exception is specified.</param>
		public BadDataException(string field, string rawRecord, CsvContext context, string message, Exception innerException) : base(context, message, innerException)
		{
			Field = field;
			RawRecord = rawRecord;
		}
	}
}