Skip to main content

A minimal Hy utility library, using mostly the standard libraries.

Project description

🦑 Hyjinx

Functions and macros useful for modern living in the Hy REPL.

Compatible with Hy 0.29.0.

Hylights

  • A Hy code beautifier and in-REPL syntax highlighting
  • An inspect module that works like Python's, but also for Hy code
  • Pretty tracebacks with correct syntax highlighting for hy or python
  • Print/get/edit source code of a function, module etc. (e.g. (print-source hyjinx.lib.sieve)
  • A sensible, lispy defmethod
  • In-repl code analysis and discussion using LLMs (e.g. for writing docstrings)
  • In-repl syntax highlighting and latex rendering (for sixel-capable terminals) for LLM replies
  • Numpy array pretty printing
  • A zmq lazy pirate protocol
  • A minimal ncurses class

Modules

  • hyjinx.lib: a smorgasbord of convenience functions.

  • hyjinx.source: live code inspection.

  • hyjinx.inspect: code inspection.

  • hyjinx.doc: peruse hy documentation.

  • hyjinx.screen: a convenient ncurses wrapper.

  • hyjinx.mat: numpy pretty-printing for humans. (requires numpy, jax optional)

  • hyjinx.[zmq_client, zmq_server, crypto, wire]: lazy-pirate zmq RPC architecture. (requires zmq, ecdsa, zstandard, msgpack)

  • hyjinx.llm: discuss code with a Large Language Model (AI). TabbyAPI, OpenAI-compatible and Claude are supported. (requires openai and anthropic packages.)

Install

$ pip install -U hyjinx

or, with optional dependencies,

$ pip install -U hyjinx[zmq]
$ pip install -U hyjinx[llm]

To install offline hy/hyrule documentation,

$ hy -m hyjinx.docs

For syntax highlighting in the REPL, put

(import hyjinx.source [hylight]) (setv repl-output-fn hylight)

in your .hyrc.

See hyjinx.hyrc for example usage.

For in-terminal sixel rendering of latex in LLM replies, make sure pdflatex, dvipng and img2sixel are installed, and that you're using a sixel-capable terminal.

Optional dependencies

You can install with the [zmq] option which also installs ecdsa, pyzmq and zstandard for the zmq server/client

You can install with the [llm] option which also installs openai and lets you discuss code objects with ChatGPT or a locally-served LLM (via TabbyAPI or similar).

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

hyjinx-1.0.7.tar.gz (44.5 kB view details)

Uploaded Source

Built Distribution

hyjinx-1.0.7-py3-none-any.whl (47.5 kB view details)

Uploaded Python 3

File details

Details for the file hyjinx-1.0.7.tar.gz.

File metadata

  • Download URL: hyjinx-1.0.7.tar.gz
  • Upload date:
  • Size: 44.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for hyjinx-1.0.7.tar.gz
Algorithm Hash digest
SHA256 d3c8bc4e1a815edb8381562753c40132758593ab3347fa75ca0ea1b4d27282c3
MD5 fc9809d5015bcd865443a3c6fdcd7bfb
BLAKE2b-256 6ffa7da0607a265647970a133a871571c8e5d829053e3d7e149988b452cbee56

See more details on using hashes here.

File details

Details for the file hyjinx-1.0.7-py3-none-any.whl.

File metadata

  • Download URL: hyjinx-1.0.7-py3-none-any.whl
  • Upload date:
  • Size: 47.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for hyjinx-1.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ddbb6aeb5fe3458136bf4fc535c8626fefd6161f0b9f3ae1513af2ad36fb9ad3
MD5 3e917496b3ffb1acf63f388b75cce5ca
BLAKE2b-256 22d22821583862bc670cb5eda7beebfe54460c463d2b55d51dfe8cb15d1cf6bb

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