Subversion Repositories SmartDukaan

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
30 ashish 1
/*
2
 * Licensed to the Apache Software Foundation (ASF) under one
3
 * or more contributor license agreements. See the NOTICE file
4
 * distributed with this work for additional information
5
 * regarding copyright ownership. The ASF licenses this file
6
 * to you under the Apache License, Version 2.0 (the
7
 * "License"); you may not use this file except in compliance
8
 * with the License. You may obtain a copy of the License at
9
 *
10
 *   http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing,
13
 * software distributed under the License is distributed on an
14
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15
 * KIND, either express or implied. See the License for the
16
 * specific language governing permissions and limitations
17
 * under the License.
18
 */
19
 
20
#ifndef T_STRUCT_H
21
#define T_STRUCT_H
22
 
23
#include <algorithm>
24
#include <vector>
25
#include <utility>
26
#include <string>
27
 
28
#include "t_type.h"
29
#include "t_field.h"
30
 
31
// Forward declare that puppy
32
class t_program;
33
 
34
/**
35
 * A struct is a container for a set of member fields that has a name. Structs
36
 * are also used to implement exception types.
37
 *
38
 */
39
class t_struct : public t_type {
40
 public:
41
  typedef std::vector<t_field*> members_type;
42
 
43
  t_struct(t_program* program) :
44
    t_type(program),
45
    is_xception_(false),
46
    xsd_all_(false) {}
47
 
48
  t_struct(t_program* program, const std::string& name) :
49
    t_type(program, name),
50
    is_xception_(false),
51
    xsd_all_(false) {}
52
 
53
  void set_name(const std::string& name) {
54
    name_ = name;
55
  }
56
 
57
  void set_xception(bool is_xception) {
58
    is_xception_ = is_xception;
59
  }
60
 
61
  void set_union(bool is_union) {
62
    is_union_ = is_union;
63
  }
64
 
65
  void set_xsd_all(bool xsd_all) {
66
    xsd_all_ = xsd_all;
67
  }
68
 
69
  bool get_xsd_all() const {
70
    return xsd_all_;
71
  }
72
 
73
  bool append(t_field* elem) {
74
    members_.push_back(elem);
75
 
76
    typedef members_type::iterator iter_type;
77
    std::pair<iter_type, iter_type> bounds = std::equal_range(
78
            members_in_id_order_.begin(), members_in_id_order_.end(), elem, t_field::key_compare()
79
        );
80
    if (bounds.first != bounds.second) {
81
      return false;
82
    }
83
    members_in_id_order_.insert(bounds.second, elem);
84
    return true;
85
  }
86
 
87
  const members_type& get_members() {
88
    return members_;
89
  }
90
 
91
  const members_type& get_sorted_members() {
92
    return members_in_id_order_;
93
  }
94
 
95
  bool is_struct() const {
96
    return !is_xception_;
97
  }
98
 
99
  bool is_xception() const {
100
    return is_xception_;
101
  }
102
 
103
  bool is_union() const {
104
    return is_union_;
105
  }
106
 
107
  virtual std::string get_fingerprint_material() const {
108
    std::string rv = "{";
109
    members_type::const_iterator m_iter;
110
    for (m_iter = members_in_id_order_.begin(); m_iter != members_in_id_order_.end(); ++m_iter) {
111
      rv += (*m_iter)->get_fingerprint_material();
112
      rv += ";";
113
    }
114
    rv += "}";
115
    return rv;
116
  }
117
 
118
  virtual void generate_fingerprint() {
119
    t_type::generate_fingerprint();
120
    members_type::const_iterator m_iter;
121
    for (m_iter = members_in_id_order_.begin(); m_iter != members_in_id_order_.end(); ++m_iter) {
122
      (*m_iter)->get_type()->generate_fingerprint();
123
    }
124
  }
125
 
126
 private:
127
 
128
  members_type members_;
129
  members_type members_in_id_order_;
130
  bool is_xception_;
131
  bool is_union_;
132
 
133
  bool xsd_all_;
134
};
135
 
136
#endif