Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add an unused (for the moment) module file
[simgrid.git] / src / xbt / xbt_replay_trace_reader.c
1 /* Copyright (c) 2010. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6 #include "gras_config.h"
7 #include "simgrid_config.h" /* getline */
8 #include <errno.h>
9 #include "xbt/sysdep.h"
10 #include "xbt/log.h"
11 #include "xbt/str.h"
12 #include "xbt/replay_trace_reader.h"
13
14 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(replay,xbt,"Replay trace reader");
15
16 typedef struct s_replay_trace_reader {
17   FILE *fp;
18   char *line;
19   size_t line_len;
20   char *position; /* stable storage */
21   char *filename; int linenum;
22 } s_xbt_replay_trace_reader_t;
23
24 xbt_replay_trace_reader_t xbt_replay_trace_reader_new(const char *filename)
25 {
26   xbt_replay_trace_reader_t res = xbt_new0(s_xbt_replay_trace_reader_t,1);
27   res->fp = fopen(filename, "r");
28   xbt_assert2(res->fp != NULL, "Cannot open %s: %s", filename,
29       strerror(errno));
30   res->filename = xbt_strdup(filename);
31   return res;
32 }
33
34 const char *xbt_replay_trace_reader_position(xbt_replay_trace_reader_t reader)
35 {
36   if (reader->position)
37     free(reader->position);
38   reader->position = bprintf("%s:%d",reader->filename,reader->linenum);
39   return reader->position;
40 }
41
42 const char **xbt_replay_trace_reader_get(xbt_replay_trace_reader_t reader)
43 {
44   ssize_t read;
45   xbt_dynar_t d;
46   read = getline(&reader->line, &reader->line_len, reader->fp);
47   //INFO1("got from trace: %s",reader->line);
48   reader->linenum++;
49   if (read==-1)
50     return NULL; /* end of file */
51   char *comment = strchr(reader->line, '#');
52   if (comment != NULL)
53     *comment = '\0';
54   xbt_str_trim(reader->line, NULL);
55   if (reader->line[0] == '\0')
56     return xbt_replay_trace_reader_get(reader); /* Get next line */
57
58   d=xbt_str_split_quoted_in_place(reader->line);
59   if (xbt_dynar_length(d)==0) {
60     xbt_dynar_free(&d);
61     return xbt_replay_trace_reader_get(reader); /* Get next line */
62   }
63   return xbt_dynar_to_array(d);
64 }
65
66 void xbt_replay_trace_reader_free(xbt_replay_trace_reader_t *reader)
67 {
68   free((*reader)->filename);
69   if ((*reader)->position)
70     free((*reader)->position);
71   fclose((*reader)->fp);
72   free((*reader)->line);
73   free(*reader);
74   *reader=NULL;
75 }