OLD | NEW |
| (Empty) |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "base/rand_util.h" | |
6 #include "ppapi/c/dev/ppb_crypto_dev.h" | |
7 #include "ppapi/thunk/thunk.h" | |
8 | |
9 // The crypto interface doesn't have a normal C -> C++ thunk since it doesn't | |
10 // actually have any proxy wrapping or associated objects; it's just a call | |
11 // into base. So we implement the entire interface here, using the thunk | |
12 // namespace so it magically gets hooked up in the proper places. | |
13 | |
14 namespace ppapi { | |
15 | |
16 namespace { | |
17 | |
18 void GetRandomBytes(char* buffer, uint32_t num_bytes) { | |
19 base::RandBytes(buffer, num_bytes); | |
20 } | |
21 | |
22 const PPB_Crypto_Dev crypto_interface = { | |
23 &GetRandomBytes | |
24 }; | |
25 | |
26 } // namespace | |
27 | |
28 namespace thunk { | |
29 | |
30 PPAPI_THUNK_EXPORT const PPB_Crypto_Dev* GetPPB_Crypto_Dev_Thunk() { | |
31 return &crypto_interface; | |
32 } | |
33 | |
34 } // namespace thunk | |
35 | |
36 } // namespace ppapi | |
OLD | NEW |