Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Show also the sub-scheduling rounds.
[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   xbt_replay_trace_reader_t res = xbt_new0(s_xbt_replay_trace_reader_t,1);
26   res->fp = fopen(filename, "r");
27   xbt_assert2(res->fp != NULL, "Cannot open %s: %s", filename,
28       strerror(errno));
29   res->filename = xbt_strdup(filename);
30   return res;
31 }
32
33 const char *xbt_replay_trace_reader_position(xbt_replay_trace_reader_t reader) {
34   if (reader->position)
35     free(reader->position);
36   reader->position = bprintf("%s:%d",reader->filename,reader->linenum);
37   return (const char*)reader->position;
38 }
39 char * const *xbt_replay_trace_reader_get(xbt_replay_trace_reader_t reader) {
40   ssize_t read;
41   xbt_dynar_t d;
42   read = getline(&reader->line, &reader->line_len, reader->fp);
43   //INFO1("got from trace: %s",reader->line);
44   reader->linenum++;
45   if (read==-1)
46     return NULL; /* end of file */
47   char *comment = strchr(reader->line, '#');
48   if (comment != NULL)
49     *comment = '\0';
50   xbt_str_trim(reader->line, NULL);
51   if (reader->line[0] == '\0')
52     return xbt_replay_trace_reader_get(reader); /* Get next line */
53
54   d=xbt_str_split_quoted_in_place(reader->line);
55   if (xbt_dynar_length(d)==0) {
56     xbt_free(d);
57     return xbt_replay_trace_reader_get(reader); /* Get next line */
58   }
59   return xbt_dynar_to_array(d);
60 }
61
62 void xbt_replay_trace_reader_free(xbt_replay_trace_reader_t *reader) {
63   free((*reader)->filename);
64   if ((*reader)->position)
65     free((*reader)->position);
66   fclose((*reader)->fp);
67   free((*reader)->line);
68   free(*reader);
69   *reader=NULL;
70 }