Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migrate pirita / native executables feature from wasmer-private #3258

Merged
merged 50 commits into from
Nov 2, 2022
Merged
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
1e2617c
Add feature=pirita_file
fschutt Oct 26, 2022
e8977ed
cargo clippy --fix
fschutt Oct 26, 2022
c4bf4e1
Fix cargo clippy
fschutt Oct 27, 2022
705dc8f
Compilation with make-wasmer-pirita now works
fschutt Oct 27, 2022
48cdaf3
Add python.wasmer
fschutt Oct 27, 2022
f7c647a
Add support for WASI args, add integration test for run pirita
fschutt Oct 27, 2022
2109f0f
Add integration test for create-exe
fschutt Oct 27, 2022
968d74c
Add webc-vfs
fschutt Oct 27, 2022
acc5ac1
Add WasiRunner and EmscriptenRunner
fschutt Oct 27, 2022
ba68952
Update Cargo.lock
fschutt Oct 27, 2022
afdffbe
cargo fmt
fschutt Oct 27, 2022
87aa82f
cargo fmt
fschutt Oct 27, 2022
6d404de
Move runners into wasmer/api crate
fschutt Oct 27, 2022
7e76db8
Fixed most dependency errors
fschutt Oct 27, 2022
d2d3b4e
Remove .cargo/config
fschutt Oct 27, 2022
a0d9248
Move /runners into wasmer-wasi
fschutt Oct 28, 2022
a3f833f
Fix compilation bugs with webc
fschutt Oct 28, 2022
cf3ab70
cargo fmt
fschutt Oct 28, 2022
178f469
Fix make lint
fschutt Oct 28, 2022
ad1f72a
Merge branch 'master' into migrate-wasmer-private
fschutt Oct 28, 2022
acdf8f5
Fix doctest, add execution to integration test
fschutt Oct 28, 2022
37f88c9
Fix cargo deny
fschutt Oct 28, 2022
5c941b3
Fix integration test to zip a tarball from the /package directory
fschutt Oct 28, 2022
86ef576
Added function to auto-download and install zig when cross-compiling
fschutt Oct 28, 2022
fde919f
Fixed CI not running integration tests
fschutt Oct 29, 2022
5160cb5
Fix "wasmer_static_module_new" function
fschutt Nov 1, 2022
51ae0b6
Merge branch 'master' into migrate-wasmer-private
fschutt Nov 1, 2022
84feb95
Fix bug in wasmer_module_new
fschutt Nov 1, 2022
d6fb6a1
Fix error in make package not running
fschutt Nov 1, 2022
eb7f14a
Rename wasmer_module_new -> wasmer_object_module_new
fschutt Nov 1, 2022
ad7937e
Remove check to prevent both wasi and emscripten imports
fschutt Nov 1, 2022
f738e6d
Added more debugging for wasmer test
fschutt Nov 1, 2022
de7b451
Move test-integration-cli step to front of queue
fschutt Nov 1, 2022
b7cc838
Set the current directory for integration tests
fschutt Nov 1, 2022
a7309c0
Try to fix unit test again
fschutt Nov 1, 2022
81974bf
Fix get_repo_root_path
fschutt Nov 1, 2022
430ed72
Implemented maximum level of root dir depth to prevent infinite loop
fschutt Nov 1, 2022
1061360
Add debugging to see why the CI isn't working
fschutt Nov 2, 2022
786e273
Fix get_repo_root_path function
fschutt Nov 2, 2022
9ae02d5
Remove debugging println
fschutt Nov 2, 2022
6d61514
Enable running integration tests on Windows
fschutt Nov 2, 2022
5bf9c69
Debug libwasmer path not found
fschutt Nov 2, 2022
71be0ae
Use bash on Windows for running scripts
fschutt Nov 2, 2022
f7ad826
Add explicit target to window integration tests
fschutt Nov 2, 2022
907a734
Remove nuke-dir dependency
fschutt Nov 2, 2022
2c93fcb
Try to fix CI error on Windows
fschutt Nov 2, 2022
8288ef5
Ignore create-exe test on linux-musl (see #3271)
fschutt Nov 2, 2022
ebb8e74
Run "make build-wasmer" before "make package"
fschutt Nov 2, 2022
c00113a
Add build-wasmer to make test-integration-cli step
fschutt Nov 2, 2022
f00a59a
Remove println
fschutt Nov 2, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
cargo fmt
  • Loading branch information
fschutt committed Oct 27, 2022
commit 87aa82f33ba3c4dac2b8e2f73a5ab059afc964ee
1 change: 0 additions & 1 deletion lib/c-api/Cargo.toml
Original file line number Diff line number Diff line change
@@ -97,7 +97,6 @@ wasmer-artifact-create = ["wasmer-compiler/wasmer-artifact-create"]
static-artifact-load = ["wasmer-compiler/static-artifact-load"]
static-artifact-create = ["wasmer-compiler/static-artifact-create"]
pirita_file = ["pirita"]

# Deprecated features.
jit = ["compiler"]

23 changes: 10 additions & 13 deletions lib/cli/src/runners/mod.rs
Original file line number Diff line number Diff line change
@@ -68,7 +68,7 @@ impl WapmContainer {
.bindings
.iter()
.find(|b| b.name == bindings)
.ok_or(ParseBindingsError::NoBindings(bindings.to_string()))?;
.ok_or_else(|| ParseBindingsError::NoBindings(bindings.to_string()))?;

T::parse_bindings(self, &bindings.annotations).map_err(ParseBindingsError::ParseBindings)
}
@@ -97,7 +97,7 @@ pub struct WitBindings {}

impl WitBindings {
/// Unused: creates default wit bindings
pub fn from_str(_s: &str) -> Result<Self, String> {
pub fn parse(_s: &str) -> Result<Self, String> {
Ok(Self::default())
}
}
@@ -128,7 +128,7 @@ impl Bindings for WitBindings {
let wit_bindings_str = std::str::from_utf8(wit_bindings)
.map_err(|e| format!("could not get WitBindings file {wit_bindgen_filepath:?}: {e}"))?;

Self::from_str(wit_bindings_str)
Self::parse(wit_bindings_str)
}
}

@@ -177,16 +177,13 @@ pub trait Runner {
cmd: &str,
) -> Result<Self::Output, Box<dyn StdError>> {
let path = format!("{}", container.webc.path.display());
let command_to_exec =
container
.webc
.webc
.manifest
.commands
.get(cmd)
.ok_or(anyhow::anyhow!(
"{path}: command {cmd:?} not found in manifest"
))?;
let command_to_exec = container
.webc
.webc
.manifest
.commands
.get(cmd)
.ok_or_else(|| anyhow::anyhow!("{path}: command {cmd:?} not found in manifest"))?;

let _path = format!("{}", container.webc.path.display());

12 changes: 7 additions & 5 deletions lib/vfs/src/static_fs.rs
Original file line number Diff line number Diff line change
@@ -94,7 +94,7 @@ impl FileOpener for WebCFileOpener {
}

#[derive(Debug)]
struct WebCFile {
pub struct WebCFile {
pub volumes: Arc<webc::IndexMap<String, webc::Volume<'static>>>,
pub package: String,
pub volume: String,
@@ -138,10 +138,12 @@ impl Read for WebCFile {
let bytes = self
.volumes
.get(&self.volume)
.ok_or(IoError::new(
IoErrorKind::NotFound,
anyhow!("Unknown volume {:?}", self.volume),
))?
.ok_or_else(|| {
IoError::new(
IoErrorKind::NotFound,
anyhow!("Unknown volume {:?}", self.volume),
)
})?
.get_file_bytes(&self.entry)
.map_err(|e| IoError::new(IoErrorKind::NotFound, e))?;

16 changes: 9 additions & 7 deletions lib/vfs/src/webc_fs.rs
Original file line number Diff line number Diff line change
@@ -66,7 +66,7 @@ where
) -> Result<Box<dyn VirtualFile + Send + Sync>, FsError> {
match get_volume_name_opt(path) {
Some(volume) => {
let file = (&*self.webc)
let file = (*self.webc)
.volumes
.get(&volume)
.ok_or(FsError::EntityNotFound)?
@@ -168,10 +168,12 @@ where
.webc
.volumes
.get(&self.volume)
.ok_or(IoError::new(
IoErrorKind::NotFound,
anyhow!("Unknown volume {:?}", self.volume),
))?
.ok_or_else(|| {
IoError::new(
IoErrorKind::NotFound,
anyhow!("Unknown volume {:?}", self.volume),
)
})?
.get_file_bytes(&self.entry)
.map_err(|e| IoError::new(IoErrorKind::NotFound, e))?;

@@ -246,7 +248,7 @@ fn get_volume_name_opt<P: AsRef<Path>>(path: P) -> Option<String> {

#[allow(dead_code)]
fn get_volume_name<P: AsRef<Path>>(path: P) -> String {
get_volume_name_opt(path).unwrap_or("atom".to_string())
get_volume_name_opt(path).unwrap_or_else(|| "atom".to_string())
}

fn transform_into_read_dir<'a>(path: &Path, fs_entries: &[FsEntry<'a>]) -> crate::ReadDir {
@@ -277,7 +279,7 @@ where
let read_dir_result = self
.webc
.read_dir(&self.package, &path)
.map(|o| transform_into_read_dir(&Path::new(&path), o.as_ref()))
.map(|o| transform_into_read_dir(Path::new(&path), o.as_ref()))
.map_err(|_| FsError::EntityNotFound);

match read_dir_result {