blob: 6bdab39e71508ffa2d10c641d37c0b12dde54134 [file] [log] [blame]
// Copyright 2020 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_GTK_GTK_UI_DELEGATE_H_
#define UI_GTK_GTK_UI_DELEGATE_H_
#include "base/component_export.h"
#include "ui/gfx/native_widget_types.h"
using GdkKeymap = struct _GdkKeymap;
using GdkWindow = struct _GdkWindow;
namespace ui {
// GtkUiDelegate encapsulates platform-specific functionalities required by
// a Gtk-based LinuxUI implementation. The main goal of this interface is to
// make GtkUi platform agnostic, moving the platform specifics to lower level
// layers (e.g: ozone). Linux backends (e.g: ozone/x11, aura/x11, ozone/wayland)
// must provide a GtkUiDelegate implementation and inject its singleton instance
// of it via |SetInstance| in order to be able to use GtkUi.
class COMPONENT_EXPORT(UI_GTK) GtkUiDelegate {
public:
virtual ~GtkUiDelegate() = default;
// Sets the singleton delegate instance to be used by GtkUi. This makes it
// possible for ozone-based backends, for example, to inject the GtkUiDelegate
// object without polluting Ozone API, since just a small subset of ozone
// backends make use of GtkUi. This pointer is not owned, and if this method
// is called a second time, the first instance is not deleted.
static void SetInstance(GtkUiDelegate* instance);
// Returns the current active instance.
static GtkUiDelegate* instance();
// Gets the GdkKeymap instance, which is used to translate KeyEvents into
// GdkEvents before filtering them through GtkIM API.
virtual GdkKeymap* GetGdkKeymap() = 0;
// Creates/Gets a GdkWindow out of a Aura window id. Caller owns the returned
// object. This function is meant to be used in GtkIM-based IME implementation
// and is supported only in X11 backend (both Aura and Ozone).
virtual GdkWindow* GetGdkWindow(gfx::AcceleratedWidget window_id) = 0;
// Gtk dialog windows must be set transient for the browser window. This
// function abstracts away such functionality.
virtual bool SetGdkWindowTransientFor(GdkWindow* window,
gfx::AcceleratedWidget parent) = 0;
};
} // namespace ui
#endif // UI_GTK_GTK_UI_DELEGATE_H_