Skip to content

Commit

Permalink
Improve deprecation handling in unquote function
Browse files Browse the repository at this point in the history
Fixes #1291
  • Loading branch information
mgreter authored and xzyfer committed Jul 8, 2015
1 parent 0a57e9d commit a6b7dbd
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 2 deletions.
9 changes: 9 additions & 0 deletions error_handling.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,15 @@ namespace Sass {
warn(msg, pstate);
}

void deprecated(string msg, ParserState pstate)
{
string cwd(Sass::File::get_cwd());
cerr << "DEPRECATION WARNING: " << msg << endl;
cerr << "will be an error in future versions of Sass." << endl;
string rel_path(Sass::File::resolve_relative_path(pstate.path, cwd, cwd));
cerr << " on line " << pstate.line+1 << " of " << rel_path << endl;
}

void error(string msg, ParserState pstate)
{
throw Sass_Error(Sass_Error::syntax, pstate, msg);
Expand Down
3 changes: 3 additions & 0 deletions error_handling.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,9 @@ namespace Sass {
void warn(string msg, ParserState pstate);
void warn(string msg, ParserState pstate, Backtrace* bt);

void deprecated(string msg, ParserState pstate);
// void deprecated(string msg, ParserState pstate, Backtrace* bt);

void error(string msg, ParserState pstate);
void error(string msg, ParserState pstate, Backtrace* bt);

Expand Down
11 changes: 9 additions & 2 deletions functions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -777,8 +777,15 @@ namespace Sass {
result->sass_fix_1291(string_quoted->quote_mark() != 0);
return result;
}
To_String to_string(&ctx);
return new (ctx.mem) String_Constant(pstate, unquote(string(arg->perform(&to_string))));
else if (dynamic_cast<String_Constant*>(arg)) {
return (Expression*) arg;
}
else {
To_String to_string(&ctx);
string val(arg->perform(&to_string));
deprecated("Passing " + val + ", a non-string value, to unquote()", pstate);
return (Expression*) arg;
}
}

Signature quote_sig = "quote($string)";
Expand Down

0 comments on commit a6b7dbd

Please sign in to comment.