Skip to content

Commit

Permalink
Fix bug in C-API with context compiler status
Browse files Browse the repository at this point in the history
Fixes sass#1035
  • Loading branch information
mgreter committed Apr 2, 2015
1 parent fd7f20f commit 7ee0c1b
Showing 1 changed file with 32 additions and 24 deletions.
56 changes: 32 additions & 24 deletions sass_context.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -342,7 +342,7 @@ extern "C" {
}

// generic compilation function (not exported, use file/data compile instead)
static Context* sass_prepare_context (Sass_Context* c_ctx, Context::Data cpp_opt) throw()
static Sass_Compiler* sass_prepare_context (Sass_Context* c_ctx, Context::Data cpp_opt) throw()
{
try {

Expand Down Expand Up @@ -452,8 +452,17 @@ extern "C" {
c_ctx->error_line = string::npos;
c_ctx->error_column = string::npos;

// allocate a new compiler instance
Sass_Compiler* compiler = (struct Sass_Compiler*) calloc(1, sizeof(struct Sass_Compiler));

// store in sass compiler
compiler->c_ctx = c_ctx;
compiler->cpp_ctx = cpp_ctx;
cpp_ctx->c_compiler = compiler;
compiler->state = SASS_COMPILER_CREATED;

// use to parse block
return cpp_ctx;
return compiler;

}
// pass errors to generic error handler
Expand All @@ -464,8 +473,17 @@ extern "C" {

}

static Block* sass_parse_block (Sass_Context* c_ctx, Context* cpp_ctx) throw()
static Block* sass_parse_block (Sass_Compiler* compiler) throw()
{

// assert valid pointer
if (compiler == 0) return 0;
// The cpp context must be set by now
Context* cpp_ctx = compiler->cpp_ctx;
Sass_Context* c_ctx = compiler->c_ctx;
// We will take care to wire up the rest
compiler->cpp_ctx->c_compiler = compiler;

try {

// get input/output path from options
Expand Down Expand Up @@ -509,16 +527,19 @@ extern "C" {
static int sass_compile_context (Sass_Context* c_ctx, Context::Data cpp_opt)
{

// first prepare the c++ context
Context* cpp_ctx = sass_prepare_context(c_ctx, cpp_opt);
// prepare sass compiler with context and options
Sass_Compiler* compiler = sass_prepare_context(c_ctx, cpp_opt);

// parse given context and return root block
Block* root = cpp_ctx ? sass_parse_block(c_ctx, cpp_ctx) : 0;
Block* root = compiler ? sass_parse_block(compiler) : 0;

if (cpp_ctx && root) {
if (compiler && root) {

try {

// get cpp context from compiler
Context* cpp_ctx = compiler->cpp_ctx;

// now compile the parsed root block
c_ctx->output_string = cpp_ctx->compile_block(root);

Expand All @@ -531,7 +552,7 @@ extern "C" {

}

delete cpp_ctx;
sass_delete_compiler(compiler);

return c_ctx->error_status;
}
Expand Down Expand Up @@ -586,29 +607,17 @@ extern "C" {
struct Sass_Compiler* ADDCALL sass_make_file_compiler (struct Sass_File_Context* c_ctx)
{
if (c_ctx == 0) return 0;
struct Sass_Compiler* compiler = (struct Sass_Compiler*) calloc(1, sizeof(struct Sass_Compiler));
if (compiler == 0) { cerr << "Error allocating memory for file compiler" << endl; return 0; }
compiler->state = SASS_COMPILER_CREATED;
compiler->c_ctx = c_ctx;
Context::Data cpp_opt = Context::Data();
cpp_opt.entry_point(c_ctx->input_path);
compiler->cpp_ctx = sass_prepare_context(c_ctx, cpp_opt);
compiler->cpp_ctx->c_compiler = compiler;
return compiler;
return sass_prepare_context(c_ctx, cpp_opt);
}

struct Sass_Compiler* ADDCALL sass_make_data_compiler (struct Sass_Data_Context* c_ctx)
{
if (c_ctx == 0) return 0;
struct Sass_Compiler* compiler = (struct Sass_Compiler*) calloc(1, sizeof(struct Sass_Compiler));
if (compiler == 0) { cerr << "Error allocating memory for data compiler" << endl; return 0; }
compiler->state = SASS_COMPILER_CREATED;
compiler->c_ctx = c_ctx;
Context::Data cpp_opt = Context::Data();
cpp_opt.source_c_str(c_ctx->source_string);
compiler->cpp_ctx = sass_prepare_context(c_ctx, cpp_opt);
compiler->cpp_ctx->c_compiler = compiler;
return compiler;
return sass_prepare_context(c_ctx, cpp_opt);
}

int ADDCALL sass_compile_data_context(Sass_Data_Context* data_ctx)
Expand Down Expand Up @@ -653,9 +662,8 @@ extern "C" {
if (compiler->c_ctx->error_status)
return compiler->c_ctx->error_status;
compiler->state = SASS_COMPILER_PARSED;
Context* cpp_ctx = (Context*) compiler->cpp_ctx;
// parse the context we have set up (file or data)
compiler->root = sass_parse_block(compiler->c_ctx, cpp_ctx);
compiler->root = sass_parse_block(compiler);
// success
return 0;
}
Expand Down

0 comments on commit 7ee0c1b

Please sign in to comment.