Dazzlesum is a handy checksum tool designed for data integrity verification across different machines and operating systems. It generates folder-specific checksum files (.shasum) that enable verification of file collections, with special attention to DOS shell compatibility and cross-platform consistency.
- Multiple Hash Algorithms: SHA256 (default), SHA512, SHA1, MD5 with consistent cross-platform behavior
- Cross-Platform Support: Seamlessly handle checksums between Windows, macOS, Linux, and BSD
- DOS Compatibility: ASCII-only output that works perfectly in Windows Command Prompt
- Native Tool Integration: Uses system tools (certutil, shasum, fsum) with intelligent Python fallback
- Flexible Generation Modes: Individual
.shasumfiles per directory, monolithic files, or both simultaneously - Advanced Verification: Problems-only output shows only failed, missing, or extra files by default
- Management Operations: Backup, remove, restore, and list
.shasumfiles with comprehensive metadata - Enhanced Logging: 11-level verbosity system (-6 to +4) with granular output control and smart filtering
- Advanced Exit Codes: 7 different exit codes based on aggregate verification results for precise automation
- Squelch System: Filter specific message types (SUCCESS, NO_SHASUM) for customized output
- Context-Aware Operations: Auto-detects whether to create or verify based on directory contents
- Shadow Directory Support: Keep source directories clean by storing checksum files in parallel shadow structure
Maintain consistent checksum verification across different operating systems. Generate checksums on your Windows machine and verify them on your Linux environment without losing any data integrity checks.
Simplify management of complex directory structures and checksum file collections. Document and reproduce checksum configurations for backup or disaster recovery scenarios.
Create organizational structures using checksum verification, then export and share these verification systems with others. Perfect for media libraries (similar to SFVs), project references, or any scenario where data integrity needs to be maintained across multiple locations.
Automatically handle different representations of network paths across systems while maintaining all checksum metadata and verification capabilities.
- Python 3.7 or higher
- Operating System: Windows, macOS, Linux, BSD
- Dependencies: None (pure Python standard library)
- Optional:
unctoolspackage for enhanced Windows UNC path support
pip install dazzlesumgit clone https://github.com/djdarcy/dazzlesum.git
cd dazzlesum
pip install -e .On Windows:
pip install -e ".[windows]"Other potential dependencies down the line:
pip install -e ".[dev,test,docs]"# Generate checksums for current directory
dazzlesum create
# Generate checksums recursively
dazzlesum create -r
# Create monolithic checksum file
dazzlesum create -r --mode monolithic
# Generate with verbose output (11 levels available: -6 to +4)
dazzlesum create -r -vv
# Silent mode for automation
dazzlesum verify -r -qqqqqq
# Problems-only with custom squelch filters
dazzlesum verify -r --squelch=SUCCESS,NO_SHASUM
# Keep source directories clean with shadow directory
dazzlesum create -r --shadow-dir ./checksums
# Generate monolithic checksum in shadow directory
dazzlesum create -r --mode monolithic --shadow-dir ./checksums# Verify existing checksums
dazzlesum verify -r
# Verify with detailed output
dazzlesum verify -r -v
# Show all verification results
dazzlesum verify -r --show-all-verifications
# Verify checksums stored in shadow directory
dazzlesum verify -r --shadow-dir ./checksums# Update existing checksums for changed files
dazzlesum update -r
# Update only specific file types
dazzlesum update -r --include "*.txt,*.doc"# Backup all .shasum files
dazzlesum manage -r backup --backup-dir ./checksum-backup
# List all .shasum files with details
dazzlesum manage -r list
# Remove all .shasum files (with confirmation)
dazzlesum manage -r remove
# Restore from backup
dazzlesum manage -r restore --backup-dir ./checksum-backup# General help
dazzlesum --help
# Help for specific commands
dazzlesum create --help
dazzlesum verify --help
# Detailed help topics
dazzlesum mode # Help for --mode parameter
dazzlesum examples # Comprehensive usage examples
dazzlesum shadow # Shadow directory help- Installation Guide - Detailed installation instructions for all platforms
- Usage Examples - Practical examples for common use cases
- Shadow Directory Guide - Complete guide to shadow directory operations
- Command Reference - Complete command-line reference
- File Formats - Details about
.shasumfile formats and compatibility
- Command Prompt: Full ASCII compatibility
- PowerShell: Native support
- Tools: Uses
certutilorfsumwhen available - Paths: Handles UNC paths with optional
unctoolspackage
- Terminal: Full compatibility
- Tools: Uses
shasumwhen available - Paths: Native Unix path handling
- Performance: Optimized for large file trees
- Path Normalization: Automatic path separator handling
- Line Ending Support: Configurable line ending strategies
- Symlink Safety: Intelligent symlink and junction detection
- Encoding: UTF-8 with fallback handling
- Python: 3.7 or higher
- Operating System: Windows, macOS, Linux, BSD
- Dependencies: None (pure Python standard library)
- Optional:
unctoolspackage for enhanced Windows UNC path support
- Incremental Updates: Smart update detection
- Compression: Archive support for checksum collections
- Remote Storage: Cloud backup integration? (maybe)
Contributions are welcome! Issues, suggestions, and bug reports are all appreciated. Please open an issue if you find something that can be improved. Or:
- Fork this repository and clone a fork.
- Make changes on a new branch (e.g.,
feature/new_thing). - Submit a pull request describing your changes.
Please see CONTRIBUTING.md for detailed guidelines.
Like the project?
This project is licensed under the GPL-3.0 License - see the LICENSE file for details.
See CHANGELOG.md for version history and release notes.
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Documentation: Check the docs/ folder for additional guides
Made with ️☕. Designed for reliable, consistent data integrity verification across all platforms.
