OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. |
| 4 |
| 5 library polymer.deserialize; |
| 6 |
| 7 import 'dart:convert' show JSON; |
| 8 |
| 9 final _typeHandlers = { |
| 10 String: (x, _) => x, |
| 11 Null: (x, _) => x, |
| 12 DateTime: (x, def) { |
| 13 // TODO(jmesserly): shouldn't need to try-catch here |
| 14 // See: https://code.google.com/p/dart/issues/detail?id=1878 |
| 15 try { |
| 16 return DateTime.parse(x); |
| 17 } catch (e) { |
| 18 return def; |
| 19 } |
| 20 }, |
| 21 bool: (x, _) => x != 'false', |
| 22 int: (x, def) => int.parse(x, onError: (_) => def), |
| 23 double: (x, def) => double.parse(x, (_) => def), |
| 24 }; |
| 25 |
| 26 /// Convert representation of [value] based on [type] and [currentValue]. |
| 27 Object deserializeValue(String value, Object currentValue, Type type) { |
| 28 var handler = _typeHandlers[type]; |
| 29 if (handler != null) return handler(value, currentValue); |
| 30 |
| 31 try { |
| 32 // If the string is an object, we can parse is with the JSON library. |
| 33 // include convenience replace for single-quotes. If the author omits |
| 34 // quotes altogether, parse will fail. |
| 35 return JSON.decode(value.replaceAll("'", '"')); |
| 36 |
| 37 // TODO(jmesserly): deserialized JSON is not assignable to most objects in |
| 38 // Dart. We should attempt to convert it appropriately. |
| 39 } catch(e) { |
| 40 // The object isn't valid JSON, return the raw value |
| 41 return value; |
| 42 } |
| 43 } |
OLD | NEW |