Skip to main content

Search engine for your files!

Project description

Cosma

Version Discord

Cosma Logo

Search engine for your files!

Use it yourself or plug it into your agents. Comes with a CLI, TUI, and macOS app.

How It Works

Choose which directories to index, and Cosma will process all files in those directories into a search-optimized index. It'll also watch for changes to keep the index updated.

After files are indexed, you can search for them with natural language! Cosma uses vector-powered search to find files quickly and easily.

Cosma can run 100% locally or in the cloud.

Get Started

Cosma has been tested on MacOS ARM and Windows. Linux support is in progress.

Installing

Cosma can be downloaded from PyPI. The installation commands below use uvx.sh to install Cosma via uv. If you prefer using uv directly, use uv tool install cosma.

MacOS/Linux

curl -LsSf uvx.sh/cosma/install.sh | sh

Windows

powershell -ExecutionPolicy ByPass -c "irm https://uvx.sh/cosma/install.ps1 | iex"

Upgrading

To upgrade to the latest version:

uv tool upgrade cosma --no-cache

Running

Backend

Make sure you have Ollama installed.

Cosma has a backend to serve search queries, so it must be started first. This needs to always be running to watch for file changes and process files in the background. For persistent use, consider running this as a background process or configure it as a system service.

cosma serve

[!IMPORTANT]
The backend must be running for the following commands to work (see above).

CLI

Cosma includes a CLI with three output modes:

  • default - Rich formatted output with colors and tables for interactive use
  • --plain - Simple text output without colors, for piping and scripts
  • --json - Structured JSON output for agents and programmatic access
cosma search "my query"               # Search indexed files
cosma index /path/to/dir              # Index a directory
cosma status                          # Check backend status
cosma watch add /path/to/dir          # Watch directory for changes
cosma files stats                     # Get file statistics

Run cosma --help for all commands.

TUI

Cosma also comes with a terminal UI (TUI).

cosma tui /path/to/directory/to/search

[!WARNING] This will begin processing all files in the directory specified, which will take some time if running locally.

Contributing

Cosma is open source, and we'd love to have you contribute! Please feel free to open an issue or pull request with code changes, or join our Discord. We'll have documentation for how best to contribute soon!

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

cosma-1.2.1.tar.gz (13.6 kB view details)

Uploaded Source

Built Distribution

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

cosma-1.2.1-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file cosma-1.2.1.tar.gz.

File metadata

  • Download URL: cosma-1.2.1.tar.gz
  • Upload date:
  • Size: 13.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cosma-1.2.1.tar.gz
Algorithm Hash digest
SHA256 4b1bea89bf4c692f87787ea39a755a1ed781cd52c03d58f97aa9d643951d36c8
MD5 6dce8b2170c55f49a0d86e59deb3e189
BLAKE2b-256 459c9e27377764a7722eefb59f0b09bc065b69cbaf8dc8640d9d50cb2fd58e3f

See more details on using hashes here.

Provenance

The following attestation bundles were made for cosma-1.2.1.tar.gz:

Publisher: release.yml on cosmasense/cosma

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cosma-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: cosma-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cosma-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e8bba022a2fecd25c638da3d728c3df25882d6ffd57a66ad5183222292753b06
MD5 f79cd9913a1636dcfffaf001573d683d
BLAKE2b-256 8f8b581c93e27a1d45aa471ef744f03f5ec664b4d0f8ea40d40cdca1b0d1a3d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for cosma-1.2.1-py3-none-any.whl:

Publisher: release.yml on cosmasense/cosma

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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