Move stuff around
This commit is contained in:
parent
ce3c41aef0
commit
a1ff43045b
|
@ -18,7 +18,7 @@ libnixrust_LDFLAGS_USE += -Wl,-rpath,$(abspath $(d)/target/$(RUST_DIR))
|
|||
libnixrust_LDFLAGS_USE_INSTALLED += -Wl,-rpath,$(libdir)
|
||||
endif
|
||||
|
||||
$(libnixrust_PATH): $(wildcard $(d)/src/*.rs) $(d)/Cargo.toml
|
||||
$(libnixrust_PATH): $(call rwildcard, $(d)/src, *.rs) $(d)/Cargo.toml
|
||||
$(trace-gen) cd nix-rust && CARGO_HOME=$$(if [[ -d vendor ]]; then echo vendor; fi) \
|
||||
$(libnixrust_BUILD_FLAGS) \
|
||||
RUSTC_BOOTSTRAP=1 cargo build $(RUST_MODE) $$(if [[ -d vendor ]]; then echo --offline; fi) \
|
||||
|
|
42
nix-rust/src/c.rs
Normal file
42
nix-rust/src/c.rs
Normal file
|
@ -0,0 +1,42 @@
|
|||
use super::{foreign::{self, CBox}, error, util, store};
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn unpack_tarfile(
|
||||
source: foreign::Source,
|
||||
dest_dir: &str,
|
||||
) -> CBox<Result<(), error::CppException>> {
|
||||
CBox::new(util::tarfile::unpack_tarfile(source, dest_dir).map_err(|err| err.into()))
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn rust_test() {
|
||||
use crate::store::Store;
|
||||
use futures::future::{FutureExt, TryFutureExt};
|
||||
use std::path::Path;
|
||||
|
||||
let fut = async move {
|
||||
let store: Box<dyn Store> = Box::new(store::BinaryCacheStore::new(
|
||||
"https://cache.nixos.org".to_string(),
|
||||
));
|
||||
|
||||
let path = store
|
||||
.parse_store_path(&Path::new(
|
||||
"/nix/store/7h7qgvs4kgzsn8a6rb273saxyqh4jxlz-konsole-18.12.3",
|
||||
))
|
||||
.unwrap();
|
||||
|
||||
/*
|
||||
let info = store.query_path_info(&path).await.unwrap();
|
||||
|
||||
eprintln!("INFO = {:?}", info);
|
||||
*/
|
||||
|
||||
let closure = store.compute_path_closure(vec![path].into_iter().collect()).await.unwrap();
|
||||
|
||||
eprintln!("CLOSURE = {:?}", closure.len());
|
||||
|
||||
Ok(())
|
||||
};
|
||||
|
||||
tokio::run(fut.boxed().compat());
|
||||
}
|
|
@ -12,3 +12,22 @@ impl std::io::Read for Source {
|
|||
Ok(n)
|
||||
}
|
||||
}
|
||||
|
||||
pub struct CBox<T> {
|
||||
pub ptr: *mut libc::c_void,
|
||||
phantom: std::marker::PhantomData<T>,
|
||||
}
|
||||
|
||||
impl<T> CBox<T> {
|
||||
pub fn new(t: T) -> Self {
|
||||
unsafe {
|
||||
let size = std::mem::size_of::<T>();
|
||||
let ptr = libc::malloc(size);
|
||||
*(ptr as *mut T) = t; // FIXME: probably UB
|
||||
Self {
|
||||
ptr,
|
||||
phantom: std::marker::PhantomData,
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,70 +1,9 @@
|
|||
#![feature(await_macro, async_await)]
|
||||
|
||||
mod binary_cache_store;
|
||||
mod c;
|
||||
mod error;
|
||||
mod foreign;
|
||||
mod store;
|
||||
mod tarfile;
|
||||
mod path_info;
|
||||
mod util;
|
||||
|
||||
pub use error::Error;
|
||||
|
||||
pub struct CBox<T> {
|
||||
pub ptr: *mut libc::c_void,
|
||||
phantom: std::marker::PhantomData<T>,
|
||||
}
|
||||
|
||||
impl<T> CBox<T> {
|
||||
fn new(t: T) -> Self {
|
||||
unsafe {
|
||||
let size = std::mem::size_of::<T>();
|
||||
let ptr = libc::malloc(size);
|
||||
*(ptr as *mut T) = t; // FIXME: probably UB
|
||||
Self {
|
||||
ptr,
|
||||
phantom: std::marker::PhantomData,
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn unpack_tarfile(
|
||||
source: foreign::Source,
|
||||
dest_dir: &str,
|
||||
) -> CBox<Result<(), error::CppException>> {
|
||||
CBox::new(tarfile::unpack_tarfile(source, dest_dir).map_err(|err| err.into()))
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn rust_test() {
|
||||
use crate::store::Store;
|
||||
use futures::future::{FutureExt, TryFutureExt};
|
||||
use std::path::Path;
|
||||
|
||||
let fut = async move {
|
||||
let store: Box<dyn Store> = Box::new(binary_cache_store::BinaryCacheStore::new(
|
||||
"https://cache.nixos.org".to_string(),
|
||||
));
|
||||
|
||||
let path = store
|
||||
.parse_store_path(&Path::new(
|
||||
"/nix/store/7h7qgvs4kgzsn8a6rb273saxyqh4jxlz-konsole-18.12.3",
|
||||
))
|
||||
.unwrap();
|
||||
|
||||
/*
|
||||
let info = store.query_path_info(&path).await.unwrap();
|
||||
|
||||
eprintln!("INFO = {:?}", info);
|
||||
*/
|
||||
|
||||
let closure = store.compute_path_closure(vec![path].into_iter().collect()).await.unwrap();
|
||||
|
||||
eprintln!("CLOSURE = {:?}", closure.len());
|
||||
|
||||
Ok(())
|
||||
};
|
||||
|
||||
tokio::run(fut.boxed().compat());
|
||||
}
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
use crate::store::{Store, StorePath};
|
||||
use crate::path_info::PathInfo;
|
||||
use super::{Store, StorePath, PathInfo};
|
||||
use crate::Error;
|
||||
use futures::compat::Future01CompatExt;
|
||||
|
7
nix-rust/src/store/mod.rs
Normal file
7
nix-rust/src/store/mod.rs
Normal file
|
@ -0,0 +1,7 @@
|
|||
mod binary_cache_store;
|
||||
mod path_info;
|
||||
mod store;
|
||||
|
||||
pub use binary_cache_store::BinaryCacheStore;
|
||||
pub use path_info::PathInfo;
|
||||
pub use store::{Store, StorePath};
|
|
@ -1,4 +1,4 @@
|
|||
use crate::path_info::PathInfo;
|
||||
use super::PathInfo;
|
||||
use crate::Error;
|
||||
use std::collections::{BTreeMap, BTreeSet};
|
||||
use std::path::Path;
|
1
nix-rust/src/util/mod.rs
Normal file
1
nix-rust/src/util/mod.rs
Normal file
|
@ -0,0 +1 @@
|
|||
pub mod tarfile;
|
Loading…
Reference in a new issue