| #ifndef T_SCOPE_H |
| #define T_SCOPE_H |
| |
| #include <map> |
| #include <string> |
| |
| #include "t_type.h" |
| #include "t_service.h" |
| |
| /** |
| * This represents a variable scope used for looking up predefined types and |
| * services. Typically, a scope is associated with a t_program. Scopes are not |
| * used to determine code generation, but rather to resolve identifiers at |
| * parse time. |
| * |
| * @author Mark Slee <mcslee@facebook.com> |
| */ |
| class t_scope { |
| public: |
| t_scope() {} |
| |
| void add_type(std::string name, t_type* type) { |
| types_[name] = type; |
| } |
| |
| t_type* get_type(std::string name) { |
| return types_[name]; |
| } |
| |
| void add_service(std::string name, t_service* service) { |
| services_[name] = service; |
| } |
| |
| t_service* get_service(std::string name) { |
| return services_[name]; |
| } |
| |
| void print() { |
| std::map<std::string, t_type*>::iterator iter; |
| for (iter = types_.begin(); iter != types_.end(); ++iter) { |
| printf("%s => %s\n", |
| iter->first.c_str(), |
| iter->second->get_name().c_str()); |
| } |
| } |
| |
| private: |
| |
| // Map of names to types |
| std::map<std::string, t_type*> types_; |
| |
| // Map of names to services |
| std::map<std::string, t_service*> services_; |
| |
| }; |
| |
| #endif |