mirror of
https://gitlab.com/veilid/veilid.git
synced 2025-01-13 00:09:47 -05:00
Merge branch 'main' into 'main'
updated capnp version 0.18 --> 0.19 See merge request veilid/veilid!279
This commit is contained in:
commit
2bfb6c635c
12
Cargo.lock
generated
12
Cargo.lock
generated
@ -823,18 +823,18 @@ checksum = "514de17de45fdb8dc022b1a7975556c53c86f9f0aa5f534b98977b171857c2c9"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "capnp"
|
name = "capnp"
|
||||||
version = "0.18.13"
|
version = "0.19.5"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "384b671a5b39eadb909b0c2b81d22a400d446526e651e64be9eb6674b33644a4"
|
checksum = "3aed85272154b3c0bfda873c40395f13adcfbc89696bf639a512291077f8cd17"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"embedded-io",
|
"embedded-io",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "capnpc"
|
name = "capnpc"
|
||||||
version = "0.18.1"
|
version = "0.19.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "a642faaaa78187e70bdcc0014c593c213553cfeda3b15054426d0d596048b131"
|
checksum = "c75ba30e0f08582d53c2f3710cf4bb65ff562614b1ba86906d7391adffe189ec"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"capnp",
|
"capnp",
|
||||||
]
|
]
|
||||||
@ -1697,9 +1697,9 @@ checksum = "a47c1c47d2f5964e29c61246e81db715514cd532db6b5116a25ea3c03d6780a2"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "embedded-io"
|
name = "embedded-io"
|
||||||
version = "0.5.0"
|
version = "0.6.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "658bbadc628dc286b9ae02f0cb0f5411c056eb7487b72f0083203f115de94060"
|
checksum = "edd0f118536f44f5ccd48bcb8b111bdc3de888b58c74639dfb034a357d0f206d"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "encode_unicode"
|
name = "encode_unicode"
|
||||||
|
@ -124,7 +124,7 @@ async-std-resolver = { version = "0.24.0", optional = true }
|
|||||||
hickory-resolver = { version = "0.24.0", optional = true }
|
hickory-resolver = { version = "0.24.0", optional = true }
|
||||||
|
|
||||||
# Serialization
|
# Serialization
|
||||||
capnp = { version = "0.18.10", default-features = false, features = ["alloc"] }
|
capnp = { version = "0.19.5", default-features = false, features = ["alloc"] }
|
||||||
serde = { version = "1.0.193", features = ["derive", "rc"] }
|
serde = { version = "1.0.193", features = ["derive", "rc"] }
|
||||||
serde_json = { version = "1.0.108" }
|
serde_json = { version = "1.0.108" }
|
||||||
serde-big-array = "0.5.1"
|
serde-big-array = "0.5.1"
|
||||||
@ -269,7 +269,7 @@ wasm-logger = "0.2.0"
|
|||||||
### BUILD OPTIONS
|
### BUILD OPTIONS
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
capnpc = "0.18.0"
|
capnpc = "0.19.0"
|
||||||
glob = "0.3.1"
|
glob = "0.3.1"
|
||||||
filetime = "0.2.23"
|
filetime = "0.2.23"
|
||||||
sha2 = "0.10.8"
|
sha2 = "0.10.8"
|
||||||
|
@ -8,7 +8,7 @@ use std::{
|
|||||||
process::{Command, Stdio},
|
process::{Command, Stdio},
|
||||||
};
|
};
|
||||||
|
|
||||||
const CAPNP_VERSION: &str = "1.0.1";
|
const CAPNP_VERSION: &str = "1.0.2";
|
||||||
|
|
||||||
fn get_desired_capnp_version_string() -> String {
|
fn get_desired_capnp_version_string() -> String {
|
||||||
CAPNP_VERSION.to_string()
|
CAPNP_VERSION.to_string()
|
||||||
@ -36,14 +36,30 @@ where
|
|||||||
P: AsRef<Path>,
|
P: AsRef<Path>,
|
||||||
Q: AsRef<Path>,
|
Q: AsRef<Path>,
|
||||||
{
|
{
|
||||||
let Some(out_bh) = get_build_hash(output) else {
|
let (Some(out_bh), Some(out_capnp_hash)) = get_build_hash_and_capnp_version_hash(output) else {
|
||||||
// output file not found or no build hash, we are outdated
|
// output file not found or no build hash, we are outdated
|
||||||
|
println!("cargo:warning=Output file not found or no build hash.");
|
||||||
return Ok(true);
|
return Ok(true);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Check if desired CAPNP_VERSION hash has changed
|
||||||
|
let mut hasher = Sha256::new();
|
||||||
|
hasher.update(get_desired_capnp_version_string().as_bytes());
|
||||||
|
let capnp_hash = hasher.finalize().to_vec();
|
||||||
|
|
||||||
let in_bh = make_build_hash(input);
|
let in_bh = make_build_hash(input);
|
||||||
|
|
||||||
Ok(out_bh != in_bh)
|
if out_bh != in_bh {
|
||||||
|
println!("cargo:warning=Build hash has changed.");
|
||||||
|
return Ok(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
if out_capnp_hash != capnp_hash {
|
||||||
|
println!("cargo:warning=Capnp desired version hash has changed.");
|
||||||
|
return Ok(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn calculate_hash(lines: std::io::Lines<std::io::BufReader<std::fs::File>>) -> Vec<u8> {
|
fn calculate_hash(lines: std::io::Lines<std::io::BufReader<std::fs::File>>) -> Vec<u8> {
|
||||||
@ -58,15 +74,27 @@ fn calculate_hash(lines: std::io::Lines<std::io::BufReader<std::fs::File>>) -> V
|
|||||||
out.to_vec()
|
out.to_vec()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_build_hash<Q: AsRef<Path>>(output_path: Q) -> Option<Vec<u8>> {
|
fn get_build_hash_and_capnp_version_hash<Q: AsRef<Path>>(
|
||||||
let lines = std::io::BufReader::new(std::fs::File::open(output_path).ok()?).lines();
|
output_path: Q,
|
||||||
|
) -> (Option<Vec<u8>>, Option<Vec<u8>>) {
|
||||||
|
let output_file = match std::fs::File::open(output_path).ok() {
|
||||||
|
// Returns a file handle if the file exists
|
||||||
|
Some(f) => f,
|
||||||
|
// Returns None, None if the file does not exist
|
||||||
|
None => return (None, None),
|
||||||
|
};
|
||||||
|
let lines = std::io::BufReader::new(output_file).lines();
|
||||||
|
let mut build_hash = None;
|
||||||
|
let mut capnp_version_hash = None;
|
||||||
for l in lines {
|
for l in lines {
|
||||||
let l = l.unwrap();
|
let l = l.unwrap();
|
||||||
if let Some(rest) = l.strip_prefix("//BUILDHASH:") {
|
if let Some(rest) = l.strip_prefix("//BUILDHASH:") {
|
||||||
return Some(hex::decode(rest).unwrap());
|
build_hash = Some(hex::decode(rest).unwrap());
|
||||||
|
} else if let Some(rest) = l.strip_prefix("//CAPNPDESIREDVERSIONHASH:") {
|
||||||
|
capnp_version_hash = Some(hex::decode(rest).unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None
|
(build_hash, capnp_version_hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn make_build_hash<P: AsRef<Path>>(input_path: P) -> Vec<u8> {
|
fn make_build_hash<P: AsRef<Path>>(input_path: P) -> Vec<u8> {
|
||||||
@ -75,13 +103,26 @@ fn make_build_hash<P: AsRef<Path>>(input_path: P) -> Vec<u8> {
|
|||||||
calculate_hash(lines)
|
calculate_hash(lines)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn append_hash<P: AsRef<Path>, Q: AsRef<Path>>(input_path: P, output_path: Q) {
|
fn append_hash_and_desired_capnp_version_hash<P: AsRef<Path>, Q: AsRef<Path>>(
|
||||||
|
input_path: P,
|
||||||
|
output_path: Q,
|
||||||
|
) {
|
||||||
let input_path = input_path.as_ref();
|
let input_path = input_path.as_ref();
|
||||||
let output_path = output_path.as_ref();
|
let output_path = output_path.as_ref();
|
||||||
let lines = std::io::BufReader::new(std::fs::File::open(input_path).unwrap()).lines();
|
let lines = std::io::BufReader::new(std::fs::File::open(input_path).unwrap()).lines();
|
||||||
let h = calculate_hash(lines);
|
let h = calculate_hash(lines);
|
||||||
|
|
||||||
let mut out_file = OpenOptions::new().append(true).open(output_path).unwrap();
|
let mut out_file = OpenOptions::new().append(true).open(output_path).unwrap();
|
||||||
writeln!(out_file, "\n//BUILDHASH:{}", hex::encode(h)).unwrap();
|
writeln!(out_file, "\n//BUILDHASH:{}", hex::encode(h)).unwrap();
|
||||||
|
|
||||||
|
let mut hasher = Sha256::new();
|
||||||
|
hasher.update(get_desired_capnp_version_string().as_bytes());
|
||||||
|
writeln!(
|
||||||
|
out_file,
|
||||||
|
"\n//CAPNPDESIREDVERSIONHASH:{}",
|
||||||
|
hex::encode(hasher.finalize())
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn do_capnp_build() {
|
fn do_capnp_build() {
|
||||||
@ -122,7 +163,8 @@ fn do_capnp_build() {
|
|||||||
.expect("compiling schema");
|
.expect("compiling schema");
|
||||||
|
|
||||||
// If successful, append a hash of the input to the output file
|
// If successful, append a hash of the input to the output file
|
||||||
append_hash("proto/veilid.capnp", "proto/veilid_capnp.rs");
|
// Also append a hash of the desired capnp version to the output file
|
||||||
|
append_hash_and_desired_capnp_version_hash("proto/veilid.capnp", "proto/veilid_capnp.rs");
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user