diff options
author | Matthias Clasen <mclasen@redhat.com> | 2020-08-19 16:02:10 -0400 |
---|---|---|
committer | Matthias Clasen <mclasen@redhat.com> | 2020-08-19 16:42:24 -0400 |
commit | 13f8625431eba74e070e846b23fcfc2a0ff2b34d (patch) | |
tree | ad63768096e1e011278bdc1b3c34a6b73c5c7d2b /pango/pango-trace-private.h | |
parent | e08269b8847d64843498f7ebf5bc6e5de6fbc45e (diff) | |
download | pango-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.h | 53 |
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 |