Index: ash/monitor/multi_monitor_manager.cc |
diff --git a/ash/monitor/multi_monitor_manager.cc b/ash/monitor/multi_monitor_manager.cc |
index 926aac119c4f9e2e43086d13e2643e1345b30bc2..01a9f0232c64926261d0c2ccfc217367acf591d0 100644 |
--- a/ash/monitor/multi_monitor_manager.cc |
+++ b/ash/monitor/multi_monitor_manager.cc |
@@ -90,11 +90,15 @@ void MultiMonitorManager::OnNativeMonitorsChanged( |
NotifyMonitorAdded(monitor); |
} |
} else { |
- // Monitors are removed. |
- while (monitors_.size() > new_monitors.size()) { |
+ // Monitors are removed. We keep the monitor for the primary |
+ // monitor (at index 0) because it needs the monitor information |
+ // even if it doesn't exit. |
+ while (monitors_.size() > new_monitors.size() && monitors_.size() > 1) { |
Monitor* monitor = monitors_.back(); |
// Monitor object is deleted in OnWindowDestroying. |
NotifyMonitorRemoved(monitor); |
+ DCHECK(find(monitors_.begin(), monitors_.end(), monitor) == |
+ monitors_.end()); |
} |
} |
} |