A language-agnostic library for code querying and manipulation
Project description
CodeHem
CodeHem is a language-agnostic library designed for sophisticated querying and manipulation of source code. It provides a high-level interface to effortlessly navigate, analyze, and modify code elements such as functions, classes, methods, and properties across multiple programming languages, including Python, JavaScript, and TypeScript.
Key Features
- Advanced Code Querying: Easily locate functions, classes, methods, properties, imports, and more within your source code, using a uniform, intuitive API.
- Powerful Code Manipulation: Replace, add, or remove functions, methods, classes, properties, or entire code sections with minimal effort.
- Syntax-aware Operations: Ensures accurate manipulation preserving syntax integrity through the
tree-sitterparser. - Language Detection: Automatically identifies the programming language based on file extensions or code analysis.
- Extensible Architecture: Easily add support for new programming languages through the strategy pattern.
Supported Languages
- Python
- JavaScript / TypeScript (including TSX)
Project Structure
CodeHem/
├── ast_handler.py # Unified interface for AST operations
├── caching/ # Performance optimization through caching
│ ├── __init__.py
│ └── cache_manager.py
│
├── finder/ # Code element location
│ ├── base.py # Abstract base class for querying code elements
│ ├── factory.py # Factory for creating code finders
│ └── lang/
│ ├── python_code_finder.py
│ └── typescript_code_finder.py
│
├── formatting/ # Code formatting system
│ ├── __init__.py
│ ├── formatter.py # Base formatter class
│ ├── python_formatter.py # Python-specific formatter
│ └── typescript_formatter.py # TypeScript-specific formatter
│
├── language_handler.py # High-level language handling interface (LangHem)
├── languages.py # Language definitions and parsers
│
├── manipulator/ # Code manipulation
│ ├── abstract.py # Abstract interface for code manipulators
│ ├── base.py # Base implementation
│ ├── factory.py # Factory for manipulators
│ └── lang/
│ ├── python_manipulator.py
│ └── typescript_manipulator.py
│
├── query_builder.py # Unified query construction
│
├── strategies/ # Strategy pattern for language-specific operations
│ ├── __init__.py
│ ├── language_strategy.py # Abstract strategy interface
│ ├── python_strategy.py # Python-specific strategy
│ └── typescript_strategy.py # TypeScript-specific strategy
│
├── templates/ # Templates for adding new languages
│ └── new_language_template.py
│
└── utils/
└── logs.py # Logging utilities
## Installation
Ensure Python 3.7 or later is installed, then:
Dependencies include tree-sitter and language-specific parsers.
Usage Example
Querying Code
Create a handler for Python code
handler = LangHem('python')
code = ''' class Example: def greet(self): print("Hello") '''
Find method location
start, end = handler.finder.find_method(code, 'Example', 'greet') print(f'Method found from line {start} to {end}')
### Manipulating Code
handler = LangHem('python')
original_code = '''
def greet():
print("Hello")
'''
new_function = '''
def greet():
print("Hello, World!")
'''
modified_code = handler.manipulator.replace_function(original_code, 'greet', new_function)
Contributing
We warmly welcome contributions, whether it's through reporting issues, suggesting enhancements, or submitting pull requests. Feel free to participate!
License
This project is licensed under the MIT license. See LICENSE 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file codehem-0.1.6.tar.gz.
File metadata
- Download URL: codehem-0.1.6.tar.gz
- Upload date:
- Size: 98.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
92686ae6405cb514d21d62dbf2ab2701cb9d25f43f8ed71c8b691eb0ed96cd2c
|
|
| MD5 |
8df9337e74008e83c36baeb1ead633e3
|
|
| BLAKE2b-256 |
74ecff671a7fec114b58eb4845f4f4d9cec7b5e93202ca35ff85a0830b938ab9
|
File details
Details for the file codehem-0.1.6-py3-none-any.whl.
File metadata
- Download URL: codehem-0.1.6-py3-none-any.whl
- Upload date:
- Size: 155.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
059fdec52e92d6cbece9038e001fc77d4541752fb1ac70dde25580cdc583fee3
|
|
| MD5 |
49d14439aa494edab03afb5790191196
|
|
| BLAKE2b-256 |
c991007cdb14ac86086673d8a6866c587b0a7d29b78ee04df8cfe717ded5f3ca
|