Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(478)

Side by Side Diff: content/public/renderer/v8_value_converter.h

Issue 19730002: V8ValueConverter for the activity logger that does not invoke interceptors and (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Ben's comments, fix for mac compilation Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698