njs_generate_function_declaration(njs_vm_t *vm, njs_parser_t *parser,
njs_parser_node_t *node)
{
+ njs_variable_t *var;
njs_function_lambda_t *lambda;
- lambda = node->u.value.data.u.function->u.lambda;
+ var = njs_variable_get(vm, node, NJS_NAME_DECLARATION);
+ if (nxt_slow_path(var == NULL)) {
+ return NXT_ERROR;
+ }
+
+ lambda = var->value.data.u.function->u.lambda;
return njs_generate_function_scope(vm, lambda, node);
}
static njs_token_t
njs_parser_function_declaration(njs_vm_t *vm, njs_parser_t *parser)
{
+ njs_ret_t ret;
njs_token_t token;
njs_variable_t *var;
njs_function_t *function;
return NJS_TOKEN_ERROR;
}
+ ret = njs_variable_reference(vm, parser, node);
+ if (nxt_slow_path(ret != NXT_OK)) {
+ return NJS_TOKEN_ERROR;
+ }
+
token = njs_parser_token(parser);
if (nxt_slow_path(token <= NJS_TOKEN_ILLEGAL)) {
return token;
var->value.type = NJS_FUNCTION;
var->value.data.truth = 1;
- node->u.value = var->value;
-
parser = njs_parser_function_create(vm, parser);
if (nxt_slow_path(parser == NULL)) {
return NJS_TOKEN_ERROR;
var = lhq.value;
- value = (njs_value_t *) ((u_char *) vm->global_scope
- + njs_offset(var->index) - NJS_INDEX_GLOBAL_OFFSET);
+ value = njs_global_variable_value(vm, var);
if (njs_is_function(value)) {
return value->data.u.function;
nxt_int_t ret;
njs_lexer_t *lexer;
njs_parser_t *parser;
+ njs_variable_t *var;
njs_parser_node_t *node;
parser = nxt_mem_cache_zalloc(vm->mem_cache_pool, sizeof(njs_parser_t));
if (function != NULL) {
if (node->token == NJS_TOKEN_CALL) {
- *function = node->right->u.value.data.u.function;
+ var = njs_variable_get(vm, node->right, NJS_NAME_DECLARATION);
+ if (nxt_slow_path(var == NULL)) {
+ return NJS_ERROR;
+ }
+
+ *function = var->value.data.u.function;
} else {
*function = NULL;
vm->global_scope = parser->local_scope;
vm->scope_size = parser->scope_size;
+ vm->variables_hash = parser->scope->variables;
vm->parser = NULL;