OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ | 5 #ifndef CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ |
6 #define CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ | 6 #define CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ |
7 | 7 |
8 #include "content/common/content_export.h" | 8 #include "content/common/content_export.h" |
9 #include "v8/include/v8.h" | 9 #include "v8/include/v8.h" |
10 | 10 |
11 namespace base { | 11 namespace base { |
12 class Value; | 12 class Value; |
13 } | 13 } |
14 | 14 |
15 namespace content { | 15 namespace content { |
16 | 16 |
17 // Converts between v8::Value (JavaScript values in the v8 heap) and Chrome's | 17 // Converts between v8::Value (JavaScript values in the v8 heap) and Chrome's |
18 // values (from base/values.h). Lists and dictionaries are converted | 18 // values (from base/values.h). Lists and dictionaries are converted |
19 // recursively. | 19 // recursively. |
20 // | 20 // |
21 // The JSON types (null, boolean, string, number, array, and object) as well as | 21 // The JSON types (null, boolean, string, number, array, and object) as well as |
22 // binary values are supported. For binary values, we convert to WebKit | 22 // binary values are supported. For binary values, we convert to WebKit |
23 // ArrayBuffers, and support converting from an ArrayBuffer or any of the | 23 // ArrayBuffers, and support converting from an ArrayBuffer or any of the |
24 // ArrayBufferView subclasses (Uint8Array, etc.). | 24 // ArrayBufferView subclasses (Uint8Array, etc.). |
25 class CONTENT_EXPORT V8ValueConverter { | 25 class CONTENT_EXPORT V8ValueConverter { |
26 public: | 26 public: |
| 27 // Extends the default behaviour of V8ValueConverter. |
| 28 class CONTENT_EXPORT Strategy { |
| 29 public: |
| 30 virtual ~Strategy() {} |
| 31 // If false is returned, V8ValueConverter proceeds with the default |
| 32 // behavior. |
| 33 virtual bool FromV8Object(v8::Handle<v8::Object> value, |
| 34 base::Value** out) const = 0; |
| 35 // If false is returned, V8ValueConverter proceeds with the default |
| 36 // behavior. |
| 37 virtual bool FromV8Array(v8::Handle<v8::Array> value, |
| 38 base::Value** out) const = 0; |
| 39 }; |
| 40 |
27 static V8ValueConverter* create(); | 41 static V8ValueConverter* create(); |
28 | 42 |
29 virtual ~V8ValueConverter() {} | 43 virtual ~V8ValueConverter() {} |
30 | 44 |
31 // If true, Date objects are converted into DoubleValues with the number of | 45 // If true, Date objects are converted into DoubleValues with the number of |
32 // seconds since Unix epoch. | 46 // seconds since Unix epoch. |
33 // | 47 // |
34 // Otherwise they are converted into DictionaryValues with whatever additional | 48 // Otherwise they are converted into DictionaryValues with whatever additional |
35 // properties has been set on them. | 49 // properties has been set on them. |
36 virtual void SetDateAllowed(bool val) = 0; | 50 virtual void SetDateAllowed(bool val) = 0; |
37 | 51 |
38 // If true, RegExp objects are converted into StringValues with the regular | 52 // If true, RegExp objects are converted into StringValues with the regular |
39 // expression between / and /, for example "/ab?c/". | 53 // expression between / and /, for example "/ab?c/". |
40 // | 54 // |
41 // Otherwise they are converted into DictionaryValues with whatever additional | 55 // Otherwise they are converted into DictionaryValues with whatever additional |
42 // properties has been set on them. | 56 // properties has been set on them. |
43 virtual void SetRegExpAllowed(bool val) = 0; | 57 virtual void SetRegExpAllowed(bool val) = 0; |
44 | 58 |
45 // If true, Function objects are converted into DictionaryValues with whatever | 59 // If true, Function objects are converted into DictionaryValues with whatever |
46 // additional properties has been set on them. | 60 // additional properties has been set on them. |
47 // | 61 // |
48 // Otherwise they are treated as unsupported, see FromV8Value. | 62 // Otherwise they are treated as unsupported, see FromV8Value. |
49 virtual void SetFunctionAllowed(bool val) = 0; | 63 virtual void SetFunctionAllowed(bool val) = 0; |
50 | 64 |
51 // If true, null values are stripped from objects. This is often useful when | 65 // If true, null values are stripped from objects. This is often useful when |
52 // converting arguments to extension APIs. | 66 // converting arguments to extension APIs. |
53 virtual void SetStripNullFromObjects(bool val) = 0; | 67 virtual void SetStripNullFromObjects(bool val) = 0; |
54 | 68 |
| 69 // Extend default behavior of V8ValueConverter. |
| 70 virtual void SetStrategy(Strategy* strategy) = 0; |
| 71 |
55 // Converts a base::Value to a v8::Value. | 72 // Converts a base::Value to a v8::Value. |
56 // | 73 // |
57 // Unsupported types are replaced with null. If an array or object throws | 74 // Unsupported types are replaced with null. If an array or object throws |
58 // while setting a value, that property or item is skipped, leaving a hole in | 75 // while setting a value, that property or item is skipped, leaving a hole in |
59 // the case of arrays. | 76 // the case of arrays. |
60 virtual v8::Handle<v8::Value> ToV8Value( | 77 virtual v8::Handle<v8::Value> ToV8Value( |
61 const base::Value* value, | 78 const base::Value* value, |
62 v8::Handle<v8::Context> context) const = 0; | 79 v8::Handle<v8::Context> context) const = 0; |
63 | 80 |
64 // Converts a v8::Value to base::Value. | 81 // Converts a v8::Value to base::Value. |
65 // | 82 // |
66 // Unsupported types (unless explicitly configured) are not converted, so | 83 // Unsupported types (unless explicitly configured) are not converted, so |
67 // this method may return NULL -- the exception is when converting arrays, | 84 // this method may return NULL -- the exception is when converting arrays, |
68 // where unsupported types are converted to Value(TYPE_NULL). | 85 // where unsupported types are converted to Value(TYPE_NULL). |
69 // | 86 // |
70 // Likewise, if an object throws while converting a property it will not be | 87 // Likewise, if an object throws while converting a property it will not be |
71 // converted, whereas if an array throws while converting an item it will be | 88 // converted, whereas if an array throws while converting an item it will be |
72 // converted to Value(TYPE_NULL). | 89 // converted to Value(TYPE_NULL). |
73 virtual base::Value* FromV8Value(v8::Handle<v8::Value> value, | 90 virtual base::Value* FromV8Value(v8::Handle<v8::Value> value, |
74 v8::Handle<v8::Context> context) const = 0; | 91 v8::Handle<v8::Context> context) const = 0; |
75 }; | 92 }; |
76 | 93 |
77 } // namespace content | 94 } // namespace content |
78 | 95 |
79 #endif // CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ | 96 #endif // CONTENT_PUBLIC_RENDERER_V8_VALUE_CONVERTER_H_ |
OLD | NEW |