/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ #ifndef T_STRUCT_H #define T_STRUCT_H #include #include #include #include #include "t_type.h" #include "t_field.h" // Forward declare that puppy class t_program; /** * A struct is a container for a set of member fields that has a name. Structs * are also used to implement exception types. * */ class t_struct : public t_type { public: typedef std::vector members_type; t_struct(t_program* program) : t_type(program), is_xception_(false), xsd_all_(false) {} t_struct(t_program* program, const std::string& name) : t_type(program, name), is_xception_(false), xsd_all_(false) {} void set_name(const std::string& name) { name_ = name; } void set_xception(bool is_xception) { is_xception_ = is_xception; } void set_xsd_all(bool xsd_all) { xsd_all_ = xsd_all; } bool get_xsd_all() const { return xsd_all_; } bool append(t_field* elem) { members_.push_back(elem); typedef members_type::iterator iter_type; std::pair bounds = std::equal_range( members_in_id_order_.begin(), members_in_id_order_.end(), elem, t_field::key_compare() ); if (bounds.first != bounds.second) { return false; } members_in_id_order_.insert(bounds.second, elem); return true; } const members_type& get_members() { return members_; } const members_type& get_sorted_members() { return members_in_id_order_; } bool is_struct() const { return !is_xception_; } bool is_xception() const { return is_xception_; } virtual std::string get_fingerprint_material() const { std::string rv = "{"; members_type::const_iterator m_iter; for (m_iter = members_in_id_order_.begin(); m_iter != members_in_id_order_.end(); ++m_iter) { rv += (*m_iter)->get_fingerprint_material(); rv += ";"; } rv += "}"; return rv; } virtual void generate_fingerprint() { t_type::generate_fingerprint(); members_type::const_iterator m_iter; for (m_iter = members_in_id_order_.begin(); m_iter != members_in_id_order_.end(); ++m_iter) { (*m_iter)->get_type()->generate_fingerprint(); } } private: members_type members_; members_type members_in_id_order_; bool is_xception_; bool xsd_all_; }; #endif