From 09ab1ca8fbed63aaff7b258562dcd6afb5bec0e0 Mon Sep 17 00:00:00 2001 From: threadexception Date: Sat, 18 Sep 2021 18:08:21 +0200 Subject: [PATCH 1/5] Start implement modding --- Cargo.lock | 20 ++++-- Cargo.toml | 12 ++-- modding/Cargo.lock | 174 +++++++++++++++++++++++++++++++++++++++++++++ modding/Cargo.toml | 12 ++++ modding/src/lib.rs | 124 ++++++++++++++++++++++++++++++++ 5 files changed, 334 insertions(+), 8 deletions(-) create mode 100644 modding/Cargo.lock create mode 100644 modding/Cargo.toml create mode 100644 modding/src/lib.rs diff --git a/Cargo.lock b/Cargo.lock index d861af25..9f4b8000 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -673,9 +673,9 @@ dependencies = [ [[package]] name = "flate2" -version = "1.0.21" +version = "1.0.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80edafed416a46fb378521624fab1cfa2eb514784fd8921adbe8a8d8321da811" +checksum = "1e6988e897c1c9c485f43b47a529cef42fde0547f9d8d41a7062518f1d8fc53f" dependencies = [ "cfg-if 1.0.0", "crc32fast", @@ -1169,6 +1169,7 @@ dependencies = [ "instant", "lazy_static", "leafish_blocks", + "leafish_modding", "leafish_protocol", "leafish_resources", "leafish_shared", @@ -1197,6 +1198,17 @@ dependencies = [ "parking_lot", ] +[[package]] +name = "leafish_modding" +version = "0.0.1" +dependencies = [ + "dashmap", + "libloading 0.7.0", + "log", + "serde", + "serde_json", +] + [[package]] name = "leafish_protocol" version = "0.0.1" @@ -2292,9 +2304,9 @@ dependencies = [ [[package]] name = "serde_json" -version = "1.0.67" +version = "1.0.68" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a7f9e390c27c3c0ce8bc5d725f6e4d30a29d26659494aa4b17535f7522c5c950" +checksum = "0f690853975602e1bfe1ccbf50504d67174e3bcf340f23b5ea9992e0587a52d8" dependencies = [ "itoa", "ryu", diff --git a/Cargo.toml b/Cargo.toml index 6b22c139..1a50d125 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -26,9 +26,9 @@ opt-level = 1 winit = "0.25.0" glow = "0.10.0" byteorder = "1.4.3" -serde = "1.0.127" -serde_json = "1.0.66" -flate2 = { version = "1.0.20", features = ["rust_backend"], default-features = false } +serde = "1.0.130" +serde_json = "1.0.68" +flate2 = { version = "1.0.22", features = ["rust_backend"], default-features = false } zip = { version = "0.5.13", features = ["deflate"], default-features = false } image = "0.23.14" getrandom = { version = "0.2.3", features = ["js"] } @@ -40,7 +40,7 @@ cgmath = "0.17.0" lazy_static = "1.4.0" collision = "0.20.1" rsa_public_encrypt_pkcs1 = "0.4.0" -structopt = "0.3.22" +structopt = "0.3.23" copypasta = "0.7.1" instant = "0.1.10" dirs = "3.0.2" @@ -72,6 +72,10 @@ version = "0" path = "./protocol" version = "0" +[dependencies.leafish_modding] +path = "./modding" +version = "0" + #[dependencies.std_or_web] #path = "./std_or_web" #version = "0" diff --git a/modding/Cargo.lock b/modding/Cargo.lock new file mode 100644 index 00000000..9f419504 --- /dev/null +++ b/modding/Cargo.lock @@ -0,0 +1,174 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "dashmap" +version = "4.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e77a43b28d0668df09411cb0bc9a8c2adc40f9a048afe863e05fd43251e8e39c" +dependencies = [ + "cfg-if", + "num_cpus", +] + +[[package]] +name = "hermit-abi" +version = "0.1.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62b467343b94ba476dcb2500d242dadbb39557df889310ac77c5d99100aaac33" +dependencies = [ + "libc", +] + +[[package]] +name = "itoa" +version = "0.4.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b71991ff56294aa922b450139ee08b3bfc70982c6b2c7562771375cf73542dd4" + +[[package]] +name = "leafish_modding" +version = "0.0.1" +dependencies = [ + "dashmap", + "libloading", + "log", + "serde", + "serde_json", +] + +[[package]] +name = "libc" +version = "0.2.102" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2a5ac8f984bfcf3a823267e5fde638acc3325f6496633a5da6bb6eb2171e103" + +[[package]] +name = "libloading" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6f84d96438c15fcd6c3f244c8fce01d1e2b9c6b5623e9c711dc9286d8fc92d6a" +dependencies = [ + "cfg-if", + "winapi", +] + +[[package]] +name = "log" +version = "0.4.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51b9bbe6c47d51fc3e1a9b945965946b4c44142ab8792c50835a980d362c2710" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "num_cpus" +version = "1.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05499f3756671c15885fee9034446956fff3f243d6077b91e5767df161f766b3" +dependencies = [ + "hermit-abi", + "libc", +] + +[[package]] +name = "proc-macro2" +version = "1.0.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b9f5105d4fdaab20335ca9565e106a5d9b82b6219b5ba735731124ac6711d23d" +dependencies = [ + "unicode-xid", +] + +[[package]] +name = "quote" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3d0b9745dc2debf507c8422de05d7226cc1f0644216dfdfead988f9b1ab32a7" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "ryu" +version = "1.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "71d301d4193d031abdd79ff7e3dd721168a9572ef3fe51a1517aba235bd8f86e" + +[[package]] +name = "serde" +version = "1.0.130" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f12d06de37cf59146fbdecab66aa99f9fe4f78722e3607577a5375d66bd0c913" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde_derive" +version = "1.0.130" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d7bc1a1ab1961464eae040d96713baa5a724a8152c1222492465b54322ec508b" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "serde_json" +version = "1.0.68" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0f690853975602e1bfe1ccbf50504d67174e3bcf340f23b5ea9992e0587a52d8" +dependencies = [ + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "syn" +version = "1.0.76" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6f107db402c2c2055242dbf4d2af0e69197202e9faacbef9571bbe47f5a1b84" +dependencies = [ + "proc-macro2", + "quote", + "unicode-xid", +] + +[[package]] +name = "unicode-xid" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8ccb82d61f80a663efe1f787a51b16b5a51e3314d6ac365b08639f52387b33f3" + +[[package]] +name = "winapi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" +dependencies = [ + "winapi-i686-pc-windows-gnu", + "winapi-x86_64-pc-windows-gnu", +] + +[[package]] +name = "winapi-i686-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" + +[[package]] +name = "winapi-x86_64-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" diff --git a/modding/Cargo.toml b/modding/Cargo.toml new file mode 100644 index 00000000..ea65694c --- /dev/null +++ b/modding/Cargo.toml @@ -0,0 +1,12 @@ +[package] +name = "leafish_modding" +version = "0.0.1" +edition = "2018" +authors = [ "terrarier2111" ] + +[dependencies] +serde = { version = "1.0.130", features = ["derive"] } +serde_json = "1.0.68" +libloading = "0.7" +dashmap = "4.0.2" +log = { version = "0.4.14", features = ["std"] } \ No newline at end of file diff --git a/modding/src/lib.rs b/modding/src/lib.rs new file mode 100644 index 00000000..18f3f5be --- /dev/null +++ b/modding/src/lib.rs @@ -0,0 +1,124 @@ +use std::any::Any; +use libloading::{Library, Symbol, Error}; +use std::sync::Arc; +use dashmap::DashMap; +use std::path::Path; +use log::warn; +extern crate serde; +use serde::{Deserialize, Serialize}; + +pub trait Plugin: Any + Send + Sync { + + fn on_enable(&self); + + fn on_disable(&self) {} + + fn get_name(&self) -> &'static str; + +} + +pub struct PluginManager { + + plugins: Arc>, + +} + +impl PluginManager { + + pub fn load_plugin(&self, path: String) -> bool { + let raw_plugin_meta = std::fs::read_to_string(format!("{}/meta.json", path)); + let plugin_meta = if let Ok(meta) = raw_plugin_meta { + if let Ok(meta) = serde_json::from_str(&*meta) { + meta + } else { + PluginMeta::default() + } + } else { + PluginMeta::default() + }; + + let potential_library = unsafe { Library::new(format!("{}/bin", path)) }; + if let Ok(library) = potential_library { + let create_plugin: Result Box>, Error> = unsafe { library.get(b"create_plugin") }; + if let Ok(create_plugin) = create_plugin { + let wrapped_plugin = WrappedPlugin { + plugin: create_plugin(), + _library: library, + meta: plugin_meta, + }; + let file_name = Path::new(&path).file_name().unwrap(); + self.plugins.clone().insert(String::from(file_name.to_str().unwrap()), wrapped_plugin); + return true; + } else { + let file_name = Path::new(&path).file_name().unwrap(); + warn!("There is no \"create_plugin\" function available in {}!", file_name.to_str().unwrap()); + } + } + false + } + + pub fn unload_plugin(&self, plugin: String) -> bool { + if let Some(plugin) = self.plugins.clone().remove(&*plugin) { + plugin.1.plugin.on_disable(); + return true; + } + false + } + + pub fn unload_all(&self) { + for plugin in self.plugins.clone().iter() { + plugin.plugin.on_disable(); + } + self.plugins.clear(); + } + +} + +pub struct WrappedPlugin { + + plugin: Box, + _library: Library, + meta: PluginMeta, + +} + +impl WrappedPlugin { + + pub fn name(&self) -> &'static str { + self.plugin.get_name() + } + + pub fn version(&self) -> usize { + self.meta.version + } + + pub fn authors(&self) -> &Vec { + &self.meta.authors + } + + pub fn permissions(&self) -> &Vec { + &self.meta.permissions + } + +} + +#[derive(Serialize, Deserialize, Default)] +pub struct PluginMeta { + + version: usize, + authors: Vec, + permissions: Vec, // TODO: Implement this! + modified: bool, + +} + + +#[derive(Serialize, Deserialize)] +pub enum PluginPermission { + + File, + Network, + Device, // grants permission for devices and drivers + All, + +} \ No newline at end of file From 30bdd2d91402f5511d47193ee9f8d140573665c3 Mon Sep 17 00:00:00 2001 From: threadexception Date: Sat, 18 Sep 2021 19:09:59 +0200 Subject: [PATCH 2/5] Implement events --- modding/src/lib.rs | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/modding/src/lib.rs b/modding/src/lib.rs index 18f3f5be..f81835da 100644 --- a/modding/src/lib.rs +++ b/modding/src/lib.rs @@ -15,6 +15,8 @@ pub trait Plugin: Any + Send + Sync { fn get_name(&self) -> &'static str; + fn handle_event(&self, event: ClientEvent) -> bool; + } pub struct PluginManager { @@ -100,6 +102,11 @@ impl WrappedPlugin { &self.meta.permissions } + /// handles an event, returns whether or not the result is `cancel` + pub fn handle_event(&self, event: ClientEvent) -> bool { + self.plugin.handle_event(event) + } + } #[derive(Serialize, Deserialize, Default)] @@ -121,4 +128,13 @@ pub enum PluginPermission { Device, // grants permission for devices and drivers All, +} + +#[repr(C)] +pub enum ClientEvent { + + UserInput, // INPUTTYPE: Mouse, Keyboard | down: bool | input: (mousekey or keyboardkey) + Resize, // dimensions maybe? + Screen, // SUBTYPE: Open, Close + } \ No newline at end of file From 00f2044fde3ad351e00368601d7490aff6354df2 Mon Sep 17 00:00:00 2001 From: threadexception Date: Sat, 13 Nov 2021 12:58:28 +0100 Subject: [PATCH 3/5] Extend modding api --- Cargo.lock | 12 - modding/Cargo.lock | 1816 ++++++++++++++++++++++++++++++++++++++++++-- modding/Cargo.toml | 6 +- modding/src/lib.rs | 184 ++++- 4 files changed, 1937 insertions(+), 81 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b42e0ff8..539919a7 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1536,7 +1536,6 @@ dependencies = [ "instant", "lazy_static", "leafish_blocks", - "leafish_modding", "leafish_protocol", "leafish_resources", "leafish_shared", @@ -1566,17 +1565,6 @@ dependencies = [ "parking_lot", ] -[[package]] -name = "leafish_modding" -version = "0.0.1" -dependencies = [ - "dashmap", - "libloading 0.7.0", - "log", - "serde", - "serde_json", -] - [[package]] name = "leafish_protocol" version = "0.0.1" diff --git a/modding/Cargo.lock b/modding/Cargo.lock index 9f419504..c8a19a99 100644 --- a/modding/Cargo.lock +++ b/modding/Cargo.lock @@ -2,121 +2,1592 @@ # It is not intended for manual editing. version = 3 +[[package]] +name = "Inflector" +version = "0.11.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fe438c63458706e03479442743baae6c88256498e6431708f6dfc520a26515d3" + +[[package]] +name = "adler" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" + +[[package]] +name = "aes" +version = "0.7.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e8b47f52ea9bae42228d07ec09eb676433d7c4ed1ebdf0f1d1c29ed446f1ab8" +dependencies = [ + "cfg-if", + "cipher", + "cpufeatures", + "opaque-debug", +] + +[[package]] +name = "ahash" +version = "0.7.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fcb51a0695d8f838b1ee009b3fbf66bda078cd64590202a864a8f3e8c4315c47" +dependencies = [ + "getrandom", + "once_cell", + "version_check", +] + +[[package]] +name = "approx" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f0e60b75072ecd4168020818c0107f2857bb6c4e64252d8d3983f6263b40a5c3" +dependencies = [ + "num-traits", +] + +[[package]] +name = "async-channel" +version = "1.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2114d64672151c0c5eaa5e131ec84a74f06e1e559830dabba01ca30605d66319" +dependencies = [ + "concurrent-queue", + "event-listener", + "futures-core", +] + +[[package]] +name = "async-executor" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "871f9bb5e0a22eeb7e8cf16641feb87c9dc67032ccf8ff49e772eb9941d3a965" +dependencies = [ + "async-task", + "concurrent-queue", + "fastrand", + "futures-lite", + "once_cell", + "slab", +] + +[[package]] +name = "async-task" +version = "4.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e91831deabf0d6d7ec49552e489aed63b7456a7a3c46cff62adad428110b0af0" + +[[package]] +name = "async-trait" +version = "0.1.51" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "44318e776df68115a881de9a8fd1b9e53368d7a4a5ce4cc48517da3393233a5e" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "autocfg" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1d49d90015b3c36167a20fe2810c5cd875ad504b39cff3d4eae7977e6b7c1cb2" + +[[package]] +name = "autocfg" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cdb031dd78e28731d87d56cc8ffef4a8f36ca26c38fe2de700543e627f8a464a" + +[[package]] +name = "base64" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "904dfeac50f3cdaba28fc6f57fdcddb75f49ed61346676a78c4ffe55877802fd" + +[[package]] +name = "bevy_derive" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "Inflector", + "bevy_macro_utils", + "quote", + "syn", +] + +[[package]] +name = "bevy_ecs" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "async-channel", + "bevy_ecs_macros", + "bevy_reflect", + "bevy_tasks", + "bevy_utils", + "downcast-rs", + "fixedbitset", + "fxhash", + "serde", + "thiserror", +] + +[[package]] +name = "bevy_ecs_macros" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "bevy_macro_utils", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "bevy_macro_utils" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "cargo-manifest", + "syn", +] + +[[package]] +name = "bevy_reflect" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "bevy_reflect_derive", + "bevy_utils", + "downcast-rs", + "erased-serde", + "parking_lot", + "serde", + "thiserror", +] + +[[package]] +name = "bevy_reflect_derive" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "bevy_macro_utils", + "proc-macro2", + "quote", + "syn", + "uuid", +] + +[[package]] +name = "bevy_tasks" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "async-channel", + "async-executor", + "event-listener", + "futures-lite", + "num_cpus", + "wasm-bindgen-futures", +] + +[[package]] +name = "bevy_utils" +version = "0.5.0" +source = "git+https://github.com/terrarier2111/bevy#fdeb0c7204c635a9d05fb302ab467d4d90421afc" +dependencies = [ + "ahash", + "bevy_derive", + "getrandom", + "instant", + "tracing", + "uuid", +] + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "block-buffer" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4152116fd6e9dadb291ae18fc1ec3575ed6d84c29642d97890f4b4a3417297e4" +dependencies = [ + "generic-array", +] + +[[package]] +name = "bumpalo" +version = "3.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f1e260c3a9040a7c19a12468758f4c16f31a81a1fe087482be9570ec864bb6c" + +[[package]] +name = "byteorder" +version = "1.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "14c189c53d098945499cdfa7ecc63567cf3886b3332b312a5b4585d8d3a6a610" + +[[package]] +name = "bytes" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4872d67bab6358e59559027aa3b9157c53d9358c51423c17554809a8858e0f8" + +[[package]] +name = "cache-padded" +version = "1.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "631ae5198c9be5e753e5cc215e1bd73c2b466a3565173db433f52bb9d3e66dba" + +[[package]] +name = "cargo-manifest" +version = "0.2.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af6d65c7592744998c67947ec771c62687c76f00179a83ffd563c0482046bb98" +dependencies = [ + "serde", + "serde_derive", + "toml", +] + +[[package]] +name = "cc" +version = "1.0.72" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "22a9137b95ea06864e018375b72adfb7db6e6f68cfc8df5a04d00288050485ee" + +[[package]] +name = "cfb8" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3a4b6c43bf284e617a659ce5dc149676680530a3a4a9bb6b278d1a9ed5b229d" +dependencies = [ + "cipher", +] + [[package]] name = "cfg-if" version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "cgmath" +version = "0.17.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "283944cdecc44bf0b8dd010ec9af888d3b4f142844fdbe026c20ef68148d6fe7" +dependencies = [ + "approx", + "num-traits", + "rand 0.6.5", +] + +[[package]] +name = "cipher" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7ee52072ec15386f770805afd189a01c8841be8696bed250fa2f13c4c0d6dfb7" +dependencies = [ + "generic-array", +] + +[[package]] +name = "cloudabi" +version = "0.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ddfc5b9aa5d4507acaf872de71051dfd0e309860e88966e1051e462a077aac4f" +dependencies = [ + "bitflags", +] + +[[package]] +name = "concurrent-queue" +version = "1.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "30ed07550be01594c6026cff2a1d7fe9c8f683caa798e12b68694ac9e88286a3" +dependencies = [ + "cache-padded", +] + +[[package]] +name = "core-foundation" +version = "0.9.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6888e10551bb93e424d8df1d07f1a8b4fceb0001a3a4b048bfc47554946f47b3" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "core-foundation-sys" +version = "0.8.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5827cebf4670468b8772dd191856768aedcb1b0278a04f989f7766351917b9dc" + +[[package]] +name = "cpufeatures" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95059428f66df56b63431fdb4e1947ed2190586af5c5a8a8b71122bdf5a7f469" +dependencies = [ + "libc", +] + +[[package]] +name = "crc32fast" +version = "1.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81156fece84ab6a9f2afdb109ce3ae577e42b1228441eded99bd77f627953b1a" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "dashmap" +version = "4.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e77a43b28d0668df09411cb0bc9a8c2adc40f9a048afe863e05fd43251e8e39c" +dependencies = [ + "cfg-if", + "num_cpus", +] + +[[package]] +name = "data-encoding" +version = "2.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3ee2393c4a91429dffb4bedf19f4d6abf27d8a732c8ce4980305d782e5426d57" + +[[package]] +name = "digest" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3dd60d1080a57a05ab032377049e0591415d2b31afd7028356dbf3cc6dcb066" +dependencies = [ + "generic-array", +] + +[[package]] +name = "downcast-rs" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ea835d29036a4087793836fa931b08837ad5e957da9e23886b29586fb9b6650" + +[[package]] +name = "encoding_rs" +version = "0.8.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a74ea89a0a1b98f6332de42c95baff457ada66d1cb4030f9ff151b2041a1c746" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "enum-as-inner" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7c5f0096a91d210159eceb2ff5e1c4da18388a170e1e3ce948aac9c8fdbbf595" +dependencies = [ + "heck", + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "erased-serde" +version = "0.3.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3de9ad4541d99dc22b59134e7ff8dc3d6c988c89ecd7324bf10a8362b07a2afa" +dependencies = [ + "serde", +] + +[[package]] +name = "event-listener" +version = "2.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f7531096570974c3a9dcf9e4b8e1cede1ec26cf5046219fb3b9d897503b9be59" + +[[package]] +name = "fastrand" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b394ed3d285a429378d3b384b9eb1285267e7df4b166df24b7a6939a04dc392e" +dependencies = [ + "instant", +] + +[[package]] +name = "fixedbitset" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "398ea4fabe40b9b0d885340a2a991a44c8a645624075ad966d21f88688e2b69e" + +[[package]] +name = "flate2" +version = "1.0.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e6988e897c1c9c485f43b47a529cef42fde0547f9d8d41a7062518f1d8fc53f" +dependencies = [ + "cfg-if", + "crc32fast", + "libc", + "miniz_oxide", +] + +[[package]] +name = "fnv" +version = "1.0.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" + +[[package]] +name = "foreign-types" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" +dependencies = [ + "foreign-types-shared", +] + +[[package]] +name = "foreign-types-shared" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" + +[[package]] +name = "form_urlencoded" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5fc25a87fa4fd2094bffb06925852034d90a17f0d1e05197d4956d3555752191" +dependencies = [ + "matches", + "percent-encoding", +] + +[[package]] +name = "fuchsia-cprng" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a06f77d526c1a601b7c4cdd98f54b5eaabffc14d5f2f0296febdc7f357c6d3ba" + +[[package]] +name = "futures-channel" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5da6ba8c3bb3c165d3c7319fc1cc8304facf1fb8db99c5de877183c08a273888" +dependencies = [ + "futures-core", +] + +[[package]] +name = "futures-core" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88d1c26957f23603395cd326b0ffe64124b818f4449552f960d815cfba83a53d" + +[[package]] +name = "futures-io" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "522de2a0fe3e380f1bc577ba0474108faf3f6b18321dbf60b3b9c39a75073377" + +[[package]] +name = "futures-lite" +version = "1.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7694489acd39452c77daa48516b894c153f192c3578d5a839b62c58099fcbf48" +dependencies = [ + "fastrand", + "futures-core", + "futures-io", + "memchr", + "parking", + "pin-project-lite", + "waker-fn", +] + +[[package]] +name = "futures-sink" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "36ea153c13024fe480590b3e3d4cad89a0cfacecc24577b68f86c6ced9c2bc11" + +[[package]] +name = "futures-task" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1d3d00f4eddb73e498a54394f228cd55853bdf059259e8e7bc6e69d408892e99" + +[[package]] +name = "futures-util" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "36568465210a3a6ee45e1f165136d68671471a501e632e9a98d96872222b5481" +dependencies = [ + "autocfg 1.0.1", + "futures-core", + "futures-io", + "futures-task", + "memchr", + "pin-project-lite", + "pin-utils", + "slab", +] + +[[package]] +name = "fxhash" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c31b6d751ae2c7f11320402d34e41349dd1016f8d5d45e48c4312bc8625af50c" +dependencies = [ + "byteorder", +] + +[[package]] +name = "generic-array" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "501466ecc8a30d1d3b7fc9229b122b2ce8ed6e9d9223f1138d4babb253e51817" +dependencies = [ + "typenum", + "version_check", +] + +[[package]] +name = "getrandom" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7fcd999463524c52659517fe2cea98493cfe485d10565e7b0fb07dbba7ad2753" +dependencies = [ + "cfg-if", + "js-sys", + "libc", + "wasi", + "wasm-bindgen", +] + +[[package]] +name = "h2" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7fd819562fcebdac5afc5c113c3ec36f902840b70fd4fc458799c8ce4607ae55" +dependencies = [ + "bytes", + "fnv", + "futures-core", + "futures-sink", + "futures-util", + "http", + "indexmap", + "slab", + "tokio", + "tokio-util", + "tracing", +] + +[[package]] +name = "hashbrown" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ab5ef0d4909ef3724cc8cce6ccc8572c5c817592e9285f5464f8e86f8bd3726e" + +[[package]] +name = "heck" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6d621efb26863f0e9924c6ac577e8275e5e6b77455db64ffa6c65c904e9e132c" +dependencies = [ + "unicode-segmentation", +] + +[[package]] +name = "hermit-abi" +version = "0.1.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62b467343b94ba476dcb2500d242dadbb39557df889310ac77c5d99100aaac33" +dependencies = [ + "libc", +] + +[[package]] +name = "hex" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" + +[[package]] +name = "hostname" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c731c3e10504cc8ed35cfe2f1db4c9274c3d35fa486e3b31df46f068ef3e867" +dependencies = [ + "libc", + "match_cfg", + "winapi", +] + +[[package]] +name = "http" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1323096b05d41827dadeaee54c9981958c0f94e670bc94ed80037d1a7b8b186b" +dependencies = [ + "bytes", + "fnv", + "itoa", +] + +[[package]] +name = "http-body" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1ff4f84919677303da5f147645dbea6b1881f368d03ac84e1dc09031ebd7b2c6" +dependencies = [ + "bytes", + "http", + "pin-project-lite", +] + +[[package]] +name = "httparse" +version = "1.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "acd94fdbe1d4ff688b67b04eee2e17bd50995534a61539e45adfefb45e5e5503" + +[[package]] +name = "httpdate" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6456b8a6c8f33fee7d958fcd1b60d55b11940a79e63ae87013e6d22e26034440" + +[[package]] +name = "hyper" +version = "0.14.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b91bb1f221b6ea1f1e4371216b70f40748774c2fb5971b450c07773fb92d26b" +dependencies = [ + "bytes", + "futures-channel", + "futures-core", + "futures-util", + "h2", + "http", + "http-body", + "httparse", + "httpdate", + "itoa", + "pin-project-lite", + "socket2 0.4.2", + "tokio", + "tower-service", + "tracing", + "want", +] + +[[package]] +name = "hyper-tls" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" +dependencies = [ + "bytes", + "hyper", + "native-tls", + "tokio", + "tokio-native-tls", +] + +[[package]] +name = "idna" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "418a0a6fab821475f634efe3ccc45c013f742efe03d853e8d3355d5cb850ecf8" +dependencies = [ + "matches", + "unicode-bidi", + "unicode-normalization", +] + +[[package]] +name = "indexmap" +version = "1.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc633605454125dec4b66843673f01c7df2b89479b32e0ed634e43a91cff62a5" +dependencies = [ + "autocfg 1.0.1", + "hashbrown", +] + +[[package]] +name = "instant" +version = "0.1.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a5bbe824c507c5da5956355e86a746d82e0e1464f65d862cc5e71da70e94b2c" +dependencies = [ + "cfg-if", + "js-sys", + "wasm-bindgen", + "web-sys", +] + +[[package]] +name = "ipconfig" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f7e2f18aece9709094573a9f24f483c4f65caa4298e2f7ae1b71cc65d853fad7" +dependencies = [ + "socket2 0.3.19", + "widestring", + "winapi", + "winreg 0.6.2", +] + +[[package]] +name = "ipnet" +version = "2.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68f2d64f2edebec4ce84ad108148e67e1064789bee435edc5b60ad398714a3a9" + +[[package]] +name = "itoa" +version = "0.4.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b71991ff56294aa922b450139ee08b3bfc70982c6b2c7562771375cf73542dd4" + +[[package]] +name = "js-sys" +version = "0.3.55" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7cc9ffccd38c451a86bf13657df244e9c3f37493cce8e5e21e940963777acc84" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "lazy_static" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" + +[[package]] +name = "leafish_modding" +version = "0.0.1" +dependencies = [ + "dashmap", + "leafish_protocol", + "libloading", + "log", + "serde", + "serde_json", +] + +[[package]] +name = "leafish_protocol" +version = "0.0.1" +dependencies = [ + "aes", + "bevy_ecs", + "byteorder", + "cfb8", + "cgmath", + "dashmap", + "flate2", + "hex", + "instant", + "lazy_static", + "leafish_shared", + "log", + "num-traits", + "reqwest", + "serde", + "serde_json", + "sha-1", + "trust-dns-resolver", +] + +[[package]] +name = "leafish_shared" +version = "0.0.1" +dependencies = [ + "bevy_ecs", +] + +[[package]] +name = "libc" +version = "0.2.102" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2a5ac8f984bfcf3a823267e5fde638acc3325f6496633a5da6bb6eb2171e103" + +[[package]] +name = "libloading" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6f84d96438c15fcd6c3f244c8fce01d1e2b9c6b5623e9c711dc9286d8fc92d6a" +dependencies = [ + "cfg-if", + "winapi", +] + +[[package]] +name = "linked-hash-map" +version = "0.5.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7fb9b38af92608140b86b693604b9ffcc5824240a484d1ecd4795bacb2fe88f3" + +[[package]] +name = "lock_api" +version = "0.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "712a4d093c9976e24e7dbca41db895dabcbac38eb5f4045393d17a95bdfb1109" +dependencies = [ + "scopeguard", +] + +[[package]] +name = "log" +version = "0.4.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51b9bbe6c47d51fc3e1a9b945965946b4c44142ab8792c50835a980d362c2710" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "lru-cache" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "31e24f1ad8321ca0e8a1e0ac13f23cb668e6f5466c2c57319f6a5cf1cc8e3b1c" +dependencies = [ + "linked-hash-map", +] + +[[package]] +name = "match_cfg" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ffbee8634e0d45d258acb448e7eaab3fce7a0a467395d4d9f228e3c1f01fb2e4" + +[[package]] +name = "matches" +version = "0.1.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a3e378b66a060d48947b590737b30a1be76706c8dd7b8ba0f2fe3989c68a853f" + +[[package]] +name = "memchr" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "308cc39be01b73d0d18f82a0e7b2a3df85245f84af96fdddc5d202d27e47b86a" + +[[package]] +name = "mime" +version = "0.3.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2a60c7ce501c71e03a9c9c0d35b861413ae925bd979cc7a4e30d060069aaac8d" + +[[package]] +name = "miniz_oxide" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a92518e98c078586bc6c934028adcca4c92a53d6a958196de835170a01d84e4b" +dependencies = [ + "adler", + "autocfg 1.0.1", +] + +[[package]] +name = "mio" +version = "0.7.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8067b404fe97c70829f082dec8bcf4f71225d7eaea1d8645349cb76fa06205cc" +dependencies = [ + "libc", + "log", + "miow", + "ntapi", + "winapi", +] + +[[package]] +name = "miow" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b9f1c5b025cda876f66ef43a113f91ebc9f4ccef34843000e0adf6ebbab84e21" +dependencies = [ + "winapi", +] + +[[package]] +name = "native-tls" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "48ba9f7719b5a0f42f338907614285fb5fd70e53858141f69898a1fb7203b24d" +dependencies = [ + "lazy_static", + "libc", + "log", + "openssl", + "openssl-probe", + "openssl-sys", + "schannel", + "security-framework", + "security-framework-sys", + "tempfile", +] + +[[package]] +name = "ntapi" +version = "0.3.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3f6bb902e437b6d86e03cce10a7e2af662292c5dfef23b65899ea3ac9354ad44" +dependencies = [ + "winapi", +] + +[[package]] +name = "num-traits" +version = "0.2.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a64b1ec5cda2586e284722486d802acf1f7dbdc623e2bfc57e65ca1cd099290" +dependencies = [ + "autocfg 1.0.1", +] + +[[package]] +name = "num_cpus" +version = "1.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05499f3756671c15885fee9034446956fff3f243d6077b91e5767df161f766b3" +dependencies = [ + "hermit-abi", + "libc", +] + +[[package]] +name = "once_cell" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "692fcb63b64b1758029e0a96ee63e049ce8c5948587f2f7208df04625e5f6b56" + +[[package]] +name = "opaque-debug" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" + +[[package]] +name = "openssl" +version = "0.10.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0c7ae222234c30df141154f159066c5093ff73b63204dcda7121eb082fc56a95" +dependencies = [ + "bitflags", + "cfg-if", + "foreign-types", + "libc", + "once_cell", + "openssl-sys", +] + +[[package]] +name = "openssl-probe" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "28988d872ab76095a6e6ac88d99b54fd267702734fd7ffe610ca27f533ddb95a" + +[[package]] +name = "openssl-sys" +version = "0.9.70" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6517987b3f8226b5da3661dad65ff7f300cc59fb5ea8333ca191fc65fde3edf" +dependencies = [ + "autocfg 1.0.1", + "cc", + "libc", + "pkg-config", + "vcpkg", +] + +[[package]] +name = "parking" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "427c3892f9e783d91cc128285287e70a59e206ca452770ece88a76f7a3eddd72" + +[[package]] +name = "parking_lot" +version = "0.11.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7d17b78036a60663b797adeaee46f5c9dfebb86948d1255007a1d6be0271ff99" +dependencies = [ + "instant", + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.8.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d76e8e1493bcac0d2766c42737f34458f1c8c50c0d23bcb24ea953affb273216" +dependencies = [ + "cfg-if", + "instant", + "libc", + "redox_syscall", + "smallvec", + "winapi", +] + +[[package]] +name = "percent-encoding" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d4fd5641d01c8f18a23da7b6fe29298ff4b55afcccdf78973b24cf3175fee32e" + +[[package]] +name = "pin-project-lite" +version = "0.2.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8d31d11c69a6b52a174b42bdc0c30e5e11670f90788b2c471c31c1d17d449443" + +[[package]] +name = "pin-utils" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" + +[[package]] +name = "pkg-config" +version = "0.3.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "12295df4f294471248581bc09bef3c38a5e46f1e36d6a37353621a0c6c357e1f" + +[[package]] +name = "ppv-lite86" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed0cfbc8191465bed66e1718596ee0b0b35d5ee1f41c5df2189d0fe8bde535ba" + +[[package]] +name = "proc-macro2" +version = "1.0.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b9f5105d4fdaab20335ca9565e106a5d9b82b6219b5ba735731124ac6711d23d" +dependencies = [ + "unicode-xid", +] + +[[package]] +name = "quick-error" +version = "1.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a1d01941d82fa2ab50be1e79e6714289dd7cde78eba4c074bc5a4374f650dfe0" + +[[package]] +name = "quote" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c3d0b9745dc2debf507c8422de05d7226cc1f0644216dfdfead988f9b1ab32a7" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "rand" +version = "0.6.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6d71dacdc3c88c1fde3885a3be3fbab9f35724e6ce99467f7d9c5026132184ca" +dependencies = [ + "autocfg 0.1.7", + "libc", + "rand_chacha 0.1.1", + "rand_core 0.4.2", + "rand_hc 0.1.0", + "rand_isaac", + "rand_jitter", + "rand_os", + "rand_pcg", + "rand_xorshift", + "winapi", +] + +[[package]] +name = "rand" +version = "0.8.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2e7573632e6454cf6b99d7aac4ccca54be06da05aca2ef7423d22d27d4d4bcd8" +dependencies = [ + "libc", + "rand_chacha 0.3.1", + "rand_core 0.6.3", + "rand_hc 0.3.1", +] + +[[package]] +name = "rand_chacha" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "556d3a1ca6600bfcbab7c7c91ccb085ac7fbbcd70e008a98742e7847f4f7bcef" +dependencies = [ + "autocfg 0.1.7", + "rand_core 0.3.1", +] + +[[package]] +name = "rand_chacha" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" +dependencies = [ + "ppv-lite86", + "rand_core 0.6.3", +] + +[[package]] +name = "rand_core" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a6fdeb83b075e8266dcc8762c22776f6877a63111121f5f8c7411e5be7eed4b" +dependencies = [ + "rand_core 0.4.2", +] + +[[package]] +name = "rand_core" +version = "0.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c33a3c44ca05fa6f1807d8e6743f3824e8509beca625669633be0acbdf509dc" + +[[package]] +name = "rand_core" +version = "0.6.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d34f1408f55294453790c48b2f1ebbb1c5b4b7563eb1f418bcfcfdbb06ebb4e7" +dependencies = [ + "getrandom", +] + +[[package]] +name = "rand_hc" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b40677c7be09ae76218dc623efbf7b18e34bced3f38883af07bb75630a21bc4" +dependencies = [ + "rand_core 0.3.1", +] + +[[package]] +name = "rand_hc" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d51e9f596de227fda2ea6c84607f5558e196eeaf43c986b724ba4fb8fdf497e7" +dependencies = [ + "rand_core 0.6.3", +] + +[[package]] +name = "rand_isaac" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ded997c9d5f13925be2a6fd7e66bf1872597f759fd9dd93513dd7e92e5a5ee08" +dependencies = [ + "rand_core 0.3.1", +] + +[[package]] +name = "rand_jitter" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1166d5c91dc97b88d1decc3285bb0a99ed84b05cfd0bc2341bdf2d43fc41e39b" +dependencies = [ + "libc", + "rand_core 0.4.2", + "winapi", +] + +[[package]] +name = "rand_os" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b75f676a1e053fc562eafbb47838d67c84801e38fc1ba459e8f180deabd5071" +dependencies = [ + "cloudabi", + "fuchsia-cprng", + "libc", + "rand_core 0.4.2", + "rdrand", + "winapi", +] + +[[package]] +name = "rand_pcg" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "abf9b09b01790cfe0364f52bf32995ea3c39f4d2dd011eac241d2914146d0b44" +dependencies = [ + "autocfg 0.1.7", + "rand_core 0.4.2", +] + +[[package]] +name = "rand_xorshift" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cbf7e9e623549b0e21f6e97cf8ecf247c1a8fd2e8a992ae265314300b2455d5c" +dependencies = [ + "rand_core 0.3.1", +] + +[[package]] +name = "rdrand" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "678054eb77286b51581ba43620cc911abf02758c91f93f479767aed0f90458b2" +dependencies = [ + "rand_core 0.3.1", +] + +[[package]] +name = "redox_syscall" +version = "0.2.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8383f39639269cde97d255a32bdb68c047337295414940c68bdd30c2e13203ff" +dependencies = [ + "bitflags", +] + +[[package]] +name = "remove_dir_all" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3acd125665422973a33ac9d3dd2df85edad0f4ae9b00dafb1a05e43a9f5ef8e7" +dependencies = [ + "winapi", +] + +[[package]] +name = "reqwest" +version = "0.11.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "66d2927ca2f685faf0fc620ac4834690d29e7abb153add10f5812eef20b5e280" +dependencies = [ + "base64", + "bytes", + "encoding_rs", + "futures-core", + "futures-util", + "http", + "http-body", + "hyper", + "hyper-tls", + "ipnet", + "js-sys", + "lazy_static", + "log", + "mime", + "native-tls", + "percent-encoding", + "pin-project-lite", + "serde", + "serde_json", + "serde_urlencoded", + "tokio", + "tokio-native-tls", + "url", + "wasm-bindgen", + "wasm-bindgen-futures", + "web-sys", + "winreg 0.7.0", +] + +[[package]] +name = "resolv-conf" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "52e44394d2086d010551b14b53b1f24e31647570cd1deb0379e2c21b329aba00" +dependencies = [ + "hostname", + "quick-error", +] + +[[package]] +name = "ryu" +version = "1.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "71d301d4193d031abdd79ff7e3dd721168a9572ef3fe51a1517aba235bd8f86e" + +[[package]] +name = "schannel" +version = "0.1.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f05ba609c234e60bee0d547fe94a4c7e9da733d1c962cf6e59efa4cd9c8bc75" +dependencies = [ + "lazy_static", + "winapi", +] + +[[package]] +name = "scopeguard" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d29ab0c6d3fc0ee92fe66e2d99f700eab17a8d57d1c1d3b748380fb20baa78cd" + +[[package]] +name = "security-framework" +version = "2.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "525bc1abfda2e1998d152c45cf13e696f76d0a4972310b22fac1658b05df7c87" +dependencies = [ + "bitflags", + "core-foundation", + "core-foundation-sys", + "libc", + "security-framework-sys", +] + +[[package]] +name = "security-framework-sys" +version = "2.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a9dd14d83160b528b7bfd66439110573efcfbe281b17fc2ca9f39f550d619c7e" +dependencies = [ + "core-foundation-sys", + "libc", +] + +[[package]] +name = "serde" +version = "1.0.130" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f12d06de37cf59146fbdecab66aa99f9fe4f78722e3607577a5375d66bd0c913" +dependencies = [ + "serde_derive", +] [[package]] -name = "dashmap" -version = "4.0.2" +name = "serde_derive" +version = "1.0.130" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e77a43b28d0668df09411cb0bc9a8c2adc40f9a048afe863e05fd43251e8e39c" +checksum = "d7bc1a1ab1961464eae040d96713baa5a724a8152c1222492465b54322ec508b" dependencies = [ - "cfg-if", - "num_cpus", + "proc-macro2", + "quote", + "syn", ] [[package]] -name = "hermit-abi" -version = "0.1.19" +name = "serde_json" +version = "1.0.68" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62b467343b94ba476dcb2500d242dadbb39557df889310ac77c5d99100aaac33" +checksum = "0f690853975602e1bfe1ccbf50504d67174e3bcf340f23b5ea9992e0587a52d8" dependencies = [ - "libc", + "itoa", + "ryu", + "serde", ] [[package]] -name = "itoa" -version = "0.4.8" +name = "serde_urlencoded" +version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b71991ff56294aa922b450139ee08b3bfc70982c6b2c7562771375cf73542dd4" +checksum = "edfa57a7f8d9c1d260a549e7224100f6c43d43f9103e06dd8b4095a9b2b43ce9" +dependencies = [ + "form_urlencoded", + "itoa", + "ryu", + "serde", +] [[package]] -name = "leafish_modding" -version = "0.0.1" +name = "sha-1" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "99cd6713db3cf16b6c84e06321e049a9b9f699826e16096d23bbcc44d15d51a6" dependencies = [ - "dashmap", - "libloading", - "log", - "serde", - "serde_json", + "block-buffer", + "cfg-if", + "cpufeatures", + "digest", + "opaque-debug", ] [[package]] -name = "libc" -version = "0.2.102" +name = "slab" +version = "0.4.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a2a5ac8f984bfcf3a823267e5fde638acc3325f6496633a5da6bb6eb2171e103" +checksum = "9def91fd1e018fe007022791f865d0ccc9b3a0d5001e01aabb8b40e46000afb5" [[package]] -name = "libloading" -version = "0.7.0" +name = "smallvec" +version = "1.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6f84d96438c15fcd6c3f244c8fce01d1e2b9c6b5623e9c711dc9286d8fc92d6a" +checksum = "1ecab6c735a6bb4139c0caafd0cc3635748bbb3acf4550e8138122099251f309" + +[[package]] +name = "socket2" +version = "0.3.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "122e570113d28d773067fab24266b66753f6ea915758651696b6e35e49f88d6e" dependencies = [ "cfg-if", + "libc", "winapi", ] [[package]] -name = "log" -version = "0.4.14" +name = "socket2" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "51b9bbe6c47d51fc3e1a9b945965946b4c44142ab8792c50835a980d362c2710" +checksum = "5dc90fe6c7be1a323296982db1836d1ea9e47b6839496dde9a541bc496df3516" +dependencies = [ + "libc", + "winapi", +] + +[[package]] +name = "syn" +version = "1.0.76" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6f107db402c2c2055242dbf4d2af0e69197202e9faacbef9571bbe47f5a1b84" +dependencies = [ + "proc-macro2", + "quote", + "unicode-xid", +] + +[[package]] +name = "tempfile" +version = "3.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dac1c663cfc93810f88aed9b8941d48cabf856a1b111c29a40439018d870eb22" dependencies = [ "cfg-if", + "libc", + "rand 0.8.4", + "redox_syscall", + "remove_dir_all", + "winapi", ] [[package]] -name = "num_cpus" +name = "thiserror" +version = "1.0.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "854babe52e4df1653706b98fcfc05843010039b406875930a70e4d9644e5c417" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aa32fd3f627f367fe16f893e2597ae3c05020f8bba2666a4e6ea73d377e5714b" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tinyvec" +version = "1.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2c1c1d5a42b6245520c249549ec267180beaffcc0615401ac8e31853d4b6d8d2" +dependencies = [ + "tinyvec_macros", +] + +[[package]] +name = "tinyvec_macros" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c" + +[[package]] +name = "tokio" version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "05499f3756671c15885fee9034446956fff3f243d6077b91e5767df161f766b3" +checksum = "588b2d10a336da58d877567cd8fb8a14b463e2104910f8132cd054b4b96e29ee" dependencies = [ - "hermit-abi", + "autocfg 1.0.1", + "bytes", "libc", + "memchr", + "mio", + "num_cpus", + "pin-project-lite", + "winapi", ] [[package]] -name = "proc-macro2" -version = "1.0.29" +name = "tokio-native-tls" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b9f5105d4fdaab20335ca9565e106a5d9b82b6219b5ba735731124ac6711d23d" +checksum = "f7d995660bd2b7f8c1568414c1126076c13fbb725c40112dc0120b78eb9b717b" dependencies = [ - "unicode-xid", + "native-tls", + "tokio", ] [[package]] -name = "quote" -version = "1.0.9" +name = "tokio-util" +version = "0.6.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3d0b9745dc2debf507c8422de05d7226cc1f0644216dfdfead988f9b1ab32a7" +checksum = "9e99e1983e5d376cd8eb4b66604d2e99e79f5bd988c3055891dcd8c9e2604cc0" dependencies = [ - "proc-macro2", + "bytes", + "futures-core", + "futures-sink", + "log", + "pin-project-lite", + "tokio", ] [[package]] -name = "ryu" -version = "1.0.5" +name = "toml" +version = "0.5.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "71d301d4193d031abdd79ff7e3dd721168a9572ef3fe51a1517aba235bd8f86e" +checksum = "a31142970826733df8241ef35dc040ef98c679ab14d7c3e54d827099b3acecaa" +dependencies = [ + "indexmap", + "serde", +] [[package]] -name = "serde" -version = "1.0.130" +name = "tower-service" +version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f12d06de37cf59146fbdecab66aa99f9fe4f78722e3607577a5375d66bd0c913" +checksum = "360dfd1d6d30e05fda32ace2c8c70e9c0a9da713275777f5a4dbb8a1893930c6" + +[[package]] +name = "tracing" +version = "0.1.29" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "375a639232caf30edfc78e8d89b2d4c375515393e7af7e16f01cd96917fb2105" dependencies = [ - "serde_derive", + "cfg-if", + "pin-project-lite", + "tracing-attributes", + "tracing-core", ] [[package]] -name = "serde_derive" -version = "1.0.130" +name = "tracing-attributes" +version = "0.1.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d7bc1a1ab1961464eae040d96713baa5a724a8152c1222492465b54322ec508b" +checksum = "f4f480b8f81512e825f337ad51e94c1eb5d3bbdf2b363dcd01e2b19a9ffe3f8e" dependencies = [ "proc-macro2", "quote", @@ -124,33 +1595,236 @@ dependencies = [ ] [[package]] -name = "serde_json" -version = "1.0.68" +name = "tracing-core" +version = "0.1.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f690853975602e1bfe1ccbf50504d67174e3bcf340f23b5ea9992e0587a52d8" +checksum = "1f4ed65637b8390770814083d20756f87bfa2c21bf2f110babdc5438351746e4" dependencies = [ - "itoa", - "ryu", - "serde", + "lazy_static", ] [[package]] -name = "syn" -version = "1.0.76" +name = "trust-dns-proto" +version = "0.20.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c6f107db402c2c2055242dbf4d2af0e69197202e9faacbef9571bbe47f5a1b84" +checksum = "ad0d7f5db438199a6e2609debe3f69f808d074e0a2888ee0bccb45fe234d03f4" dependencies = [ - "proc-macro2", - "quote", - "unicode-xid", + "async-trait", + "cfg-if", + "data-encoding", + "enum-as-inner", + "futures-channel", + "futures-io", + "futures-util", + "idna", + "ipnet", + "lazy_static", + "log", + "rand 0.8.4", + "smallvec", + "thiserror", + "tinyvec", + "tokio", + "url", +] + +[[package]] +name = "trust-dns-resolver" +version = "0.20.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f6ad17b608a64bd0735e67bde16b0636f8aa8591f831a25d18443ed00a699770" +dependencies = [ + "cfg-if", + "futures-util", + "ipconfig", + "lazy_static", + "log", + "lru-cache", + "parking_lot", + "resolv-conf", + "smallvec", + "thiserror", + "tokio", + "trust-dns-proto", +] + +[[package]] +name = "try-lock" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "59547bce71d9c38b83d9c0e92b6066c4253371f15005def0c30d9657f50c7642" + +[[package]] +name = "typenum" +version = "1.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b63708a265f51345575b27fe43f9500ad611579e764c79edbc2037b1121959ec" + +[[package]] +name = "unicode-bidi" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1a01404663e3db436ed2746d9fefef640d868edae3cceb81c3b8d5732fda678f" + +[[package]] +name = "unicode-normalization" +version = "0.1.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d54590932941a9e9266f0832deed84ebe1bf2e4c9e4a3554d393d18f5e854bf9" +dependencies = [ + "tinyvec", ] +[[package]] +name = "unicode-segmentation" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8895849a949e7845e06bd6dc1aa51731a103c42707010a5b591c0038fb73385b" + [[package]] name = "unicode-xid" version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8ccb82d61f80a663efe1f787a51b16b5a51e3314d6ac365b08639f52387b33f3" +[[package]] +name = "url" +version = "2.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a507c383b2d33b5fc35d1861e77e6b383d158b2da5e14fe51b83dfedf6fd578c" +dependencies = [ + "form_urlencoded", + "idna", + "matches", + "percent-encoding", +] + +[[package]] +name = "uuid" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc5cf98d8186244414c848017f0e2676b3fcb46807f6668a97dfe67359a3c4b7" +dependencies = [ + "getrandom", + "serde", +] + +[[package]] +name = "vcpkg" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" + +[[package]] +name = "version_check" +version = "0.9.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5fecdca9a5291cc2b8dcf7dc02453fee791a280f3743cb0905f8822ae463b3fe" + +[[package]] +name = "waker-fn" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d5b2c62b4012a3e1eca5a7e077d13b3bf498c4073e33ccd58626607748ceeca" + +[[package]] +name = "want" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1ce8a968cb1cd110d136ff8b819a556d6fb6d919363c61534f6860c7eb172ba0" +dependencies = [ + "log", + "try-lock", +] + +[[package]] +name = "wasi" +version = "0.10.2+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fd6fbd9a79829dd1ad0cc20627bf1ed606756a7f77edff7b66b7064f9cb327c6" + +[[package]] +name = "wasm-bindgen" +version = "0.2.78" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "632f73e236b219150ea279196e54e610f5dbafa5d61786303d4da54f84e47fce" +dependencies = [ + "cfg-if", + "wasm-bindgen-macro", +] + +[[package]] +name = "wasm-bindgen-backend" +version = "0.2.78" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a317bf8f9fba2476b4b2c85ef4c4af8ff39c3c7f0cdfeed4f82c34a880aa837b" +dependencies = [ + "bumpalo", + "lazy_static", + "log", + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-futures" +version = "0.4.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e8d7523cb1f2a4c96c1317ca690031b714a51cc14e05f712446691f413f5d39" +dependencies = [ + "cfg-if", + "js-sys", + "wasm-bindgen", + "web-sys", +] + +[[package]] +name = "wasm-bindgen-macro" +version = "0.2.78" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d56146e7c495528bf6587663bea13a8eb588d39b36b679d83972e1a2dbbdacf9" +dependencies = [ + "quote", + "wasm-bindgen-macro-support", +] + +[[package]] +name = "wasm-bindgen-macro-support" +version = "0.2.78" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7803e0eea25835f8abdc585cd3021b3deb11543c6fe226dcd30b228857c5c5ab" +dependencies = [ + "proc-macro2", + "quote", + "syn", + "wasm-bindgen-backend", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-shared" +version = "0.2.78" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0237232789cf037d5480773fe568aac745bfe2afbc11a863e97901780a6b47cc" + +[[package]] +name = "web-sys" +version = "0.3.55" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "38eb105f1c59d9eaa6b5cdc92b859d85b926e82cb2e0945cd0c9259faa6fe9fb" +dependencies = [ + "js-sys", + "wasm-bindgen", +] + +[[package]] +name = "widestring" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c168940144dd21fd8046987c16a46a33d5fc84eec29ef9dcddc2ac9e31526b7c" + [[package]] name = "winapi" version = "0.3.9" @@ -172,3 +1846,21 @@ name = "winapi-x86_64-pc-windows-gnu" version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" + +[[package]] +name = "winreg" +version = "0.6.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b2986deb581c4fe11b621998a5e53361efe6b48a151178d0cd9eeffa4dc6acc9" +dependencies = [ + "winapi", +] + +[[package]] +name = "winreg" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0120db82e8a1e0b9fb3345a539c478767c0048d842860994d96113d5b667bd69" +dependencies = [ + "winapi", +] diff --git a/modding/Cargo.toml b/modding/Cargo.toml index ea65694c..8dc134d9 100644 --- a/modding/Cargo.toml +++ b/modding/Cargo.toml @@ -9,4 +9,8 @@ serde = { version = "1.0.130", features = ["derive"] } serde_json = "1.0.68" libloading = "0.7" dashmap = "4.0.2" -log = { version = "0.4.14", features = ["std"] } \ No newline at end of file +log = { version = "0.4.14", features = ["std"] } + +[dependencies.leafish_protocol] +path = "../protocol" +version = "0" \ No newline at end of file diff --git a/modding/src/lib.rs b/modding/src/lib.rs index f81835da..0b8c6fd7 100644 --- a/modding/src/lib.rs +++ b/modding/src/lib.rs @@ -6,6 +6,9 @@ use std::path::Path; use log::warn; extern crate serde; use serde::{Deserialize, Serialize}; +use leafish_protocol::protocol::mapped_packet::MappedPacket; +use leafish_protocol::protocol::packet::Packet; +use leafish_protocol::protocol::Version; pub trait Plugin: Any + Send + Sync { @@ -47,6 +50,7 @@ impl PluginManager { plugin: create_plugin(), _library: library, meta: plugin_meta, + packet_handler: (None, None), }; let file_name = Path::new(&path).file_name().unwrap(); self.plugins.clone().insert(String::from(file_name.to_str().unwrap()), wrapped_plugin); @@ -81,28 +85,34 @@ pub struct WrappedPlugin { plugin: Box, _library: Library, meta: PluginMeta, + packet_handler: (Option>, Option>), } impl WrappedPlugin { + #[inline] pub fn name(&self) -> &'static str { self.plugin.get_name() } - pub fn version(&self) -> usize { + #[inline] + pub fn version(&self) -> u64 { self.meta.version } + #[inline] pub fn authors(&self) -> &Vec { &self.meta.authors } + #[inline] pub fn permissions(&self) -> &Vec { &self.meta.permissions } /// handles an event, returns whether or not the result is `cancel` + #[inline] pub fn handle_event(&self, event: ClientEvent) -> bool { self.plugin.handle_event(event) } @@ -110,17 +120,19 @@ impl WrappedPlugin { } #[derive(Serialize, Deserialize, Default)] +#[repr(C)] pub struct PluginMeta { - version: usize, + version: u64, /// The plugin's version. authors: Vec, permissions: Vec, // TODO: Implement this! - modified: bool, + modified: bool, // what is this used for? } #[derive(Serialize, Deserialize)] +#[repr(C)] pub enum PluginPermission { File, @@ -130,11 +142,171 @@ pub enum PluginPermission { } +pub trait RawPacketHandler { + + #[inline] + fn incoming_priority(&self) -> i64 { + 0 + } + + fn handle_incoming(&self, packet: *mut Packet) -> bool; + + #[inline] + fn outgoing_priority(&self) -> i64 { + 0 + } + + fn handle_outgoing(&self, packet: *mut Packet) -> bool; + +} + +pub trait MappedPacketHandler { + + #[inline] + fn incoming_priority(&self) -> i64 { + 0 + } + + fn handle_incoming(&self, packet: *mut MappedPacket) -> bool; + + #[inline] + fn outgoing_priority(&self) -> i64 { + 0 + } + + fn handle_outgoing(&self, packet: *mut MappedPacket) -> bool; + +} + #[repr(C)] pub enum ClientEvent { - UserInput, // INPUTTYPE: Mouse, Keyboard | down: bool | input: (mousekey or keyboardkey) - Resize, // dimensions maybe? - Screen, // SUBTYPE: Open, Close + UserInput(InputEvent), + Screen(ScreenEvent), + Entity, + ChannelMessage, + Inventory(InputEvent), + World(WorldEvent), + Player, + +} + +/// Events for local player updates +#[repr(C)] +pub enum PlayerEvent { + + Exp, + Health, + Position, + Vehicle, + Block, + Interact, + EntityInteract, + HotBar, + Food, + +} + +#[repr(C)] +pub enum InputEvent { + + Mouse(MouseAction), + Keyboard(bool, ), // down, key board key(input) + +} + +#[repr(C)] +pub enum WorldEvent { + + Block, + Weather, + Time, + +} + +#[repr(C)] +pub enum InventoryEvent { + + Open, + Close, + UpdateSlot, + +} + +#[repr(C)] +pub enum ScreenEvent { + + Open, + Close, + +} + +#[repr(C)] +pub enum EntityEvent { + + Spawn, + Despawn, + Move, + UpdateArmor, + UpdateHandItem, + UpdateName, + +} + +#[repr(C)] +pub enum MouseAction { + + UpdateKey(bool, MouseKey), // down, mouse key(input) + UseWheel(f64), + +} + +#[repr(C)] +pub enum MouseKey { + + Left, + Middle, // pressed mouse wheel + Right, + Other(i64), + +} + +#[no_mangle] +pub trait WorldAccess { + + fn get_block(&self); + + fn set_block(&self); + +} + +#[no_mangle] +pub trait ServerAccess { + + fn protocol(&self) -> i64; + + fn mapped_version(&self) -> Version; + + fn world(&self) -> Box; + +} + +#[no_mangle] +pub trait ScreenSystemAccess { + + fn pop_screen(&self); + + fn push_screen(&self); + +} + +#[repr(C)] +pub struct ScreenBuilder { + + name: String, + active: Option, &mut ui::Container)>, + de_active: Option, &mut ui::Container)>, + init: Option, &mut ui::Container)>, + de_init: Option, &mut ui::Container)>, } \ No newline at end of file From dd810e6d9f2084ce8edd41abb417b4ee24227a3f Mon Sep 17 00:00:00 2001 From: threadexception Date: Sat, 15 Jan 2022 21:40:28 +0100 Subject: [PATCH 4/5] Improve modding api --- modding/src/lib.rs | 166 +++++++++++++++++++++++++++------------------ 1 file changed, 99 insertions(+), 67 deletions(-) diff --git a/modding/src/lib.rs b/modding/src/lib.rs index 0b8c6fd7..6cc015b8 100644 --- a/modding/src/lib.rs +++ b/modding/src/lib.rs @@ -1,35 +1,33 @@ -use std::any::Any; -use libloading::{Library, Symbol, Error}; -use std::sync::Arc; use dashmap::DashMap; -use std::path::Path; +use libloading::{Error, Library, Symbol}; use log::warn; +use std::any::Any; +use std::path::Path; +use std::sync::Arc; extern crate serde; -use serde::{Deserialize, Serialize}; use leafish_protocol::protocol::mapped_packet::MappedPacket; use leafish_protocol::protocol::packet::Packet; use leafish_protocol::protocol::Version; +use serde::{Deserialize, Serialize}; -pub trait Plugin: Any + Send + Sync { +const CREATE_PLUGIN_FN_NAME: &[u8] = b"create_plugin"; +#[no_mangle] +pub trait Plugin: Any + Send + Sync { fn on_enable(&self); fn on_disable(&self) {} - fn get_name(&self) -> &'static str; + fn get_name(&self) -> &'static str; // TODO: Should this get removed and moved into metadata? fn handle_event(&self, event: ClientEvent) -> bool; - } pub struct PluginManager { - plugins: Arc>, - } impl PluginManager { - pub fn load_plugin(&self, path: String) -> bool { let raw_plugin_meta = std::fs::read_to_string(format!("{}/meta.json", path)); let plugin_meta = if let Ok(meta) = raw_plugin_meta { @@ -44,7 +42,8 @@ impl PluginManager { let potential_library = unsafe { Library::new(format!("{}/bin", path)) }; if let Ok(library) = potential_library { - let create_plugin: Result Box>, Error> = unsafe { library.get(b"create_plugin") }; + let create_plugin: Result Box>, Error> = + unsafe { library.get(CREATE_PLUGIN_FN_NAME) }; if let Ok(create_plugin) = create_plugin { let wrapped_plugin = WrappedPlugin { plugin: create_plugin(), @@ -53,11 +52,16 @@ impl PluginManager { packet_handler: (None, None), }; let file_name = Path::new(&path).file_name().unwrap(); - self.plugins.clone().insert(String::from(file_name.to_str().unwrap()), wrapped_plugin); + self.plugins + .clone() + .insert(String::from(file_name.to_str().unwrap()), wrapped_plugin); return true; } else { let file_name = Path::new(&path).file_name().unwrap(); - warn!("There is no \"create_plugin\" function available in {}!", file_name.to_str().unwrap()); + warn!( + "There is no \"create_plugin\" function available in {}!", + file_name.to_str().unwrap() + ); } } false @@ -77,20 +81,20 @@ impl PluginManager { } self.plugins.clear(); } - } pub struct WrappedPlugin { - plugin: Box, _library: Library, meta: PluginMeta, - packet_handler: (Option>, Option>), - + packet_handler: ( + Option>, + Option>, + ), } +#[no_mangle] impl WrappedPlugin { - #[inline] pub fn name(&self) -> &'static str { self.plugin.get_name() @@ -101,6 +105,11 @@ impl WrappedPlugin { self.meta.version } + #[inline] + pub fn description(&self) -> &String { + &self.meta.description + } + #[inline] pub fn authors(&self) -> &Vec { &self.meta.authors @@ -111,39 +120,35 @@ impl WrappedPlugin { &self.meta.permissions } - /// handles an event, returns whether or not the result is `cancel` + /// Handles an event, returns whether or not the result is `cancel` #[inline] pub fn handle_event(&self, event: ClientEvent) -> bool { self.plugin.handle_event(event) } - } #[derive(Serialize, Deserialize, Default)] #[repr(C)] pub struct PluginMeta { - - version: u64, /// The plugin's version. + version: u64, + /// The plugin's version. + description: String, authors: Vec, permissions: Vec, // TODO: Implement this! - modified: bool, // what is this used for? - + modified: bool, // what is this used for? } - #[derive(Serialize, Deserialize)] #[repr(C)] pub enum PluginPermission { - File, Network, Device, // grants permission for devices and drivers All, - } +#[no_mangle] pub trait RawPacketHandler { - #[inline] fn incoming_priority(&self) -> i64 { 0 @@ -157,11 +162,10 @@ pub trait RawPacketHandler { } fn handle_outgoing(&self, packet: *mut Packet) -> bool; - } +#[no_mangle] pub trait MappedPacketHandler { - #[inline] fn incoming_priority(&self) -> i64 { 0 @@ -175,26 +179,22 @@ pub trait MappedPacketHandler { } fn handle_outgoing(&self, packet: *mut MappedPacket) -> bool; - } #[repr(C)] pub enum ClientEvent { - UserInput(InputEvent), Screen(ScreenEvent), - Entity, + Entity(EntityEvent), ChannelMessage, Inventory(InputEvent), World(WorldEvent), - Player, - + Player(PlayerEvent), } /// Events for local player updates #[repr(C)] pub enum PlayerEvent { - Exp, Health, Position, @@ -204,109 +204,141 @@ pub enum PlayerEvent { EntityInteract, HotBar, Food, - } #[repr(C)] pub enum InputEvent { - Mouse(MouseAction), - Keyboard(bool, ), // down, key board key(input) - + Keyboard(bool), // down, key board key(input) } #[repr(C)] pub enum WorldEvent { - Block, Weather, Time, - } #[repr(C)] pub enum InventoryEvent { - Open, Close, UpdateSlot, - } #[repr(C)] pub enum ScreenEvent { - Open, Close, - } #[repr(C)] pub enum EntityEvent { - Spawn, Despawn, Move, - UpdateArmor, - UpdateHandItem, - UpdateName, - + UpdateArmor, // TODO: Should this be combined with UpdateMetadata? + UpdateHandItem, // TODO: Should this be combined with UpdateMetadata? + UpdateName, // TODO: Should this be combined with UpdateMetadata? + UpdateMetadata, + UpdateHealth, // TODO: Should this be combined with UpdateMetadata? } #[repr(C)] pub enum MouseAction { - UpdateKey(bool, MouseKey), // down, mouse key(input) UseWheel(f64), - } #[repr(C)] pub enum MouseKey { - Left, Middle, // pressed mouse wheel Right, Other(i64), - } #[no_mangle] pub trait WorldAccess { - fn get_block(&self); fn set_block(&self); + fn is_chunk_loaded(&self, x: i32, z: i32); } #[no_mangle] pub trait ServerAccess { + // TODO: Combine protocol_version methods into one! + fn protocol_version_id(&self) -> i64; - fn protocol(&self) -> i64; - - fn mapped_version(&self) -> Version; + fn protocol_version(&self) -> Version; fn world(&self) -> Box; + fn is_connected(&self) -> bool; } #[no_mangle] pub trait ScreenSystemAccess { - fn pop_screen(&self); - fn push_screen(&self); - + fn push_screen(&self, screen_builder: ScreenBuilder); } +#[no_mangle] +pub trait ScreenAccess {} + #[repr(C)] pub struct ScreenBuilder { - name: String, - active: Option, &mut ui::Container)>, - de_active: Option, &mut ui::Container)>, + activate: Option, &mut ui::Container)>, + de_activate: Option, &mut ui::Container)>, init: Option, &mut ui::Container)>, de_init: Option, &mut ui::Container)>, +} + +#[no_mangle] +impl ScreenBuilder { + #[inline] + pub fn name(mut self, name: String) -> Self { + self.name = name; + self + } + + #[inline] + pub fn on_activate( + mut self, + on_activate: Option, &mut ui::Container)>, + ) -> Self { + self.activate = on_activate; + self + } -} \ No newline at end of file + #[inline] + pub fn on_de_activate( + mut self, + on_de_activate: Option, &mut ui::Container)>, + ) -> Self { + self.de_activate = on_de_activate; + self + } + + #[inline] + pub fn on_init( + mut self, + init: Option, &mut ui::Container)>, + ) -> Self { + self.init = init; + self + } + + #[inline] + pub fn on_de_init( + mut self, + de_init: Option, &mut ui::Container)>, + ) -> Self { + self.de_init = de_init; + self + } +} From fa49e04a73a2f722c868cc9449b80f6067d26b93 Mon Sep 17 00:00:00 2001 From: threadexception Date: Sat, 15 Jan 2022 23:43:02 +0100 Subject: [PATCH 5/5] Improve modding api --- modding/src/lib.rs | 36 ++++++++++++++++++++++-------------- protocol/src/protocol/mod.rs | 12 +++++++----- 2 files changed, 29 insertions(+), 19 deletions(-) diff --git a/modding/src/lib.rs b/modding/src/lib.rs index 6cc015b8..68aff61f 100644 --- a/modding/src/lib.rs +++ b/modding/src/lib.rs @@ -7,7 +7,7 @@ use std::sync::Arc; extern crate serde; use leafish_protocol::protocol::mapped_packet::MappedPacket; use leafish_protocol::protocol::packet::Packet; -use leafish_protocol::protocol::Version; +use leafish_protocol::protocol::{PacketType, Version}; use serde::{Deserialize, Serialize}; const CREATE_PLUGIN_FN_NAME: &[u8] = b"create_plugin"; @@ -130,8 +130,9 @@ impl WrappedPlugin { #[derive(Serialize, Deserialize, Default)] #[repr(C)] pub struct PluginMeta { + /// The plugin's version version: u64, - /// The plugin's version. + /// The plugin's description description: String, authors: Vec, permissions: Vec, // TODO: Implement this! @@ -277,25 +278,32 @@ pub trait ServerAccess { fn world(&self) -> Box; fn is_connected(&self) -> bool; + + fn write_packet(&self, packet: T); // FIXME: Should this be renamed to "send_packet"? } #[no_mangle] pub trait ScreenSystemAccess { - fn pop_screen(&self); + fn pop_screen(&self) -> Box; fn push_screen(&self, screen_builder: ScreenBuilder); + + fn current_screen(&self) -> Box<&dyn ScreenAccess>; } #[no_mangle] -pub trait ScreenAccess {} +pub trait ScreenAccess { + fn ty(&self) -> ScreenType; +} #[repr(C)] pub struct ScreenBuilder { name: String, + // FIXME: Why not use a single trait instead of all these closures? activate: Option, &mut ui::Container)>, - de_activate: Option, &mut ui::Container)>, + deactivate: Option, &mut ui::Container)>, init: Option, &mut ui::Container)>, - de_init: Option, &mut ui::Container)>, + deinit: Option, &mut ui::Container)>, } #[no_mangle] @@ -316,29 +324,29 @@ impl ScreenBuilder { } #[inline] - pub fn on_de_activate( + pub fn on_deactivate( mut self, - on_de_activate: Option, &mut ui::Container)>, + on_deactivate: Option, &mut ui::Container)>, ) -> Self { - self.de_activate = on_de_activate; + self.deactivate = on_deactivate; self } #[inline] pub fn on_init( mut self, - init: Option, &mut ui::Container)>, + on_init: Option, &mut ui::Container)>, ) -> Self { - self.init = init; + self.init = on_init; self } #[inline] - pub fn on_de_init( + pub fn on_deinit( mut self, - de_init: Option, &mut ui::Container)>, + on_deinit: Option, &mut ui::Container)>, ) -> Self { - self.de_init = de_init; + self.deinit = on_deinit; self } } diff --git a/protocol/src/protocol/mod.rs b/protocol/src/protocol/mod.rs index ffa0dd14..9e393dc2 100644 --- a/protocol/src/protocol/mod.rs +++ b/protocol/src/protocol/mod.rs @@ -59,6 +59,7 @@ static CURRENT_PROTOCOL_VERSION: AtomicI32 = AtomicI32::new(SUPPORTED_PROTOCOLS[ static NETWORK_DEBUG: AtomicBool = AtomicBool::new(false); /// A list of all supported versions +#[repr(C)] #[derive(PartialOrd, PartialEq, Debug, Copy, Clone)] pub enum Version { Other, @@ -1665,8 +1666,8 @@ pub struct StatusPlayer { impl Read for Conn { fn read(&mut self, buf: &mut [u8]) -> io::Result { match self.read_cipher.clone().write().unwrap().as_mut() { - Option::None => self.stream.read(buf), - Option::Some(cipher) => { + None => self.stream.read(buf), + Some(cipher) => { let ret = self.stream.read(buf)?; cipher.decrypt(&mut buf[..ret]); @@ -1679,8 +1680,8 @@ impl Read for Conn { impl Write for Conn { fn write(&mut self, buf: &[u8]) -> io::Result { match self.write_cipher.clone().write().unwrap().as_mut() { - Option::None => self.stream.write(buf), - Option::Some(cipher) => { + None => self.stream.write(buf), + Some(cipher) => { let mut data = vec![0; buf.len()]; data[..buf.len()].clone_from_slice(&buf[..]); @@ -1699,7 +1700,7 @@ impl Write for Conn { impl Clone for Conn { fn clone(&self) -> Self { - Conn { + Self { stream: self.stream.try_clone().unwrap(), host: self.host.clone(), port: self.port, @@ -1714,6 +1715,7 @@ impl Clone for Conn { } } +#[no_mangle] pub trait PacketType { fn packet_id(&self, protocol_version: i32) -> i32;