Blame src/listize.cpp

Packit bfcc33
#include "sass.hpp"
Packit bfcc33
#include <iostream>
Packit bfcc33
#include <typeinfo>
Packit bfcc33
#include <string>
Packit bfcc33
Packit bfcc33
#include "listize.hpp"
Packit bfcc33
#include "context.hpp"
Packit bfcc33
#include "backtrace.hpp"
Packit bfcc33
#include "error_handling.hpp"
Packit bfcc33
Packit bfcc33
namespace Sass {
Packit bfcc33
Packit bfcc33
  Listize::Listize()
Packit bfcc33
  {  }
Packit bfcc33
Packit bfcc33
  Expression_Ptr Listize::operator()(Selector_List_Ptr sel)
Packit bfcc33
  {
Packit bfcc33
    List_Obj l = SASS_MEMORY_NEW(List, sel->pstate(), sel->length(), SASS_COMMA);
Packit bfcc33
    l->from_selector(true);
Packit bfcc33
    for (size_t i = 0, L = sel->length(); i < L; ++i) {
Packit bfcc33
      if (!sel->at(i)) continue;
Packit bfcc33
      l->append(sel->at(i)->perform(this));
Packit bfcc33
    }
Packit bfcc33
    if (l->length()) return l.detach();
Packit bfcc33
    return SASS_MEMORY_NEW(Null, l->pstate());
Packit bfcc33
  }
Packit bfcc33
Packit bfcc33
  Expression_Ptr Listize::operator()(Compound_Selector_Ptr sel)
Packit bfcc33
  {
Packit bfcc33
    std::string str;
Packit bfcc33
    for (size_t i = 0, L = sel->length(); i < L; ++i) {
Packit bfcc33
      Expression_Ptr e = (*sel)[i]->perform(this);
Packit bfcc33
      if (e) str += e->to_string();
Packit bfcc33
    }
Packit bfcc33
    return SASS_MEMORY_NEW(String_Quoted, sel->pstate(), str);
Packit bfcc33
  }
Packit bfcc33
Packit bfcc33
  Expression_Ptr Listize::operator()(Complex_Selector_Ptr sel)
Packit bfcc33
  {
Packit bfcc33
    List_Obj l = SASS_MEMORY_NEW(List, sel->pstate(), 2);
Packit bfcc33
    l->from_selector(true);
Packit bfcc33
    Compound_Selector_Obj head = sel->head();
Packit bfcc33
    if (head && !head->is_empty_reference())
Packit bfcc33
    {
Packit bfcc33
      Expression_Ptr hh = head->perform(this);
Packit bfcc33
      if (hh) l->append(hh);
Packit bfcc33
    }
Packit bfcc33
Packit bfcc33
    std::string reference = ! sel->reference() ? ""
Packit bfcc33
      : sel->reference()->to_string();
Packit bfcc33
    switch(sel->combinator())
Packit bfcc33
    {
Packit bfcc33
      case Complex_Selector::PARENT_OF:
Packit bfcc33
        l->append(SASS_MEMORY_NEW(String_Quoted, sel->pstate(), ">"));
Packit bfcc33
      break;
Packit bfcc33
      case Complex_Selector::ADJACENT_TO:
Packit bfcc33
        l->append(SASS_MEMORY_NEW(String_Quoted, sel->pstate(), "+"));
Packit bfcc33
      break;
Packit bfcc33
      case Complex_Selector::REFERENCE:
Packit bfcc33
        l->append(SASS_MEMORY_NEW(String_Quoted, sel->pstate(), "/" + reference + "/"));
Packit bfcc33
      break;
Packit bfcc33
      case Complex_Selector::PRECEDES:
Packit bfcc33
        l->append(SASS_MEMORY_NEW(String_Quoted, sel->pstate(), "~"));
Packit bfcc33
      break;
Packit bfcc33
      case Complex_Selector::ANCESTOR_OF:
Packit bfcc33
      break;
Packit bfcc33
      default: break;
Packit bfcc33
    }
Packit bfcc33
Packit bfcc33
    Complex_Selector_Obj tail = sel->tail();
Packit bfcc33
    if (tail)
Packit bfcc33
    {
Packit bfcc33
      Expression_Obj tt = tail->perform(this);
Packit bfcc33
      if (List_Ptr ls = Cast<List>(tt))
Packit bfcc33
      { l->concat(ls); }
Packit bfcc33
    }
Packit bfcc33
    if (l->length() == 0) return 0;
Packit bfcc33
    return l.detach();
Packit bfcc33
  }
Packit bfcc33
Packit bfcc33
  Expression_Ptr Listize::fallback_impl(AST_Node_Ptr n)
Packit bfcc33
  {
Packit bfcc33
    return Cast<Expression>(n);
Packit bfcc33
  }
Packit bfcc33
Packit bfcc33
}