Skip to main content

publish PDB and PE files to symbols store

Project description

A python module and command line utility for publishing windows debugging symbols to symbols store. The symbols published in this format can be consumed by the common development tools for windows, such as Visual Studio and WinDbg. See Using SymStore for more information on windows symbols store.

Currently it is possible to publish PDB and PE (exe and dll) files to a local file system.

Installing

Install with pip utility by running:

$ pip install symstore

This will install the command line utility symstore as well as python module symstore.

It is also possible to install symstore package from source code. For example, clone symstore’s git repository with:

$ git clone <repo-url> symstore

and install it with pip:

$ pip install symstore/

Using

command line

Use the symstore command to publish the symbols. Run symstore --help for details.

Python module

To publish symbols programmatically use the symstore module. See symstore/command_line.py for an example on how to use the API.

Compression

The symstore package supports compressing the data files when publishing them. This can lead to significant reduction of data that needs to be transferred while accessing symbols.

The compression mode is activated with --compress or -z flag to symstore command line utility.

Symstore uses the native gcab library via introspection to compress data. The required packages must be available on the system for the compression mode to work.

On ubuntu 18.04, install following packages:

  • gir1.2-gcab-1.0

  • python-gi

On ubuntu 16.04, install following packages:

  • gir1.2-libgcab-1.0

  • python-gi

In case symstore is not able to locate python-gi and gir packages while compression mode is requested, following error message will be displayed:

gcab module not available, compression not supported

Change Log

0.2.6 (29 August 2019)

  • don’t leak open file handles during operation (issue #10)

0.2.5 (16 December 2018)

  • officially support python 3.7

  • fixed write errors to history.txt on windows/python2.7

0.2.4 (31 January 2018)

  • improved error handling on missing GCab python binding

0.2.3 (24 June 2017)

  • support publishing PDBs with longer root stream (even larger files)

  • officially support python 3.6

0.2.2 (16 January 2017)

  • support republishing same file in a new transaction

  • print nice error message on unexpected file extensions

  • more details in the docs on how to setup gcab to enable compression

0.2.1 (29 September 2016)

  • generate correct signature for PDBs with age larger then 10

  • support publishing PDBs with multi-page root stream (larger files)

  • fetch PDB age from DBI stream

  • support publishing PDBs without DBI stream

0.2.0 (22 March 2016)

  • added compression support

0.1.1 (10 February 2016)

  • dropped dependency to pdbparse and construct modules

  • added support for python 3

0.1.0 (14 January 2016)

  • dropped dependency to pefile module

  • print nice error message on currupt PE files

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

symstore-0.2.6.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

symstore-0.2.6-py2.py3-none-any.whl (12.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file symstore-0.2.6.tar.gz.

File metadata

  • Download URL: symstore-0.2.6.tar.gz
  • Upload date:
  • Size: 10.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.6.7

File hashes

Hashes for symstore-0.2.6.tar.gz
Algorithm Hash digest
SHA256 f49ac8031b7572b5f3bcac3a8296d498fcd2a410225b3886f1c6b90b21c5bbf0
MD5 bdd1424a5f11dfa5c9d3d4fa9894db96
BLAKE2b-256 6f6576a2016ba3fc3e834fe2b0ee33c25bc86e9aae4e1cbe862dbefcb4aa0a86

See more details on using hashes here.

File details

Details for the file symstore-0.2.6-py2.py3-none-any.whl.

File metadata

  • Download URL: symstore-0.2.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 12.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.6.7

File hashes

Hashes for symstore-0.2.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e96fba9f0c43678e88bbfcbebd58f5354dc89bc7fd2e42ea18807bf484a0a30c
MD5 c9db3549400b4d0ecef686fe35013051
BLAKE2b-256 0a132addd4add0156a3e819b20b6e980900a305491035de0527f23bc9ba3290a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page