mirror of
https://github.com/janet-lang/janet
synced 2025-01-13 17:10:27 +00:00
parent
16fe32215b
commit
a1cc5ca045
@ -2004,7 +2004,6 @@ error:
|
|||||||
|
|
||||||
static void janet_ev_go(JanetFiber *fiber, Janet value, JanetChannel *supervisor_channel) {
|
static void janet_ev_go(JanetFiber *fiber, Janet value, JanetChannel *supervisor_channel) {
|
||||||
fiber->supervisor_channel = supervisor_channel;
|
fiber->supervisor_channel = supervisor_channel;
|
||||||
/* janet_channel_push(supervisor_channel, make_supervisor_event("new", fiber), 2); */
|
|
||||||
janet_schedule(fiber, value);
|
janet_schedule(fiber, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2031,6 +2030,17 @@ static Janet cfun_ev_call(int32_t argc, Janet *argv) {
|
|||||||
return janet_wrap_fiber(fiber);
|
return janet_wrap_fiber(fiber);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Janet cfun_ev_give_supervisor(int32_t argc, Janet *argv) {
|
||||||
|
janet_arity(argc, 1, -1);
|
||||||
|
JanetChannel *chan = janet_vm_root_fiber->supervisor_channel;
|
||||||
|
if (NULL != chan) {
|
||||||
|
if (janet_channel_push(chan, janet_wrap_tuple(janet_tuple_n(argv, argc)), 0)) {
|
||||||
|
janet_await();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return janet_wrap_nil();
|
||||||
|
}
|
||||||
|
|
||||||
JANET_NO_RETURN void janet_sleep_await(double sec) {
|
JANET_NO_RETURN void janet_sleep_await(double sec) {
|
||||||
JanetTimeout to;
|
JanetTimeout to;
|
||||||
to.when = ts_delta(ts_now(), sec);
|
to.when = ts_delta(ts_now(), sec);
|
||||||
@ -2139,6 +2149,13 @@ static const JanetReg ev_cfuns[] = {
|
|||||||
"events occur in the newly scheduled fiber, an event will be pushed to the supervisor. "
|
"events occur in the newly scheduled fiber, an event will be pushed to the supervisor. "
|
||||||
"If not provided, the new fiber will inherit the current supervisor.")
|
"If not provided, the new fiber will inherit the current supervisor.")
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"ev/give-supervisor", cfun_ev_give_supervisor,
|
||||||
|
JDOC("(ev/give-supervsior tag & payload)\n\n"
|
||||||
|
"Send a message to the current supervior channel if there is one. The message will be a "
|
||||||
|
"tuple of all of the arguments combined into a single message, where the first element is tag. "
|
||||||
|
"By convention, tag should be a keyword indicating the type of message. Returns nil.")
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"ev/sleep", cfun_ev_sleep,
|
"ev/sleep", cfun_ev_sleep,
|
||||||
JDOC("(ev/sleep sec)\n\n"
|
JDOC("(ev/sleep sec)\n\n"
|
||||||
|
@ -602,7 +602,10 @@ static const JanetReg fiber_cfuns[] = {
|
|||||||
"Create a new fiber with function body func. Can optionally "
|
"Create a new fiber with function body func. Can optionally "
|
||||||
"take a set of signals to block from the current parent fiber "
|
"take a set of signals to block from the current parent fiber "
|
||||||
"when called. The mask is specified as a keyword where each character "
|
"when called. The mask is specified as a keyword where each character "
|
||||||
"is used to indicate a signal to block. The default sigmask is :y. "
|
"is used to indicate a signal to block. If the ev module is enabled, and "
|
||||||
|
"this fiber is used as an argument to `ev/go`, these \"blocked\" signals "
|
||||||
|
"will result in messages being sent to the supervisor channel. "
|
||||||
|
"The default sigmask is :y. "
|
||||||
"For example,\n\n"
|
"For example,\n\n"
|
||||||
" (fiber/new myfun :e123)\n\n"
|
" (fiber/new myfun :e123)\n\n"
|
||||||
"blocks error signals and user signals 1, 2 and 3. The signals are "
|
"blocks error signals and user signals 1, 2 and 3. The signals are "
|
||||||
|
@ -322,6 +322,9 @@ static const JanetAbstractType ProcAT;
|
|||||||
#define JANET_PROC_WAITED 2
|
#define JANET_PROC_WAITED 2
|
||||||
#define JANET_PROC_WAITING 4
|
#define JANET_PROC_WAITING 4
|
||||||
#define JANET_PROC_ERROR_NONZERO 8
|
#define JANET_PROC_ERROR_NONZERO 8
|
||||||
|
#define JANET_PROC_OWNS_STDIN 16
|
||||||
|
#define JANET_PROC_OWNS_STDOUT 32
|
||||||
|
#define JANET_PROC_OWNS_STDERR 64
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int flags;
|
int flags;
|
||||||
#ifdef JANET_WINDOWS
|
#ifdef JANET_WINDOWS
|
||||||
@ -889,12 +892,9 @@ static Janet os_execute_impl(int32_t argc, Janet *argv, int is_spawn) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Wait for child */
|
/* Wait for child */
|
||||||
|
os_execute_cleanup(envp, child_argv);
|
||||||
if (status) {
|
if (status) {
|
||||||
os_execute_cleanup(envp, child_argv);
|
|
||||||
janet_panicf("%p: %s", argv[0], strerror(errno));
|
janet_panicf("%p: %s", argv[0], strerror(errno));
|
||||||
} else {
|
|
||||||
/* Wait to complete */
|
|
||||||
os_execute_cleanup(envp, child_argv);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
@ -909,6 +909,12 @@ static Janet os_execute_impl(int32_t argc, Janet *argv, int is_spawn) {
|
|||||||
proc->in = NULL;
|
proc->in = NULL;
|
||||||
proc->out = NULL;
|
proc->out = NULL;
|
||||||
proc->err = NULL;
|
proc->err = NULL;
|
||||||
|
proc->flags = 0;
|
||||||
|
if (janet_flag_at(flags, 2)) {
|
||||||
|
proc->flags |= JANET_PROC_ERROR_NONZERO;
|
||||||
|
}
|
||||||
|
if (is_spawn) {
|
||||||
|
/* Only set up pointers to stdin, stdout, and stderr if os/spawn. */
|
||||||
if (new_in != JANET_HANDLE_NONE) {
|
if (new_in != JANET_HANDLE_NONE) {
|
||||||
proc->in = get_stdio_for_handle(new_in, orig_in, 1);
|
proc->in = get_stdio_for_handle(new_in, orig_in, 1);
|
||||||
if (NULL == proc->in) janet_panic("failed to construct proc");
|
if (NULL == proc->in) janet_panic("failed to construct proc");
|
||||||
@ -921,12 +927,6 @@ static Janet os_execute_impl(int32_t argc, Janet *argv, int is_spawn) {
|
|||||||
proc->err = get_stdio_for_handle(new_err, orig_err, 0);
|
proc->err = get_stdio_for_handle(new_err, orig_err, 0);
|
||||||
if (NULL == proc->err) janet_panic("failed to construct proc");
|
if (NULL == proc->err) janet_panic("failed to construct proc");
|
||||||
}
|
}
|
||||||
proc->flags = 0;
|
|
||||||
if (janet_flag_at(flags, 2)) {
|
|
||||||
proc->flags |= JANET_PROC_ERROR_NONZERO;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_spawn) {
|
|
||||||
return janet_wrap_abstract(proc);
|
return janet_wrap_abstract(proc);
|
||||||
} else {
|
} else {
|
||||||
#ifdef JANET_EV
|
#ifdef JANET_EV
|
||||||
|
@ -74,6 +74,25 @@
|
|||||||
(calc-2 "(+ 9 10 11 12)"))
|
(calc-2 "(+ 9 10 11 12)"))
|
||||||
@[10 26 42]) "parallel subprocesses 2")
|
@[10 26 42]) "parallel subprocesses 2")
|
||||||
|
|
||||||
|
# File piping
|
||||||
|
|
||||||
|
(assert-no-error "file writing 1"
|
||||||
|
(with [f (file/temp)]
|
||||||
|
(os/execute [janet "-e" `(repeat 20 (print :hello))`] :p {:out f})))
|
||||||
|
|
||||||
|
(assert-no-error "file writing 2"
|
||||||
|
(with [f (file/open "unique.txt" :w)]
|
||||||
|
(os/execute [janet "-e" `(repeat 20 (print :hello))`] :p {:out f})
|
||||||
|
(file/flush f)))
|
||||||
|
|
||||||
|
# Issue #593
|
||||||
|
(assert-no-error "file writing 3"
|
||||||
|
(def outfile (file/open "unique.txt" :w))
|
||||||
|
(os/execute [janet "-e" "(pp (seq [i :range (1 10)] i))"] :p {:out outfile})
|
||||||
|
(file/flush outfile)
|
||||||
|
(file/close outfile)
|
||||||
|
(os/rm "unique.txt"))
|
||||||
|
|
||||||
# ev/gather
|
# ev/gather
|
||||||
|
|
||||||
(assert (deep= @[1 2 3] (ev/gather 1 2 3)) "ev/gather 1")
|
(assert (deep= @[1 2 3] (ev/gather 1 2 3)) "ev/gather 1")
|
||||||
|
Loading…
Reference in New Issue
Block a user