This change moves ScopedComInitializer out of core_audio_utility and into rtc_base/win so it can be reused elsewhere more easily. It also adds HSTRING and GetActivationFactory functionality to rtc_base/win. These two were heavily based on what is already present base/win. All of these are necessary for the new window capturer based on the Windows.Graphics.Capture API. You can see how these APIs will be used in this CL: 186603: Implement WgcCaptureSession | https://webrtc-review.googlesource.com/c/src/+/186603 Bug: webrtc:9273 Change-Id: I0a36373aac98be779ccbabe1053bb8d6e234f6a3 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/188523 Commit-Queue: Tommi <tommi@webrtc.org> Reviewed-by: Tommi <tommi@webrtc.org> Cr-Commit-Position: refs/heads/master@{#32522}
55 lines
2.0 KiB
C++
55 lines
2.0 KiB
C++
/*
|
|
* Copyright (c) 2020 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include "rtc_base/win/scoped_com_initializer.h"
|
|
|
|
namespace webrtc {
|
|
|
|
ScopedCOMInitializer::ScopedCOMInitializer() {
|
|
RTC_DLOG(INFO) << "Single-Threaded Apartment (STA) COM thread";
|
|
Initialize(COINIT_APARTMENTTHREADED);
|
|
}
|
|
|
|
// Constructor for MTA initialization.
|
|
ScopedCOMInitializer::ScopedCOMInitializer(SelectMTA mta) {
|
|
RTC_DLOG(INFO) << "Multi-Threaded Apartment (MTA) COM thread";
|
|
Initialize(COINIT_MULTITHREADED);
|
|
}
|
|
|
|
ScopedCOMInitializer::~ScopedCOMInitializer() {
|
|
if (Succeeded()) {
|
|
CoUninitialize();
|
|
}
|
|
}
|
|
|
|
void ScopedCOMInitializer::Initialize(COINIT init) {
|
|
// Initializes the COM library for use by the calling thread, sets the
|
|
// thread's concurrency model, and creates a new apartment for the thread
|
|
// if one is required. CoInitializeEx must be called at least once, and is
|
|
// usually called only once, for each thread that uses the COM library.
|
|
hr_ = CoInitializeEx(NULL, init);
|
|
RTC_CHECK_NE(RPC_E_CHANGED_MODE, hr_)
|
|
<< "Invalid COM thread model change (MTA->STA)";
|
|
// Multiple calls to CoInitializeEx by the same thread are allowed as long
|
|
// as they pass the same concurrency flag, but subsequent valid calls
|
|
// return S_FALSE. To close the COM library gracefully on a thread, each
|
|
// successful call to CoInitializeEx, including any call that returns
|
|
// S_FALSE, must be balanced by a corresponding call to CoUninitialize.
|
|
if (hr_ == S_OK) {
|
|
RTC_DLOG(INFO)
|
|
<< "The COM library was initialized successfully on this thread";
|
|
} else if (hr_ == S_FALSE) {
|
|
RTC_DLOG(WARNING)
|
|
<< "The COM library is already initialized on this thread";
|
|
}
|
|
}
|
|
|
|
} // namespace webrtc
|