[System.Net] Add support for .pac proxy config scripts on mac
[mono.git] / mcs / class / System.Data / System.Data.ProviderBase.jvm / AbstractDbErrorCollection.cs
1 //\r
2 // System.Data.ProviderBase.AbstractDbErrorCollection\r
3 //
4 // Authors:
5 //      Konstantin Triger <kostat@mainsoft.com>
6 //      Boris Kirzner <borisk@mainsoft.com>
7 //      
8 // (C) 2005 Mainsoft Corporation (http://www.mainsoft.com)
9 //
10
11 //
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:
19 // 
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
22 // 
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.
30 //\r
31 \r
32 \r
33 namespace System.Data.ProviderBase {\r
34 \r
35 \r
36         using System.Collections;\r
37         using java.sql;\r
38         using System.Data.Common;\r
39 \r
40         [Serializable]\r
41         public abstract class AbstractDbErrorCollection : ICollection, IEnumerable {\r
42                 private ArrayList _list;\r
43 \r
44                 protected AbstractDbErrorCollection(SQLException e, AbstractDBConnection connection) {\r
45                         _list = new ArrayList();\r
46 \r
47                         while(e != null) {\r
48                                 _list.Add(CreateDbError(e, connection));\r
49                                 e = e.getNextException();\r
50                         }\r
51                 }\r
52 \r
53                 protected abstract AbstractDbError CreateDbError(SQLException e, AbstractDBConnection connection);\r
54                 /**\r
55                  * Gets the error at the specified index.\r
56                  *\r
57                  * @param index of the error\r
58                  * @return Error on specified index\r
59                  */\r
60                 protected AbstractDbError GetDbItem(int index) {\r
61                         return (AbstractDbError)_list[index];\r
62                 }\r
63 \r
64                 /**\r
65                  * Adds new Error to the collection\r
66                  *\r
67                  * @param value new OleDbError\r
68                  */\r
69                 public void Add(object value) {\r
70                         _list.Add(value);\r
71                 }\r
72         \r
73                 public int Count {\r
74                         get {\r
75                                 return _list.Count;\r
76                         }\r
77                 }\r
78 \r
79                 public IEnumerator GetEnumerator() {\r
80                         return _list.GetEnumerator();\r
81                 }\r
82         \r
83                 public void CopyTo(System.Array arr, int index) {\r
84                         _list.CopyTo(arr, index);\r
85                 }\r
86 \r
87                 bool ICollection.IsSynchronized {\r
88                         get {\r
89                                 return _list.IsSynchronized;\r
90                         }\r
91                 }\r
92 \r
93                 Object ICollection.SyncRoot {\r
94                         get {\r
95                                 return _list.SyncRoot;\r
96                         }\r
97                 }\r
98         \r
99         }\r
100 }