Browse Source

Import Lib

import_zecw
Aditya Kulkarni 5 years ago
parent
commit
c916cc29ba
  1. 2
      lib/.gitignore
  2. 2470
      lib/Cargo.lock
  3. 14
      lib/Cargo.toml
  4. 85
      lib/src/lib.rs
  5. 17
      lib/zecwalletlitelib.h

2
lib/.gitignore

@ -0,0 +1,2 @@
/target/

2470
lib/Cargo.lock

File diff suppressed because it is too large

14
lib/Cargo.toml

@ -0,0 +1,14 @@
[package]
name = "qtlib"
version = "0.1.0"
authors = ["ZecWallet"]
edition = "2018"
[lib]
name = "zecwalletlite"
crate-type = ["staticlib"]
[dependencies]
libc = "0.2.58"
lazy_static = "1.4.0"
zecwalletlitelib = { git = "https://github.com/adityapk00/zecwallet-lite-lib" }

85
lib/src/lib.rs

@ -0,0 +1,85 @@
#[macro_use]
extern crate lazy_static;
use libc::{c_char};
use std::ffi::{CStr, CString};
use std::sync::{Mutex};
use std::cell::RefCell;
use zecwalletlitelib::{commands, lightclient::{LightClient, LightClientConfig}};
// We'll use a MUTEX to store a global lightclient instance,
// so we don't have to keep creating it. We need to store it here, in rust
// because we can't return such a complex structure back to C++
lazy_static! {
static ref LIGHTCLIENT: Mutex<RefCell<Option<LightClient>>> = Mutex::new(RefCell::new(None));
}
// Initialize a new lightclient and store its value
#[no_mangle]
pub extern fn initialze(dangerous: bool, server: *const c_char) -> *mut c_char {
let server_str = unsafe {
assert!(!server.is_null());
CStr::from_ptr(server).to_string_lossy().into_owned()
};
let server = LightClientConfig::get_server_or_default(Some(server_str));
let (config, latest_block_height) = match LightClientConfig::create(server, dangerous) {
Ok((c, h)) => (c, h),
Err(e) => {
let e_str = CString::new(format!("Error: {}", e)).unwrap();
return e_str.into_raw();
}
};
let lightclient = match LightClient::new(None, &config, latest_block_height) {
Ok(l) => l,
Err(e) => {
let e_str = CString::new(format!("Error: {}", e)).unwrap();
return e_str.into_raw();
}
};
LIGHTCLIENT.lock().unwrap().replace(Some(lightclient));
let c_str = CString::new("OK").unwrap();
return c_str.into_raw();
}
#[no_mangle]
pub extern fn execute(cmd: *const c_char) -> *mut c_char {
let cmd_str = unsafe {
assert!(!cmd.is_null());
CStr::from_ptr(cmd).to_string_lossy().into_owned()
};
let resp: String;
{
let lc = LIGHTCLIENT.lock().unwrap();
if lc.borrow().is_none() {
let e_str = CString::new("Error: Light Client is not initialized").unwrap();
return e_str.into_raw();
}
resp = commands::do_user_command(&cmd_str, &vec![], lc.borrow().as_ref().unwrap()).clone();
};
let c_str = CString::new(resp.as_bytes()).unwrap();
return c_str.into_raw();
}
/**
* Callers that receive string return values from other functions should call this to return the string
* back to rust, so it can be freed. Failure to call this function will result in a memory leak
*/
#[no_mangle]
pub extern fn rust_free_string(s: *mut c_char) {
unsafe {
if s.is_null() { return }
CString::from_raw(s)
};
}

17
lib/zecwalletlitelib.h

@ -0,0 +1,17 @@
#ifndef _ZEC_PAPER_RUST_H
#define _ZEC_PAPER_RUST_H
#ifdef __cplusplus
extern "C"{
#endif
extern char * initialze (bool dangerous, const char* server);
extern char * execute (char* s);
extern void rust_free_string (char* s);
#ifdef __cplusplus
}
#endif
#endif
Loading…
Cancel
Save