This commit merges [CraneStation/wasi-common] repo as a subdir of this repo while preserving **all** of git history. There is an initiative to pull `wasi-common` into [CraneStation/wasmtime], and [CraneStation/wasmtime] becoming a monorepo. This came about for several reasons with a common theme of convenience, namely, having a monorepo: 1. cleans up the problem of dependencies (as we have seen first hand with dependabot enabled, it can cause some grief) 2. completely removes the problem of syncing the closely dependent repos (e.g., updating `wasi-common` with say a bugfix generally implies creating a "sync" commit for pulling in the changes into the "parent" repo, in this case, `wasmtime`) 3. mainly for the two reasons above, makes publishing to crates.io easier 4. hopefully streamlines the process of getting the community involved in contributing to `wasi-common` as now everything is one place [CraneStation/wasi-common]: https://github.com/CraneStation/wasi-common [CraneStation/wasmtime]: https://github.com/CraneStation/wasmtime
26 lines
660 B
Rust
26 lines
660 B
Rust
pub mod utils;
|
|
pub mod wasi_wrappers;
|
|
|
|
use libc;
|
|
use std::ffi::CString;
|
|
use std::io;
|
|
use wasi::wasi_unstable;
|
|
|
|
pub fn open_scratch_directory(path: &str) -> Result<wasi_unstable::Fd, String> {
|
|
// Open the scratch directory.
|
|
let dir_fd: wasi_unstable::Fd = unsafe {
|
|
let cstr = CString::new(path.as_bytes()).unwrap();
|
|
libc::open(cstr.as_ptr(), libc::O_RDONLY | libc::O_DIRECTORY)
|
|
} as wasi_unstable::Fd;
|
|
|
|
if (dir_fd as std::os::raw::c_int) < 0 {
|
|
Err(format!(
|
|
"error opening scratch directory '{}': {}",
|
|
path,
|
|
io::Error::last_os_error()
|
|
))
|
|
} else {
|
|
Ok(dir_fd)
|
|
}
|
|
}
|