summaryrefslogtreecommitdiff
path: root/src/bin/eolian_mono/eolian/mono/alias_definition.hh
blob: 91659fb7bd8f4549351c2c87a14ca1cdfab75acb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#ifndef EOLIAN_MONO_ALIAS_DEFINITION_HH
#define EOLIAN_MONO_ALIAS_DEFINITION_HH

#include "grammar/generator.hpp"
#include "grammar/klass_def.hpp"
#include "grammar/indentation.hpp"

#include "using_decl.hh"
#include "name_helpers.hh"
#include "blacklist.hh"
#include "documentation.hh"
#include "generation_contexts.hh"

namespace eolian_mono {

struct alias_definition_generator
{
  template<typename OutputIterator, typename Context>
  bool generate(OutputIterator sink, attributes::alias_def const& alias, Context const& context) const
  {
     if (blacklist::is_alias_blacklisted(alias))
       {
          EINA_CXX_DOM_LOG_DBG(eolian_mono::domain) << "Alias " <<  name_helpers::alias_full_eolian_name(alias) << "is blacklisted. Skipping.";
          return true;
       }

     if (alias.is_undefined)
       {
          EINA_CXX_DOM_LOG_DBG(eolian_mono::domain) << "Alias " <<  name_helpers::alias_full_eolian_name(alias) << "is undefined. Skipping.";
          return true;
       }

     if (!name_helpers::open_namespaces(sink, alias.namespaces, context))
       return false;

     std::string const& alias_name = alias.eolian_name;
     if (!as_generator(
                 "public struct " << alias_name << " {\n"
                 << scope_tab << "private " << type << " payload;\n"
                 << scope_tab << "public static implicit operator " << alias_name << "(" << type << " x)\n"
                 << scope_tab << "{\n"
                 << scope_tab << scope_tab << "return new " << alias_name << "{payload=x};\n"
                 << scope_tab << "}\n"
                 << scope_tab << "public static implicit operator " << type << "(" << alias_name << " x)\n"
                 << scope_tab << "{\n"
                 << scope_tab << scope_tab << "return x.payload;\n"
                 << scope_tab << "}\n"
                 << "}\n"
                 ).generate(sink, std::make_tuple(alias.base_type, alias.base_type, alias.base_type), context))
       return false;

     if (!name_helpers::close_namespaces(sink, alias.namespaces, context))
       return false;

     return true;
  }
} const alias_definition {};

}

namespace efl { namespace eolian { namespace grammar {

template<>
struct is_eager_generator< ::eolian_mono::alias_definition_generator> : std::true_type {};
template<>
struct is_generator< ::eolian_mono::alias_definition_generator> : std::true_type {};

namespace type_traits {

template<>
struct attributes_needed< ::eolian_mono::alias_definition_generator> : std::integral_constant<int, 1> {};

}

} } }

#endif