Mark Slee | e9ce01c | 2007-05-16 02:29:53 +0000 | [diff] [blame] | 1 | // Copyright (c) 2006- Facebook |
| 2 | // Distributed under the Thrift Software License |
| 3 | // |
| 4 | // See accompanying file LICENSE or visit the Thrift site at: |
| 5 | // http://developers.facebook.com/thrift/ |
| 6 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 7 | #ifndef T_PROGRAM_H |
| 8 | #define T_PROGRAM_H |
| 9 | |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 10 | #include <map> |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 11 | #include <string> |
| 12 | #include <vector> |
| 13 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 14 | // For program_name() |
| 15 | #include "main.h" |
| 16 | |
David Reiss | c2532a9 | 2007-07-30 23:46:11 +0000 | [diff] [blame] | 17 | #include "t_doc.h" |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 18 | #include "t_scope.h" |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 19 | #include "t_base_type.h" |
| 20 | #include "t_typedef.h" |
| 21 | #include "t_enum.h" |
Mark Slee | 3015287 | 2006-11-28 01:24:07 +0000 | [diff] [blame] | 22 | #include "t_const.h" |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 23 | #include "t_struct.h" |
| 24 | #include "t_service.h" |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 25 | #include "t_list.h" |
| 26 | #include "t_map.h" |
| 27 | #include "t_set.h" |
ccheever | f53b5cf | 2007-02-05 20:33:11 +0000 | [diff] [blame] | 28 | //#include "t_doc.h" |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 29 | |
| 30 | /** |
| 31 | * Top level class representing an entire thrift program. A program consists |
| 32 | * fundamentally of the following: |
| 33 | * |
| 34 | * Typedefs |
| 35 | * Enumerations |
Mark Slee | 3015287 | 2006-11-28 01:24:07 +0000 | [diff] [blame] | 36 | * Constants |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 37 | * Structs |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 38 | * Exceptions |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 39 | * Services |
| 40 | * |
Mark Slee | f5377b3 | 2006-10-10 01:42:59 +0000 | [diff] [blame] | 41 | * The program module also contains the definitions of the base types. |
| 42 | * |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 43 | * @author Mark Slee <mcslee@facebook.com> |
| 44 | */ |
David Reiss | c2532a9 | 2007-07-30 23:46:11 +0000 | [diff] [blame] | 45 | class t_program : public t_doc { |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 46 | public: |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 47 | t_program(std::string path, std::string name) : |
Mark Slee | 2c44d20 | 2007-05-16 02:18:07 +0000 | [diff] [blame] | 48 | path_(path), |
dweatherford | 65b7075 | 2007-10-31 02:18:14 +0000 | [diff] [blame] | 49 | name_(name), |
| 50 | out_path_("./") { |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 51 | scope_ = new t_scope(); |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 52 | } |
| 53 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 54 | t_program(std::string path) : |
dweatherford | 65b7075 | 2007-10-31 02:18:14 +0000 | [diff] [blame] | 55 | path_(path), |
| 56 | out_path_("./") { |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 57 | name_ = program_name(path); |
| 58 | scope_ = new t_scope(); |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 59 | } |
| 60 | |
Mark Slee | 2c44d20 | 2007-05-16 02:18:07 +0000 | [diff] [blame] | 61 | // Path accessor |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 62 | const std::string& get_path() const { return path_; } |
| 63 | |
dweatherford | 65b7075 | 2007-10-31 02:18:14 +0000 | [diff] [blame] | 64 | // Output path accessor |
| 65 | const std::string& get_out_path() const { return out_path_; } |
| 66 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 67 | // Name accessor |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 68 | const std::string& get_name() const { return name_; } |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 69 | |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 70 | // Namespace |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 71 | const std::string& get_namespace() const { return namespace_; } |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 72 | |
kholst | 76f2c88 | 2008-01-16 02:47:41 +0000 | [diff] [blame] | 73 | // Include prefix accessor |
| 74 | const std::string& get_include_prefix() const { return include_prefix_; } |
| 75 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 76 | // Accessors for program elements |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 77 | const std::vector<t_typedef*>& get_typedefs() const { return typedefs_; } |
| 78 | const std::vector<t_enum*>& get_enums() const { return enums_; } |
Mark Slee | 3015287 | 2006-11-28 01:24:07 +0000 | [diff] [blame] | 79 | const std::vector<t_const*>& get_consts() const { return consts_; } |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 80 | const std::vector<t_struct*>& get_structs() const { return structs_; } |
| 81 | const std::vector<t_struct*>& get_xceptions() const { return xceptions_; } |
Mark Slee | 1c4ced7 | 2008-01-14 23:04:43 +0000 | [diff] [blame] | 82 | const std::vector<t_struct*>& get_objects() const { return objects_; } |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 83 | const std::vector<t_service*>& get_services() const { return services_; } |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 84 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 85 | // Program elements |
| 86 | void add_typedef (t_typedef* td) { typedefs_.push_back(td); } |
| 87 | void add_enum (t_enum* te) { enums_.push_back(te); } |
Mark Slee | 3015287 | 2006-11-28 01:24:07 +0000 | [diff] [blame] | 88 | void add_const (t_const* tc) { consts_.push_back(tc); } |
Mark Slee | 1c4ced7 | 2008-01-14 23:04:43 +0000 | [diff] [blame] | 89 | void add_struct (t_struct* ts) { objects_.push_back(ts); |
| 90 | structs_.push_back(ts); } |
| 91 | void add_xception (t_struct* tx) { objects_.push_back(tx); |
| 92 | xceptions_.push_back(tx); } |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 93 | void add_service (t_service* ts) { services_.push_back(ts); } |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 94 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 95 | // Programs to include |
| 96 | const std::vector<t_program*>& get_includes() const { return includes_; } |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 97 | |
dweatherford | 65b7075 | 2007-10-31 02:18:14 +0000 | [diff] [blame] | 98 | void set_out_path(std::string out_path) { |
| 99 | out_path_ = out_path; |
| 100 | // Ensure that it ends with a trailing '/' (or '\' for windows machines) |
| 101 | char c = out_path_.at(out_path_.size() - 1); |
| 102 | if (!(c == '/' || c == '\\')) { |
| 103 | out_path_.push_back('/'); |
| 104 | } |
| 105 | } |
| 106 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 107 | // Scoping and namespacing |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 108 | void set_namespace(std::string name) { |
| 109 | namespace_ = name; |
| 110 | } |
| 111 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 112 | // Scope accessor |
| 113 | t_scope* scope() { |
| 114 | return scope_; |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 115 | } |
Mark Slee | f5377b3 | 2006-10-10 01:42:59 +0000 | [diff] [blame] | 116 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 117 | // Includes |
| 118 | |
kholst | 76f2c88 | 2008-01-16 02:47:41 +0000 | [diff] [blame] | 119 | void add_include(std::string path, std::string include_site) { |
| 120 | t_program* program = new t_program(path); |
| 121 | |
| 122 | // include prefix for this program is the site at which it was included |
| 123 | // (minus the filename) |
| 124 | std::string include_prefix; |
| 125 | std::string::size_type last_slash = std::string::npos; |
| 126 | if ((last_slash = include_site.rfind("/")) != std::string::npos) { |
| 127 | include_prefix = include_site.substr(0, last_slash); |
| 128 | } |
| 129 | |
| 130 | program->set_include_prefix(include_prefix); |
| 131 | includes_.push_back(program); |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 132 | } |
Mark Slee | f5377b3 | 2006-10-10 01:42:59 +0000 | [diff] [blame] | 133 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 134 | std::vector<t_program*>& get_includes() { |
| 135 | return includes_; |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 136 | } |
Mark Slee | f5377b3 | 2006-10-10 01:42:59 +0000 | [diff] [blame] | 137 | |
kholst | 76f2c88 | 2008-01-16 02:47:41 +0000 | [diff] [blame] | 138 | void set_include_prefix(std::string include_prefix) { |
| 139 | include_prefix_ = include_prefix; |
| 140 | |
| 141 | // this is intended to be a directory; add a trailing slash if necessary |
| 142 | int len = include_prefix_.size(); |
| 143 | if (len > 0 && include_prefix_[len - 1] != '/') { |
| 144 | include_prefix_ += '/'; |
| 145 | } |
| 146 | } |
| 147 | |
David Reiss | 79eca14 | 2008-02-27 01:55:13 +0000 | [diff] [blame] | 148 | // Language neutral namespace / packaging |
| 149 | void set_namespace(std::string language, std::string name_space) { |
| 150 | namespaces_[language] = name_space; |
| 151 | } |
| 152 | |
| 153 | std::string get_namespace(std::string language) const { |
| 154 | std::map<std::string, std::string>::const_iterator iter = namespaces_.find(language); |
| 155 | if (iter == namespaces_.end()) { |
| 156 | return std::string(); |
| 157 | } |
| 158 | return iter->second; |
| 159 | } |
| 160 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 161 | // Language specific namespace / packaging |
| 162 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 163 | void add_cpp_include(std::string path) { |
| 164 | cpp_includes_.push_back(path); |
| 165 | } |
| 166 | |
| 167 | const std::vector<std::string>& get_cpp_includes() { |
| 168 | return cpp_includes_; |
| 169 | } |
| 170 | |
Mark Slee | e888b37 | 2007-01-12 01:06:24 +0000 | [diff] [blame] | 171 | void set_php_namespace(std::string php_namespace) { |
| 172 | php_namespace_ = php_namespace; |
| 173 | } |
| 174 | |
| 175 | const std::string& get_php_namespace() const { |
| 176 | return php_namespace_; |
| 177 | } |
| 178 | |
Mark Slee | 0d9199e | 2007-01-31 02:08:30 +0000 | [diff] [blame] | 179 | void set_xsd_namespace(std::string xsd_namespace) { |
| 180 | xsd_namespace_ = xsd_namespace; |
| 181 | } |
| 182 | |
| 183 | const std::string& get_xsd_namespace() const { |
| 184 | return xsd_namespace_; |
| 185 | } |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 186 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 187 | private: |
Mark Slee | f5377b3 | 2006-10-10 01:42:59 +0000 | [diff] [blame] | 188 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 189 | // File path |
| 190 | std::string path_; |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 191 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 192 | // Name |
| 193 | std::string name_; |
| 194 | |
dweatherford | 65b7075 | 2007-10-31 02:18:14 +0000 | [diff] [blame] | 195 | // Output directory |
| 196 | std::string out_path_; |
| 197 | |
Mark Slee | 9cb7c61 | 2006-09-01 22:17:45 +0000 | [diff] [blame] | 198 | // Namespace |
| 199 | std::string namespace_; |
| 200 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 201 | // Included programs |
| 202 | std::vector<t_program*> includes_; |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 203 | |
kholst | 76f2c88 | 2008-01-16 02:47:41 +0000 | [diff] [blame] | 204 | // Include prefix for this program, if any |
| 205 | std::string include_prefix_; |
| 206 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 207 | // Identifier lookup scope |
| 208 | t_scope* scope_; |
Mark Slee | e854063 | 2006-05-30 09:24:40 +0000 | [diff] [blame] | 209 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 210 | // Components to generate code for |
| 211 | std::vector<t_typedef*> typedefs_; |
| 212 | std::vector<t_enum*> enums_; |
Mark Slee | 3015287 | 2006-11-28 01:24:07 +0000 | [diff] [blame] | 213 | std::vector<t_const*> consts_; |
Mark Slee | 1c4ced7 | 2008-01-14 23:04:43 +0000 | [diff] [blame] | 214 | std::vector<t_struct*> objects_; |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 215 | std::vector<t_struct*> structs_; |
| 216 | std::vector<t_struct*> xceptions_; |
| 217 | std::vector<t_service*> services_; |
| 218 | |
David Reiss | 79eca14 | 2008-02-27 01:55:13 +0000 | [diff] [blame] | 219 | // Dynamic namespaces |
| 220 | std::map<std::string, std::string> namespaces_; |
| 221 | |
Mark Slee | f0712dc | 2006-10-25 19:03:57 +0000 | [diff] [blame] | 222 | // C++ extra includes |
| 223 | std::vector<std::string> cpp_includes_; |
| 224 | |
Mark Slee | e888b37 | 2007-01-12 01:06:24 +0000 | [diff] [blame] | 225 | // PHP namespace |
| 226 | std::string php_namespace_; |
| 227 | |
Mark Slee | 0d9199e | 2007-01-31 02:08:30 +0000 | [diff] [blame] | 228 | // XSD namespace |
| 229 | std::string xsd_namespace_; |
| 230 | |
Mark Slee | 3198572 | 2006-05-24 21:45:31 +0000 | [diff] [blame] | 231 | }; |
| 232 | |
| 233 | #endif |