Tool use with gptel: looking for testers!

submited by
Style Pass
2025-01-01 09:00:03

A short one today, without the usual flourishes. gptel is a large language model (LLM) client for Emacs. At its core is a wrapper around the HTTP APIs provided by all LLM providers, including the smaller language models you can run locally on your machine. At its surface… well, it tries not to have a surface at all, and blend in with Emacs’ design metaphors and affordances instead.

What does that mean? For one, it’s available at any time and in any buffer, even in places where it probably shouldn’t, like tooltips and the minibuffer. It treats text – yours or that generated by LLMs – as Emacs treats text. You can sling it around, propertize it, redirect it, shove it into buffers and more. You can save LLM conversation states by just saving the buffer, treat hierarchical Org documents as parallel conversation threads, and so on. Second, it’s programmable: you can use a simple API to script gptel into your tools instead of adapting your tools to gptel Unfortunately, one caveat is that gptel is presently async-only, so you’ll have to write a callback instead of just inserting a call to gptel-request in the middle of your code. .

A generalist tool like an LLM can be used in more ways than can be captured by any rigid design, and we’re some distance away from answering this simple question: Can the most flexible text editor ever written provide a generic interface to the most flexible text generator ever created? I am puzzled.

Leave a Comment