blob: ac10d573768314791f4c39673bdd2ed2f6b35b3f [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +00001/*
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 */
Mark Sleee9ce01c2007-05-16 02:29:53 +000019
Mark Slee31985722006-05-24 21:45:31 +000020#ifndef T_FIELD_H
21#define T_FIELD_H
22
23#include <string>
David Reissaca320d2010-08-31 16:51:26 +000024#include <sstream>
Mark Slee31985722006-05-24 21:45:31 +000025
David Reissf011bd42008-10-29 00:07:45 +000026#include "t_doc.h"
27
Mark Slee748d83f2007-02-07 01:20:08 +000028// Forward declare for xsd_attrs
29class t_struct;
30
Mark Slee31985722006-05-24 21:45:31 +000031/**
Mark Sleef5377b32006-10-10 01:42:59 +000032 * Class to represent a field in a thrift structure. A field has a data type,
33 * a symbolic name, and a numeric identifier.
Mark Slee31985722006-05-24 21:45:31 +000034 *
Mark Slee31985722006-05-24 21:45:31 +000035 */
David Reissf011bd42008-10-29 00:07:45 +000036class t_field : public t_doc {
Mark Slee31985722006-05-24 21:45:31 +000037 public:
Mark Sleeb15a68b2006-06-07 06:46:24 +000038 t_field(t_type* type, std::string name) :
Mark Sleef5377b32006-10-10 01:42:59 +000039 type_(type),
40 name_(name),
Mark Slee36bfa2e2007-01-19 20:09:51 +000041 key_(0),
Mark Slee7ff32452007-02-01 05:26:18 +000042 value_(NULL),
Mark Slee7df0e2a2007-02-06 21:03:18 +000043 xsd_optional_(false),
Mark Slee748d83f2007-02-07 01:20:08 +000044 xsd_nillable_(false),
45 xsd_attrs_(NULL) {}
Mark Sleeb15a68b2006-06-07 06:46:24 +000046
Mark Slee9cb7c612006-09-01 22:17:45 +000047 t_field(t_type* type, std::string name, int32_t key) :
Mark Sleef5377b32006-10-10 01:42:59 +000048 type_(type),
49 name_(name),
Mark Slee36bfa2e2007-01-19 20:09:51 +000050 key_(key),
David Reiss204420f2008-01-11 20:59:03 +000051 req_(T_OPT_IN_REQ_OUT),
Mark Slee7ff32452007-02-01 05:26:18 +000052 value_(NULL),
Mark Slee7df0e2a2007-02-06 21:03:18 +000053 xsd_optional_(false),
Mark Slee748d83f2007-02-07 01:20:08 +000054 xsd_nillable_(false),
55 xsd_attrs_(NULL) {}
Mark Slee31985722006-05-24 21:45:31 +000056
57 ~t_field() {}
58
Mark Sleef5377b32006-10-10 01:42:59 +000059 t_type* get_type() const {
60 return type_;
61 }
62
63 const std::string& get_name() const {
64 return name_;
65 }
66
67 int32_t get_key() const {
68 return key_;
69 }
Mark Slee31985722006-05-24 21:45:31 +000070
David Reiss8320a922007-08-14 19:59:26 +000071 enum e_req {
David Reiss204420f2008-01-11 20:59:03 +000072 T_REQUIRED,
73 T_OPTIONAL,
Roger Meier0069cc42010-10-13 18:10:18 +000074 T_OPT_IN_REQ_OUT
David Reiss8320a922007-08-14 19:59:26 +000075 };
76
77 void set_req(e_req req) {
78 req_ = req;
79 }
80
81 e_req get_req() const {
82 return req_;
83 }
84
Mark Slee21135c32007-02-05 21:52:08 +000085 void set_value(t_const_value* value) {
86 value_ = value;
87 }
88
89 t_const_value* get_value() {
90 return value_;
91 }
92
Mark Slee36bfa2e2007-01-19 20:09:51 +000093 void set_xsd_optional(bool xsd_optional) {
94 xsd_optional_ = xsd_optional;
95 }
96
97 bool get_xsd_optional() const {
98 return xsd_optional_;
99 }
100
Mark Slee7df0e2a2007-02-06 21:03:18 +0000101 void set_xsd_nillable(bool xsd_nillable) {
102 xsd_nillable_ = xsd_nillable;
103 }
104
105 bool get_xsd_nillable() const {
106 return xsd_nillable_;
107 }
108
Mark Slee748d83f2007-02-07 01:20:08 +0000109 void set_xsd_attrs(t_struct* xsd_attrs) {
110 xsd_attrs_ = xsd_attrs;
Mark Slee7ff32452007-02-01 05:26:18 +0000111 }
112
Mark Slee748d83f2007-02-07 01:20:08 +0000113 t_struct* get_xsd_attrs() {
Mark Slee21135c32007-02-05 21:52:08 +0000114 return xsd_attrs_;
Mark Slee7ff32452007-02-01 05:26:18 +0000115 }
116
David Reiss18bf22d2007-08-28 20:49:17 +0000117 // This is not the same function as t_type::get_fingerprint_material,
118 // but it does the same thing.
119 std::string get_fingerprint_material() const {
David Reissaca320d2010-08-31 16:51:26 +0000120 std::ostringstream keystm;
121 keystm << key_;
122 return keystm.str() + ":" +
David Reiss204420f2008-01-11 20:59:03 +0000123 ((req_ == T_OPTIONAL) ? "opt-" : "") +
David Reiss18bf22d2007-08-28 20:49:17 +0000124 type_->get_fingerprint_material();
125 }
126
Bryan Duxburyff219ac2009-04-10 21:51:00 +0000127 /**
128 * Comparator to sort fields in ascending order by key.
129 * Make this a functor instead of a function to help GCC inline it.
130 * The arguments are (const) references to const pointers to const t_fields.
131 */
132 struct key_compare {
133 bool operator()(t_field const * const & a, t_field const * const & b) {
134 return a->get_key() < b->get_key();
135 }
136 };
137
David Reiss53c10e02010-03-05 07:51:51 +0000138 std::map<std::string, std::string> annotations_;
Bryan Duxburyff219ac2009-04-10 21:51:00 +0000139
Mark Slee31985722006-05-24 21:45:31 +0000140 private:
141 t_type* type_;
142 std::string name_;
Mark Slee9cb7c612006-09-01 22:17:45 +0000143 int32_t key_;
David Reiss8320a922007-08-14 19:59:26 +0000144 e_req req_;
Mark Slee7ff32452007-02-01 05:26:18 +0000145 t_const_value* value_;
ccheeverf53b5cf2007-02-05 20:33:11 +0000146
Mark Slee36bfa2e2007-01-19 20:09:51 +0000147 bool xsd_optional_;
Mark Slee7df0e2a2007-02-06 21:03:18 +0000148 bool xsd_nillable_;
Mark Slee748d83f2007-02-07 01:20:08 +0000149 t_struct* xsd_attrs_;
Mark Slee36bfa2e2007-01-19 20:09:51 +0000150
Mark Slee31985722006-05-24 21:45:31 +0000151};
152
Bryan Duxburyc7206a42011-08-17 23:17:04 +0000153/**
154 * A simple struct for the parser to use to store a field ID, and whether or
155 * not it was specified by the user or automatically chosen.
156 */
157struct t_field_id {
158 int64_t value;
159 bool auto_assigned;
160};
161
Mark Slee31985722006-05-24 21:45:31 +0000162#endif