pytorch/torch/csrc/jit/jit_log.cpp
Nikolay Korovaiko 0196e0bafb add line numbers to jit_log.h
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/22630

Differential Revision: D16172090

Pulled By: Krovatkin

fbshipit-source-id: 26cdb0077a0bfbf9981e39359472f3251546db53
2019-07-10 15:28:29 -07:00

67 lines
1.6 KiB
C++

#include <torch/csrc/jit/jit_log.h>
#include <c10/util/Exception.h>
#include <torch/csrc/jit/ir.h>
#include <c10/util/StringUtil.h>
#include <cstdlib>
#include <iomanip>
#include <sstream>
namespace torch {
namespace jit {
JitLoggingLevels jit_log_level() {
static const char* c_log_level = std::getenv("PYTORCH_JIT_LOG_LEVEL");
static const JitLoggingLevels log_level = c_log_level
? static_cast<JitLoggingLevels>(std::atoi(c_log_level))
: JitLoggingLevels::OFF;
return log_level;
}
std::string debugValueOrDefault(const Node* n) {
return n->outputs().size() > 0 ? n->outputs().at(0)->debugName() : "n/a";
}
std::string jit_log_prefix(
JitLoggingLevels level,
const char* fn,
int l,
const std::string& in_str) {
std::stringstream in_ss(in_str);
std::stringstream out_ss(in_str);
std::string line;
while (std::getline(in_ss, line, '\n')) {
out_ss << "[";
out_ss << level << " ";
out_ss << c10::detail::StripBasename(std::string(fn)) << ":";
out_ss << std::setfill('0') << std::setw(3) << l;
out_ss << "] ";
out_ss << line << std::endl;
}
return out_ss.str();
}
std::ostream& operator<<(std::ostream& out, JitLoggingLevels level) {
switch (level) {
case JitLoggingLevels::OFF:
TORCH_INTERNAL_ASSERT("UNREACHABLE");
break;
case JitLoggingLevels::GRAPH_DUMP:
out << "DUMP";
break;
case JitLoggingLevels::GRAPH_UPDATE:
out << "UPDATE";
break;
case JitLoggingLevels::GRAPH_DEBUG:
out << "DEBUG";
break;
default:
TORCH_INTERNAL_ASSERT("Invalid level");
}
return out;
}
} // namespace jit
} // namespace torch