blob: ec847d16bbed81590e5d964fb65c3e975cd8f094 [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_ENUM_H
21#define T_ENUM_H
22
Mark Slee30152872006-11-28 01:24:07 +000023#include "t_enum_value.h"
Mark Slee31985722006-05-24 21:45:31 +000024#include <vector>
25
Mark Sleef5377b32006-10-10 01:42:59 +000026/**
Mark Slee30152872006-11-28 01:24:07 +000027 * An enumerated type. A list of constant objects with a name for the type.
Mark Sleef5377b32006-10-10 01:42:59 +000028 *
Mark Sleef5377b32006-10-10 01:42:59 +000029 */
Mark Slee31985722006-05-24 21:45:31 +000030class t_enum : public t_type {
31 public:
Mark Sleef0712dc2006-10-25 19:03:57 +000032 t_enum(t_program* program) :
33 t_type(program) {}
Mark Slee31985722006-05-24 21:45:31 +000034
Mark Slee32007a52008-01-18 00:57:59 +000035 void set_name(const std::string& name) {
Mark Sleef5377b32006-10-10 01:42:59 +000036 name_ = name;
37 }
Mark Slee32007a52008-01-18 00:57:59 +000038
Mark Slee30152872006-11-28 01:24:07 +000039 void append(t_enum_value* constant) {
Mark Sleef5377b32006-10-10 01:42:59 +000040 constants_.push_back(constant);
41 }
Mark Slee31985722006-05-24 21:45:31 +000042
Mark Slee30152872006-11-28 01:24:07 +000043 const std::vector<t_enum_value*>& get_constants() {
Mark Sleef5377b32006-10-10 01:42:59 +000044 return constants_;
45 }
46
Bryan Duxbury2d804702009-12-18 19:41:11 +000047 t_enum_value* get_constant_by_name(const std::string name) {
48 const std::vector<t_enum_value*>& enum_values = get_constants();
49 std::vector<t_enum_value*>::const_iterator c_iter;
50 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
51 if ((*c_iter)->get_name() == name) {
52 return *c_iter;
53 }
54 }
55 return NULL;
56 }
57
58 t_enum_value* get_constant_by_value(int64_t value) {
59 const std::vector<t_enum_value*>& enum_values = get_constants();
60 std::vector<t_enum_value*>::const_iterator c_iter;
61 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
62 if ((*c_iter)->get_value() == value) {
63 return *c_iter;
64 }
65 }
66 return NULL;
67 }
68
Roger Meier60b7ad62014-07-29 23:23:36 +020069 t_enum_value* get_min_value() {
70 const std::vector<t_enum_value*>& enum_values = get_constants();
71 std::vector<t_enum_value*>::const_iterator c_iter;
72 t_enum_value* min_value;
73 if (enum_values.size() == 0) {
74 min_value = NULL;
75 }
76 else {
77 int min_value_value;
78 min_value = enum_values.front();
79 min_value_value = (min_value->has_value() ? min_value->get_value() : 1);
80 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
81 if ((*c_iter)->has_value() &&
82 ((*c_iter)->get_value() < min_value_value)) {
83 min_value = (*c_iter);
84 min_value_value = min_value->get_value();
85 }
86 }
87 }
88 return min_value;
89 }
90
91 t_enum_value* get_max_value() {
92 const std::vector<t_enum_value*>& enum_values = get_constants();
93 std::vector<t_enum_value*>::const_iterator c_iter;
94 t_enum_value* max_value;
95 if (enum_values.size() == 0) {
96 max_value = NULL;
97 }
98 else {
99 int max_value_value;
100 max_value = enum_values.back();
101 max_value_value =
102 (max_value->has_value() ? max_value->get_value() : enum_values.size());
103 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
104 if ((*c_iter)->has_value() &&
105 ((*c_iter)->get_value() > max_value_value)) {
106 max_value = (*c_iter);
107 max_value_value = max_value->get_value();
108 }
109 }
110 }
111 return max_value;
112 }
113
Mark Sleef5377b32006-10-10 01:42:59 +0000114 bool is_enum() const {
115 return true;
116 }
Mark Slee31985722006-05-24 21:45:31 +0000117
David Reiss18bf22d2007-08-28 20:49:17 +0000118 virtual std::string get_fingerprint_material() const {
119 return "enum";
120 }
121
Bryan Duxbury2d804702009-12-18 19:41:11 +0000122 void resolve_values() {
123 const std::vector<t_enum_value*>& enum_values = get_constants();
124 std::vector<t_enum_value*>::const_iterator c_iter;
125 int lastValue = -1;
126 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
127 if (! (*c_iter)->has_value()) {
128 (*c_iter)->set_value(++lastValue);
129 } else {
130 lastValue = (*c_iter)->get_value();
131 }
132 }
133 }
134
Mark Slee31985722006-05-24 21:45:31 +0000135 private:
Mark Slee30152872006-11-28 01:24:07 +0000136 std::vector<t_enum_value*> constants_;
Mark Slee31985722006-05-24 21:45:31 +0000137};
138
139#endif