mirror of
https://github.com/element-hq/synapse.git
synced 2026-04-17 09:55:43 +00:00
# What is done? - resolves #19403 - Adds build-time Rust compiler detection and captures the rustc --version value during the build. - Exposes the captured compiler version from the Rust extension via a new Python-callable function. - Exports a new Prometheus metric for rustc version. # How to test? - compile `poetry install` - add `enable_metrics: true` and ```yaml resources: - compress: false names: - client - federation - metrics ``` to homeserver.yaml - start synapse - find the rustc version at `http://localhost:8008/_synapse/metrics` ### Pull Request Checklist <!-- Please read https://element-hq.github.io/synapse/latest/development/contributing_guide.html before submitting your pull request --> * [x] Pull request is based on the develop branch * [x] Pull request includes a [changelog file](https://element-hq.github.io/synapse/latest/development/contributing_guide.html#changelog). The entry should: - Be a short description of your change which makes sense to users. "Fixed a bug that prevented receiving messages from other servers." instead of "Moved X method from `EventStore` to `EventWorkerStore`.". - Use markdown where necessary, mostly for `code blocks`. - End with either a period (.) or an exclamation mark (!). - Start with a capital letter. - Feel free to credit yourself, by adding a sentence "Contributed by @github_username." or "Contributed by [Your Name]." to the end of the entry. * [x] [Code style](https://element-hq.github.io/synapse/latest/code_style.html) is correct (run the [linters](https://element-hq.github.io/synapse/latest/development/contributing_guide.html#run-the-linters)) --------- Co-authored-by: Quentin Gliech <quenting@element.io>
66 lines
2.1 KiB
Rust
66 lines
2.1 KiB
Rust
//! This build script calculates the hash of all files in the `src/`
|
|
//! directory and adds it as an environment variable during build time.
|
|
//!
|
|
//! This is used so that the python code can detect when the built native module
|
|
//! does not match the source in-tree, helping to detect the case where the
|
|
//! source has been updated but the library hasn't been rebuilt.
|
|
|
|
use std::path::PathBuf;
|
|
|
|
use blake2::{Blake2b512, Digest};
|
|
use rustc_version::version_meta;
|
|
|
|
fn main() -> Result<(), std::io::Error> {
|
|
let mut dirs = vec![PathBuf::from("src")];
|
|
|
|
let mut paths = Vec::new();
|
|
while let Some(path) = dirs.pop() {
|
|
let mut entries = std::fs::read_dir(path)?
|
|
.map(|res| res.map(|e| e.path()))
|
|
.collect::<Result<Vec<_>, std::io::Error>>()?;
|
|
|
|
entries.sort();
|
|
|
|
for entry in entries {
|
|
if entry.is_dir() {
|
|
dirs.push(entry);
|
|
} else {
|
|
paths.push(entry.to_str().expect("valid rust paths").to_string());
|
|
}
|
|
}
|
|
}
|
|
|
|
// Manually add Cargo.toml's, Cargo.lock and build.rs to the hash, since changes to
|
|
// these files should also invalidate the built module.
|
|
paths.push("Cargo.toml".to_string());
|
|
paths.push("../Cargo.lock".to_string());
|
|
paths.push("../Cargo.toml".to_string());
|
|
paths.push("build.rs".to_string());
|
|
|
|
paths.sort();
|
|
|
|
let mut hasher = Blake2b512::new();
|
|
|
|
for path in paths {
|
|
let bytes = std::fs::read(path)?;
|
|
hasher.update(bytes);
|
|
}
|
|
|
|
let hex_digest = hex::encode(hasher.finalize());
|
|
println!("cargo:rustc-env=SYNAPSE_RUST_DIGEST={hex_digest}");
|
|
|
|
let rustc_version = version_meta()
|
|
.map(|v| v.short_version_string)
|
|
.unwrap_or_else(|_| "unknown".to_string());
|
|
println!("cargo:rustc-env=SYNAPSE_RUSTC_VERSION={}", rustc_version,);
|
|
|
|
// The default rules don't pick up trivial changes to the workspace config
|
|
// files, but we need to rebuild if those change to pick up the changed
|
|
// hashes.
|
|
println!("cargo::rerun-if-changed=.");
|
|
println!("cargo::rerun-if-changed=../Cargo.lock");
|
|
println!("cargo::rerun-if-changed=../Cargo.toml");
|
|
|
|
Ok(())
|
|
}
|