-/* Copyright (c) 2010-2017. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2010-2020. The SimGrid Team. All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
#define INSTR_PAJE_EVENTS_HPP
#include "src/instr/instr_private.hpp"
+#include "src/internal_config.h"
+#include <sstream>
#include <string>
namespace simgrid {
namespace instr {
class EntityValue;
+class TIData;
enum e_event_type : unsigned int {
PAJE_DefineContainerType,
class PajeEvent {
Container* container_;
Type* type_;
-
-protected:
- Type* getType() { return type_; }
- Container* getContainer() { return container_; }
public:
+ static xbt::signal<void(PajeEvent&)> on_creation;
+ static xbt::signal<void(PajeEvent&)> on_destruction;
+
double timestamp_;
e_event_type eventType_;
- PajeEvent(Container* container, Type* type, double timestamp, e_event_type eventType)
- : container_(container), type_(type), timestamp_(timestamp), eventType_(eventType){};
- virtual ~PajeEvent() = default;
+ std::stringstream stream_;
+
+ PajeEvent(Container* container, Type* type, double timestamp, e_event_type eventType);
+ virtual ~PajeEvent();
+
+ Container* get_container() const { return container_; }
+ Type* get_type() const { return type_; }
+
virtual void print() = 0;
- void insertIntoBuffer();
+ void insert_into_buffer();
};
class VariableEvent : public PajeEvent {
- double value;
+ double value_;
public:
- VariableEvent(double timestamp, Container* container, Type* type, e_event_type event_type, double value);
- void print() override;
+ VariableEvent(double timestamp, Container* container, Type* type, e_event_type event_type, double value)
+ : PajeEvent::PajeEvent(container, type, timestamp, event_type), value_(value)
+ {
+ }
+ void print() override { stream_ << " " << value_; }
};
class StateEvent : public PajeEvent {
EntityValue* value;
- std::string filename;
- int linenumber;
- void* extra_ = nullptr;
+#if HAVE_SMPI
+ std::string filename = "(null)";
+ int linenumber = -1;
+#endif
+ std::unique_ptr<TIData> extra_;
public:
- StateEvent(Container* container, Type* type, e_event_type event_type, EntityValue* value);
- StateEvent(Container* container, Type* type, e_event_type event_type, EntityValue* value, void* extra);
+ static xbt::signal<void(StateEvent&)> on_destruction;
+ StateEvent(Container* container, Type* type, e_event_type event_type, EntityValue* value, TIData* extra);
+ ~StateEvent() { on_destruction(*this); }
+ bool has_extra() { return extra_ != nullptr; }
void print() override;
};
int size_ = -1;
public:
- LinkEvent(Container* container, Type* type, e_event_type event_type, Container* sourceContainer, std::string value,
- std::string key);
- LinkEvent(Container* container, Type* type, e_event_type event_type, Container* sourceContainer, std::string value,
- std::string key, int size);
+ LinkEvent(Container* container, Type* type, e_event_type event_type, Container* sourceContainer,
+ const std::string& value, const std::string& key, int size)
+ : PajeEvent(container, type, SIMIX_get_clock(), event_type)
+ , endpoint_(sourceContainer)
+ , value_(value)
+ , key_(key)
+ , size_(size)
+ {
+ }
void print() override;
};
class NewEvent : public PajeEvent {
- EntityValue* val;
+ EntityValue* value;
public:
- NewEvent(double timestamp, Container* container, Type* type, EntityValue* val);
+ NewEvent(double timestamp, Container* container, Type* type, EntityValue* value)
+ : PajeEvent::PajeEvent(container, type, timestamp, PAJE_NewEvent), value(value)
+ {
+ }
void print() override;
};
-}
-}
+} // namespace instr
+} // namespace simgrid
#endif