summaryrefslogtreecommitdiff
path: root/pango/pango-trace-private.h
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2020-08-19 16:02:10 -0400
committerMatthias Clasen <mclasen@redhat.com>2020-08-19 16:42:24 -0400
commit13f8625431eba74e070e846b23fcfc2a0ff2b34d (patch)
treead63768096e1e011278bdc1b3c34a6b73c5c7d2b /pango/pango-trace-private.h
parente08269b8847d64843498f7ebf5bc6e5de6fbc45e (diff)
downloadpango-13f8625431eba74e070e846b23fcfc2a0ff2b34d.tar.gz
Add sysprof tracing support
Add support for adding sysprof marks. Strongly inspired by equivalent GLib support.
Diffstat (limited to 'pango/pango-trace-private.h')
-rw-r--r--pango/pango-trace-private.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/pango/pango-trace-private.h b/pango/pango-trace-private.h
new file mode 100644
index 00000000..5d2a4fdf
--- /dev/null
+++ b/pango/pango-trace-private.h
@@ -0,0 +1,53 @@
+/* Pango
+ * pango-trace-private.h:
+ *
+ * Copyright (C) 2020 Red Hat, Inc
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#pragma once
+
+
+#ifdef HAVE_SYSPROF
+#include <sysprof-capture.h>
+#endif
+
+#include <glib.h>
+
+G_BEGIN_DECLS
+
+#ifdef HAVE_SYSPROF
+#define PANGO_TRACE_CURRENT_TIME SYSPROF_CAPTURE_CURRENT_TIME
+#else
+#define PANGO_TRACE_CURRENT_TIME 0
+#endif
+
+void pango_trace_mark (gint64 begin_time,
+ const gchar *name,
+ const gchar *message_format,
+ ...) G_GNUC_PRINTF (3, 4);
+
+#ifndef HAVE_SYSPROF
+/* Optimise the whole call out */
+#if defined(G_HAVE_ISO_VARARGS)
+#define g_trace_mark(b, n, m, ...)
+#elif defined(G_HAVE_GNUC_VARARGS)
+#define g_trace_mark(b, n, m...)
+#else
+/* no varargs macro support; the call will have to be optimised out by the compiler */
+#endif
+#endif
+
+G_END_DECLS