// Copyright (c) 2012 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. #include "ui/aura/env.h" #include "base/command_line.h" #include "ui/aura/env_observer.h" #include "ui/aura/input_state_lookup.h" #include "ui/aura/window.h" #include "ui/compositor/compositor.h" #include "ui/compositor/compositor_switches.h" #include "ui/events/event_target_iterator.h" #if defined(USE_X11) #include "base/message_loop/message_pump_x11.h" #endif namespace aura { // static Env* Env::instance_ = NULL; //////////////////////////////////////////////////////////////////////////////// // Env, public: Env::Env() : mouse_button_flags_(0), is_touch_down_(false), input_state_lookup_(InputStateLookup::Create().Pass()) { } Env::~Env() { #if defined(USE_X11) base::MessagePumpX11::Current()->RemoveObserver( &device_list_updater_aurax11_); #endif FOR_EACH_OBSERVER(EnvObserver, observers_, OnWillDestroyEnv()); ui::Compositor::Terminate(); } //static void Env::CreateInstance() { if (!instance_) { instance_ = new Env; instance_->Init(); } } // static Env* Env::GetInstance() { DCHECK(instance_) << "Env::CreateInstance must be called before getting " "the instance of Env."; return instance_; } // static void Env::DeleteInstance() { delete instance_; instance_ = NULL; } void Env::AddObserver(EnvObserver* observer) { observers_.AddObserver(observer); } void Env::RemoveObserver(EnvObserver* observer) { observers_.RemoveObserver(observer); } bool Env::IsMouseButtonDown() const { return input_state_lookup_.get() ? input_state_lookup_->IsMouseButtonDown() : mouse_button_flags_ != 0; } #if !defined(OS_MACOSX) && !defined(OS_ANDROID) && \ !defined(USE_GTK_MESSAGE_PUMP) base::MessageLoop::Dispatcher* Env::GetDispatcher() { #if defined(USE_X11) return base::MessagePumpX11::Current(); #else return dispatcher_.get(); #endif } #endif void Env::RootWindowActivated(RootWindow* root_window) { FOR_EACH_OBSERVER(EnvObserver, observers_, OnRootWindowActivated(root_window)); } //////////////////////////////////////////////////////////////////////////////// // Env, private: void Env::Init() { #if !defined(OS_MACOSX) && !defined(OS_ANDROID) && !defined(USE_X11) && \ !defined(USE_OZONE) dispatcher_.reset(CreateDispatcher()); #endif #if defined(USE_X11) // We can't do this with a root window listener because XI_HierarchyChanged // messages don't have a target window. base::MessagePumpX11::Current()->AddObserver( &device_list_updater_aurax11_); #endif ui::Compositor::Initialize(); } void Env::NotifyWindowInitialized(Window* window) { FOR_EACH_OBSERVER(EnvObserver, observers_, OnWindowInitialized(window)); } void Env::NotifyRootWindowInitialized(RootWindow* root_window) { FOR_EACH_OBSERVER(EnvObserver, observers_, OnRootWindowInitialized(root_window)); } //////////////////////////////////////////////////////////////////////////////// // Env, ui::EventTarget implementation: bool Env::CanAcceptEvent(const ui::Event& event) { return true; } ui::EventTarget* Env::GetParentTarget() { return NULL; } scoped_ptr<ui::EventTargetIterator> Env::GetChildIterator() const { return scoped_ptr<ui::EventTargetIterator>(); } ui::EventTargeter* Env::GetEventTargeter() { NOTREACHED(); return NULL; } } // namespace aura