Metadata-Version: 2.4
Name: jaci
Version: 0.1.0
Summary: A fast, extensible file system navigation library
Author-email: Lucas Pereira <pip@lumelab.org>
Maintainer-email: Lucas Pereira <pip@lumelab.org>
License: Apache-2.0
Project-URL: Homepage, https://lumelab.org
Project-URL: Documentation, https://jaci.lumelab.org
Project-URL: Repository, https://github.com/lumelab-ai/jaci.git
Project-URL: Bug Tracker, https://github.com/lumelab-ai/jaci/issues
Project-URL: Changelog, https://github.com/lumelab-ai/jaci/blob/main/CHANGELOG.md
Keywords: filesystem,navigation,search,filter,watch,fuzzy,mime,gitignore,file-browser,file-explorer
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: System :: Filesystems
Classifier: Topic :: System :: Systems Administration
Classifier: Typing :: Typed
Requires-Python: >=3.11
Description-Content-Type: text/markdown
License-File: LICENSE
Provides-Extra: ignore
Requires-Dist: pathspec>=0.11.0; extra == "ignore"
Provides-Extra: fuzzy
Requires-Dist: rapidfuzz>=3.0.0; extra == "fuzzy"
Provides-Extra: watch
Requires-Dist: watchfiles>=0.20.0; extra == "watch"
Provides-Extra: mime
Requires-Dist: python-magic>=0.4.27; extra == "mime"
Provides-Extra: mime-alt
Requires-Dist: filetype>=1.2.0; extra == "mime-alt"
Provides-Extra: remotes
Requires-Dist: fsspec>=2023.0.0; extra == "remotes"
Requires-Dist: s3fs>=2023.0.0; extra == "remotes"
Requires-Dist: gcsfs>=2023.0.0; extra == "remotes"
Provides-Extra: tui
Requires-Dist: textual>=0.41.0; extra == "tui"
Provides-Extra: all
Requires-Dist: jaci[fuzzy,ignore,mime,remotes,tui,watch]; extra == "all"
Provides-Extra: dev
Requires-Dist: jaci[all]; extra == "dev"
Requires-Dist: pytest>=7.0.0; extra == "dev"
Requires-Dist: pytest-cov>=4.0.0; extra == "dev"
Requires-Dist: pytest-asyncio>=0.21.0; extra == "dev"
Requires-Dist: pytest-mock>=3.10.0; extra == "dev"
Requires-Dist: hypothesis>=6.0.0; extra == "dev"
Requires-Dist: ruff>=0.1.0; extra == "dev"
Requires-Dist: mypy>=1.0.0; extra == "dev"
Requires-Dist: pyright>=1.1.0; extra == "dev"
Requires-Dist: black>=23.0.0; extra == "dev"
Requires-Dist: isort>=5.12.0; extra == "dev"
Requires-Dist: pre-commit>=3.0.0; extra == "dev"
Requires-Dist: mkdocs>=1.5.0; extra == "dev"
Requires-Dist: mkdocs-material>=9.0.0; extra == "dev"
Requires-Dist: mkdocstrings[python]>=0.23.0; extra == "dev"
Requires-Dist: mkdocs-gen-files>=0.5.0; extra == "dev"
Requires-Dist: mkdocs-literate-nav>=0.6.0; extra == "dev"
Requires-Dist: mkdocs-section-index>=0.3.0; extra == "dev"
Requires-Dist: textual>=0.41.0; extra == "dev"
Dynamic: license-file

# jaci

A fast, extensible file system navigation library for Python.

**Jaci** (Just Another Content Inspector) provides a stable, fast, and extensible API for navigating, filtering, searching, and watching local file systems. Built with performance and extensibility in mind, it works with Python's standard library and offers optional extras for advanced functionality.

## Features

### Core Functionality (Standard Library Only)

- **Fast directory listing** with streaming and pagination
- **Composable filters**: glob, extension, size, mtime, regex, include/exclude
- **Flexible sorting**: name, size, mtime, extension with natural sort
- **Safe path resolution** with sandboxing and symlink loop detection
- **Metadata extraction**: file size, timestamps, permissions
- **TTL-based caching** with automatic invalidation
- **Cross-platform**: macOS, Linux, Windows support

### Optional Extras

- **`ignore`** - `.gitignore`-style pattern matching (requires `pathspec`)
- **`fuzzy`** - Fuzzy search with relevance ranking (requires `rapidfuzz`)  
- **`watch`** - File system event monitoring (requires `watchfiles` or `watchdog`)
- **`mime`** - MIME type detection (requires `python-magic` or `filetype`)
- **`remotes`** - Remote file system support (requires `fsspec`)

## Quick Start

### Installation

```bash
# Core functionality only
pip install jaci

# With all extras
pip install jaci[all]

# Selective extras
pip install jaci[ignore,fuzzy,watch]
```

### Basic Usage

```python
import jaci
from pathlib import Path

# List directory contents
entries = list(jaci.list_entries(Path(".")))
print(f"Found {len(entries)} entries")

# Get file metadata
entry = jaci.stat("README.md")
print(f"README.md: {entry.size} bytes, modified {entry.mtime}")

# Search files
results = list(jaci.search(".", "README"))
print(f"Search results: {len(results)} entries")

# Safe path resolution
resolved = jaci.resolve("../config.yaml", sandbox_root=Path("/home/user"))
print(f"Resolved path: {resolved}")

# Check available features
caps = jaci.capabilities()
print(f"Available extras: {caps['extras']}")
```

### Advanced Usage with Extras

```python
import jaci
from jaci.models import Query, Order

# Create ignore engine (requires ignore extra)
from jaci.ignore import create_ignore_engine, get_common_patterns

patterns = get_common_patterns(['python', 'git'])
ignore_engine = create_ignore_engine(patterns=patterns)

# Fuzzy search (requires fuzzy extra)
from jaci.fuzzy import create_fuzzy_matcher

matcher = create_fuzzy_matcher(score_threshold=70)
matches = matcher.match("readme", ["README.md", "readme.txt", "notes.md"])

# File watching (requires watch extra)
from jaci.watch import create_watcher

watcher = create_watcher(debounce_ms=100)
for event in watcher.watch(Path("."), recursive=True):
    print(f"File {event.path} was {event.event_type}")

# MIME detection (requires mime extra)
from jaci.mime import create_mime_detector

detector = create_mime_detector()
mime_type = detector.detect_mime_type(Path("document.pdf"))
print(f"MIME type: {mime_type}")
```

### Filtering and Sorting

```python
from jaci.models import Query, Order, SelectionMode

# Complex query
query = Query(
    include_glob="*.py",
    extensions=["py"],
    size_range=(0, 10240),  # Files under 10KB
    include_hidden=False,
    selection_mode=SelectionMode.FILES_ONLY,
    limit=50
)

# Natural sorting
order = Order(
    by="name",
    direction="asc", 
    natural=True
)

# Apply to directory listing
entries = list(jaci.list_entries(".", query=query, order=order))
```

## API Reference

### Core Functions

- `list_entries(directory, query=None, order=None, use_cache=True)` - List directory contents
- `search(directory, query, fuzzy_spec=None, use_cache=True)` - Search files with optional fuzzy matching
- `stat(path, use_cache=True)` - Get file/directory metadata
- `watch(directory, query=None, recursive=True, debounce_ms=100)` - Monitor file system events
- `resolve(path, base_dir=None, sandbox_root=None)` - Safe path resolution
- `capabilities()` - Check available features and extras
- `probe(directory)` - Get diagnostic information about a directory

### Data Models

- `Entry` - Immutable file/directory metadata
- `Query` - Composable filtering criteria  
- `Order` - Sorting specifications
- `FuzzySpec` - Fuzzy search configuration
- `SelectionMode` - File/directory selection modes

## Performance

Jaci is designed for performance:

- **Lazy iteration** - O(1) memory per entry for large directories
- **TTL caching** - Reduces redundant filesystem calls
- **Streaming pagination** - Handle 100K+ files efficiently
- **Native Python** - Fast with standard library only
- **Optional extras** - Only load what you need

Benchmarks on a directory with 100,000 files:
- Directory listing: ~50ms
- Filtering with patterns: ~80ms  
- Cached listing: ~2ms
- Fuzzy search: ~120ms

## Configuration

Jaci supports configuration via:

1. **Environment variables** (prefix: `LUMELAB_JACI_`)
2. **Configuration file** (`~/.config/lumelab/jaci/config.yaml`)
3. **API parameters** (highest precedence)

Example configuration:

```yaml
jaci:
  sandbox_root: "/home/user/projects"
  follow_symlinks: false
  ignore:
    from_gitignore: true
    patterns: ["*.tmp", ".env"]
  fuzzy:
    enabled: true
    score_threshold: 70
  watch:
    provider: "watchfiles"
    debounce_ms: 100
  mime:
    enabled: true
    backend: "python-magic"
```

## Development

### Setup

```bash
git clone https://github.com/lumelab-ai/jaci.git
cd jaci
pip install -e ".[dev]"
```

### Running Tests

```bash
# All tests
pytest

# Unit tests only
pytest tests/unit

# Integration tests
pytest tests/integration

# With coverage
pytest --cov=src/jaci --cov-report=html
```

### Code Quality

```bash
# Linting and formatting
ruff check src/
ruff format src/

# Type checking
mypy src/
pyright src/

# Security checks
bandit -r src/
```

## Architecture

Jaci follows a modular architecture:

```
src/jaci/
├── api.py          # Public API functions
├── models.py       # Core data models
├── exceptions.py   # Exception hierarchy
├── providers/      # File system providers
├── filters/        # Composable filters
├── sorters/        # Sorting strategies
├── cache/          # TTL caching
├── config/         # Configuration management
├── utils/          # Utilities (logging, security)
├── ignore/         # .gitignore support (extra)
├── fuzzy/          # Fuzzy search (extra)
├── watch/          # File watching (extra)
└── mime/           # MIME detection (extra)
```

## Contributing

Contributions are welcome! Please see our [Contributing Guide](CONTRIBUTING.md) for details.

### Development Principles

1. **Core works with stdlib only** - Extras are truly optional
2. **Lazy evaluation** - Don't load what you don't need  
3. **Type safety** - Full type annotations required
4. **Performance first** - Benchmark before optimizing
5. **Cross-platform** - Test on macOS, Linux, Windows
6. **Security conscious** - Sandboxing and path validation

## License

MIT License - see [LICENSE](LICENSE) file for details.

## Changelog

See [CHANGELOG.md](CHANGELOG.md) for version history.

## Support

- **Documentation**: https://jaci.lumelab.org
- **Issues**: https://github.com/lumelab-ai/jaci/issues
- **Discussions**: https://github.com/lumelab-ai/jaci/discussions

---

**Jaci** - Just Another Content Inspector  
Part of the [Lumelab](https://lumelab.org) ecosystem
