Merged branch back to the trunk. Build is passing with no changes.
[castle.git] / MonoRail / Castle.MonoRail.Framework / Helpers / JSONHelper.cs
blob81ba5b39f765dab088c3a1530ba9badbc0698a46
1 // Copyright 2004-2007 Castle Project - http://www.castleproject.org/
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
15 namespace Castle.MonoRail.Framework.Helpers
17 using Services;
19 /// <summary>
20 /// Provides utilities methods to work with JSON.
21 /// </summary>
22 public class JSONHelper : AbstractHelper
24 /// <summary>
25 /// Converts a instance of the model to its JSON representation.
26 /// </summary>
27 /// <param name="model">The model.</param>
28 /// <returns>The JSON representation of the model.</returns>
29 /// <example>
30 /// Suppose you have a car object instance, like this one:
31 /// <code>
32 /// Car car = new Car();
33 ///
34 /// car.Wheels = 4;
35 /// car.Model = "Cheap";
36 /// car.Year = 2007;
37 /// </code>
38 /// And to transform it to JSON, you must invoke the method passing the instance.
39 /// <code>
40 /// $helper.ToJSON(car)
41 /// </code>
42 /// Which will generate the JSON string:
43 /// <code>
44 /// {Wheels=4,Year=2007,Model='Cheap'}
45 /// </code>
46 /// </example>
47 public string ToJSON(object model)
49 IJSONSerializer serializer = Context.Services.JSONSerializer;
51 if (serializer == null)
53 throw new MonoRailException("Attempt to serialize object failed because the serializer is not available");
56 return serializer.Serialize(model);