blob: 6c44d936e1f896f71d80682fbcc0e81a0824a3bd [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef UI_DISPLAY_MANAGER_CONFIGURE_DISPLAYS_TASK_H_
#define UI_DISPLAY_MANAGER_CONFIGURE_DISPLAYS_TASK_H_
#include <stddef.h>
#include <queue>
#include <vector>
#include "base/callback.h"
#include "base/containers/queue.h"
#include "base/macros.h"
#include "base/memory/weak_ptr.h"
#include "ui/display/manager/display_manager_export.h"
#include "ui/display/types/native_display_observer.h"
#include "ui/gfx/geometry/point.h"
namespace display {
class DisplayMode;
class DisplaySnapshot;
class NativeDisplayDelegate;
struct DISPLAY_MANAGER_EXPORT DisplayConfigureRequest {
DisplayConfigureRequest(DisplaySnapshot* display,
const DisplayMode* mode,
const gfx::Point& origin);
DisplaySnapshot* display;
const DisplayMode* mode;
gfx::Point origin;
};
// Applies the display configuration asynchronously.
class DISPLAY_MANAGER_EXPORT ConfigureDisplaysTask
: public NativeDisplayObserver {
public:
enum Status {
// At least one of the displays failed to apply any mode it supports.
ERROR,
// The requested configuration was applied.
SUCCESS,
// At least one of the displays failed to apply the requested
// configuration, but it managed to fall back to another mode.
PARTIAL_SUCCESS,
};
typedef base::Callback<void(Status)> ResponseCallback;
ConfigureDisplaysTask(NativeDisplayDelegate* delegate,
const std::vector<DisplayConfigureRequest>& requests,
const ResponseCallback& callback);
~ConfigureDisplaysTask() override;
// Starts the configuration task.
void Run();
// display::NativeDisplayObserver:
void OnConfigurationChanged() override;
void OnDisplaySnapshotsInvalidated() override;
private:
void OnConfigured(size_t index, bool success);
NativeDisplayDelegate* delegate_; // Not owned.
std::vector<DisplayConfigureRequest> requests_;
// When the task finishes executing it runs the callback to notify that the
// task is done and the task status.
ResponseCallback callback_;
// Stores the indexes of pending requests in |requests_|.
base::queue<size_t> pending_request_indexes_;
// Used to keep make sure that synchronous executions do not recurse during
// the configuration.
bool is_configuring_;
// Number of display configured. This is used to check whether there are
// pending requests.
size_t num_displays_configured_;
Status task_status_;
base::WeakPtrFactory<ConfigureDisplaysTask> weak_ptr_factory_;
DISALLOW_COPY_AND_ASSIGN(ConfigureDisplaysTask);
};
} // namespace display
#endif // UI_DISPLAY_MANAGER_CONFIGURE_DISPLAYS_TASK_H_