aboutsummaryrefslogtreecommitdiff
path: root/gprofng/src/PreviewExp.cc
blob: e7c10d8a915021e0132a301074fb01e7161f6fd1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/* Copyright (C) 2021-2023 Free Software Foundation, Inc.
   Contributed by Oracle.

   This file is part of GNU Binutils.

   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, 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, 51 Franklin Street - Fifth Floor, Boston,
   MA 02110-1301, USA.  */

#include "config.h"
#include <stdio.h>

#include "PreviewExp.h"
#include "Data_window.h"
#include "DbeSession.h"
#include "Emsg.h"
#include "Print.h"
#include "i18n.h"

PreviewExp::PreviewExp (): Experiment () { }

PreviewExp::~PreviewExp () { }//~PreviewExp

Experiment::Exp_status
PreviewExp::experiment_open (char *path)
{
  // Find experiment directory
  if ((status = find_expdir (path)) != SUCCESS)
    {
      size_t len = strlen (path);
      is_group = ((len > 4) && !strcmp (&path[len - 4], NTXT (".erg")));
      return status;
    }
  else
    is_group = 0;

  read_log_file ();
  if (status == FAILURE)
    return status;

  if (status == INCOMPLETE && resume_ts != MAX_TIME)
    // experiment is incomplete and "resumed" (non-paused)
    // PreviewExp does not process all the packets, therefore...
    //    ... last_event does not reflect reality
    //    ... we don't know the duration or the end.
    last_event = ZERO_TIME; // mark last_event as uninitialized

  read_notes_file ();
  return status;
}

Vector<char*> *
PreviewExp::preview_info ()
{
  Vector<char*> *info = new Vector<char*>;
  if (is_group)
    info->append (GTXT ("Experiment Group"));
  else
    info->append (GTXT ("Experiment"));
  info->append (expt_name);

  if (status == FAILURE /* != SUCCESS */)
    {
      if (is_group)
	{
	  Vector<char*> *grp_list = dbeSession->get_group_or_expt (expt_name);
	  for (int i = 0, grp_sz = grp_list->size (); i < grp_sz; i++)
	    {
	      char *nm = grp_list->fetch (i);
	      char *str = dbe_sprintf (GTXT ("Exp.#%d"), i + 1);
	      info->append (str);
	      info->append (nm);
	    }
	  delete grp_list;
	}
      else
	{
	  info->append (GTXT ("Error message"));
	  info->append (mqueue_str (errorq, GTXT ("No errors\n")));
	}
      return info;
    }
  info->append (GTXT ("Experiment header"));
  info->append (mqueue_str (commentq, GTXT ("Empty header\n")));
  info->append (GTXT ("Error message"));
  info->append (mqueue_str (errorq, GTXT ("No errors\n")));
  info->append (GTXT ("Warning message"));
  info->append (mqueue_str (warnq, GTXT ("No warnings\n")));
  info->append (GTXT ("Notes"));
  info->append (mqueue_str (notesq, GTXT ("\n")));
  return info;
}

char *
PreviewExp::mqueue_str (Emsgqueue *msgqueue, char *null_str)
{
  char *mesgs = pr_mesgs (msgqueue->fetch (), null_str, "");
  char *last = mesgs + strlen (mesgs) - 1;
  if (*last == '\n')
    *last = '\0';
  return mesgs;
}