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

Side by Side Diff: ui/base/dragdrop/os_exchange_data_provider_factory.cc

Issue 2179813003: Allow OSExchangeData::Provider to be overridden at run time. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Delete that. ;_; Created 4 years, 4 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 "ui/base/dragdrop/os_exchange_data_provider_factory.h"
6
7 #if defined(USE_X11) && !defined(OS_CHROMEOS)
8 #include "ui/base/dragdrop/os_exchange_data_provider_aurax11.h"
9 #elif defined(OS_LINUX)
10 #include "ui/base/dragdrop/os_exchange_data_provider_aura.h"
11 #elif defined(OS_MACOSX)
12 #include "ui/base/dragdrop/os_exchange_data_provider_builder_mac.h"
13 #elif defined(OS_WIN)
14 #include "ui/base/dragdrop/os_exchange_data_provider_win.h"
15 #endif
16
17 namespace ui {
18
19 OSExchangeDataProviderFactory::Factory* factory_ = nullptr;
20
21 // static
22 void OSExchangeDataProviderFactory::SetFactory(Factory* factory) {
23 factory_ = factory;
24 }
25
26 //static
27 OSExchangeData::Provider* OSExchangeDataProviderFactory::CreateProvider() {
28 if (factory_)
29 return factory_->BuildProvider();
30
31 #if defined(USE_X11) && !defined(OS_CHROMEOS)
32 return new OSExchangeDataProviderAuraX11();
33 #elif defined(OS_LINUX)
34 return new OSExchangeDataProviderAura();
35 #elif defined(OS_MACOSX)
36 return ui::BuildOSExchangeDataProviderMac();
37 #elif defined(OS_WIN)
38 return new OSExchangeDataProviderWin();
39 #else
40 #error "Unknown operating system"
41 #endif
42 }
43
44 } // namespace ui
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698