Crates.io | symsrv |
lib.rs | symsrv |
version | 0.5.3 |
source | src |
created_at | 2022-05-17 13:23:36.485642 |
updated_at | 2024-07-30 15:55:12.776161 |
description | A Microsoft symsrv symbol server consumer (downloader + cache) |
homepage | |
repository | https://github.com/mstange/symsrv/ |
max_upload_size | |
id | 588324 |
size | 166,022 |
This crate lets you download and cache symbol files from symbol servers,
according to the rules from the _NT_SYMBOL_PATH
environment variable.
It exposes an async API. Internally it uses reqwest
and tokio
.
The downloaded symbols are stored on the file system. No automatic expiration
or eviction is performed. If you want to enforce a cache size limit or expire
old files, you can observe cache file creations and accesses with the
[SymsrvObserver
] trait, and then write your own implementation for automatic
file cleanup.
use symsrv::SymsrvDownloader;
// Parse the _NT_SYMBOL_PATH environment variable.
let symbol_path_env = symsrv::get_symbol_path_from_environment();
let symbol_path =
symbol_path_env.as_deref().unwrap_or("srv**https://msdl.microsoft.com/download/symbols");
let parsed_symbol_path = symsrv::parse_nt_symbol_path(symbol_path);
// Create a downloader which follows the _NT_SYMBOL_PATH recipe.
let mut downloader = SymsrvDownloader::new(parsed_symbol_path);
downloader.set_default_downstream_store(symsrv::get_home_sym_dir());
// Download and cache a PDB file.
let local_path = downloader.get_file("dcomp.pdb", "648B8DD0780A4E22FA7FA89B84633C231").await?;
// Use the PDB file.
open_pdb_at_path(&local_path);
symfetch
This repository also contains a small example program called symfetch
.
You can install it as follows:
cargo install --examples symsrv
Run it with symfetch <filename> <hash>
- see symfetch --help
for details.
Licensed under either of
LICENSE-APACHE
or http://www.apache.org/licenses/LICENSE-2.0)LICENSE-MIT
or http://opensource.org/licenses/MIT)at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.