Skip to main content

LLM plugin for models served by LMStudio (local LLM studio HTTP API)

Project description

llm-lmstudio

PyPI Changelog Tests License

This is a plugin for Simon Willison's LLM command-line utility that lets you talk to models running on a local LMStudio server.

Installation

Make sure you have llm installed, then install this plugin from PyPI:

pip install llm-lmstudio

Or, to install the latest development version directly from GitHub:

llm install -U git+https://github.com/agustif/llm-lmstudio.git

Alternatively, llm install llm-lmstudio will also find and install the plugin.

Usage

First, you need LMStudio running with a model loaded. The plugin talks to the LMStudio server API, which usually runs at http://localhost:1234.

Once the server is up, the plugin should automatically find the models you have loaded in LMStudio. You can check this using the llm models command:

llm models list

You should see your LMStudio models listed, prefixed with lmstudio/ (e.g., lmstudio/llava-v1.5-7b).

To run a prompt against a model:

# Replace 'your-model-id' with the actual ID shown in 'llm models list'
# e.g., llm -m lmstudio/llava-v1.5-7b "Describe this image"
llm -m lmstudio/your-model-id -o temperature 0.7 -o max_tokens 100 "Tell me a joke"

To start an interactive chat session:

llm chat -m lmstudio/your-model-id

You can exit the chat by typing exit or quit.

Vision Model Support

The plugin supports vision-language models (VLMs).

  • When using a VLM, you can attach images using the standard llm attachment syntax:
    llm chat -m lmstudio/your-vlm-id -a path/to/image.png "Describe this image"
    
    Or for a single prompt:
    llm -m lmstudio/your-vlm-id -a path/to/image.png "What is in this picture?"
    
  • The plugin will encode the image and send it to the model.
  • This feature's success depends on the specific VLM, its configuration in LM Studio, and LM Studio's API correctly handling image data.
  • Models that support vision may have a 👁️ (eye icon) in their display_suffix when inspected via llm inspect -m lmstudio/your-vlm-id, though this may not always render in llm models list.

Tool Support

Some models loaded in LMStudio can call tools. The plugin will surface those tool invocations and their results when interacting with such models.

Example:

$ llm --tool llm_version "What version of LLM is this?" --td

For more information about tool calling support consult the llm documentation on tools.

Embedding Models

If you have embedding models loaded in LMStudio (their names usually contain "embed"), the plugin will register them too. You can list them with:

llm embed-models

You should see models like lmstudio/text-embedding-nomic-embed-text-v1.5@f16.

To generate embeddings for text using one of these models:

llm embed -m lmstudio/your-embedding-model-id -c "This is the text to embed"

Configuration

The plugin connects to the LMStudio server API. By default, it tries http://localhost:1234.

You can configure the server URL(s) using the LMSTUDIO_API_BASE environment variable.

  • For a single server:
    export LMSTUDIO_API_BASE="http://your-server-address:port"
    
  • For multiple servers (the plugin will try them in order):
    export LMSTUDIO_API_BASE="http://server1:1234,http://server2:5678,https://server3:custom_port"
    

The variable accepts one or more http[s]://host:port values, separated by commas (spaces around commas are optional). The plugin automatically attempts to append /v1 or /api/v0 to the determined base URL(s) as needed when probing the server.

Model Options

You can pass generation options supported by the LMStudio API (like temperature, max_tokens, top_p, stop) using the -o flag:

llm -m lmstudio/your-model-id -o temperature 0.7 -o max_tokens 100 "Tell me a joke"

Automatic Model Loading

If a selected model is not currently loaded in LM Studio, the plugin will attempt to automatically load it by invoking lms load <model_id> (if lms CLI is installed and configured). You may see progress messages from LM Studio in your terminal during this process.

Development

To set up this plugin for development:

  1. Clone the repository.
  2. Run tests uv run --all-extras pytest

Or do the classic complicated dance:

  1. Create a virtual environment: python -m venv .venv
  2. Activate it: source .venv/bin/activate
  3. Install dependencies, including test dependencies: pip install -e ".[test]"
  4. Run tests: pytest or PYTHONPATH=. pytest -v

The asynchronous tests in tests/test_llm_lmstudio_async.py use pytest-vcr to record and replay HTTP interactions with the LM Studio server. To record new cassettes:

  1. Ensure LM Studio is running with the target model(s) loaded (e.g., llava-v1.5-7b).
  2. Temporarily set record_mode='all' in the @pytest.mark.vcr decorator for the relevant tests in tests/test_llm_lmstudio_async.py.
  3. Run PYTHONPATH=. pytest -v -s tests/test_llm_lmstudio_async.py.
  4. Cassettes will be saved in tests/cassettes/.
  5. Important: Change record_mode back to 'once' after recording.
  6. Commit the new/updated cassettes.

Missing features / Known Issues:

  • The reliability and capabilities of image support can vary significantly based on the specific VLM and its implementation within LM Studio.

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

llm_lmstudio-0.2.0.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

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

llm_lmstudio-0.2.0-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

File details

Details for the file llm_lmstudio-0.2.0.tar.gz.

File metadata

  • Download URL: llm_lmstudio-0.2.0.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for llm_lmstudio-0.2.0.tar.gz
Algorithm Hash digest
SHA256 3e863bf30d7abbc408fc76334eb7cccaaf9564fc15f6d6d6f443ce56a9033334
MD5 f68e0a0e7e034643d63c7cc38a49eb9c
BLAKE2b-256 183fb52b6af89927529dfe8bf5c3742cb425554e520a79fe7641897257e2c6e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for llm_lmstudio-0.2.0.tar.gz:

Publisher: publish.yml on agustif/llm-lmstudio

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

File details

Details for the file llm_lmstudio-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: llm_lmstudio-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 19.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for llm_lmstudio-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 675c9f2ca1197b9beb5e70ba311b5a31ac3bc09b3d827a8034ee1362585f2d88
MD5 8ae813e7faf248ee7a930bef2be5b186
BLAKE2b-256 df7e3a0eea9adf6e7d7266cc7dc0551442efb36af621664e300ca3a5b3da7288

See more details on using hashes here.

Provenance

The following attestation bundles were made for llm_lmstudio-0.2.0-py3-none-any.whl:

Publisher: publish.yml on agustif/llm-lmstudio

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