Sha256: c786454a086bf18f385f6ee020d2e2ebcc5833b39c391833734404c0655d2c94
Contents?: true
Size: 1.58 KB
Versions: 25
Compression:
Stored size: 1.58 KB
Contents
#include "to_c.hpp" #include "ast.hpp" #include "sass_values.h" namespace Sass { using namespace std; Sass_Value* To_C::fallback_impl(AST_Node* n) { return sass_make_null(); } Sass_Value* To_C::operator()(Boolean* b) { return sass_make_boolean(b->value()); } Sass_Value* To_C::operator()(Number* n) { return sass_make_number(n->value(), n->unit().c_str()); } Sass_Value* To_C::operator()(Color* c) { return sass_make_color(c->r(), c->g(), c->b(), c->a()); } Sass_Value* To_C::operator()(String_Constant* s) { return sass_make_string(s->value().c_str()); } Sass_Value* To_C::operator()(List* l) { Sass_Value* v = sass_make_list(l->length(), l->separator() == List::COMMA ? SASS_COMMA : SASS_SPACE); for (size_t i = 0, L = l->length(); i < L; ++i) { sass_list_set_value(v, i, (*l)[i]->perform(this)); } return v; } Sass_Value* To_C::operator()(Map* m) { Sass_Value* v = sass_make_map(m->length()); int i = 0; for (auto key : m->keys()) { sass_map_set_key(v, i, key->perform(this)); sass_map_set_value(v, i, m->at(key)->perform(this)); i++; } return v; } Sass_Value* To_C::operator()(Arguments* a) { Sass_Value* v = sass_make_list(a->length(), SASS_COMMA); for (size_t i = 0, L = a->length(); i < L; ++i) { sass_list_set_value(v, i, (*a)[i]->perform(this)); } return v; } Sass_Value* To_C::operator()(Argument* a) { return a->value()->perform(this); } // not strictly necessary because of the fallback Sass_Value* To_C::operator()(Null* n) { return sass_make_null(); } };
Version data entries
25 entries across 25 versions & 2 rubygems