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

Side by Side Diff: device/gamepad/gamepad_data_fetcher_manager.cc

Issue 2129003002: Refactored gamepad polling to support dynamic sources (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed unit test issue and Mac XBoxDataFetcher constructor Created 4 years, 5 months 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "device/gamepad/gamepad_data_fetcher_manager.h"
6
7 #include "device/gamepad/gamepad_data_fetcher.h"
8 #include "device/gamepad/gamepad_platform_data_fetcher.h"
9
10 namespace device {
11
12 namespace {
13 GamepadDataFetcherManager* g_gamepad_data_fetcher_manager = 0;
14 }
15
16 GamepadDataFetcherManager::GamepadDataFetcherManager() : provider_(nullptr) {}
17
18 GamepadDataFetcherManager::~GamepadDataFetcherManager() {}
19
20 GamepadDataFetcherManager* GamepadDataFetcherManager::GetInstance() {
21 if (!g_gamepad_data_fetcher_manager) {
22 g_gamepad_data_fetcher_manager = new GamepadDataFetcherManager;
23
24 // Add platform specific data fetchers
25 AddGamepadPlatformDataFetchers(g_gamepad_data_fetcher_manager);
26 }
27 return g_gamepad_data_fetcher_manager;
28 }
29
30 void GamepadDataFetcherManager::AddFactory(GamepadDataFetcherFactory* factory) {
31 factories_.push_back(factory);
32 if (provider_) {
33 provider_->AddGamepadDataFetcher(factory->CreateDataFetcher());
34 }
35 }
36
37 void GamepadDataFetcherManager::RemoveSourceFactory(GamepadSource source) {
38 if (provider_)
39 provider_->RemoveSourceGamepadDataFetcher(source);
40
41 for (FactoryVector::iterator it = factories_.begin(); it != factories_.end();
42 ++it) {
43 if ((*it)->source() == source) {
44 delete (*it);
45 factories_.erase(it);
46 }
47 }
48 }
49
50 void GamepadDataFetcherManager::InitializeProvider(GamepadProvider* provider) {
51 DCHECK(!provider_);
52
53 provider_ = provider;
54 for (const auto& it : factories_) {
55 provider_->AddGamepadDataFetcher(it->CreateDataFetcher());
56 }
57 }
58
59 void GamepadDataFetcherManager::ClearProvider() {
60 provider_ = nullptr;
61 }
62
63 } // namespace device
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698