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.20-py3-none-win_amd64.whl (18.5 MB view details)

Uploaded Python 3Windows x86-64

py_cymbal-0.1.20-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.20-py3-none-manylinux_2_17_aarch64.whl (5.9 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

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

Uploaded Python 3macOS 11.0+ ARM64

py_cymbal-0.1.20-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.20-py3-none-win_amd64.whl.

File metadata

  • Download URL: py_cymbal-0.1.20-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.20-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 2979911fe95f1fbc9ecfe56bda3f70661328ad721766cafe93741faa0b91e884
MD5 78683d7afbb9b03a296e03cf6867714d
BLAKE2b-256 602e537371cafd9252018218c4b5901fe802f11b9b4332768b8675439530a626

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for py_cymbal-0.1.20-py3-none-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 a4e6c8d57c5de89c60c4f1f028eb337eba6e364e5da209c726540ec85bb24e90
MD5 f373b0166d321c83009b59baa177a55e
BLAKE2b-256 bdc8ddc0bec679bd049f91b29a7184138664ccc200c6d493cd817244498be29f

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for py_cymbal-0.1.20-py3-none-manylinux_2_17_aarch64.whl
Algorithm Hash digest
SHA256 c6ef8b33254581c04e2b712c760dc21a0a9e8a8542119a7fb5fa9071f2b25c1b
MD5 678d91531ea7042206903cee2ff73562
BLAKE2b-256 e0fa34557ff41839dd7351f42117572e435d9413cdf5075afd92ca80be52bcbc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for py_cymbal-0.1.20-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 fd495b37e122f779a9f72c83cb6435584746ab9240649ca95674c30b39a06867
MD5 fd56f72e00a0bdfb4bb270dfd9b3c020
BLAKE2b-256 1a8fc104879ccfeff237f728683ef533649605fbda3972cb0f6130bfe015c619

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for py_cymbal-0.1.20-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 d9ff9496d922725275aa08c34838c464af44f718d0c762824e67077a9915c85a
MD5 5959a5a31b8874f1d474d6df5b186b82
BLAKE2b-256 0b3a459f832a3bbe190428ad2539283f63439b53ca9d71321c491291c9525d93

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