mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
* Added new flag `JERRY_FLAG_ABORT_ON_FAIL`. * Added new internal api function `jerry_is_abort_on_fail` to check the status of the flag. * Changed `jerry_fatal` bail-out function to call `abort` when the flag is set and exit code is non-zero (i.e., not only for assertion failures). * Added `--abort-on-fail` command line option to linux and nuttx apps to set the flag. JerryScript-DCO-1.0-Signed-off-by: Akos Kiss akiss@inf.u-szeged.hu
211 lines
4.5 KiB
C++
211 lines
4.5 KiB
C++
/* Copyright 2015 Samsung Electronics Co., Ltd.
|
|
*
|
|
* 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 <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include "jerry.h"
|
|
|
|
/**
|
|
* The module interface routine
|
|
*/
|
|
extern "C" int jerry_main (int argc, char *argv[]);
|
|
|
|
/**
|
|
* Maximum command line arguments number
|
|
*/
|
|
#define JERRY_MAX_COMMAND_LINE_ARGS (64)
|
|
|
|
/**
|
|
* Maximum size of source code buffer
|
|
*/
|
|
#define JERRY_SOURCE_BUFFER_SIZE (1024)
|
|
|
|
/**
|
|
* Standalone Jerry exit codes
|
|
*/
|
|
#define JERRY_STANDALONE_EXIT_CODE_OK (0)
|
|
#define JERRY_STANDALONE_EXIT_CODE_FAIL (1)
|
|
|
|
static uint8_t source_buffer[ JERRY_SOURCE_BUFFER_SIZE ];
|
|
|
|
static const char*
|
|
read_sources (const char *script_file_names[],
|
|
int files_count,
|
|
size_t *out_source_size_p)
|
|
{
|
|
int i;
|
|
uint8_t *source_buffer_tail = source_buffer;
|
|
|
|
FILE *file = NULL;
|
|
|
|
for (i = 0; i < files_count; i++)
|
|
{
|
|
const char *script_file_name = script_file_names[i];
|
|
|
|
file = fopen (script_file_name, "r");
|
|
|
|
if (file == NULL)
|
|
{
|
|
break;
|
|
}
|
|
|
|
int fseek_status = fseek (file, 0, SEEK_END);
|
|
|
|
if (fseek_status != 0)
|
|
{
|
|
break;
|
|
}
|
|
|
|
long script_len = ftell (file);
|
|
|
|
if (script_len < 0)
|
|
{
|
|
break;
|
|
}
|
|
|
|
rewind (file);
|
|
|
|
const size_t current_source_size = (size_t)script_len;
|
|
|
|
if (source_buffer_tail + current_source_size >= source_buffer + sizeof (source_buffer))
|
|
{
|
|
break;
|
|
}
|
|
|
|
size_t bytes_read = fread (source_buffer_tail, 1, current_source_size, file);
|
|
if (bytes_read < current_source_size)
|
|
{
|
|
break;
|
|
}
|
|
|
|
fclose (file);
|
|
file = NULL;
|
|
|
|
source_buffer_tail += current_source_size;
|
|
}
|
|
|
|
if (file != NULL)
|
|
{
|
|
fclose (file);
|
|
}
|
|
|
|
if (i < files_count)
|
|
{
|
|
printf ("Failed to read script N%d\n", i + 1);
|
|
|
|
return NULL;
|
|
}
|
|
else
|
|
{
|
|
const size_t source_size = (size_t) (source_buffer_tail - source_buffer);
|
|
|
|
*out_source_size_p = source_size;
|
|
|
|
return (const char*)source_buffer;
|
|
}
|
|
}
|
|
|
|
int jerry_main (int argc, char *argv[])
|
|
{
|
|
if (argc >= JERRY_MAX_COMMAND_LINE_ARGS)
|
|
{
|
|
printf ("Too many command line arguments. Current maximum is %d (JERRY_MAX_COMMAND_LINE_ARGS)\n", argc);
|
|
|
|
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
|
}
|
|
|
|
const char *file_names[JERRY_MAX_COMMAND_LINE_ARGS];
|
|
int i;
|
|
int files_counter = 0;
|
|
|
|
for (i = 0; i < argc; i++)
|
|
{
|
|
printf ("PARAM %d : [%s]\n", i, argv[i]);
|
|
}
|
|
|
|
jerry_flag_t flags = JERRY_FLAG_EMPTY;
|
|
|
|
for (i = 1; i < argc; i++)
|
|
{
|
|
if (!strcmp ("-v", argv[i]))
|
|
{
|
|
printf ("Build date: \t%s\n", jerry_build_date);
|
|
printf ("Commit hash:\t%s\n", jerry_commit_hash);
|
|
printf ("Branch name:\t%s\n", jerry_branch_name);
|
|
}
|
|
else if (!strcmp ("--mem-stats", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_MEM_STATS;
|
|
}
|
|
else if (!strcmp ("--mem-stats-per-opcode", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_MEM_STATS_PER_OPCODE;
|
|
}
|
|
else if (!strcmp ("--mem-stats-separate", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_MEM_STATS_SEPARATE;
|
|
}
|
|
else if (!strcmp ("--parse-only", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_PARSE_ONLY;
|
|
}
|
|
else if (!strcmp ("--show-opcodes", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_SHOW_OPCODES;
|
|
}
|
|
else if (!strcmp ("--abort-on-fail", argv[i]))
|
|
{
|
|
flags |= JERRY_FLAG_ABORT_ON_FAIL;
|
|
}
|
|
else
|
|
{
|
|
file_names[files_counter++] = argv[i];
|
|
}
|
|
}
|
|
|
|
if (files_counter == 0)
|
|
{
|
|
printf ("Jerry: file count 0\n");
|
|
return JERRY_STANDALONE_EXIT_CODE_OK;
|
|
}
|
|
else
|
|
{
|
|
size_t source_size;
|
|
const char *source_p = read_sources (file_names, files_counter, &source_size);
|
|
|
|
if (source_p == NULL)
|
|
{
|
|
printf ("Err: JERRY_STANDALONE_EXIT_CODE_FAIL\n");
|
|
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
|
}
|
|
else
|
|
{
|
|
printf ("Source:\n------------\n%s\n------------\n", source_p);
|
|
|
|
jerry_completion_code_t ret_code = jerry_run_simple (source_p, source_size, flags);
|
|
|
|
if (ret_code == JERRY_COMPLETION_CODE_OK)
|
|
{
|
|
return JERRY_STANDALONE_EXIT_CODE_OK;
|
|
}
|
|
else
|
|
{
|
|
return JERRY_STANDALONE_EXIT_CODE_FAIL;
|
|
}
|
|
}
|
|
}
|
|
}
|