mirror of
https://github.com/varun-r-mallya/sysprof.git
synced 2025-12-31 20:36:25 +00:00
Sat May 7 13:57:17 2005 Søren Sandmann <sandmann@redhat.com> * sfile.c (sfile_output_free): Implement this function * sfile.c (sfile_input_free): Implement this function
144 lines
4.7 KiB
C
144 lines
4.7 KiB
C
/* Sysprof -- Sampling, systemwide CPU profiler
|
|
* Copyright 2004, Red Hat, Inc.
|
|
* Copyright 2004, 2005, Soeren Sandmann
|
|
*
|
|
* 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 2 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, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
typedef struct SFormat SFormat;
|
|
typedef struct SFileInput SFileInput;
|
|
typedef struct SFileOutput SFileOutput;
|
|
typedef guint SType;
|
|
|
|
|
|
/* A possibly better API/naming scheme
|
|
*
|
|
* Serializer *serializer_new (SerializerFormat *format);
|
|
*
|
|
* SerializerReadContext *serializer_begin_read_filename (serializer *serialize,
|
|
* const char *filename,
|
|
* GError *err);
|
|
* serializer_get_blah (SerializerReadContext *);
|
|
* void serialzier_end_read (...);
|
|
*
|
|
* SerializerWritecontext *...;
|
|
* serializer_begin_write (context);
|
|
* serializer_write_int ();
|
|
* serializer_end_write (..., GError **err);
|
|
*
|
|
*
|
|
* For formats consider:
|
|
*
|
|
* Format *format_new (void);
|
|
* void format_set_record (Format *f, Content *r);
|
|
* Content *new_record (Content *c1, ...);
|
|
*
|
|
* List *format_new_list (Format *f
|
|
*
|
|
*
|
|
* Consider adding optional elements:
|
|
*
|
|
* sformat_new_optional (gpointer content)
|
|
*
|
|
* enums, optionals, selections, empties
|
|
*
|
|
*
|
|
*==============================================
|
|
* Also think about versioning - apps will want to be able to read and write
|
|
* different versions of the format, and they want to be able to sniff the
|
|
* format + version
|
|
*
|
|
*/
|
|
|
|
/* - Describing Types - */
|
|
SFormat *sformat_new (gpointer f);
|
|
gpointer sformat_new_record (const char *name,
|
|
SType *type,
|
|
gpointer content,
|
|
...);
|
|
gpointer sformat_new_list (const char *name,
|
|
SType *type,
|
|
gpointer content);
|
|
gpointer sformat_new_pointer (const char *name,
|
|
SType *target_type);
|
|
gpointer sformat_new_integer (const char *name);
|
|
gpointer sformat_new_string (const char *name);
|
|
void sformat_free (SFormat *format);
|
|
|
|
|
|
/* - Reading - */
|
|
SFileInput * sfile_load (const char *filename,
|
|
SFormat *format,
|
|
GError **err);
|
|
void sfile_begin_get_record (SFileInput *file,
|
|
const char *name);
|
|
int sfile_begin_get_list (SFileInput *file,
|
|
const char *name);
|
|
void sfile_get_pointer (SFileInput *file,
|
|
const char *name,
|
|
gpointer *pointer);
|
|
void sfile_get_integer (SFileInput *file,
|
|
const char *name,
|
|
int *integer);
|
|
void sfile_get_string (SFileInput *file,
|
|
const char *name,
|
|
char **string);
|
|
void sfile_end_get (SFileInput *file,
|
|
const char *name,
|
|
gpointer object);
|
|
void sfile_input_free (SFileInput *file);
|
|
|
|
#if 0
|
|
/* incremental loading (worth considering at least) */
|
|
SFileLoader *sfile_loader_new (SFormat *format);
|
|
void sfile_loader_add_text (SFileLoader *loader,
|
|
const char *text,
|
|
int len);
|
|
SFile * sfile_loader_finish (SFileLoader *loader,
|
|
GError **err);
|
|
void sfile_loader_free (SFileLoader *loader);
|
|
#endif
|
|
|
|
/* - Writing - */
|
|
|
|
/* FIXME - not10: see if we can't get rid of the names. It
|
|
* should be possible to pass NULL to state_transition_check()
|
|
* and have it interprete that as "whatever". We would need
|
|
* a way to get the name back then, though.
|
|
*/
|
|
|
|
SFileOutput * sfile_output_new (SFormat *format);
|
|
void sfile_begin_add_record (SFileOutput *file,
|
|
const char *name);
|
|
void sfile_begin_add_list (SFileOutput *file,
|
|
const char *name);
|
|
void sfile_end_add (SFileOutput *file,
|
|
const char *name,
|
|
gpointer object);
|
|
void sfile_add_string (SFileOutput *file,
|
|
const char *name,
|
|
const char *string);
|
|
void sfile_add_integer (SFileOutput *file,
|
|
const char *name,
|
|
int integer);
|
|
void sfile_add_pointer (SFileOutput *file,
|
|
const char *name,
|
|
gpointer pointer);
|
|
gboolean sfile_output_save (SFileOutput *sfile,
|
|
const char *filename,
|
|
GError **err);
|
|
|
|
void sfile_output_free (SFileOutput *sfile);
|