chromium/components/exo/wayland/zaura_output_manager.h

// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef COMPONENTS_EXO_WAYLAND_ZAURA_OUTPUT_MANAGER_H_
#define COMPONENTS_EXO_WAYLAND_ZAURA_OUTPUT_MANAGER_H_

#include <aura-shell-server-protocol.h>

#include <cstdint>

#include "base/memory/raw_ptr.h"

namespace display {
class Display;
}  // namespace display

namespace exo::wayland {

inline constexpr uint32_t kZAuraOutputManagerVersion =
    ZAURA_OUTPUT_MANAGER_OVERSCAN_INSETS_SINCE_VERSION;

void bind_aura_output_manager(wl_client* client,
                              void* data,
                              uint32_t version,
                              uint32_t id);

// Responsible for relaying display/output state required by clients for all
// supported output extensions when first bound and subsequently as needed.
class AuraOutputManager {
 public:
  explicit AuraOutputManager(wl_resource* manager_resource);
  AuraOutputManager(const AuraOutputManager&) = delete;
  AuraOutputManager& operator=(const AuraOutputManager&) = delete;
  virtual ~AuraOutputManager() = default;

  // Returns nullptr if there is no metrics manager bound to `client`.
  static AuraOutputManager* Get(wl_client* client);

  // Returns the display id associated with the `output_resource`. Returns
  // display::kInvalidDisplayId if `output_resource` is nullptr.
  static int64_t GetDisplayIdForOutput(wl_resource* outout_resource);

  // Dispatches multiple events to the client for the full set of output state
  // required to correctly represent a display. Returns true if any state events
  // were sent based on the the bit-flags in `changed_metrics`.
  bool SendOutputMetrics(wl_resource* output_resource,
                         const display::Display& display,
                         uint32_t changed_metrics);

  // Dispatches the activated event for the `output_resource` to the associated
  // client.
  void SendOutputActivated(wl_resource* output_resource);

 private:
  const raw_ptr<wl_client> client_;
  const raw_ptr<wl_resource> manager_resource_;
};

}  // namespace exo::wayland

#endif  // COMPONENTS_EXO_WAYLAND_ZAURA_OUTPUT_MANAGER_H_