blob: 94cb26ea503115d7ed8b9192971a96ccab4c0377 [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();
Jens Geyerae0b22c2014-09-04 23:04:21 +020079 min_value_value = min_value->get_value();
Roger Meier60b7ad62014-07-29 23:23:36 +020080 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
Jens Geyerae0b22c2014-09-04 23:04:21 +020081 if ((*c_iter)->get_value() < min_value_value) {
Roger Meier60b7ad62014-07-29 23:23:36 +020082 min_value = (*c_iter);
83 min_value_value = min_value->get_value();
84 }
85 }
86 }
87 return min_value;
88 }
89
90 t_enum_value* get_max_value() {
91 const std::vector<t_enum_value*>& enum_values = get_constants();
92 std::vector<t_enum_value*>::const_iterator c_iter;
93 t_enum_value* max_value;
94 if (enum_values.size() == 0) {
95 max_value = NULL;
96 }
97 else {
98 int max_value_value;
99 max_value = enum_values.back();
Jens Geyerae0b22c2014-09-04 23:04:21 +0200100 max_value_value = max_value->get_value();
Roger Meier60b7ad62014-07-29 23:23:36 +0200101 for (c_iter = enum_values.begin(); c_iter != enum_values.end(); ++c_iter) {
Jens Geyerae0b22c2014-09-04 23:04:21 +0200102 if ((*c_iter)->get_value() > max_value_value) {
Roger Meier60b7ad62014-07-29 23:23:36 +0200103 max_value = (*c_iter);
104 max_value_value = max_value->get_value();
105 }
106 }
107 }
108 return max_value;
109 }
110
Mark Sleef5377b32006-10-10 01:42:59 +0000111 bool is_enum() const {
112 return true;
113 }
Mark Slee31985722006-05-24 21:45:31 +0000114
David Reiss18bf22d2007-08-28 20:49:17 +0000115 virtual std::string get_fingerprint_material() const {
116 return "enum";
117 }
118
Bryan Duxbury2d804702009-12-18 19:41:11 +0000119
Mark Slee31985722006-05-24 21:45:31 +0000120 private:
Mark Slee30152872006-11-28 01:24:07 +0000121 std::vector<t_enum_value*> constants_;
Mark Slee31985722006-05-24 21:45:31 +0000122};
123
124#endif