Allow only one bookmark to be added for multiple fast starring
[chromium-blink-merge.git] / crypto / scoped_capi_types.h
blobac92e394b9c5dcd5c1979a52ad8b47de1efff34b
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
3 // found in the LICENSE file.
5 #ifndef CRYPTO_SCOPED_CAPI_TYPES_H_
6 #define CRYPTO_SCOPED_CAPI_TYPES_H_
8 #include <windows.h>
10 #include <algorithm>
12 #include "base/logging.h"
13 #include "crypto/wincrypt_shim.h"
15 namespace crypto {
17 // Simple destructor for the Free family of CryptoAPI functions, such as
18 // CryptDestroyHash, which take only a single argument to release.
19 template <typename CAPIHandle, BOOL (WINAPI *Destroyer)(CAPIHandle)>
20 struct CAPIDestroyer {
21 void operator()(CAPIHandle handle) const {
22 if (handle) {
23 BOOL ok = Destroyer(handle);
24 DCHECK(ok);
29 // Destructor for the Close/Release family of CryptoAPI functions, which take
30 // a second DWORD parameter indicating flags to use when closing or releasing.
31 // This includes functions like CertCloseStore or CryptReleaseContext.
32 template <typename CAPIHandle, BOOL (WINAPI *Destroyer)(CAPIHandle, DWORD),
33 DWORD flags>
34 struct CAPIDestroyerWithFlags {
35 void operator()(CAPIHandle handle) const {
36 if (handle) {
37 BOOL ok = Destroyer(handle, flags);
38 DCHECK(ok);
43 // scoped_ptr-like class for the CryptoAPI cryptography and certificate
44 // handles. Because these handles are defined as integer types, and not
45 // pointers, the existing scoped classes, such as scoped_ptr, are insufficient.
46 // The semantics are the same as scoped_ptr.
47 template <class CAPIHandle, typename FreeProc>
48 class ScopedCAPIHandle {
49 public:
50 explicit ScopedCAPIHandle(CAPIHandle handle = NULL) : handle_(handle) {}
52 ~ScopedCAPIHandle() {
53 reset();
56 void reset(CAPIHandle handle = NULL) {
57 if (handle_ != handle) {
58 FreeProc free_proc;
59 free_proc(handle_);
60 handle_ = handle;
64 operator CAPIHandle() const { return handle_; }
65 CAPIHandle get() const { return handle_; }
67 CAPIHandle* receive() {
68 CHECK(handle_ == NULL);
69 return &handle_;
72 bool operator==(CAPIHandle handle) const {
73 return handle_ == handle;
76 bool operator!=(CAPIHandle handle) const {
77 return handle_ != handle;
80 void swap(ScopedCAPIHandle& b) {
81 CAPIHandle tmp = b.handle_;
82 b.handle_ = handle_;
83 handle_ = tmp;
86 CAPIHandle release() {
87 CAPIHandle tmp = handle_;
88 handle_ = NULL;
89 return tmp;
92 private:
93 CAPIHandle handle_;
95 DISALLOW_COPY_AND_ASSIGN(ScopedCAPIHandle);
98 template<class CH, typename FP> inline
99 bool operator==(CH h, const ScopedCAPIHandle<CH, FP>& b) {
100 return h == b.get();
103 template<class CH, typename FP> inline
104 bool operator!=(CH h, const ScopedCAPIHandle<CH, FP>& b) {
105 return h != b.get();
108 typedef ScopedCAPIHandle<
109 HCRYPTPROV,
110 CAPIDestroyerWithFlags<HCRYPTPROV,
111 CryptReleaseContext, 0> > ScopedHCRYPTPROV;
113 typedef ScopedCAPIHandle<
114 HCRYPTKEY, CAPIDestroyer<HCRYPTKEY, CryptDestroyKey> > ScopedHCRYPTKEY;
116 typedef ScopedCAPIHandle<
117 HCRYPTHASH, CAPIDestroyer<HCRYPTHASH, CryptDestroyHash> > ScopedHCRYPTHASH;
119 } // namespace crypto
121 #endif // CRYPTO_SCOPED_CAPI_TYPES_H_