diff options
author | erg@chromium.org <erg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-07-19 00:57:58 +0000 |
---|---|---|
committer | erg@chromium.org <erg@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-07-19 00:57:58 +0000 |
commit | 3ecf8289a6e5d7e07b8e52cf1f3e40bf436e814c (patch) | |
tree | 72b3487aead1628b6375f783ff31646f67337ec6 | |
parent | 1f6c86af09fd5fa00f4717040e57f276fecd46f2 (diff) | |
download | chromium_src-3ecf8289a6e5d7e07b8e52cf1f3e40bf436e814c.zip chromium_src-3ecf8289a6e5d7e07b8e52cf1f3e40bf436e814c.tar.gz chromium_src-3ecf8289a6e5d7e07b8e52cf1f3e40bf436e814c.tar.bz2 |
mojo: Make InterfacePtr<> testable in if() statements without .get().
This also goes and changes a lot of "if (obj.get())" to "if (obj)".
BUG=394639
Review URL: https://codereview.chromium.org/405653003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@284269 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | mojo/examples/nesting_app/nesting_app.cc | 2 | ||||
-rw-r--r-- | mojo/examples/window_manager/window_manager.cc | 2 | ||||
-rw-r--r-- | mojo/gles2/command_buffer_client_impl.cc | 2 | ||||
-rw-r--r-- | mojo/public/cpp/bindings/interface_ptr.h | 10 | ||||
-rw-r--r-- | mojo/public/cpp/bindings/lib/interface_ptr_internal.h | 4 | ||||
-rw-r--r-- | mojo/public/cpp/bindings/tests/handle_passing_unittest.cc | 6 | ||||
-rw-r--r-- | mojo/public/cpp/bindings/tests/interface_ptr_unittest.cc | 14 | ||||
-rw-r--r-- | mojo/services/gles2/command_buffer_impl.cc | 6 | ||||
-rw-r--r-- | mojo/services/html_viewer/html_viewer.cc | 2 | ||||
-rw-r--r-- | mojo/services/native_viewport/native_viewport_service.cc | 2 | ||||
-rw-r--r-- | mojo/services/view_manager/view_manager_init_service_impl.cc | 4 | ||||
-rw-r--r-- | mojo/shell/dynamic_service_loader.cc | 2 | ||||
-rw-r--r-- | mojo/spy/spy.cc | 2 | ||||
-rw-r--r-- | mojo/system/local_data_pipe.cc | 4 | ||||
-rw-r--r-- | mojo/views/native_widget_view_manager.cc | 2 |
15 files changed, 39 insertions, 25 deletions
diff --git a/mojo/examples/nesting_app/nesting_app.cc b/mojo/examples/nesting_app/nesting_app.cc index 9b488d2..e62f1b7 100644 --- a/mojo/examples/nesting_app/nesting_app.cc +++ b/mojo/examples/nesting_app/nesting_app.cc @@ -72,7 +72,7 @@ class NestingApp : public ApplicationDelegate, connection->ConnectToService(&window_manager_); connection->AddService<Navigator>(this); // TODO(davemoore): Is this ok? - if (!navigator_.get()) { + if (!navigator_) { connection->ConnectToApplication( kEmbeddedAppURL)->ConnectToService(&navigator_); } diff --git a/mojo/examples/window_manager/window_manager.cc b/mojo/examples/window_manager/window_manager.cc index f672c5f..e1cb54d 100644 --- a/mojo/examples/window_manager/window_manager.cc +++ b/mojo/examples/window_manager/window_manager.cc @@ -464,7 +464,7 @@ class WindowManager : public ApplicationDelegate, navigation::NavigationDetailsPtr nav_details, navigation::ResponseDetailsPtr response) { node->Embed(app_url); - if (nav_details.get()) { + if (nav_details) { navigation::NavigatorPtr navigator; app_->ConnectToService(app_url, &navigator); navigator->Navigate(node->id(), nav_details.Pass(), response.Pass()); diff --git a/mojo/gles2/command_buffer_client_impl.cc b/mojo/gles2/command_buffer_client_impl.cc index 1a03468..3a71697 100644 --- a/mojo/gles2/command_buffer_client_impl.cc +++ b/mojo/gles2/command_buffer_client_impl.cc @@ -288,7 +288,7 @@ void CommandBufferClientImpl::MakeProgressAndUpdateState() { command_buffer_->MakeProgress(last_state_.get_offset); CommandBufferStatePtr state = sync_client_impl_->WaitForProgress(); - if (!state.get()) { + if (!state) { VLOG(1) << "Channel encountered error while waiting for command buffer"; // TODO(piman): is it ok for this to re-enter? DidDestroy(); diff --git a/mojo/public/cpp/bindings/interface_ptr.h b/mojo/public/cpp/bindings/interface_ptr.h index 0d8473d..eaa57f6 100644 --- a/mojo/public/cpp/bindings/interface_ptr.h +++ b/mojo/public/cpp/bindings/interface_ptr.h @@ -102,6 +102,16 @@ class InterfacePtr { return &internal_state_; } + // Allow InterfacePtr<> to be used in boolean expressions, but not + // implicitly convertible to a real bool (which is dangerous). + private: + typedef internal::InterfacePtrState<Interface> InterfacePtr::*Testable; + + public: + operator Testable() const { + return internal_state_.is_bound() ? &InterfacePtr::internal_state_ : NULL; + } + private: typedef internal::InterfacePtrState<Interface> State; mutable State internal_state_; diff --git a/mojo/public/cpp/bindings/lib/interface_ptr_internal.h b/mojo/public/cpp/bindings/lib/interface_ptr_internal.h index 437ce8e..7e9a262 100644 --- a/mojo/public/cpp/bindings/lib/interface_ptr_internal.h +++ b/mojo/public/cpp/bindings/lib/interface_ptr_internal.h @@ -69,6 +69,10 @@ class InterfacePtrState { return handle_.Pass(); } + bool is_bound() const { + return handle_.is_valid() || router_; + } + void set_client(typename Interface::Client* client) { ConfigureProxyIfNecessary(); diff --git a/mojo/public/cpp/bindings/tests/handle_passing_unittest.cc b/mojo/public/cpp/bindings/tests/handle_passing_unittest.cc index ab2e475..d2e287f 100644 --- a/mojo/public/cpp/bindings/tests/handle_passing_unittest.cc +++ b/mojo/public/cpp/bindings/tests/handle_passing_unittest.cc @@ -94,7 +94,7 @@ class SampleFactoryImpl : public InterfaceImpl<sample::Factory> { response->pipe = pipe0.Pass(); client()->DidStuff(response.Pass(), text1); - if (request->obj.get()) + if (request->obj) request->obj->DoSomething(); } @@ -335,14 +335,14 @@ TEST_F(HandlePassingTest, CreateNamedObject) { BindToProxy(new SampleFactoryImpl(), &factory); sample::NamedObjectPtr object1; - EXPECT_FALSE(object1.get()); + EXPECT_FALSE(object1); InterfaceRequest<sample::NamedObject> object1_request = Get(&object1); EXPECT_TRUE(object1_request.is_pending()); factory->CreateNamedObject(object1_request.Pass()); EXPECT_FALSE(object1_request.is_pending()); // We've passed the request. - ASSERT_TRUE(object1.get()); + ASSERT_TRUE(object1); object1->SetName("object1"); sample::NamedObjectPtr object2; diff --git a/mojo/public/cpp/bindings/tests/interface_ptr_unittest.cc b/mojo/public/cpp/bindings/tests/interface_ptr_unittest.cc index 8f1de63..533d990 100644 --- a/mojo/public/cpp/bindings/tests/interface_ptr_unittest.cc +++ b/mojo/public/cpp/bindings/tests/interface_ptr_unittest.cc @@ -252,19 +252,19 @@ TEST_F(InterfacePtrTest, Movable) { math::CalculatorPtr b; BindToProxy(new MathCalculatorImpl(), &b); - EXPECT_TRUE(!a.get()); - EXPECT_FALSE(!b.get()); + EXPECT_TRUE(!a); + EXPECT_FALSE(!b); a = b.Pass(); - EXPECT_FALSE(!a.get()); - EXPECT_TRUE(!b.get()); + EXPECT_FALSE(!a); + EXPECT_TRUE(!b); } TEST_F(InterfacePtrTest, Resettable) { math::CalculatorPtr a; - EXPECT_TRUE(!a.get()); + EXPECT_TRUE(!a); MessagePipe pipe; @@ -273,11 +273,11 @@ TEST_F(InterfacePtrTest, Resettable) { a = MakeProxy<math::Calculator>(pipe.handle0.Pass()); - EXPECT_FALSE(!a.get()); + EXPECT_FALSE(!a); a.reset(); - EXPECT_TRUE(!a.get()); + EXPECT_TRUE(!a); EXPECT_FALSE(a.internal_state()->router_for_testing()); // Test that handle was closed. diff --git a/mojo/services/gles2/command_buffer_impl.cc b/mojo/services/gles2/command_buffer_impl.cc index 4b836d8..1f40444 100644 --- a/mojo/services/gles2/command_buffer_impl.cc +++ b/mojo/services/gles2/command_buffer_impl.cc @@ -52,7 +52,7 @@ CommandBufferImpl::CommandBufferImpl(gfx::AcceleratedWidget widget, CommandBufferImpl::~CommandBufferImpl() { client()->DidDestroy(); - if (decoder_.get()) { + if (decoder_) { bool have_context = decoder_->MakeCurrent(); decoder_->Destroy(have_context); } @@ -130,7 +130,7 @@ bool CommandBufferImpl::DoInitialize( const size_t kSize = sizeof(gpu::CommandBufferSharedState); scoped_ptr<gpu::BufferBacking> backing( gles2::MojoBufferBacking::Create(shared_state.Pass(), kSize)); - if (!backing.get()) + if (!backing) return false; command_buffer_->SetSharedStateBuffer(backing.Pass()); @@ -159,7 +159,7 @@ void CommandBufferImpl::RegisterTransferBuffer( // This validates the size. scoped_ptr<gpu::BufferBacking> backing( gles2::MojoBufferBacking::Create(transfer_buffer.Pass(), size)); - if (!backing.get()) { + if (!backing) { DVLOG(0) << "Failed to map shared memory."; return; } diff --git a/mojo/services/html_viewer/html_viewer.cc b/mojo/services/html_viewer/html_viewer.cc index 431bbac..8490e69 100644 --- a/mojo/services/html_viewer/html_viewer.cc +++ b/mojo/services/html_viewer/html_viewer.cc @@ -83,7 +83,7 @@ class HTMLViewer : public ApplicationDelegate, } void MaybeLoad() { - if (document_view_ && response_.get()) + if (document_view_ && response_) document_view_->Load(response_.Pass()); } diff --git a/mojo/services/native_viewport/native_viewport_service.cc b/mojo/services/native_viewport/native_viewport_service.cc index b7c8052..203ec10 100644 --- a/mojo/services/native_viewport/native_viewport_service.cc +++ b/mojo/services/native_viewport/native_viewport_service.cc @@ -73,7 +73,7 @@ class NativeViewportImpl virtual void CreateGLES2Context( InterfaceRequest<CommandBuffer> command_buffer_request) OVERRIDE { - if (command_buffer_.get() || command_buffer_request_.is_pending()) { + if (command_buffer_ || command_buffer_request_.is_pending()) { LOG(ERROR) << "Can't create multiple contexts on a NativeViewport"; return; } diff --git a/mojo/services/view_manager/view_manager_init_service_impl.cc b/mojo/services/view_manager/view_manager_init_service_impl.cc index 9cb337b..f7822fc 100644 --- a/mojo/services/view_manager/view_manager_init_service_impl.cc +++ b/mojo/services/view_manager/view_manager_init_service_impl.cc @@ -44,7 +44,7 @@ void ViewManagerInitServiceImpl::MaybeEmbedRoot( void ViewManagerInitServiceImpl::EmbedRoot( const String& url, const Callback<void(bool)>& callback) { - if (connect_params_.get()) { + if (connect_params_) { DVLOG(1) << "Ignoring second connect"; callback.Run(false); return; @@ -58,7 +58,7 @@ void ViewManagerInitServiceImpl::EmbedRoot( void ViewManagerInitServiceImpl::OnRootViewManagerWindowTreeHostCreated() { DCHECK(!is_tree_host_ready_); is_tree_host_ready_ = true; - if (connect_params_.get()) + if (connect_params_) MaybeEmbedRoot(connect_params_->url, connect_params_->callback); } diff --git a/mojo/shell/dynamic_service_loader.cc b/mojo/shell/dynamic_service_loader.cc index 6f1fc80..5939d4b 100644 --- a/mojo/shell/dynamic_service_loader.cc +++ b/mojo/shell/dynamic_service_loader.cc @@ -167,7 +167,7 @@ void DynamicServiceLoader::LoadService(ServiceManager* manager, if (resolved_url.SchemeIsFile()) { loader = new LocalLoader(runner.Pass()); } else { - if (!network_service_.get()) { + if (!network_service_) { context_->service_manager()->ConnectToService( GURL("mojo:mojo_network_service"), &network_service_); diff --git a/mojo/spy/spy.cc b/mojo/spy/spy.cc index 58310d8..4c7ed0d 100644 --- a/mojo/spy/spy.cc +++ b/mojo/spy/spy.cc @@ -239,7 +239,7 @@ class SpyInterceptor : public mojo::ServiceManager::Interceptor { // You can get an invalid handle if the app (or service) is // created by unconventional means, for example the command line. - if (!real_client.get()) + if (!real_client) return real_client.Pass(); mojo::ScopedMessagePipeHandle faux_client; diff --git a/mojo/system/local_data_pipe.cc b/mojo/system/local_data_pipe.cc index 8f4bbd6a..eb799cc 100644 --- a/mojo/system/local_data_pipe.cc +++ b/mojo/system/local_data_pipe.cc @@ -287,7 +287,7 @@ HandleSignalsState LocalDataPipe::ConsumerGetHandleSignalsStateNoLock() const { void LocalDataPipe::EnsureBufferNoLock() { DCHECK(producer_open_no_lock()); - if (buffer_.get()) + if (buffer_) return; buffer_.reset(static_cast<char*>( base::AlignedAlloc(capacity_num_bytes(), kDataPipeBufferAlignmentBytes))); @@ -297,7 +297,7 @@ void LocalDataPipe::DestroyBufferNoLock() { #ifndef NDEBUG // Scribble on the buffer to help detect use-after-frees. (This also helps the // unit test detect certain bugs without needing ASAN or similar.) - if (buffer_.get()) + if (buffer_) memset(buffer_.get(), 0xcd, capacity_num_bytes()); #endif buffer_.reset(); diff --git a/mojo/views/native_widget_view_manager.cc b/mojo/views/native_widget_view_manager.cc index e4b0248..69fcf7f 100644 --- a/mojo/views/native_widget_view_manager.cc +++ b/mojo/views/native_widget_view_manager.cc @@ -162,7 +162,7 @@ void NativeWidgetViewManager::OnNodeActiveViewChanged( void NativeWidgetViewManager::OnViewInputEvent(view_manager::View* view, const EventPtr& event) { scoped_ptr<ui::Event> ui_event(event.To<scoped_ptr<ui::Event> >()); - if (ui_event.get()) + if (ui_event) window_tree_host_->SendEventToProcessor(ui_event.get()); } |