1 /* Copyright (c) 2010-2021. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #ifndef INSTR_PAJE_TYPES_HPP
7 #define INSTR_PAJE_TYPES_HPP
9 #include "src/instr/instr_private.hpp"
19 long long int new_paje_id();
22 long long int id_ = new_paje_id();
26 std::map<std::string, std::unique_ptr<Type>, std::less<>> children_;
27 Container* issuer_ = nullptr;
30 Container* get_issuer() const { return issuer_; }
33 static xbt::signal<void(Type const&, PajeEventType event_type)> on_creation;
35 Type(PajeEventType event_type, const std::string& name, const std::string& alias, const std::string& color,
37 virtual ~Type() = default;
39 long long int get_id() const { return id_; }
40 const std::string& get_name() const { return name_; }
41 const char* get_cname() const { return name_.c_str(); }
42 const std::string& get_color() const { return color_; }
43 Type* get_father() const { return father_; }
44 const std::map<std::string, std::unique_ptr<Type>, std::less<>>& get_children() const { return children_; }
45 bool is_colored() const { return not color_.empty(); }
47 Type* by_name(const std::string& name);
48 LinkType* by_name_or_create(const std::string& name, const Type* source, const Type* dest);
49 VariableType* by_name_or_create(const std::string& name, const std::string& color);
51 template <class T> T* by_name_or_create(const std::string& name)
53 auto cont = children_.find(name);
54 return cont == children_.end() ? new T(name, this) : static_cast<T*>(cont->second.get());
57 Type* set_calling_container(Container* container)
64 class ContainerType : public Type {
66 explicit ContainerType(const std::string& name) : Type(PajeEventType::DefineContainerType, name, name, "", nullptr){};
67 ContainerType(const std::string& name, Type* father)
68 : Type(PajeEventType::DefineContainerType, name, name, "", father){};
71 class VariableType : public Type {
72 std::vector<VariableEvent*> events_;
74 VariableType(const std::string& name, const std::string& color, Type* father)
75 : Type(PajeEventType::DefineVariableType, name, name, color, father)
78 void instr_event(double now, double delta, const char* resource, double value);
79 void set_event(double timestamp, double value);
80 void add_event(double timestamp, double value);
81 void sub_event(double timestamp, double value);
84 class ValueType : public Type {
86 std::map<std::string, EntityValue, std::less<>> values_;
87 ValueType(PajeEventType event_type, const std::string& name, const std::string& alias, Type* father)
88 : Type(event_type, name, alias, "", father){};
89 ValueType(PajeEventType event_type, const std::string& name, Type* father)
90 : Type(event_type, name, name, "", father){};
91 void add_entity_value(const std::string& name, const std::string& color);
92 void add_entity_value(const std::string& name);
93 EntityValue* get_entity_value(const std::string& name);
96 class LinkType : public ValueType {
98 static xbt::signal<void(LinkType const&, Type const&, Type const&)> on_creation;
99 LinkType(const std::string& name, const Type* source, const Type* dest, const std::string& alias, Type* father)
100 : ValueType(PajeEventType::DefineLinkType, name, alias, father)
102 on_creation(*this, *source, *dest);
104 void start_event(Container* startContainer, const std::string& value, const std::string& key,
105 size_t size = static_cast<size_t>(-1));
106 void end_event(Container* endContainer, const std::string& value, const std::string& key);
109 class EventType : public ValueType {
111 EventType(const std::string& name, Type* father) : ValueType(PajeEventType::DefineEventType, name, father) {}
114 class StateType : public ValueType {
115 std::vector<StateEvent*> events_;
117 StateType(const std::string& name, Type* father) : ValueType(PajeEventType::DefineStateType, name, father) {}
118 void set_event(const std::string& value_name);
119 void push_event(const std::string& value_name);
120 void push_event(const std::string& value_name, TIData* extra);
122 void pop_event(TIData* extra);
125 } // namespace simgrid