summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--base/scoped_comptr_win.h7
-rw-r--r--base/scoped_comptr_win_unittest.cc24
2 files changed, 24 insertions, 7 deletions
diff --git a/base/scoped_comptr_win.h b/base/scoped_comptr_win.h
index 3fa419f..dbe2805 100644
--- a/base/scoped_comptr_win.h
+++ b/base/scoped_comptr_win.h
@@ -89,6 +89,13 @@ class ScopedComPtr : public scoped_refptr<Interface> {
return ptr_->QueryInterface(p);
}
+ // QI for times when the IID is not associated with the type.
+ HRESULT QueryInterface(const IID& iid, void** obj) {
+ DCHECK(obj != NULL);
+ DCHECK(ptr_ != NULL);
+ return ptr_->QueryInterface(iid, obj);
+ }
+
// Queries |other| for the interface this object wraps and returns the
// error code from the other->QueryInterface operation.
HRESULT QueryFrom(IUnknown* object) {
diff --git a/base/scoped_comptr_win_unittest.cc b/base/scoped_comptr_win_unittest.cc
index e6d6c68..3d22c56 100644
--- a/base/scoped_comptr_win_unittest.cc
+++ b/base/scoped_comptr_win_unittest.cc
@@ -2,9 +2,10 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "base/scoped_comptr_win.h"
+
#include <shlobj.h>
-#include "base/scoped_comptr_win.h"
#include "base/scoped_ptr.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -42,6 +43,12 @@ TEST(ScopedComPtrTest, ScopedComPtr) {
ScopedComPtr<IMalloc> mem_alloc;
EXPECT_TRUE(SUCCEEDED(CoGetMalloc(1, mem_alloc.Receive())));
+ ScopedComPtr<IUnknown> qi_test;
+ EXPECT_HRESULT_SUCCEEDED(mem_alloc.QueryInterface(IID_IUnknown,
+ reinterpret_cast<void**>(qi_test.Receive())));
+ EXPECT_TRUE(qi_test.get() != NULL);
+ qi_test.Release();
+
// test ScopedComPtr& constructor
ScopedComPtr<IMalloc> copy1(mem_alloc);
EXPECT_TRUE(copy1.IsSameObject(mem_alloc));
@@ -73,6 +80,7 @@ TEST(ScopedComPtrTest, ScopedComPtrVector) {
// Verify we don't get error C2558.
typedef ScopedComPtr<Dummy, &dummy_iid> Ptr;
std::vector<Ptr> bleh;
+
scoped_ptr<Dummy> p(new Dummy);
{
Ptr p2(p.get());
@@ -84,14 +92,16 @@ TEST(ScopedComPtrTest, ScopedComPtrVector) {
p3 = p2;
EXPECT_EQ(p->adds, 3);
EXPECT_EQ(p->releases, 1);
+ // To avoid hitting a reallocation.
+ bleh.reserve(1);
bleh.push_back(p2);
- EXPECT_EQ(p->adds, 5);
- EXPECT_EQ(p->releases, 2);
+ EXPECT_EQ(p->adds, 4);
+ EXPECT_EQ(p->releases, 1);
EXPECT_EQ(bleh[0], p.get());
bleh.pop_back();
- EXPECT_EQ(p->adds, 5);
- EXPECT_EQ(p->releases, 3);
+ EXPECT_EQ(p->adds, 4);
+ EXPECT_EQ(p->releases, 2);
}
- EXPECT_EQ(p->adds, 5);
- EXPECT_EQ(p->releases, 5);
+ EXPECT_EQ(p->adds, 4);
+ EXPECT_EQ(p->releases, 4);
}