Sha256: 38e6bbb490878a28de2d42d946d557c4b0c0535a84144ef6bcb083cafa3e9684
Contents?: true
Size: 1.51 KB
Versions: 16
Compression:
Stored size: 1.51 KB
Contents
#ifndef SASS_BACKTRACE_H #define SASS_BACKTRACE_H #include <sstream> #include "file.hpp" #include "position.hpp" namespace Sass { using namespace std; struct Backtrace { Backtrace* parent; ParserState pstate; string caller; Backtrace(Backtrace* prn, ParserState pstate, string c) : parent(prn), pstate(pstate), caller(c) { } string to_string(bool warning = false) { size_t i = -1; stringstream ss; string cwd(Sass::File::get_cwd()); Backtrace* this_point = this; if (!warning) ss << endl << "Backtrace:"; // the first tracepoint (which is parent-less) is an empty placeholder while (this_point->parent) { // make path relative to the current directory string rel_path(Sass::File::resolve_relative_path(this_point->pstate.path, cwd, cwd)); if (warning) { ss << endl << "\t" << (++i == 0 ? "on" : "from") << " line " << this_point->pstate.line + 1 << " of " << rel_path; } else { ss << endl << "\t" << rel_path << ":" << this_point->pstate.line + 1 << this_point->parent->caller; } this_point = this_point->parent; } return ss.str(); } size_t depth() { size_t d = 0; Backtrace* p = parent; while (p) { ++d; p = p->parent; } return d-1; } }; } #endif
Version data entries
16 entries across 16 versions & 2 rubygems