cff4b35099ed1f86015bf93bb3c83a1e4b45bf4d
[mono.git] / mcs / class / System.Web.Services / System.Web.Services.Protocols / ValueCollectionParameterReader.cs
1 // \r
2 // System.Web.Services.Protocols.ValueCollectionParameterReader.cs\r
3 //\r
4 // Author:\r
5 //   Tim Coleman (tim@timcoleman.com)\r
6 //   Lluis Sanchez Gual (lluis@ximian.com)\r
7 //\r
8 // Copyright (C) Tim Coleman, 2002\r
9 //\r
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 //
31 \r
32 using System.Collections.Specialized;\r
33 using System.Reflection;\r
34 using System.Web;\r
35 using System.Xml;\r
36 \r
37 namespace System.Web.Services.Protocols {\r
38         public abstract class ValueCollectionParameterReader : MimeParameterReader {\r
39 \r
40                 ParameterInfo[] parameters;\r
41 \r
42                 #region Constructors\r
43 \r
44                 protected ValueCollectionParameterReader () \r
45                 {\r
46                 }\r
47                 \r
48                 #endregion // Constructors\r
49 \r
50                 #region Methods\r
51 \r
52                 public override object GetInitializer (LogicalMethodInfo methodInfo)\r
53                 {\r
54                         if (IsSupported (methodInfo)) return methodInfo.Parameters;\r
55                         else return null;\r
56                 }\r
57 \r
58                 public override void Initialize (object o)\r
59                 {\r
60                         parameters = (ParameterInfo[]) o;\r
61                 }\r
62 \r
63                 public static bool IsSupported (LogicalMethodInfo methodInfo)\r
64                 {\r
65                         foreach (ParameterInfo param in methodInfo.Parameters)\r
66                                 if (!IsSupported (param)) return false;\r
67                         return true;\r
68                 }\r
69 \r
70                 public static bool IsSupported (ParameterInfo paramInfo)\r
71                 {\r
72                         Type type = paramInfo.ParameterType;\r
73                         if (type.IsByRef || paramInfo.IsOut) return false;\r
74                         if (type.IsArray) return IsSupportedPrimitive (type.GetElementType());\r
75                         else return IsSupportedPrimitive (type);\r
76                 }\r
77                 \r
78                 internal static bool IsSupportedPrimitive (Type type)\r
79                 {\r
80                         return ( type.IsPrimitive || \r
81                                          type == typeof(string) ||\r
82                                          type == typeof(DateTime) ||\r
83                                          type == typeof(Decimal)\r
84                                          );\r
85                 }\r
86 \r
87                 protected object[] Read (NameValueCollection collection)\r
88                 {\r
89                         object[] res = new object [parameters.Length];\r
90                         for (int n=0; n<res.Length; n++)\r
91                         {\r
92                                 string val = collection [parameters[n].Name];\r
93                                 if (val == null) throw new InvalidOperationException ("Missing parameter: " + parameters[n].Name);\r
94                                 try\r
95                                 {\r
96                                         res [n] = StringToObj (parameters[n].ParameterType, val);\r
97                                 }\r
98                                 catch (Exception ex)\r
99                                 {\r
100                                         string error = "Cannot convert '" + val + "' to " + parameters[n].ParameterType.FullName + "\n";\r
101                                         error += "Parameter name: " + parameters[n].Name + " --> " + ex.Message;\r
102                                         throw new InvalidOperationException (error);\r
103                                 }\r
104                         }\r
105                         return res;\r
106                 }\r
107                 #endregion // Methods\r
108         }\r
109 }