forked from AuroraMiddleware/gtk
f4f683a469
Make it more clear that the function is supposed to be called during the dispose sequence of a widget.
233 lines
8.5 KiB
C
233 lines
8.5 KiB
C
/*
|
|
* Copyright (c) 2018, Red Hat, Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included
|
|
* in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include <glib/gi18n-lib.h>
|
|
|
|
#include "logs.h"
|
|
#include "window.h"
|
|
|
|
#include "gtktextview.h"
|
|
#include "gtkmessagedialog.h"
|
|
#include "gtkfilechooserdialog.h"
|
|
#include "gtkcheckbutton.h"
|
|
#include "gtklabel.h"
|
|
#include "gtktooltip.h"
|
|
#include "gtktextiter.h"
|
|
#include "gtkprivate.h"
|
|
#include "gtkroot.h"
|
|
#include "gtkdebug.h"
|
|
#include "gtknative.h"
|
|
#include "gskdebugprivate.h"
|
|
#include "gskrendererprivate.h"
|
|
#include "gtkboxlayout.h"
|
|
|
|
#include "gdk/gdkdebug.h"
|
|
|
|
struct _GtkInspectorLogs
|
|
{
|
|
GtkWidget parent;
|
|
|
|
GtkWidget *events;
|
|
GtkWidget *misc;
|
|
GtkWidget *dnd;
|
|
GtkWidget *input;
|
|
GtkWidget *eventloop;
|
|
GtkWidget *frames;
|
|
GtkWidget *settings;
|
|
GtkWidget *opengl;
|
|
GtkWidget *vulkan;
|
|
GtkWidget *selection;
|
|
GtkWidget *clipboard;
|
|
|
|
GtkWidget *renderer;
|
|
GtkWidget *cairo;
|
|
GtkWidget *opengl_gsk;
|
|
GtkWidget *vulkan_gsk;
|
|
GtkWidget *shaders;
|
|
GtkWidget *surface;
|
|
GtkWidget *glyphcache;
|
|
|
|
GtkWidget *actions;
|
|
GtkWidget *builder;
|
|
GtkWidget *sizes;
|
|
GtkWidget *icons;
|
|
GtkWidget *keybindings;
|
|
GtkWidget *modules;
|
|
GtkWidget *printing;
|
|
GtkWidget *tree;
|
|
GtkWidget *text;
|
|
GtkWidget *constraints;
|
|
GtkWidget *layout;
|
|
GtkWidget *a11y;
|
|
|
|
GdkDisplay *display;
|
|
};
|
|
|
|
typedef struct _GtkInspectorLogsClass
|
|
{
|
|
GtkWidgetClass parent;
|
|
} GtkInspectorLogsClass;
|
|
|
|
G_DEFINE_TYPE (GtkInspectorLogs, gtk_inspector_logs, GTK_TYPE_WIDGET)
|
|
|
|
static void
|
|
gtk_inspector_logs_init (GtkInspectorLogs *logs)
|
|
{
|
|
gtk_widget_init_template (GTK_WIDGET (logs));
|
|
}
|
|
|
|
static void
|
|
dispose (GObject *object)
|
|
{
|
|
gtk_widget_dispose_template (GTK_WIDGET (object), GTK_TYPE_INSPECTOR_LOGS);
|
|
|
|
G_OBJECT_CLASS (gtk_inspector_logs_parent_class)->dispose (object);
|
|
}
|
|
|
|
static void
|
|
update_flag (GtkWidget *widget,
|
|
guint *flags,
|
|
guint flag)
|
|
{
|
|
if (gtk_check_button_get_active (GTK_CHECK_BUTTON (widget)))
|
|
*flags = *flags | flag;
|
|
else
|
|
*flags = *flags & ~flag;
|
|
}
|
|
|
|
static void
|
|
flag_toggled (GtkWidget *button,
|
|
GtkInspectorLogs *logs)
|
|
{
|
|
guint flags;
|
|
GList *toplevels, *l;
|
|
|
|
flags = gdk_display_get_debug_flags (logs->display);
|
|
update_flag (logs->events, &flags, GDK_DEBUG_EVENTS);
|
|
update_flag (logs->misc, &flags, GDK_DEBUG_MISC);
|
|
update_flag (logs->dnd, &flags, GDK_DEBUG_DND);
|
|
update_flag (logs->input, &flags, GDK_DEBUG_INPUT);
|
|
update_flag (logs->eventloop, &flags, GDK_DEBUG_EVENTLOOP);
|
|
update_flag (logs->frames, &flags, GDK_DEBUG_FRAMES);
|
|
update_flag (logs->settings, &flags, GDK_DEBUG_SETTINGS);
|
|
update_flag (logs->opengl, &flags, GDK_DEBUG_OPENGL);
|
|
update_flag (logs->vulkan, &flags, GDK_DEBUG_VULKAN);
|
|
update_flag (logs->selection, &flags, GDK_DEBUG_SELECTION);
|
|
update_flag (logs->clipboard, &flags, GDK_DEBUG_CLIPBOARD);
|
|
gdk_display_set_debug_flags (logs->display, flags);
|
|
|
|
flags = gsk_get_debug_flags ();
|
|
update_flag (logs->renderer, &flags, GSK_DEBUG_RENDERER);
|
|
update_flag (logs->cairo, &flags, GSK_DEBUG_CAIRO);
|
|
update_flag (logs->opengl_gsk, &flags, GSK_DEBUG_OPENGL);
|
|
update_flag (logs->vulkan_gsk, &flags, GSK_DEBUG_VULKAN);
|
|
update_flag (logs->shaders, &flags, GSK_DEBUG_SHADERS);
|
|
update_flag (logs->surface, &flags, GSK_DEBUG_SURFACE);
|
|
update_flag (logs->glyphcache, &flags, GSK_DEBUG_GLYPH_CACHE);
|
|
gsk_set_debug_flags (flags);
|
|
|
|
toplevels = gtk_window_list_toplevels ();
|
|
for (l = toplevels; l; l = l->next)
|
|
{
|
|
GtkWidget *toplevel = l->data;
|
|
|
|
if (gtk_root_get_display (GTK_ROOT (toplevel)) == logs->display)
|
|
{
|
|
GskRenderer *renderer = gtk_native_get_renderer (GTK_NATIVE (toplevel));
|
|
if (renderer)
|
|
gsk_renderer_set_debug_flags (renderer, flags);
|
|
}
|
|
}
|
|
g_list_free (toplevels);
|
|
|
|
flags = gtk_get_display_debug_flags (logs->display);
|
|
update_flag (logs->actions, &flags, GTK_DEBUG_ACTIONS);
|
|
update_flag (logs->builder, &flags, GTK_DEBUG_BUILDER);
|
|
update_flag (logs->sizes, &flags, GTK_DEBUG_SIZE_REQUEST);
|
|
update_flag (logs->icons, &flags, GTK_DEBUG_ICONTHEME);
|
|
update_flag (logs->keybindings, &flags, GTK_DEBUG_KEYBINDINGS);
|
|
update_flag (logs->modules, &flags, GTK_DEBUG_MODULES);
|
|
update_flag (logs->printing, &flags, GTK_DEBUG_PRINTING);
|
|
update_flag (logs->tree, &flags, GTK_DEBUG_TREE);
|
|
update_flag (logs->text, &flags, GTK_DEBUG_TEXT);
|
|
update_flag (logs->constraints, &flags, GTK_DEBUG_CONSTRAINTS);
|
|
update_flag (logs->layout, &flags, GTK_DEBUG_LAYOUT);
|
|
update_flag (logs->a11y, &flags, GTK_DEBUG_A11Y);
|
|
gtk_set_display_debug_flags (logs->display, flags);
|
|
}
|
|
|
|
static void
|
|
gtk_inspector_logs_class_init (GtkInspectorLogsClass *klass)
|
|
{
|
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
|
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
|
|
|
object_class->dispose = dispose;
|
|
|
|
gtk_widget_class_set_template_from_resource (widget_class, "/org/gtk/libgtk/inspector/logs.ui");
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, events);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, misc);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, dnd);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, input);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, eventloop);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, frames);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, settings);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, opengl);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, vulkan);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, selection);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, clipboard);
|
|
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, renderer);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, cairo);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, opengl_gsk);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, vulkan_gsk);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, shaders);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, surface);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, glyphcache);
|
|
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, actions);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, builder);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, sizes);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, icons);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, keybindings);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, modules);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, printing);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, tree);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, text);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, constraints);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, layout);
|
|
gtk_widget_class_bind_template_child (widget_class, GtkInspectorLogs, a11y);
|
|
gtk_widget_class_bind_template_callback (widget_class, flag_toggled);
|
|
|
|
gtk_widget_class_set_layout_manager_type (widget_class, GTK_TYPE_BOX_LAYOUT);
|
|
}
|
|
|
|
void
|
|
gtk_inspector_logs_set_display (GtkInspectorLogs *logs,
|
|
GdkDisplay *display)
|
|
{
|
|
logs->display = display;
|
|
}
|
|
|
|
// vim: set et sw=2 ts=2:
|