symsrv 0.5.2

A Microsoft symsrv symbol server consumer (downloader + cache)
Documentation
[![crates.io page](https://img.shields.io/crates/v/symsrv.svg)](https://crates.io/crates/symsrv)
[![docs.rs page](https://docs.rs/symsrv/badge.svg)](https://docs.rs/symsrv/)

# symsrv

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.

## Microsoft Documentation

 - [Advanced SymSrv Use]https://docs.microsoft.com/en-us/windows-hardware/drivers/debugger/advanced-symsrv-use

## Example

```rust
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);
```

## Command line tool `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.

## License

Licensed under either of

  * Apache License, Version 2.0 ([`LICENSE-APACHE`]./LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
  * MIT license ([`LICENSE-MIT`]./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.