FAQ
General
Does mini-SWE-agent work on my system?
mini-SWE-agent should work on any system that has a bash shell or uses a container runtime (e.g., docker, singularity, apptainer, etc.) to emulate one.
Should I use mini-SWE-agent or swe-agent?
You should use mini-swe-agent if
- You want a quick command line tool that works locally
- You want an agent with a very simple control flow
- You want even faster, simpler & more stable sandboxing & benchmark evaluations
- You are doing FT or RL and don't want to overfit to a specific agent scaffold
You should use swe-agent if
- You need specific tools or want to experiment with different tools
- You want to experiment with different history processors
- You want very powerful yaml configuration without touching code
What you get with both
- Excellent performance on SWE-Bench
- A trajectory browser
How is mini simpler than swe-agent?
mini is simpler than swe-agent because it:
- Does not have any tools other than bash — it doesn't even use the tool-calling interface of the LMs.
  This means you don't have to install anything in any environment you're running in. bashis all you need.
- Has a completely linear history — every step of the agent just appends to the messages and that's it.
- Executes actions with subprocess.run— every action is completely independent (as opposed to keeping a stateful shell session running). This avoids so many issues, trust me.
What are the limitations of mini-SWE-agent?
mini-SWE-agent can be extended trivially in various ways, the following assumes the default setup. As reflected in the high SWE-bench scores, none of the following limitations are a problem in practice.
- No tools other than bash
- Actions are parsed from triple-backtick blocks (rather than assuming a function calling/tool calling format)
- By default, actions are executed as subprocess.run, i.e., every action is independent of the previous ones. (meaning that the agent cannot change directories or export environment variables; however environment variables can be set per-action). This avoids so many issues, trust me.
If you want more flexibility with these items, you can use SWE-agent instead.
Where is global configuration stored?
The global configuration is stored in the .env file in the config directory.
The location is printed when you run mini --help.
The .env file is a simple key-value file that is read by the dotenv library.
Models
What models do you support?
Currently, mini-SWE-agent supports all models that are supported by litellm
or OpenRouter
and we're open to extend the models/ directory with more models should litellm not support them.
How do I set the API key for a model?
The API key can be stored either as an environment variable (note that enviroinment variables are not persistent
unless you set them in your ~/.bashrc or similar), or as a permanent key in the config file.
To temporarily set the API key as an environment variable, you can use the following command:
export OPENAI_API_KEY=sk-test123
To permanently set the API key in the config file, you can use the following command:
mini-extra config set OPENAI_API_KEY sk-test123
Alternatively, you can directly edit the .env file in the config directory
(the location is printed when you run mini --help).
How can I set the default model?
The default model is stored in the config/environment as MSWEA_MODEL_NAME.
To permanently change it:
mini-extra config set MSWEA_MODEL_NAME anthropic/claude-sonnet-4-5-20250929
Alternatively, you can directly edit the .env file in the config directory
(the location is printed when you run mini --help).
Minutia
Why is not needed a running shell session such a big deal?
Most agents so far kept a running shell session. Every action from the agent was executed in this session. However, this is far from trivial:
- It's not obvious when a command has terminated. Essentially you're just pasting input into the shell session, and press enter—but when do you stop reading output?
   We've experimented with various heuristics (watching PIDs, watching for the shell to go back to the prompt, etc.) but all of them were flaky.
   The miniagent doesn't need any of this!
- Particularly bad commands from the LM can kill the shell session. Then what?
- Interrupting a command running in a shell session can also mess up the shell itself and can in particular interfere with all the following outputs you want to extract.
mini is different: There is no running shell session. Every action is executed as a subprocess, that means
every action is independent of the previous ones (it is literally a subprocess.run/os.system/docker exec call).
This means that the agent cannot even change directories or export environment variables.
But you don't need this! You can always prefix cd /path/to/project or export FOO=bar to every action
(and in fact some LMs like Claude will do that even if you don't ask them to).
 
    