Ruby
2.5.0dev(2017-10-22revision60238)
|
A part of the implementation of ruby(1) command. More...
Macros | |
#define | RUBY_INIT_STACK |
A convenience macro to call ruby_init_stack(). More... | |
Functions | |
void | ruby_sysinit (int *argc, char ***argv) |
Initializes the process for libruby. More... | |
void | ruby_init (void) |
Calls ruby_setup() and check error. More... | |
void * | ruby_options (int argc, char **argv) |
Processes command line arguments and compiles the Ruby source to execute. More... | |
int | ruby_executable_node (void *n, int *status) |
Checks the return value of ruby_options(). More... | |
int | ruby_run_node (void *n) |
Runs the given compiled source and exits this process. More... | |
void | ruby_show_version (void) |
Prints the version information of the CRuby interpreter to stdout. More... | |
void | ruby_show_copyright (void) |
Prints the copyright notice of the CRuby interpreter to stdout. More... | |
A part of the implementation of ruby(1) command.
Other programs that embed Ruby interpreter do not always need to use these functions.
#define RUBY_INIT_STACK |
int ruby_executable_node | ( | void * | n, |
int * | status | ||
) |
Checks the return value of ruby_options().
n | return value of ruby_options(). |
status | pointer to the exit status of this process. |
ruby_options() sometimes returns a special value to indicate this process should immediately exit. This function checks if the case. Also stores the exit status that the caller have to pass to exit(3) into *status
.
non-zero | if the given opaque pointer is actually a compiled source. |
0 | if the given value is such a special value. |
Definition at line 274 of file eval.c.
References EXIT_FAILURE, EXIT_SUCCESS, FALSE, FIX2INT, FIXNUM_P, Qfalse, Qtrue, and TRUE.
Referenced by ruby_run_node().
void ruby_init | ( | void | ) |
Calls ruby_setup() and check error.
Prints errors and calls exit(3) if an error occurred.
Definition at line 76 of file eval.c.
References RTEST, ruby_debug, and ruby_setup().
Referenced by main().
void* ruby_options | ( | int | argc, |
char ** | argv | ||
) |
Processes command line arguments and compiles the Ruby source to execute.
This function does:
Definition at line 97 of file eval.c.
References EXEC_TAG, GET_THREAD, PUSH_TAG, rb_clear_trace_func(), ruby_init_stack(), ruby_process_options(), SAVE_ROOT_JMPBUF, and TAG_NONE.
int ruby_run_node | ( | void * | n | ) |
Runs the given compiled source and exits this process.
0 | if successfully run the source |
non-zero | if an error occurred. |
Definition at line 295 of file eval.c.
References ruby_cleanup(), ruby_exec_node(), and ruby_executable_node().
void ruby_show_copyright | ( | void | ) |
void ruby_show_version | ( | void | ) |
void ruby_sysinit | ( | int * | argc, |
char *** | argv | ||
) |
Initializes the process for libruby.
This function assumes this process is ruby(1) and it has just started. Usually programs that embed CRuby interpreter may not call this function, and may do their own initialization. argc and argv cannot be NULL.
Definition at line 2296 of file ruby.c.
References rb_w32_sysinit().
Referenced by main().