Commit 6e413130 authored by Marius Wachtler's avatar Marius Wachtler

Slightly speedup ASTInterpreter::initArguments

parent 9f7a8d19
...@@ -35,6 +35,7 @@ ...@@ -35,6 +35,7 @@
#include "core/stats.h" #include "core/stats.h"
#include "core/thread_utils.h" #include "core/thread_utils.h"
#include "core/util.h" #include "core/util.h"
#include "gc/roots.h"
#include "runtime/generator.h" #include "runtime/generator.h"
#include "runtime/import.h" #include "runtime/import.h"
#include "runtime/inline/boxing.h" #include "runtime/inline/boxing.h"
...@@ -299,24 +300,25 @@ void ASTInterpreter::initArguments(int nargs, BoxedClosure* _closure, BoxedGener ...@@ -299,24 +300,25 @@ void ASTInterpreter::initArguments(int nargs, BoxedClosure* _closure, BoxedGener
if (scope_info->createsClosure()) if (scope_info->createsClosure())
created_closure = createClosure(passed_closure, scope_info->getClosureSize()); created_closure = createClosure(passed_closure, scope_info->getClosureSize());
std::vector<Box*, StlCompatAllocator<Box*>> argsArray{ arg1, arg2, arg3 };
for (int i = 3; i < nargs; ++i)
argsArray.push_back(args[i - 3]);
const ParamNames& param_names = clfunc->param_names; const ParamNames& param_names = clfunc->param_names;
// make sure the AST_Name nodes are set
assert(param_names.args.size() == param_names.arg_names.size());
assert(param_names.vararg.empty() == (param_names.vararg_name == NULL));
assert(param_names.kwarg.empty() == (param_names.kwarg_name == NULL));
int i = 0; int i = 0;
for (auto& name : param_names.args) { for (auto& name : param_names.arg_names) {
doStore(source_info->getInternedStrings().get(name), Value(argsArray[i++], 0)); doStore(name, Value(getArg(i++, arg1, arg2, arg3, args), 0));
} }
if (!param_names.vararg.str().empty()) { if (param_names.vararg_name)
doStore(source_info->getInternedStrings().get(param_names.vararg), Value(argsArray[i++], 0)); doStore(param_names.vararg_name, Value(getArg(i++, arg1, arg2, arg3, args), 0));
}
if (!param_names.kwarg.str().empty()) { if (param_names.kwarg_name)
doStore(source_info->getInternedStrings().get(param_names.kwarg), Value(argsArray[i++], 0)); doStore(param_names.kwarg_name, Value(getArg(i++, arg1, arg2, arg3, args), 0));
}
assert(nargs == i);
} }
RegisterHelper::RegisterHelper() : frame_addr(NULL), interpreter(NULL) { RegisterHelper::RegisterHelper() : frame_addr(NULL), interpreter(NULL) {
......
...@@ -45,7 +45,8 @@ ...@@ -45,7 +45,8 @@
namespace pyston { namespace pyston {
// TODO terrible place for these! // TODO terrible place for these!
ParamNames::ParamNames(AST* ast, InternedStringPool& pool) : takes_param_names(true) { ParamNames::ParamNames(AST* ast, InternedStringPool& pool)
: takes_param_names(true), vararg_name(NULL), kwarg_name(NULL) {
if (ast->type == AST_TYPE::Module || ast->type == AST_TYPE::ClassDef || ast->type == AST_TYPE::Expression if (ast->type == AST_TYPE::Module || ast->type == AST_TYPE::ClassDef || ast->type == AST_TYPE::Expression
|| ast->type == AST_TYPE::Suite) { || ast->type == AST_TYPE::Suite) {
kwarg = ""; kwarg = "";
...@@ -56,22 +57,30 @@ ParamNames::ParamNames(AST* ast, InternedStringPool& pool) : takes_param_names(t ...@@ -56,22 +57,30 @@ ParamNames::ParamNames(AST* ast, InternedStringPool& pool) : takes_param_names(t
for (int i = 0; i < arguments->args.size(); i++) { for (int i = 0; i < arguments->args.size(); i++) {
AST_expr* arg = arguments->args[i]; AST_expr* arg = arguments->args[i];
if (arg->type == AST_TYPE::Name) { if (arg->type == AST_TYPE::Name) {
args.push_back(ast_cast<AST_Name>(arg)->id.s()); AST_Name* name = ast_cast<AST_Name>(arg);
arg_names.push_back(name);
args.push_back(name->id.s());
} else { } else {
InternedString dot_arg_name = pool.get("." + std::to_string(i)); InternedString dot_arg_name = pool.get("." + std::to_string(i));
arg_names.push_back(new AST_Name(dot_arg_name, AST_TYPE::Param, arg->lineno, arg->col_offset));
args.push_back(dot_arg_name.s()); args.push_back(dot_arg_name.s());
} }
} }
vararg = arguments->vararg.s(); vararg = arguments->vararg.s();
if (vararg.size())
vararg_name = new AST_Name(pool.get(vararg), AST_TYPE::Param, arguments->lineno, arguments->col_offset);
kwarg = arguments->kwarg.s(); kwarg = arguments->kwarg.s();
if (kwarg.size())
kwarg_name = new AST_Name(pool.get(kwarg), AST_TYPE::Param, arguments->lineno, arguments->col_offset);
} else { } else {
RELEASE_ASSERT(0, "%d", ast->type); RELEASE_ASSERT(0, "%d", ast->type);
} }
} }
ParamNames::ParamNames(const std::vector<llvm::StringRef>& args, llvm::StringRef vararg, llvm::StringRef kwarg) ParamNames::ParamNames(const std::vector<llvm::StringRef>& args, llvm::StringRef vararg, llvm::StringRef kwarg)
: takes_param_names(true) { : takes_param_names(true), vararg_name(NULL), kwarg_name(NULL) {
this->args = args; this->args = args;
this->vararg = vararg; this->vararg = vararg;
this->kwarg = kwarg; this->kwarg = kwarg;
......
...@@ -95,6 +95,7 @@ class AST; ...@@ -95,6 +95,7 @@ class AST;
class AST_FunctionDef; class AST_FunctionDef;
class AST_arguments; class AST_arguments;
class AST_expr; class AST_expr;
class AST_Name;
class AST_stmt; class AST_stmt;
class PhiAnalysis; class PhiAnalysis;
...@@ -147,6 +148,12 @@ struct ParamNames { ...@@ -147,6 +148,12 @@ struct ParamNames {
std::vector<llvm::StringRef> args; std::vector<llvm::StringRef> args;
llvm::StringRef vararg, kwarg; llvm::StringRef vararg, kwarg;
// This members are only set if the InternedStringPool& constructor is used (aka. source is available)!
// They are used as an optimization while interpreting because the AST_Names nodes cache important stuff
// (InternedString, lookup_type) which would otherwise have to get recomputed all the time.
std::vector<AST_Name*> arg_names;
AST_Name* vararg_name, *kwarg_name;
explicit ParamNames(AST* ast, InternedStringPool& pool); explicit ParamNames(AST* ast, InternedStringPool& pool);
ParamNames(const std::vector<llvm::StringRef>& args, llvm::StringRef vararg, llvm::StringRef kwarg); ParamNames(const std::vector<llvm::StringRef>& args, llvm::StringRef vararg, llvm::StringRef kwarg);
static ParamNames empty() { return ParamNames(); } static ParamNames empty() { return ParamNames(); }
...@@ -156,7 +163,7 @@ struct ParamNames { ...@@ -156,7 +163,7 @@ struct ParamNames {
} }
private: private:
ParamNames() : takes_param_names(false) {} ParamNames() : takes_param_names(false), vararg_name(NULL), kwarg_name(NULL) {}
}; };
// Probably overkill to copy this from ArgPassSpec // Probably overkill to copy this from ArgPassSpec
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment