auto merge of #9280 : alexcrichton/rust/less-c++, r=brson

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

Because less C++ is better C++!
This commit is contained in:
bors 2013-09-18 22:15:59 -07:00
commit 3c0013134c
5 changed files with 40 additions and 77 deletions

View File

@ -71,7 +71,6 @@ RUNTIME_CXXS_$(1)_$(2) := \
rt/sync/lock_and_signal.cpp \
rt/sync/rust_thread.cpp \
rt/rust_builtin.cpp \
rt/rust_run_program.cpp \
rt/rust_rng.cpp \
rt/rust_upcall.cpp \
rt/rust_uv.cpp \

View File

@ -643,15 +643,28 @@ fn spawn_process_os(prog: &str, args: &[~str],
use libc::funcs::bsd44::getdtablesize;
mod rustrt {
use libc::c_void;
#[abi = "cdecl"]
extern {
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 {
let pid = fork();
@ -685,7 +698,7 @@ fn spawn_process_os(prog: &str, args: &[~str],
do with_envp(env) |envp| {
if !envp.is_null() {
rustrt::rust_set_environ(envp);
set_environ(envp);
}
do with_argv(prog, args) |argv| {
execvp(*argv, argv);

View File

@ -643,6 +643,29 @@ rust_valgrind_stack_deregister(unsigned int 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:
// mode: C++

View File

@ -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:
//

View File

@ -25,7 +25,6 @@ rust_list_dir_wfd_fp_buf
rust_log_console_on
rust_log_console_off
rust_should_log_console
rust_set_environ
rust_unset_sigprocmask
rust_env_pairs
upcall_rust_personality