2 // System.Data.ProviderBase.AbstractDbErrorCollection
5 // Konstantin Triger <kostat@mainsoft.com>
6 // Boris Kirzner <borisk@mainsoft.com>
8 // (C) 2005 Mainsoft Corporation (http://www.mainsoft.com)
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
33 namespace System
.Data
.ProviderBase
{
36 using System
.Collections
;
38 using System
.Data
.Common
;
41 public abstract class AbstractDbErrorCollection
: ICollection
, IEnumerable
{
42 private ArrayList _list
;
44 protected AbstractDbErrorCollection(SQLException e
, AbstractDBConnection connection
) {
45 _list
= new ArrayList();
48 _list
.Add(CreateDbError(e
, connection
));
49 e
= e
.getNextException();
53 protected abstract AbstractDbError
CreateDbError(SQLException e
, AbstractDBConnection connection
);
55 * Gets the error at the specified index.
57 * @param index of the error
58 * @return Error on specified index
60 protected AbstractDbError
GetDbItem(int index
) {
61 return (AbstractDbError
)_list
[index
];
65 * Adds new Error to the collection
67 * @param value new OleDbError
69 public void Add(object value) {
79 public IEnumerator
GetEnumerator() {
80 return _list
.GetEnumerator();
83 public void CopyTo(System
.Array arr
, int index
) {
84 _list
.CopyTo(arr
, index
);
87 bool ICollection
.IsSynchronized
{
89 return _list
.IsSynchronized
;
93 Object ICollection
.SyncRoot
{
95 return _list
.SyncRoot
;