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

Side by Side Diff: mojo/public/cpp/bindings/lib/validate_params.h

Issue 2036623002: Validate map keys in C++ Mojo bindings (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address review comments Created 4 years, 6 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_ 5 #ifndef MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_
6 #define MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_ 6 #define MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include "base/macros.h" 10 #include "base/macros.h"
11 11
12 namespace mojo { 12 namespace mojo {
13 namespace internal { 13 namespace internal {
14 14
15 using ValidateEnumFunc = bool (*)(int32_t); 15 using ValidateEnumFunc = bool (*)(int32_t);
16 16
17 // TODO(tibell): Rename to ContainerValidateParams.
17 class ArrayValidateParams { 18 class ArrayValidateParams {
18 public: 19 public:
20 // Validates a map. A map is validated as a pair of arrays, one for the keys
21 // and one for the values. Both arguments must be non-null.
22 //
23 // ArrayValidateParams takes ownership of |in_key_validate params| and
24 // |in_element_validate params|.
25 ArrayValidateParams(ArrayValidateParams* in_key_validate_params,
26 ArrayValidateParams* in_element_validate_params)
27 : key_validate_params(in_key_validate_params),
28 element_validate_params(in_element_validate_params) {
29 DCHECK(in_key_validate_params)
30 << "Map validate params require key validate params";
31 DCHECK(in_element_validate_params)
32 << "Map validate params require element validate params";
33 }
34
35 // Validates an array.
36 //
19 // ArrayValidateParams takes ownership of |in_element_validate params|. 37 // ArrayValidateParams takes ownership of |in_element_validate params|.
20 ArrayValidateParams(uint32_t in_expected_num_elements, 38 ArrayValidateParams(uint32_t in_expected_num_elements,
21 bool in_element_is_nullable, 39 bool in_element_is_nullable,
22 ArrayValidateParams* in_element_validate_params) 40 ArrayValidateParams* in_element_validate_params)
23 : expected_num_elements(in_expected_num_elements), 41 : expected_num_elements(in_expected_num_elements),
24 element_is_nullable(in_element_is_nullable), 42 element_is_nullable(in_element_is_nullable),
25 element_validate_params(in_element_validate_params), 43 element_validate_params(in_element_validate_params) {}
26 validate_enum_func(nullptr) {}
27 44
28 // Validates an array of enums. 45 // Validates an array of enums.
29 ArrayValidateParams(uint32_t in_expected_num_elements, 46 ArrayValidateParams(uint32_t in_expected_num_elements,
30 ValidateEnumFunc in_validate_enum_func) 47 ValidateEnumFunc in_validate_enum_func)
31 : expected_num_elements(in_expected_num_elements), 48 : expected_num_elements(in_expected_num_elements),
32 element_is_nullable(false),
33 element_validate_params(nullptr),
34 validate_enum_func(in_validate_enum_func) {} 49 validate_enum_func(in_validate_enum_func) {}
35 50
36 ~ArrayValidateParams() { 51 ~ArrayValidateParams() {
37 if (element_validate_params) 52 if (element_validate_params)
38 delete element_validate_params; 53 delete element_validate_params;
54 if (key_validate_params)
55 delete key_validate_params;
39 } 56 }
40 57
41 // If |expected_num_elements| is not 0, the array is expected to have exactly 58 // If |expected_num_elements| is not 0, the array is expected to have exactly
42 // that number of elements. 59 // that number of elements.
43 uint32_t expected_num_elements; 60 uint32_t expected_num_elements = 0;
44 61
45 // Whether the elements are nullable. 62 // Whether the elements are nullable.
46 bool element_is_nullable; 63 bool element_is_nullable = false;
47 64
48 // Validation information for elements. It is either a pointer to another 65 // Validation information for the map key array. May contain other
49 // instance of ArrayValidateParams (if elements are arrays or maps), or 66 // ArrayValidateParams e.g. if the keys are strings.
50 // nullptr. In the case of maps, this is used to validate the value array. 67 ArrayValidateParams* key_validate_params = nullptr;
51 ArrayValidateParams* element_validate_params; 68
69 // For arrays: validation information for elements. It is either a pointer to
70 // another instance of ArrayValidateParams (if elements are arrays or maps),
71 // or nullptr.
72 //
73 // For maps: validation information for the whole value array. May contain
74 // other ArrayValidateParams e.g. if the values are arrays or maps.
75 ArrayValidateParams* element_validate_params = nullptr;
52 76
53 // Validation function for enum elements. 77 // Validation function for enum elements.
54 ValidateEnumFunc validate_enum_func; 78 ValidateEnumFunc validate_enum_func = nullptr;
55 79
56 private: 80 private:
57 DISALLOW_COPY_AND_ASSIGN(ArrayValidateParams); 81 DISALLOW_COPY_AND_ASSIGN(ArrayValidateParams);
58 }; 82 };
59 83
60 } // namespace internal 84 } // namespace internal
61 } // namespace mojo 85 } // namespace mojo
62 86
63 #endif // MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_ 87 #endif // MOJO_PUBLIC_CPP_BINDINGS_LIB_VALIDATE_PARAMS_H_
OLDNEW
« no previous file with comments | « mojo/public/cpp/bindings/lib/map_serialization.h ('k') | mojo/public/cpp/bindings/lib/validation_util.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698