/* Copyright 2016 Samsung Electronics Co., Ltd. * Copyright 2016 University of Szeged * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include #include "jerry-port.h" #include "jerry-port-default.h" static bool abort_on_fail = false; /** * Sets whether 'abort' should be called instead of 'exit' upon exiting with * non-zero exit code in the default implementation of jerry_port_fatal. */ void jerry_port_default_set_abort_on_fail (bool flag) /**< new value of 'abort on fail' flag */ { abort_on_fail = flag; } /* jerry_port_default_set_abort_on_fail */ /** * Check whether 'abort' should be called instead of 'exit' upon exiting with * non-zero exit code in the default implementation of jerry_port_fatal. * * @return true - if 'abort on fail' flag is set, * false - otherwise. */ bool jerry_port_default_is_abort_on_fail () { return abort_on_fail; } /* jerry_port_default_is_abort_on_fail */ /** * Default implementation of jerry_port_fatal. */ void jerry_port_fatal (jerry_fatal_code_t code, /**< fatal code enum item, */ void *lr) /**< return address at time failure occurred */ { JERRY_UNUSED (lr); if (code != 0 && code != ERR_OUT_OF_MEMORY && jerry_port_default_is_abort_on_fail ()) { abort (); } else { exit (code); } } /* jerry_port_fatal */