tracing_file << stream_.str() << std::endl;
}
-StateEvent::~StateEvent(){
- delete extra_;
-}
-
void StateEvent::print()
{
if (trace_format == simgrid::instr::TraceFormat::Paje) {
return;
/* Unimplemented calls are: WAITANY, SENDRECV, SCAN, EXSCAN, SSEND, and ISSEND. */
-
+ std::string container_name(get_container()->get_name());
// FIXME: dirty extract "rank-" from the name, as we want the bare process id here
- if (get_container()->get_name().find("rank-") != 0) {
- stream_ << get_container()->get_name() << " " << extra_->print();
- } else {
+ if (get_container()->get_name().find("rank-") == 0) {
/* Subtract -1 because this is the process id and we transform it to the rank id */
- std::string container_name(get_container()->get_name());
- stream_ << stoi(container_name.erase(0, 5)) - 1 << " " << extra_->print();
+ container_name=std::to_string(stoi(container_name.erase(0, 5)) - 1);
}
+#if HAVE_SMPI
+ if (simgrid::config::get_value<bool>("smpi/trace-call-location")) {
+ stream_ << container_name << " location " << filename << " " << linenumber << std::endl ;
+ }
+#endif
+ stream_ << container_name << " " << extra_->print();
*tracing_files.at(get_container()) << stream_.str() << std::endl;
} else {
THROW_IMPOSSIBLE;