Skip to main content

A library for LLM-based agents to navigate large codebases efficiently.

Project description

Locify 🔎

PyPI - Python Versions PyPI - Package Version GitHub - License Docs - GitHub.io

Locify is a library designed to help LLM-based agents navigate and analyze large codebases efficiently. It leverages parsing techniques to provide insights into code structure and relationships.

Features

On a Git-based repository, Locify offers:

  • Codebase Skeleton Mapping:

    • FullMapStrategy: Generates a skeleton map of the entire codebase or a directory only.
    • RepoMapStrategy: Focuses on the reference relationships, using graph theory to rank and analyze code elements.
  • Tree-sitter Integration: Utilizes Tree-sitter for precise parsing of source code, supporting multiple programming languages.

  • Command-Line Interface: Provides a user-friendly CLI for executing different mapping strategies.

Installation

Locify can be installed via pip:

pip install locify

Usage

Command-Line Interface

Locify offers a CLI to execute mapping strategies:

python -m locify.cli <strategy> get_map_with_token_count [options]
  • <strategy>: Choose between fullmap and repomap.
  • [options]: Additional options for customizing the mapping process, e.g. file's depth, or specific directories only.

Example

  • To generate a full map of a codebase:

    python -m locify.cli fullmap get_map_with_token_count --root /path/to/gitrepo
    
  • To generate a full map of the locify directory only, with maximum depth of 3:

    python -m locify.cli fullmap get_map_with_token_count 3 locify
    

Development

Directory Structure

  • locify/: Main source code directory.
    • cli.py: Command-line interface implementation.
    • indexing/: Contains strategies for code mapping.
      • full_map/: Implementation of FullMapStrategy.
      • repo_map/: Implementation of RepoMapStrategy.
    • tree_sitter/: Tree-sitter integration for parsing.
      • parser.py: Tree-sitter parser implementation.
      • queries/: Schema query files for different languages.
    • utils/: Utility functions and classes.

Testing

Tests are located in the tests directory. Run tests using:

poetry run pytest

Acknowledgements

This project was inspired by the aider's RepoMap implementation.

License

This project is licensed under the terms of the MIT license. See the LICENSE file for details.

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

locify-0.0.8.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

locify-0.0.8-py3-none-any.whl (27.9 kB view details)

Uploaded Python 3

File details

Details for the file locify-0.0.8.tar.gz.

File metadata

  • Download URL: locify-0.0.8.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.4 Linux/6.8.0-1015-azure

File hashes

Hashes for locify-0.0.8.tar.gz
Algorithm Hash digest
SHA256 5985edbc40ec15e3af2a5586e1c27057068f7c697a03f887c1b738fce0c22438
MD5 8fe95d47c5dea65e4ef04dab5dc864a9
BLAKE2b-256 6952e29357cb3275b0e0181c20cf5d8e8a871e0f166b72a6a5b4428c68858c88

See more details on using hashes here.

File details

Details for the file locify-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: locify-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 27.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.4 Linux/6.8.0-1015-azure

File hashes

Hashes for locify-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 2778cbb122bf2d1d1ea8c9df24001b9bd81b89cf083c960a9d1077f682923bf3
MD5 d444dbc4f3886c3eef207020970d2b26
BLAKE2b-256 df627790b9a5b70afcfb87ee64e4901a9a364b00b75edd9e9ef11fb4e051a174

See more details on using hashes here.

Supported by

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