Skip to main content

Python bindings for Cymbal code indexing and symbol discovery

Project description

py-cymbal: Python Bindings for Cymbal

Python bindings for the Cymbal code indexing and symbol discovery tool, wrapping the standalone binaries via a clean Python API.

Overview

Cymbal is a Go-based tool that uses tree-sitter for multi-language AST parsing and SQLite for indexed storage, providing fast symbol search, cross-references, impact analysis, and scoped diffs. These Python bindings allow Python developers to programmatically access Cymbal's powerful code analysis capabilities.

Features

  • Repository Indexing: Index code repositories for fast symbol lookup
  • Symbol Search: Search for functions, classes, variables, and other symbols
  • Symbol Investigation: Get detailed information about specific symbols including definitions and references
  • Reference Finding: Find all references to a particular symbol
  • Multi-language Support: Works with all languages supported by Cymbal (via tree-sitter)
  • Clean Python API: Pythonic interface with context managers and convenience functions

Installation

Prerequisites

  1. Bash/Curl/Unzip: Used by the build script to download binaries.
  2. Cymbal: The Go library being wrapped

Building from Source

# Clone the repository
git clone <repository-url>
cd py-cymbal

# Download the Cymbal binaries and create the Python package
./build.sh

# Install in development mode
pip install -e .

Build Script

The build.sh script automates the entire build process:

  1. Downloads the appropriate pre-compiled Cymbal binaries for Linux, macOS, and Windows.
  2. Places the binaries in the python/cymbal/bin/ directory.
  3. Creates a setup.py for pip installation that bundles the correct binary for your platform.

Usage

Basic Example

import cymbal

# Create a Cymbal instance
with cymbal.Cymbal() as c:
    # Index a repository
    stats = c.index("/path/to/your/repository")
    print(f"Indexing result: {stats}")
    
    # Search for symbols
    results = c.search("handleAuth", limit=10)
    for symbol in results:
        print(f"{symbol['name']} ({symbol['kind']}) at {symbol['file']}:{symbol['start_line']}")
    
    # Investigate a specific symbol
    investigation = c.investigate("UserModel")
    print(f"Symbol: {investigation['symbol']['name']}")
    print(f"References: {len(investigation['refs'])}")
    
    # Find references to a symbol
    references = c.find_references("DatabaseConnection", limit=20)
    for ref in references:
        print(f"Reference at {ref['file']}:{ref['line']}")

Convenience Functions

import cymbal

# Index a repository (one-liner)
stats = cymbal.index_repository("/path/to/repo")

# Search with existing database path
results = cymbal.search_symbols("config", limit=15, db_path="/path/to/index.db")

# Investigate a symbol
investigation = cymbal.investigate_symbol("ApiClient", db_path="/path/to/index.db")

Advanced Usage

import cymbal

# Reuse an existing index
try:
    c = cymbal.Cymbal()
    c.db_path = "/path/to/existing/index.db"  # Set path to existing database
    
    # Perform searches
    results = c.search("test", limit=5)
    
    # Process results
    for symbol in results:
        print(f"Found: {symbol['name']} in {symbol['file']}")
        
except Exception as e:
    print(f"Error: {e}")
finally:
    c.close()

API Reference

cymbal.Cymbal Class

__init__(repo_path=None)

Create a new Cymbal instance. Optionally index a repository immediately.

index(repo_path)

Index a repository. Returns statistics about the indexing operation.

search(query, limit=20)

Search for symbols matching the query. Returns a list of symbol results.

investigate(symbol_name)

Investigate a specific symbol. Returns an investigation result with definition and references.

find_references(symbol_name, limit=50)

Find references to a symbol. Returns a list of reference results.

db_path (property)

Get or set the current database path.

close()

Close the Cymbal instance and release resources.

Convenience Functions

index_repository(repo_path)

Convenience function to index a repository.

search_symbols(query, limit=20, db_path=None)

Convenience function to search for symbols.

investigate_symbol(symbol_name, db_path=None)

Convenience function to investigate a symbol.

Architecture

The Python package uses a subprocess-based architecture to wrap the standalone Cymbal binaries:

  1. Pre-compiled Binaries: Downloaded directly from the upstream Cymbal releases.
  2. Subprocess Wrapper: The Python API executes the binary with the appropriate flags (e.g., --json) and parses the output.
  3. Python API Layer (python/cymbal/__init__.py): Pythonic wrapper that provides a clean, intuitive interface.

File Structure

py-cymbal/
├── python/              # Python bindings
│   └── cymbal/          # Python module
│       ├── __init__.py  # Python API layer
│       └── bin/         # Downloaded Cymbal binaries
├── examples/            # Usage examples
│   └── basic_usage.py  # Basic usage demonstration
├── build.sh            # Build automation script
├── setup.py            # pip installation configuration
└── README.md           # This file

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Acknowledgments

  • Cymbal for the excellent code indexing tool
  • gopy for making Go-Python bindings possible
  • tree-sitter for robust parsing of multiple languages

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

py_cymbal-0.1.23-py3-none-win_amd64.whl (18.5 MB view details)

Uploaded Python 3Windows x86-64

py_cymbal-0.1.23-py3-none-manylinux_2_17_x86_64.whl (6.1 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

py_cymbal-0.1.23-py3-none-manylinux_2_17_aarch64.whl (5.9 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

py_cymbal-0.1.23-py3-none-macosx_11_0_arm64.whl (12.2 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

py_cymbal-0.1.23-py3-none-macosx_10_9_x86_64.whl (12.1 MB view details)

Uploaded Python 3macOS 10.9+ x86-64

File details

Details for the file py_cymbal-0.1.23-py3-none-win_amd64.whl.

File metadata

  • Download URL: py_cymbal-0.1.23-py3-none-win_amd64.whl
  • Upload date:
  • Size: 18.5 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for py_cymbal-0.1.23-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 d774d9cf9aecab9cad48ab682eb849e497092e31355792b0532ccb6278ac8890
MD5 6096a737190a3d1e4e7ed7b3c080825f
BLAKE2b-256 0ca60ff065aab49dc0c83e3fe778094a2eabfe6cf058921ef379427fe7330a6f

See more details on using hashes here.

File details

Details for the file py_cymbal-0.1.23-py3-none-manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for py_cymbal-0.1.23-py3-none-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 5d1e2178d0d02c9319551b9d4412ba35bbacee2631cee93be81abbf148a5ecbe
MD5 ecbf7468e741c1cda6ce781efb8c7a60
BLAKE2b-256 abdfcc565cb60d78406595331f8a9bcd67c44ebd57c6d94d5751a12c07d7fadc

See more details on using hashes here.

File details

Details for the file py_cymbal-0.1.23-py3-none-manylinux_2_17_aarch64.whl.

File metadata

File hashes

Hashes for py_cymbal-0.1.23-py3-none-manylinux_2_17_aarch64.whl
Algorithm Hash digest
SHA256 68dfdf63b05b5a1e79c4fa39ac1746721bc321261eb7c020ed77fce39aff4e22
MD5 9eae4e2c8c76020ba7d0a7fa308fcf44
BLAKE2b-256 37420cab4673f7e928317459bf74c483224fcf4a3b60e13aec0ece0daa183562

See more details on using hashes here.

File details

Details for the file py_cymbal-0.1.23-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for py_cymbal-0.1.23-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 5ed3c0f89af3bb497923e9356e31bac2c77ca4bbfe26066cc95cb85a8fb0fda8
MD5 55441bb42b872dc692f445b2c2698e3a
BLAKE2b-256 2223264d15e18236c8df8ecc38cd8bc57d167b6ccf800ffd8f5a521d8bc195c7

See more details on using hashes here.

File details

Details for the file py_cymbal-0.1.23-py3-none-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for py_cymbal-0.1.23-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 0ad0078fe6c286d31bb490e92db69978e24fde48c00a5c5567f791689e3115dc
MD5 24b49059c8db339b917a2bfa3bda5d1d
BLAKE2b-256 56676ab3512e4d53935c1fce6f0522d3a425952ee3b0a532a16b4bd92aa6443d

See more details on using hashes here.

Supported by

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