JsonUnknownAttribute.cs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // JsonKit v0.5 - A simple but flexible Json library in a single .cs file.
  2. //
  3. // Copyright (C) 2014 Topten Software (contact@toptensoftware.com) All rights reserved.
  4. //
  5. // Licensed under the Apache License, Version 2.0 (the "License"); you may not use this product
  6. // except in compliance with the License. You may obtain a copy of the License at
  7. //
  8. // http://www.apache.org/licenses/LICENSE-2.0
  9. //
  10. // Unless required by applicable law or agreed to in writing, software distributed under the
  11. // License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
  12. // either express or implied. See the License for the specific language governing permissions
  13. // and limitations under the License.
  14. using System;
  15. namespace Topten.JsonKit
  16. {
  17. /// <summary>
  18. /// Apply to enum values to specify which enum value to select
  19. /// if the supplied json value doesn't match any.
  20. /// If not found throws an exception
  21. /// eg, any unknown values in the json will be mapped to Fruit.unknown
  22. ///
  23. /// [JsonUnknown(Fruit.unknown)]
  24. /// enum Fruit
  25. /// {
  26. /// unknown,
  27. /// Apple,
  28. /// Pear,
  29. /// }
  30. /// </summary>
  31. [AttributeUsage(AttributeTargets.Enum)]
  32. public class JsonUnknownAttribute : Attribute
  33. {
  34. /// <summary>
  35. /// Constructs a new JsonUnknown attribute
  36. /// </summary>
  37. /// <param name="unknownValue">The value to be used for unknown enum values</param>
  38. public JsonUnknownAttribute(object unknownValue)
  39. {
  40. UnknownValue = unknownValue;
  41. }
  42. /// <summary>
  43. /// The value to be used for unknown enum values
  44. /// </summary>
  45. public object UnknownValue
  46. {
  47. get;
  48. private set;
  49. }
  50. }
  51. }