mirror of
https://github.com/varun-r-mallya/sysprof.git
synced 2025-12-31 20:36:25 +00:00
This is a major redesign a modernization of Sysprof. The core data structures and design are largely the same, but it has been ported to Gtk3 and has lots of additions that should make your profiling experience smoother. Especially for those that are new to profiling. There are some very simple help docs added, but we really need the experts to come in and write some documentation here.
93 lines
4.2 KiB
C
93 lines
4.2 KiB
C
/* sp-profiler.h
|
|
*
|
|
* Copyright (C) 2016 Christian Hergert <chergert@redhat.com>
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef SP_PROFILER_H
|
|
#define SP_PROFILER_H
|
|
|
|
#include "sp-capture-writer.h"
|
|
#include "sp-source.h"
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define SP_TYPE_PROFILER (sp_profiler_get_type())
|
|
|
|
G_DECLARE_DERIVABLE_TYPE (SpProfiler, sp_profiler, SP, PROFILER, GObject)
|
|
|
|
struct _SpProfilerClass
|
|
{
|
|
GObjectClass parent_class;
|
|
|
|
/**
|
|
* SpProfiler::failed:
|
|
* @self: A #SpProfiler
|
|
* @reason: A #GError representing the reason for the failure
|
|
*
|
|
* This signal is emitted if the profiler failed. Note that
|
|
* #SpProfiler::stopped will also be emitted, but does not allow for
|
|
* receiving the error condition.
|
|
*/
|
|
void (*failed) (SpProfiler *self,
|
|
const GError *error);
|
|
|
|
/**
|
|
* SpProfiler::stopped:
|
|
* @self: A #SpProfiler
|
|
*
|
|
* This signal is emitted when a profiler is stopped. It will always be
|
|
* emitted after a sp_profiler_start() has been called, either after
|
|
* completion of sp_profiler_stop() or after a failure or after asynchronous
|
|
* completion of stopping.
|
|
*/
|
|
void (*stopped) (SpProfiler *self);
|
|
};
|
|
|
|
SpProfiler *sp_profiler_new (void);
|
|
gdouble sp_profiler_get_elapsed (SpProfiler *self);
|
|
void sp_profiler_add_source (SpProfiler *self,
|
|
SpSource *source);
|
|
void sp_profiler_set_writer (SpProfiler *self,
|
|
SpCaptureWriter *writer);
|
|
SpCaptureWriter *sp_profiler_get_writer (SpProfiler *self);
|
|
gboolean sp_profiler_get_is_running (SpProfiler *self);
|
|
void sp_profiler_start (SpProfiler *self);
|
|
void sp_profiler_stop (SpProfiler *self);
|
|
void sp_profiler_add_pid (SpProfiler *self,
|
|
GPid pid);
|
|
void sp_profiler_remove_pid (SpProfiler *self,
|
|
GPid pid);
|
|
gboolean sp_profiler_get_is_mutable (SpProfiler *self);
|
|
gboolean sp_profiler_get_whole_system (SpProfiler *self);
|
|
void sp_profiler_set_whole_system (SpProfiler *self,
|
|
gboolean whole_system);
|
|
const GPid *sp_profiler_get_pids (SpProfiler *self,
|
|
guint *n_pids);
|
|
gboolean sp_profiler_get_spawn (SpProfiler *self);
|
|
void sp_profiler_set_spawn (SpProfiler *self,
|
|
gboolean spawn);
|
|
void sp_profiler_set_spawn_argv (SpProfiler *self,
|
|
const gchar * const *spawn_argv);
|
|
void sp_profiler_set_spawn_env (SpProfiler *self,
|
|
const gchar * const *spawn_env);
|
|
gboolean sp_profiler_get_spawn_inherit_environ (SpProfiler *self);
|
|
void sp_profiler_set_spawn_inherit_environ (SpProfiler *self,
|
|
gboolean spawn_inherit_environ);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* SP_PROFILER_H */
|