1/* Copyright JS Foundation and other contributors, http://js.foundation 2 * 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16#include "jerryscript-ext/handler.h" 17 18/** 19 * Get the resource name (usually a file name) of the currently executed script or the given function object 20 * 21 * Note: returned value must be freed with jerry_release_value, when it is no longer needed 22 * 23 * @return JS string constructed from 24 * - the currently executed function object's resource name, if the given value is undefined 25 * - resource name of the function object, if the given value is a function object 26 * - "<anonymous>", otherwise 27 */ 28jerry_value_t 29jerryx_handler_resource_name (const jerry_value_t func_obj_val, /**< function object */ 30 const jerry_value_t this_p, /**< this arg */ 31 const jerry_value_t args_p[], /**< function arguments */ 32 const jerry_length_t args_cnt) /**< number of function arguments */ 33{ 34 (void) func_obj_val; /* unused */ 35 (void) this_p; /* unused */ 36 37 jerry_value_t undefined_value = jerry_create_undefined (); 38 jerry_value_t resource_name = jerry_get_resource_name (args_cnt > 0 ? args_p[0] : undefined_value); 39 jerry_release_value (undefined_value); 40 41 return resource_name; 42} /* jerryx_handler_resource_name */ 43