Chromium Code Reviews| Index: ui/base/touch/touch_enabled.cc |
| diff --git a/ui/base/touch/touch_enabled.cc b/ui/base/touch/touch_enabled.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..6791a2557699be88b3363cfa3e3ae3669ecfb112 |
| --- /dev/null |
| +++ b/ui/base/touch/touch_enabled.cc |
| @@ -0,0 +1,51 @@ |
| +// Copyright 2015 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/base/touch/touch_enabled.h" |
| + |
| +#include "base/command_line.h" |
| +#include "base/logging.h" |
| +#include "ui/base/touch/touch_device.h" |
| +#include "ui/base/ui_base_switches.h" |
| +#include "ui/events/base_event_utils.h" |
| +#include "ui/events/event_switches.h" |
| + |
| +namespace ui { |
| + |
| +namespace { |
| + |
| +bool ComputeTouchStatus() { |
| + auto* command_line = base::CommandLine::ForCurrentProcess(); |
| + const std::string touch_enabled_switch = |
| + command_line->HasSwitch(switches::kTouchEvents) ? |
| + command_line->GetSwitchValueASCII(switches::kTouchEvents) : |
| + switches::kTouchEventsAuto; |
| + |
| + if (touch_enabled_switch.empty() || |
| + touch_enabled_switch == switches::kTouchEventsEnabled) { |
| + return true; |
| + } |
| + |
| + if (touch_enabled_switch == switches::kTouchEventsAuto) |
| + return IsTouchDevicePresent(); |
| + |
| + DLOG_IF(ERROR, touch_enabled_switch != switches::kTouchEventsDisabled) << |
| + "Invalid --touch-events option: " << touch_enabled_switch; |
| + return false; |
| +} |
| + |
| +} // namespace |
| + |
| +bool AreTouchEventsEnabled() { |
| + static bool touch_status = ComputeTouchStatus(); |
| + |
| +#if defined(OS_CHROMEOS) && defined(USE_X11) |
| + return touch_status && GetTouchEventsCrOsX11MasterSwitch(); |
|
sadrul
2015/11/18 20:58:46
On a chromeos device build (i.e. when USE_X11 is n
afakhry
2015/11/18 21:03:13
On non-X11 ChromeOS builds (i.e. Ozone builds) we
sadrul
2015/11/18 21:14:30
The various places that call AreTouchEventsEnabled
afakhry
2015/11/18 21:33:04
Valid point! Thanks. I now set the switch on ozone
|
| +#else |
| + return touch_status; |
| +#endif // !defined(OS_CHROMEOS) && defined(USE_X11) |
| +} |
| + |
| +} // namespace ui |
| + |