Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <string> | 5 #include <string> |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "ui/base/material_design/material_design_controller.h" | 9 #include "ui/base/material_design/material_design_controller.h" |
| 10 #include "ui/base/touch/touch_device.h" | |
| 10 #include "ui/base/ui_base_switches.h" | 11 #include "ui/base/ui_base_switches.h" |
| 11 | 12 |
| 12 #if defined(OS_CHROMEOS) | 13 #if defined(OS_CHROMEOS) |
| 13 #include "base/strings/string_util.h" | 14 #include <fcntl.h> |
| 14 #include "base/sys_info.h" | 15 |
| 16 #include "base/files/file_enumerator.h" | |
| 17 #include "ui/events/devices/device_data_manager.h" | |
| 18 #include "ui/events/ozone/evdev/event_device_info.h" | |
| 15 #endif // defined(OS_CHROMEOS) | 19 #endif // defined(OS_CHROMEOS) |
| 16 | 20 |
| 17 namespace ui { | 21 namespace ui { |
| 18 | 22 |
| 19 bool MaterialDesignController::is_mode_initialized_ = false; | 23 bool MaterialDesignController::is_mode_initialized_ = false; |
| 20 | 24 |
| 21 MaterialDesignController::Mode MaterialDesignController::mode_ = | 25 MaterialDesignController::Mode MaterialDesignController::mode_ = |
| 22 MaterialDesignController::Mode::NON_MATERIAL; | 26 MaterialDesignController::Mode::NON_MATERIAL; |
| 23 | 27 |
| 24 MaterialDesignController::Mode MaterialDesignController::GetMode() { | 28 MaterialDesignController::Mode MaterialDesignController::GetMode() { |
| 25 if (!is_mode_initialized_) | 29 if (!is_mode_initialized_) |
| 26 InitializeMode(); | 30 InitializeMode(); |
| 27 CHECK(is_mode_initialized_); | 31 CHECK(is_mode_initialized_); |
| 28 return mode_; | 32 return mode_; |
| 29 } | 33 } |
| 30 | 34 |
| 31 bool MaterialDesignController::IsModeMaterial() { | 35 bool MaterialDesignController::IsModeMaterial() { |
| 36 if (!is_mode_initialized_) | |
| 37 return UseMaterialOrMaterialHybridByDefault(); | |
| 38 | |
| 32 return GetMode() == Mode::MATERIAL_NORMAL || | 39 return GetMode() == Mode::MATERIAL_NORMAL || |
| 33 GetMode() == Mode::MATERIAL_HYBRID; | 40 GetMode() == Mode::MATERIAL_HYBRID; |
| 34 } | 41 } |
| 35 | 42 |
| 36 MaterialDesignController::Mode MaterialDesignController::DefaultMode() { | |
| 37 #if defined(OS_CHROMEOS) | |
| 38 // TODO(tdanderson): Enable hybrid by default for touchscreen devices. | |
| 39 // See crbug.com/588880. | |
| 40 const std::string board = base::SysInfo::GetLsbReleaseBoard(); | |
| 41 if (base::StartsWith(board, "link", base::CompareCase::SENSITIVE) || | |
| 42 base::StartsWith(board, "veyron_minnie", base::CompareCase::SENSITIVE) || | |
| 43 base::StartsWith(board, "samus", base::CompareCase::SENSITIVE)) { | |
| 44 return Mode::MATERIAL_HYBRID; | |
| 45 } | |
| 46 return Mode::MATERIAL_NORMAL; | |
| 47 #else | |
| 48 return Mode::NON_MATERIAL; | |
| 49 #endif // defined(OS_CHROMEOS) | |
| 50 } | |
| 51 | |
| 52 void MaterialDesignController::InitializeMode() { | 43 void MaterialDesignController::InitializeMode() { |
| 53 #if !defined(ENABLE_TOPCHROME_MD) | 44 #if !defined(ENABLE_TOPCHROME_MD) |
| 54 SetMode(Mode::NON_MATERIAL); | 45 SetMode(Mode::NON_MATERIAL); |
| 55 #else | 46 #else |
| 56 const std::string switch_value = | 47 const std::string switch_value = |
| 57 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( | 48 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
| 58 switches::kTopChromeMD); | 49 switches::kTopChromeMD); |
| 59 | 50 |
| 60 if (switch_value == switches::kTopChromeMDMaterial) { | 51 if (switch_value == switches::kTopChromeMDMaterial) { |
| 61 SetMode(Mode::MATERIAL_NORMAL); | 52 SetMode(Mode::MATERIAL_NORMAL); |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 78 MaterialDesignController::SetMode( | 69 MaterialDesignController::SetMode( |
| 79 MaterialDesignController::Mode::NON_MATERIAL); | 70 MaterialDesignController::Mode::NON_MATERIAL); |
| 80 is_mode_initialized_ = false; | 71 is_mode_initialized_ = false; |
| 81 } | 72 } |
| 82 | 73 |
| 83 void MaterialDesignController::SetMode(MaterialDesignController::Mode mode) { | 74 void MaterialDesignController::SetMode(MaterialDesignController::Mode mode) { |
| 84 mode_ = mode; | 75 mode_ = mode; |
| 85 is_mode_initialized_ = true; | 76 is_mode_initialized_ = true; |
| 86 } | 77 } |
| 87 | 78 |
| 79 MaterialDesignController::Mode MaterialDesignController::DefaultMode() { | |
| 80 if (!UseMaterialOrMaterialHybridByDefault()) | |
| 81 return Mode::NON_MATERIAL; | |
| 82 | |
| 83 #if defined(OS_CHROMEOS) | |
| 84 if (!DeviceDataManager::GetInstance()->device_lists_complete()) { | |
| 85 base::FileEnumerator file_enum( | |
| 86 base::FilePath(FILE_PATH_LITERAL("/dev/input")), false, | |
| 87 base::FileEnumerator::FILES, FILE_PATH_LITERAL("event*[0-9]")); | |
| 88 for (base::FilePath path = file_enum.Next(); !path.empty(); | |
| 89 path = file_enum.Next()) { | |
| 90 EventDeviceInfo devinfo; | |
| 91 int fd = open(path.value().c_str(), O_RDWR | O_NONBLOCK); | |
|
vapier
2016/03/02 21:51:54
you should use O_CLOEXEC all the time unless you h
tdanderson
2016/03/04 19:45:53
Done.
| |
| 92 if (fd >= 0 && devinfo.Initialize(fd, path) && devinfo.HasTouchscreen()) | |
|
vapier
2016/03/02 21:51:54
doesn't this leak fd ?
tdanderson
2016/03/04 19:45:53
Done.
| |
| 93 return Mode::MATERIAL_HYBRID; | |
| 94 } | |
| 95 } else if (GetTouchScreensAvailability() == | |
| 96 TouchScreensAvailablity::ENABLED) { | |
| 97 return Mode::MATERIAL_HYBRID; | |
| 98 } | |
| 99 #endif // defined(OS_CHROMEOS) | |
| 100 | |
| 101 return Mode::MATERIAL_NORMAL; | |
| 102 } | |
| 103 | |
| 104 bool MaterialDesignController::UseMaterialOrMaterialHybridByDefault() { | |
| 105 #if defined(OS_CHROMEOS) | |
| 106 return true; | |
| 107 #else | |
| 108 return false; | |
| 109 #endif // defined(OS_CHROMEOS) | |
| 110 } | |
| 111 | |
| 88 } // namespace ui | 112 } // namespace ui |
| OLD | NEW |