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

Unified Diff: base/win/enum_variant.h

Issue 8588036: Improve support for multiselect list box accessibility on Windows. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: base/win/enum_variant.h
===================================================================
--- base/win/enum_variant.h (revision 0)
+++ base/win/enum_variant.h (revision 0)
@@ -0,0 +1,56 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef BASE_WIN_ENUM_VARIANT_H_
+#define BASE_WIN_ENUM_VARIANT_H_
+#pragma once
+
+#include <unknwn.h>
+
+#include "base/memory/scoped_ptr.h"
+
+namespace base {
+namespace win {
+
+// A simple implementation of IEnumVARIANT.
+class BASE_EXPORT EnumVariant : public IEnumVARIANT {
darin (slow to review) 2011/11/22 01:16:52 I know you are naming this based on the interface
dmazzoni 2011/11/22 08:08:14 In this case, I favor something closer to the inte
+ public:
+ // The constructor allocates an array of size |count|. Then use
+ // itemAt to set the value of each item in the array to initialize it.
darin (slow to review) 2011/11/22 01:16:52 This comment refers to a function named "itemAt" t
dmazzoni 2011/11/22 08:08:14 Renamed get() -> ItemAt() as per your suggestion b
+ EnumVariant(unsigned long count);
+ virtual ~EnumVariant();
darin (slow to review) 2011/11/22 01:16:52 The destructor should not be public as deleting a
dmazzoni 2011/11/22 08:08:14 Done.
+
+ VARIANT* get(unsigned long index);
darin (slow to review) 2011/11/22 01:16:52 nit: non-inline functions should be given CamelCas
dmazzoni 2011/11/22 08:08:14 Changed back to ItemAt (as you can see from the co
+
+ // IUnknown.
+ ULONG STDMETHODCALLTYPE AddRef();
+
darin (slow to review) 2011/11/22 01:16:52 nit: nuke the extra new lines between method decla
dmazzoni 2011/11/22 08:08:14 Done.
+ ULONG STDMETHODCALLTYPE Release();
+
+ STDMETHODIMP QueryInterface(REFIID riid, void** ppv);
+
+ // IEnumVARIANT.
+ STDMETHODIMP Next(ULONG requested_count,
+ VARIANT* out_elements,
+ ULONG* out_elements_received);
+
+ STDMETHODIMP Skip(ULONG skip_count);
+
+ STDMETHODIMP Reset();
+
+ STDMETHODIMP Clone(IEnumVARIANT** out_cloned_object);
+
+ private:
+ scoped_array<VARIANT> items_;
+ ULONG count_;
+ ULONG current_index_;
+
+ // IUnknown ref count.
+ ULONG iunknown_ref_count_;
darin (slow to review) 2011/11/22 01:16:52 nit: why bother with the iunknown_ prefix here? i
dmazzoni 2011/11/22 08:08:14 Unfortunately RefCountedThreadSafe has its own Add
+};
+
+} // namespace win
+} // namespace base
+
+#endif // BASE_WIN_ENUM_VARIANT_H_
« no previous file with comments | « base/base.gypi ('k') | base/win/enum_variant.cc » ('j') | base/win/enum_variant.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698