| Index: components/arc/arc_bridge_service.cc
|
| diff --git a/components/arc/arc_bridge_service.cc b/components/arc/arc_bridge_service.cc
|
| index 80e70b66ca107b232327934014ccc0a3c84ca4ca..ad8a7c4b9503793735cbed074f76dfb7778d757d 100644
|
| --- a/components/arc/arc_bridge_service.cc
|
| +++ b/components/arc/arc_bridge_service.cc
|
| @@ -17,8 +17,10 @@ namespace arc {
|
| ArcBridgeService* g_arc_bridge_service = nullptr;
|
|
|
| ArcBridgeService::ArcBridgeService()
|
| - : available_(false), state_(State::STOPPED), weak_factory_(this) {
|
| -}
|
| + : available_(false),
|
| + state_(State::STOPPED),
|
| + stop_reason_(StopReason::SHUTDOWN),
|
| + weak_factory_(this) {}
|
|
|
| ArcBridgeService::~ArcBridgeService() {
|
| DCHECK(CalledOnValidThread());
|
| @@ -167,7 +169,7 @@ void ArcBridgeService::SetState(State state) {
|
| if (state_ == State::READY)
|
| FOR_EACH_OBSERVER(Observer, observer_list(), OnBridgeReady());
|
| else if (state == State::STOPPED)
|
| - FOR_EACH_OBSERVER(Observer, observer_list(), OnBridgeStopped());
|
| + FOR_EACH_OBSERVER(Observer, observer_list(), OnBridgeStopped(stop_reason_));
|
| }
|
|
|
| void ArcBridgeService::SetAvailable(bool available) {
|
| @@ -177,6 +179,11 @@ void ArcBridgeService::SetAvailable(bool available) {
|
| FOR_EACH_OBSERVER(Observer, observer_list(), OnAvailableChanged(available_));
|
| }
|
|
|
| +void ArcBridgeService::SetStopReason(StopReason stop_reason) {
|
| + DCHECK(CalledOnValidThread());
|
| + stop_reason_ = stop_reason;
|
| +}
|
| +
|
| bool ArcBridgeService::CalledOnValidThread() {
|
| return thread_checker_.CalledOnValidThread();
|
| }
|
|
|