blob: e03956e572d8453106d6f4b0d476ffb92a977984 [file] [log] [blame]
// Copyright (c) 2006- Facebook
// Distributed under the Thrift Software License
//
// See accompanying file LICENSE or visit the Thrift site at:
// http://developers.facebook.com/thrift/
#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 add_constant(std::string name, t_const* constant) {
constants_[name] = constant;
}
t_const* get_constant(std::string name) {
return constants_[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 constants
std::map<std::string, t_const*> constants_;
// Map of names to services
std::map<std::string, t_service*> services_;
};
#endif