vulkan-utils

Vulkan Utils

Python 3.10+ License

A simple yet powerful command-line utility for managing Vulkan SDK operations. This tool simplifies downloading, installing, and managing Vulkan SDK versions across different platforms.

๐Ÿ“– View Full Documentation

๐Ÿš€ Features

๐Ÿ“ฆ Installation

Using uvx (One-time execution)

Run vulkan_utils directly without installing it globally:

# Run commands directly with uvx
uvx vulkan-utils install-sdk
uvx vulkan-utils latest-version
uvx vulkan-utils sdk-info

Using uv (Project installation)

uv add vulkan_utils

Using pip

pip install vulkan_utils

Development Installation

# Clone the repository
git clone https://github.com/msemelman/vulkan-utils.git vulkan_utils
cd vulkan_utils

# Get dependencies
uv sync

# install in current env
uv pip install -e . # make sure venv is not active

# install globally
pip install -e .

๐Ÿ› ๏ธ Usage

After installation, the vulkan-utils command will be available in your terminal. Alternatively, you can run commands directly with uvx vulkan-utils without installing.

Basic Commands

# Show help
vulkan-utils --help
# or with uvx
uvx vulkan-utils --help

# Show version
vulkan-utils --version
# or with uvx
uvx vulkan-utils --version

Installing Vulkan SDK

# Download and install the latest Vulkan SDK for your platform
vulkan-utils install-sdk

# or run directly with uvx (no installation required)
uvx vulkan-utils install-sdk

Advanced Usage

# Install a specific version
vulkan-utils install-sdk --version 1.3.224.0
# or with uvx
uvx vulkan-utils install-sdk --version 1.3.224.0

# Install for a specific platform
vulkan-utils install-sdk --platform linux

# Install to a custom directory
vulkan-utils install-sdk --install-path /opt/VulkanSDK

# Download only (don't install)
vulkan-utils install-sdk --download-only --install-path ./downloads

Getting Version Information

# Get the latest available version for your platform
vulkan-utils latest-version
# or with uvx
uvx vulkan-utils latest-version

# Get latest version for a specific platform
vulkan-utils latest-version --platform windows

# Get detailed SDK information
vulkan-utils sdk-info
# or with uvx
uvx vulkan-utils sdk-info

# Get info for a specific version
vulkan-utils sdk-info --version 1.3.224.0 --platform mac

๐Ÿ”ง Command Reference

install-sdk

Downloads and installs the Vulkan SDK.

Options:

Examples:

# Basic installation
vulkan-utils install-sdk
# or with uvx
uvx vulkan-utils install-sdk

# Specific version for Linux
vulkan-utils install-sdk --version 1.3.224.0 --platform linux
# or with uvx
uvx vulkan-utils install-sdk --version 1.3.224.0 --platform linux

# Download to custom location without installing
vulkan-utils install-sdk --download-only --install-path ./my-downloads

latest-version

Get the latest available Vulkan SDK version.

Options:

Examples:

vulkan-utils latest-version
# or with uvx
uvx vulkan-utils latest-version

vulkan-utils latest-version --platform windows

sdk-info

Get detailed information about a Vulkan SDK version.

Options:

Examples:

vulkan-utils sdk-info
# or with uvx
uvx vulkan-utils sdk-info

vulkan-utils sdk-info --version 1.3.224.0

๐Ÿ–ฅ๏ธ Platform-Specific Notes

macOS

After installation, you may need to set environment variables if system-wide installation fails:

export VULKAN_SDK=~/VulkanSDK
export PATH=$VULKAN_SDK/bin:$PATH
export DYLD_LIBRARY_PATH=$VULKAN_SDK/lib:$DYLD_LIBRARY_PATH
export VK_LAYER_PATH=$VULKAN_SDK/share/vulkan/explicit_layer.d

Add these to your ~/.zshrc or ~/.bash_profile for persistence.

Linux

Set the following environment variables:

export VULKAN_SDK=~/VulkanSDK
export PATH=$VULKAN_SDK/bin:$PATH
export LD_LIBRARY_PATH=$VULKAN_SDK/lib:$LD_LIBRARY_PATH
export VK_LAYER_PATH=$VULKAN_SDK/share/vulkan/explicit_layer.d

Windows

Windows installations should work system-wide automatically. No additional configuration typically required.

๐Ÿ” Examples

Complete Workflow Example

# Check latest available version
vulkan-utils latest-version
# or with uvx
uvx vulkan-utils latest-version
# Output: Latest Vulkan SDK version for mac: 1.3.250.1

# Get detailed information about the latest SDK
vulkan-utils sdk-info
# or with uvx
uvx vulkan-utils sdk-info
# Output: 
# SDK Version: 1.3.250.1
# Platform: mac
# Filename: vulkan_sdk.zip
# Download URL: https://sdk.lunarg.com/sdk/download/latest/mac/vulkan_sdk.zip?Human=true
# SHA Hash: abc123...

# Download and install
vulkan-utils install-sdk
# or with uvx
uvx vulkan-utils install-sdk
# Downloads, extracts, and installs with progress indicators and platform-specific instructions

Download for Offline Installation

# Download multiple versions for different platforms
vulkan-utils install-sdk --version 1.3.250.1 --platform linux --download-only --install-path ./offline-sdks
vulkan-utils install-sdk --version 1.3.250.1 --platform windows --download-only --install-path ./offline-sdks
vulkan-utils install-sdk --version 1.3.250.1 --platform mac --download-only --install-path ./offline-sdks

# or with uvx (useful for CI/CD or one-time usage)
uvx vulkan-utils install-sdk --version 1.3.250.1 --platform linux --download-only --install-path ./offline-sdks
uvx vulkan-utils install-sdk --version 1.3.250.1 --platform windows --download-only --install-path ./offline-sdks
uvx vulkan-utils install-sdk --version 1.3.250.1 --platform mac --download-only --install-path ./offline-sdks

๐Ÿงช Development

Setting Up Development Environment

# Clone the repository
git clone https://github.com/msemelman/vulkan-utils.git vulkan_utils
cd vulkan_utils

# Install dependencies with uv
uv sync

# Run in development mode
uv run vulkan-utils --help

Running Tests

# Install development dependencies
uv sync --dev

# Run tests
uv run pytest

Code Style

This project follows Python best practices:

๐Ÿค Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

Development Guidelines

  1. Follow the existing code style and conventions
  2. Add type hints to all function parameters and return values
  3. Write comprehensive docstrings using NumPy format
  4. Use Pydantic models for data structures
  5. Write tests for new functionality using pytest
  6. Update documentation as needed

๐Ÿ“ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ†˜ Support

If you encounter any issues or have questions:

  1. Check the Issues page
  2. Create a new issue with detailed information about your problem
  3. Include your platform, Python version, and error messages

Note: This tool is not affiliated with the Khronos Group or LunarG. Itโ€™s a community tool designed to simplify Vulkan SDK management.