2014-01-17 06:58:31 -05:00
|
|
|
/**
|
|
|
|
* See Copyright Notice in picrin.h
|
|
|
|
*/
|
|
|
|
|
2013-10-20 22:51:02 -04:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "picrin.h"
|
2014-02-22 01:20:53 -05:00
|
|
|
#include "picrin/string.h"
|
2013-10-20 22:51:02 -04:00
|
|
|
#include "picrin/pair.h"
|
|
|
|
|
|
|
|
static pic_value
|
|
|
|
pic_system_cmdline(pic_state *pic)
|
|
|
|
{
|
|
|
|
pic_value v = pic_nil_value();
|
|
|
|
int i;
|
|
|
|
|
|
|
|
pic_get_args(pic, "");
|
|
|
|
|
|
|
|
for (i = 0; i < pic->argc; ++i) {
|
|
|
|
int ai = pic_gc_arena_preserve(pic);
|
|
|
|
|
2013-11-17 10:28:42 -05:00
|
|
|
v = pic_cons(pic, pic_obj_value(pic_str_new_cstr(pic, pic->argv[i])), v);
|
2013-10-20 22:51:02 -04:00
|
|
|
pic_gc_arena_restore(pic, ai);
|
|
|
|
}
|
|
|
|
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
2013-10-20 23:08:46 -04:00
|
|
|
static pic_value
|
|
|
|
pic_system_exit(pic_state *pic)
|
|
|
|
{
|
2013-10-21 01:13:08 -04:00
|
|
|
pic_value v;
|
|
|
|
int argc, status = EXIT_SUCCESS;
|
2013-12-08 23:51:34 -05:00
|
|
|
struct pic_block *blk;
|
2013-10-21 01:13:08 -04:00
|
|
|
|
|
|
|
argc = pic_get_args(pic, "|o", &v);
|
|
|
|
if (argc == 1) {
|
|
|
|
switch (pic_type(v)) {
|
|
|
|
case PIC_TT_FLOAT:
|
|
|
|
status = (int)pic_float(v);
|
|
|
|
break;
|
2013-10-27 11:21:24 -04:00
|
|
|
case PIC_TT_INT:
|
|
|
|
status = pic_int(v);
|
|
|
|
break;
|
2013-10-21 01:13:08 -04:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2013-10-20 23:08:46 -04:00
|
|
|
|
2013-12-08 23:51:34 -05:00
|
|
|
blk = pic->blk;
|
|
|
|
while (blk) {
|
|
|
|
pic_apply_argv(pic, blk->out, 0);
|
|
|
|
blk = blk->prev;
|
|
|
|
}
|
|
|
|
|
2013-10-21 01:13:08 -04:00
|
|
|
exit(status);
|
2013-10-20 23:08:46 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static pic_value
|
|
|
|
pic_system_emergency_exit(pic_state *pic)
|
|
|
|
{
|
2013-10-21 01:13:08 -04:00
|
|
|
pic_value v;
|
|
|
|
int argc, status = EXIT_FAILURE;
|
|
|
|
|
|
|
|
argc = pic_get_args(pic, "|o", &v);
|
|
|
|
if (argc == 1) {
|
|
|
|
switch (pic_type(v)) {
|
|
|
|
case PIC_TT_FLOAT:
|
|
|
|
status = (int)pic_float(v);
|
|
|
|
break;
|
2013-10-27 11:21:24 -04:00
|
|
|
case PIC_TT_INT:
|
|
|
|
status = pic_int(v);
|
|
|
|
break;
|
2013-10-21 01:13:08 -04:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2013-10-20 23:08:46 -04:00
|
|
|
|
2013-10-21 01:13:08 -04:00
|
|
|
_Exit(status);
|
2013-10-20 23:08:46 -04:00
|
|
|
}
|
|
|
|
|
2013-10-20 22:51:02 -04:00
|
|
|
static pic_value
|
|
|
|
pic_system_getenv(pic_state *pic)
|
|
|
|
{
|
|
|
|
char *str, *val;
|
|
|
|
|
2014-02-22 21:52:15 -05:00
|
|
|
pic_get_args(pic, "z", &str);
|
2013-10-20 22:51:02 -04:00
|
|
|
|
|
|
|
val = getenv(str);
|
|
|
|
|
2013-10-20 23:03:25 -04:00
|
|
|
if (val == NULL)
|
|
|
|
return pic_nil_value();
|
|
|
|
else
|
2013-11-17 10:28:42 -05:00
|
|
|
return pic_obj_value(pic_str_new_cstr(pic, val));
|
2013-10-20 22:51:02 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static pic_value
|
|
|
|
pic_system_getenvs(pic_state *pic)
|
|
|
|
{
|
|
|
|
char **envp;
|
|
|
|
pic_value data = pic_nil_value();
|
|
|
|
int ai = pic_gc_arena_preserve(pic);
|
|
|
|
|
|
|
|
pic_get_args(pic, "");
|
|
|
|
|
2014-02-13 01:37:15 -05:00
|
|
|
if (! pic->envp) {
|
|
|
|
return pic_nil_value();
|
|
|
|
}
|
|
|
|
|
2013-10-20 22:51:02 -04:00
|
|
|
for (envp = pic->envp; *envp; ++envp) {
|
|
|
|
pic_value key, val;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; (*envp)[i] != '='; ++i)
|
|
|
|
;
|
|
|
|
|
2013-11-17 10:28:42 -05:00
|
|
|
key = pic_obj_value(pic_str_new(pic, *envp, i));
|
|
|
|
val = pic_obj_value(pic_str_new_cstr(pic, getenv(*envp)));
|
2013-10-20 22:51:02 -04:00
|
|
|
|
|
|
|
/* push */
|
|
|
|
data = pic_acons(pic, key, val, data);
|
|
|
|
|
|
|
|
pic_gc_arena_restore(pic, ai);
|
|
|
|
pic_gc_protect(pic, data);
|
|
|
|
}
|
|
|
|
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
pic_init_system(pic_state *pic)
|
|
|
|
{
|
2014-02-01 01:41:30 -05:00
|
|
|
pic_deflibrary ("(scheme process-context)") {
|
2013-12-08 02:17:28 -05:00
|
|
|
pic_defun(pic, "command-line", pic_system_cmdline);
|
|
|
|
pic_defun(pic, "exit", pic_system_exit);
|
|
|
|
pic_defun(pic, "emergency-exit", pic_system_emergency_exit);
|
|
|
|
pic_defun(pic, "get-environment-variable", pic_system_getenv);
|
|
|
|
pic_defun(pic, "get-environment-variables", pic_system_getenvs);
|
|
|
|
}
|
2013-10-20 22:51:02 -04:00
|
|
|
}
|