Remove rust_run_program.cpp
Some of the functions could be converted to rust, but the functions dealing with signals were moved to rust_builtin.cpp instead (no reason to keep the original file around for one function). Closes #2674
This commit is contained in:
parent
29cdf58861
commit
c3ad785d83
1
mk/rt.mk
1
mk/rt.mk
@ -71,7 +71,6 @@ RUNTIME_CXXS_$(1)_$(2) := \
|
|||||||
rt/sync/lock_and_signal.cpp \
|
rt/sync/lock_and_signal.cpp \
|
||||||
rt/sync/rust_thread.cpp \
|
rt/sync/rust_thread.cpp \
|
||||||
rt/rust_builtin.cpp \
|
rt/rust_builtin.cpp \
|
||||||
rt/rust_run_program.cpp \
|
|
||||||
rt/rust_rng.cpp \
|
rt/rust_rng.cpp \
|
||||||
rt/rust_upcall.cpp \
|
rt/rust_upcall.cpp \
|
||||||
rt/rust_uv.cpp \
|
rt/rust_uv.cpp \
|
||||||
|
@ -643,15 +643,28 @@ fn spawn_process_os(prog: &str, args: &[~str],
|
|||||||
use libc::funcs::bsd44::getdtablesize;
|
use libc::funcs::bsd44::getdtablesize;
|
||||||
|
|
||||||
mod rustrt {
|
mod rustrt {
|
||||||
use libc::c_void;
|
|
||||||
|
|
||||||
#[abi = "cdecl"]
|
#[abi = "cdecl"]
|
||||||
extern {
|
extern {
|
||||||
pub fn rust_unset_sigprocmask();
|
pub fn rust_unset_sigprocmask();
|
||||||
pub fn rust_set_environ(envp: *c_void);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(windows)]
|
||||||
|
unsafe fn set_environ(_envp: *c_void) {}
|
||||||
|
#[cfg(target_os = "macos")]
|
||||||
|
unsafe fn set_environ(envp: *c_void) {
|
||||||
|
externfn!(fn _NSGetEnviron() -> *mut *c_void);
|
||||||
|
|
||||||
|
*_NSGetEnviron() = envp;
|
||||||
|
}
|
||||||
|
#[cfg(not(target_os = "macos"), not(windows))]
|
||||||
|
unsafe fn set_environ(envp: *c_void) {
|
||||||
|
extern {
|
||||||
|
static mut environ: *c_void;
|
||||||
|
}
|
||||||
|
environ = envp;
|
||||||
|
}
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
|
|
||||||
let pid = fork();
|
let pid = fork();
|
||||||
@ -685,7 +698,7 @@ fn spawn_process_os(prog: &str, args: &[~str],
|
|||||||
|
|
||||||
do with_envp(env) |envp| {
|
do with_envp(env) |envp| {
|
||||||
if !envp.is_null() {
|
if !envp.is_null() {
|
||||||
rustrt::rust_set_environ(envp);
|
set_environ(envp);
|
||||||
}
|
}
|
||||||
do with_argv(prog, args) |argv| {
|
do with_argv(prog, args) |argv| {
|
||||||
execvp(*argv, argv);
|
execvp(*argv, argv);
|
||||||
|
@ -643,6 +643,29 @@ rust_valgrind_stack_deregister(unsigned int id) {
|
|||||||
VALGRIND_STACK_DEREGISTER(id);
|
VALGRIND_STACK_DEREGISTER(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(__WIN32__)
|
||||||
|
|
||||||
|
extern "C" CDECL void
|
||||||
|
rust_unset_sigprocmask() {
|
||||||
|
// empty stub for windows to keep linker happy
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#include <signal.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
extern "C" CDECL void
|
||||||
|
rust_unset_sigprocmask() {
|
||||||
|
// this can't be safely converted to rust code because the
|
||||||
|
// representation of sigset_t is platform-dependent
|
||||||
|
sigset_t sset;
|
||||||
|
sigemptyset(&sset);
|
||||||
|
sigprocmask(SIG_SETMASK, &sset, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
//
|
//
|
||||||
// Local Variables:
|
// Local Variables:
|
||||||
// mode: C++
|
// mode: C++
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
|
|
||||||
// file at the top-level directory of this distribution and at
|
|
||||||
// http://rust-lang.org/COPYRIGHT.
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
||||||
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
||||||
// option. This file may not be copied, modified, or distributed
|
|
||||||
// except according to those terms.
|
|
||||||
|
|
||||||
|
|
||||||
#include "rust_globals.h"
|
|
||||||
|
|
||||||
#ifdef __APPLE__
|
|
||||||
#include <crt_externs.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__WIN32__)
|
|
||||||
|
|
||||||
extern "C" CDECL void
|
|
||||||
rust_unset_sigprocmask() {
|
|
||||||
// empty stub for windows to keep linker happy
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" CDECL void
|
|
||||||
rust_set_environ(void* envp) {
|
|
||||||
// empty stub for windows to keep linker happy
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined(__GNUC__)
|
|
||||||
|
|
||||||
#include <signal.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
#ifdef __FreeBSD__
|
|
||||||
extern char **environ;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern "C" CDECL void
|
|
||||||
rust_unset_sigprocmask() {
|
|
||||||
// this can't be safely converted to rust code because the
|
|
||||||
// representation of sigset_t is platform-dependent
|
|
||||||
sigset_t sset;
|
|
||||||
sigemptyset(&sset);
|
|
||||||
sigprocmask(SIG_SETMASK, &sset, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" CDECL void
|
|
||||||
rust_set_environ(void* envp) {
|
|
||||||
// FIXME: this could actually be converted to rust (see issue #2674)
|
|
||||||
#ifdef __APPLE__
|
|
||||||
*_NSGetEnviron() = (char **) envp;
|
|
||||||
#else
|
|
||||||
environ = (char **) envp;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
|
||||||
#error "Platform not supported."
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//
|
|
||||||
// Local Variables:
|
|
||||||
// mode: C++
|
|
||||||
// fill-column: 78;
|
|
||||||
// indent-tabs-mode: nil
|
|
||||||
// c-basic-offset: 4
|
|
||||||
// buffer-file-coding-system: utf-8-unix
|
|
||||||
// compile-command: "make -k -C $RBUILD 2>&1 | sed -e 's/\\/x\\//x:\\//g'";
|
|
||||||
// End:
|
|
||||||
//
|
|
@ -25,7 +25,6 @@ rust_list_dir_wfd_fp_buf
|
|||||||
rust_log_console_on
|
rust_log_console_on
|
||||||
rust_log_console_off
|
rust_log_console_off
|
||||||
rust_should_log_console
|
rust_should_log_console
|
||||||
rust_set_environ
|
|
||||||
rust_unset_sigprocmask
|
rust_unset_sigprocmask
|
||||||
rust_env_pairs
|
rust_env_pairs
|
||||||
upcall_rust_personality
|
upcall_rust_personality
|
||||||
|
Loading…
Reference in New Issue
Block a user