mirror of
https://github.com/Aider-AI/aider.git
synced 2025-05-20 20:35:00 +00:00
add sample aider.conf.yml
This commit is contained in:
parent
caca261587
commit
2d62e3fb1f
5 changed files with 523 additions and 2 deletions
|
@ -7,7 +7,7 @@ import sys
|
||||||
import configargparse
|
import configargparse
|
||||||
|
|
||||||
from aider import __version__, models
|
from aider import __version__, models
|
||||||
from aider.args_formatter import MarkdownHelpFormatter
|
from aider.args_formatter import MarkdownHelpFormatter, YamlHelpFormatter
|
||||||
|
|
||||||
from .dump import dump # noqa: F401
|
from .dump import dump # noqa: F401
|
||||||
|
|
||||||
|
@ -468,6 +468,20 @@ def get_help():
|
||||||
return parser.format_help()
|
return parser.format_help()
|
||||||
|
|
||||||
|
|
||||||
|
def get_sample_yaml():
|
||||||
|
os.environ["COLUMNS"] = "100"
|
||||||
|
sys.argv = ["aider"]
|
||||||
|
parser = get_parser([], None)
|
||||||
|
|
||||||
|
# This instantiates all the action.env_var values
|
||||||
|
parser.parse_known_args()
|
||||||
|
|
||||||
|
parser.formatter_class = YamlHelpFormatter
|
||||||
|
|
||||||
|
return argparse.ArgumentParser.format_help(parser)
|
||||||
|
return parser.format_help()
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
print(get_help())
|
print(get_help())
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,53 @@ import argparse
|
||||||
from .dump import dump # noqa: F401
|
from .dump import dump # noqa: F401
|
||||||
|
|
||||||
|
|
||||||
|
class YamlHelpFormatter(argparse.HelpFormatter):
|
||||||
|
def start_section(self, heading):
|
||||||
|
res = "\n\n"
|
||||||
|
res += "#" * (len(heading) + 2)
|
||||||
|
res += f"\n# {heading}"
|
||||||
|
super().start_section(res)
|
||||||
|
|
||||||
|
def _format_usage(self, usage, actions, groups, prefix):
|
||||||
|
return ""
|
||||||
|
|
||||||
|
def _format_text(self, text):
|
||||||
|
return """
|
||||||
|
##########################################################
|
||||||
|
# Sample .aider.conf.yaml
|
||||||
|
# Place in your home dir, or at the root of your git repo.
|
||||||
|
##########################################################
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
def _format_action(self, action):
|
||||||
|
parts = [""]
|
||||||
|
|
||||||
|
metavar = action.metavar
|
||||||
|
if not metavar and isinstance(action, argparse._StoreAction):
|
||||||
|
metavar = "VALUE"
|
||||||
|
|
||||||
|
if action.default not in (argparse.SUPPRESS, None):
|
||||||
|
default = action.default
|
||||||
|
else:
|
||||||
|
default = False
|
||||||
|
|
||||||
|
default = "true" if default else "false"
|
||||||
|
|
||||||
|
if action.help:
|
||||||
|
parts.append(f"# {action.help}")
|
||||||
|
|
||||||
|
parts.append(f"# {action.dest}: {default}\n")
|
||||||
|
|
||||||
|
return "\n".join(parts) + "\n"
|
||||||
|
|
||||||
|
def _format_action_invocation(self, action):
|
||||||
|
return ""
|
||||||
|
|
||||||
|
def _format_args(self, action, default_metavar):
|
||||||
|
return ""
|
||||||
|
|
||||||
|
|
||||||
class MarkdownHelpFormatter(argparse.HelpFormatter):
|
class MarkdownHelpFormatter(argparse.HelpFormatter):
|
||||||
def start_section(self, heading):
|
def start_section(self, heading):
|
||||||
super().start_section(f"## {heading}")
|
super().start_section(f"## {heading}")
|
||||||
|
|
|
@ -13,4 +13,5 @@ cog $ARG \
|
||||||
website/index.md \
|
website/index.md \
|
||||||
website/docs/commands.md \
|
website/docs/commands.md \
|
||||||
website/docs/languages.md \
|
website/docs/languages.md \
|
||||||
website/docs/options_ref.md
|
website/docs/options_ref.md \
|
||||||
|
website/docs/aider_conf.md
|
||||||
|
|
217
website/assets/sample.aider.conf.yml
Normal file
217
website/assets/sample.aider.conf.yml
Normal file
|
@ -0,0 +1,217 @@
|
||||||
|
##########################################################
|
||||||
|
# Sample .aider.conf.yaml
|
||||||
|
# Place in your home dir, or at the root of your git repo.
|
||||||
|
##########################################################
|
||||||
|
|
||||||
|
#########
|
||||||
|
# options:
|
||||||
|
|
||||||
|
# show this help message and exit
|
||||||
|
# help: false
|
||||||
|
|
||||||
|
######
|
||||||
|
# Main:
|
||||||
|
|
||||||
|
# files to edit with an LLM (optional)
|
||||||
|
# files: false
|
||||||
|
|
||||||
|
# Specify the OpenAI API key
|
||||||
|
# openai_api_key: false
|
||||||
|
|
||||||
|
# Specify the OpenAI API key
|
||||||
|
# anthropic_api_key: false
|
||||||
|
|
||||||
|
# Specify the model to use for the main chat (default: gpt-4o)
|
||||||
|
# model: true
|
||||||
|
|
||||||
|
# Use claude-3-opus-20240229 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use claude-3-sonnet-20240229 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4-0613 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4o model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4-1106-preview model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-3.5-turbo model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
################
|
||||||
|
# Model Settings:
|
||||||
|
|
||||||
|
# List known models which match the (partial) MODEL name
|
||||||
|
# models: false
|
||||||
|
|
||||||
|
# Specify the api base url
|
||||||
|
# openai_api_base: false
|
||||||
|
|
||||||
|
# Specify the api_type
|
||||||
|
# openai_api_type: false
|
||||||
|
|
||||||
|
# Specify the api_version
|
||||||
|
# openai_api_version: false
|
||||||
|
|
||||||
|
# Specify the deployment_id
|
||||||
|
# openai_api_deployment_id: false
|
||||||
|
|
||||||
|
# Specify the OpenAI organization ID
|
||||||
|
# openai_organization_id: false
|
||||||
|
|
||||||
|
# Specify what edit format the LLM should use (default depends on model)
|
||||||
|
# edit_format: false
|
||||||
|
|
||||||
|
# Specify the model to use for commit messages and chat history summarization (default depends on --model)
|
||||||
|
# weak_model: false
|
||||||
|
|
||||||
|
# Only work with models that have meta-data available (default: True)
|
||||||
|
# show_model_warnings: true
|
||||||
|
|
||||||
|
# Max number of tokens to use for repo map, use 0 to disable (default: 1024)
|
||||||
|
# map_tokens: true
|
||||||
|
|
||||||
|
# Maximum number of tokens to use for chat history. If not specified, uses the model's max_chat_history_tokens.
|
||||||
|
# max_chat_history_tokens: false
|
||||||
|
|
||||||
|
# Specify the .env file to load (default: .env in git root)
|
||||||
|
# env_file: true
|
||||||
|
|
||||||
|
###############
|
||||||
|
# History Files:
|
||||||
|
|
||||||
|
# Specify the chat input history file (default: .aider.input.history)
|
||||||
|
# input_history_file: true
|
||||||
|
|
||||||
|
# Specify the chat history file (default: .aider.chat.history.md)
|
||||||
|
# chat_history_file: true
|
||||||
|
|
||||||
|
# Restore the previous chat history messages (default: False)
|
||||||
|
# restore_chat_history: false
|
||||||
|
|
||||||
|
#################
|
||||||
|
# Output Settings:
|
||||||
|
|
||||||
|
# Use colors suitable for a dark terminal background (default: False)
|
||||||
|
# dark_mode: false
|
||||||
|
|
||||||
|
# Use colors suitable for a light terminal background (default: False)
|
||||||
|
# light_mode: false
|
||||||
|
|
||||||
|
# Enable/disable pretty, colorized output (default: True)
|
||||||
|
# pretty: true
|
||||||
|
|
||||||
|
# Enable/disable streaming responses (default: True)
|
||||||
|
# stream: true
|
||||||
|
|
||||||
|
# Set the color for user input (default: #00cc00)
|
||||||
|
# user_input_color: true
|
||||||
|
|
||||||
|
# Set the color for tool output (default: None)
|
||||||
|
# tool_output_color: false
|
||||||
|
|
||||||
|
# Set the color for tool error messages (default: red)
|
||||||
|
# tool_error_color: true
|
||||||
|
|
||||||
|
# Set the color for assistant output (default: #0088ff)
|
||||||
|
# assistant_output_color: true
|
||||||
|
|
||||||
|
# Set the markdown code theme (default: default, other options include monokai, solarized-dark, solarized-light)
|
||||||
|
# code_theme: true
|
||||||
|
|
||||||
|
# Show diffs when committing changes (default: False)
|
||||||
|
# show_diffs: false
|
||||||
|
|
||||||
|
##############
|
||||||
|
# Git Settings:
|
||||||
|
|
||||||
|
# Enable/disable looking for a git repo (default: True)
|
||||||
|
# git: true
|
||||||
|
|
||||||
|
# Enable/disable adding .aider* to .gitignore (default: True)
|
||||||
|
# gitignore: true
|
||||||
|
|
||||||
|
# Specify the aider ignore file (default: .aiderignore in git root)
|
||||||
|
# aiderignore: true
|
||||||
|
|
||||||
|
# Enable/disable auto commit of LLM changes (default: True)
|
||||||
|
# auto_commits: true
|
||||||
|
|
||||||
|
# Enable/disable commits when repo is found dirty (default: True)
|
||||||
|
# dirty_commits: true
|
||||||
|
|
||||||
|
# Perform a dry run without modifying files (default: False)
|
||||||
|
# dry_run: false
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# Fixing and committing:
|
||||||
|
|
||||||
|
# Commit all pending changes with a suitable commit message, then exit
|
||||||
|
# commit: false
|
||||||
|
|
||||||
|
# Lint and fix provided files, or dirty files if none provided
|
||||||
|
# lint: false
|
||||||
|
|
||||||
|
# Specify lint commands to run for different languages, eg: "python: flake8 --select=..." (can be used multiple times)
|
||||||
|
# lint_cmd: false
|
||||||
|
|
||||||
|
# Enable/disable automatic linting after changes (default: True)
|
||||||
|
# auto_lint: true
|
||||||
|
|
||||||
|
# Specify command to run tests
|
||||||
|
# test_cmd: false
|
||||||
|
|
||||||
|
# Enable/disable automatic testing after changes (default: False)
|
||||||
|
# auto_test: false
|
||||||
|
|
||||||
|
# Run tests and fix problems found
|
||||||
|
# test: false
|
||||||
|
|
||||||
|
################
|
||||||
|
# Other Settings:
|
||||||
|
|
||||||
|
# Specify the language for voice using ISO 639-1 code (default: auto)
|
||||||
|
# voice_language: true
|
||||||
|
|
||||||
|
# Show the version number and exit
|
||||||
|
# version: false
|
||||||
|
|
||||||
|
# Check for updates and return status in the exit code
|
||||||
|
# check_update: false
|
||||||
|
|
||||||
|
# Skips checking for the update when the program runs
|
||||||
|
# skip_check_update: false
|
||||||
|
|
||||||
|
# Apply the changes from the given file instead of running the chat (debug)
|
||||||
|
# apply: false
|
||||||
|
|
||||||
|
# Always say yes to every confirmation
|
||||||
|
# yes: false
|
||||||
|
|
||||||
|
# Enable verbose output
|
||||||
|
# verbose: false
|
||||||
|
|
||||||
|
# Print the repo map and exit (debug)
|
||||||
|
# show_repo_map: false
|
||||||
|
|
||||||
|
# Print the system prompts and exit (debug)
|
||||||
|
# show_prompts: false
|
||||||
|
|
||||||
|
# Specify a single message to send the LLM, process reply then exit (disables chat mode)
|
||||||
|
# message: false
|
||||||
|
|
||||||
|
# Specify a file containing the message to send the LLM, process reply, then exit (disables chat mode)
|
||||||
|
# message_file: false
|
||||||
|
|
||||||
|
# Specify the encoding for input and output (default: utf-8)
|
||||||
|
# encoding: true
|
||||||
|
|
||||||
|
# Specify the config file (default: search for .aider.conf.yml in git root, cwd or home directory)
|
||||||
|
# config: false
|
||||||
|
|
||||||
|
# Run aider in your browser
|
||||||
|
# gui: false
|
242
website/docs/aider_conf.md
Normal file
242
website/docs/aider_conf.md
Normal file
|
@ -0,0 +1,242 @@
|
||||||
|
---
|
||||||
|
parent: Configuration
|
||||||
|
nav_order: 15
|
||||||
|
---
|
||||||
|
|
||||||
|
## Using `.aider.conf.yml`
|
||||||
|
|
||||||
|
Most options can also be set in an `.aider.conf.yml` file
|
||||||
|
which can be placed in your home directory or at the root of
|
||||||
|
your git repo.
|
||||||
|
|
||||||
|
Below is a sample of the file.
|
||||||
|
|
||||||
|
<!--[[[cog
|
||||||
|
from aider.args import get_sample_yaml
|
||||||
|
from pathlib import Path
|
||||||
|
text=get_sample_yaml()
|
||||||
|
Path("website/assets/sample.aider.conf.yml").write_text(text)
|
||||||
|
cog.outl("```")
|
||||||
|
cog.out(text)
|
||||||
|
cog.outl("```")
|
||||||
|
]]]-->
|
||||||
|
```
|
||||||
|
##########################################################
|
||||||
|
# Sample .aider.conf.yaml
|
||||||
|
# Place in your home dir, or at the root of your git repo.
|
||||||
|
##########################################################
|
||||||
|
|
||||||
|
#########
|
||||||
|
# options:
|
||||||
|
|
||||||
|
# show this help message and exit
|
||||||
|
# help: false
|
||||||
|
|
||||||
|
######
|
||||||
|
# Main:
|
||||||
|
|
||||||
|
# files to edit with an LLM (optional)
|
||||||
|
# files: false
|
||||||
|
|
||||||
|
# Specify the OpenAI API key
|
||||||
|
# openai_api_key: false
|
||||||
|
|
||||||
|
# Specify the OpenAI API key
|
||||||
|
# anthropic_api_key: false
|
||||||
|
|
||||||
|
# Specify the model to use for the main chat (default: gpt-4o)
|
||||||
|
# model: true
|
||||||
|
|
||||||
|
# Use claude-3-opus-20240229 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use claude-3-sonnet-20240229 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4-0613 model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4o model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-4-1106-preview model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
# Use gpt-3.5-turbo model for the main chat
|
||||||
|
# model: false
|
||||||
|
|
||||||
|
################
|
||||||
|
# Model Settings:
|
||||||
|
|
||||||
|
# List known models which match the (partial) MODEL name
|
||||||
|
# models: false
|
||||||
|
|
||||||
|
# Specify the api base url
|
||||||
|
# openai_api_base: false
|
||||||
|
|
||||||
|
# Specify the api_type
|
||||||
|
# openai_api_type: false
|
||||||
|
|
||||||
|
# Specify the api_version
|
||||||
|
# openai_api_version: false
|
||||||
|
|
||||||
|
# Specify the deployment_id
|
||||||
|
# openai_api_deployment_id: false
|
||||||
|
|
||||||
|
# Specify the OpenAI organization ID
|
||||||
|
# openai_organization_id: false
|
||||||
|
|
||||||
|
# Specify what edit format the LLM should use (default depends on model)
|
||||||
|
# edit_format: false
|
||||||
|
|
||||||
|
# Specify the model to use for commit messages and chat history summarization (default depends on --model)
|
||||||
|
# weak_model: false
|
||||||
|
|
||||||
|
# Only work with models that have meta-data available (default: True)
|
||||||
|
# show_model_warnings: true
|
||||||
|
|
||||||
|
# Max number of tokens to use for repo map, use 0 to disable (default: 1024)
|
||||||
|
# map_tokens: true
|
||||||
|
|
||||||
|
# Maximum number of tokens to use for chat history. If not specified, uses the model's max_chat_history_tokens.
|
||||||
|
# max_chat_history_tokens: false
|
||||||
|
|
||||||
|
# Specify the .env file to load (default: .env in git root)
|
||||||
|
# env_file: true
|
||||||
|
|
||||||
|
###############
|
||||||
|
# History Files:
|
||||||
|
|
||||||
|
# Specify the chat input history file (default: .aider.input.history)
|
||||||
|
# input_history_file: true
|
||||||
|
|
||||||
|
# Specify the chat history file (default: .aider.chat.history.md)
|
||||||
|
# chat_history_file: true
|
||||||
|
|
||||||
|
# Restore the previous chat history messages (default: False)
|
||||||
|
# restore_chat_history: false
|
||||||
|
|
||||||
|
#################
|
||||||
|
# Output Settings:
|
||||||
|
|
||||||
|
# Use colors suitable for a dark terminal background (default: False)
|
||||||
|
# dark_mode: false
|
||||||
|
|
||||||
|
# Use colors suitable for a light terminal background (default: False)
|
||||||
|
# light_mode: false
|
||||||
|
|
||||||
|
# Enable/disable pretty, colorized output (default: True)
|
||||||
|
# pretty: true
|
||||||
|
|
||||||
|
# Enable/disable streaming responses (default: True)
|
||||||
|
# stream: true
|
||||||
|
|
||||||
|
# Set the color for user input (default: #00cc00)
|
||||||
|
# user_input_color: true
|
||||||
|
|
||||||
|
# Set the color for tool output (default: None)
|
||||||
|
# tool_output_color: false
|
||||||
|
|
||||||
|
# Set the color for tool error messages (default: red)
|
||||||
|
# tool_error_color: true
|
||||||
|
|
||||||
|
# Set the color for assistant output (default: #0088ff)
|
||||||
|
# assistant_output_color: true
|
||||||
|
|
||||||
|
# Set the markdown code theme (default: default, other options include monokai, solarized-dark, solarized-light)
|
||||||
|
# code_theme: true
|
||||||
|
|
||||||
|
# Show diffs when committing changes (default: False)
|
||||||
|
# show_diffs: false
|
||||||
|
|
||||||
|
##############
|
||||||
|
# Git Settings:
|
||||||
|
|
||||||
|
# Enable/disable looking for a git repo (default: True)
|
||||||
|
# git: true
|
||||||
|
|
||||||
|
# Enable/disable adding .aider* to .gitignore (default: True)
|
||||||
|
# gitignore: true
|
||||||
|
|
||||||
|
# Specify the aider ignore file (default: .aiderignore in git root)
|
||||||
|
# aiderignore: true
|
||||||
|
|
||||||
|
# Enable/disable auto commit of LLM changes (default: True)
|
||||||
|
# auto_commits: true
|
||||||
|
|
||||||
|
# Enable/disable commits when repo is found dirty (default: True)
|
||||||
|
# dirty_commits: true
|
||||||
|
|
||||||
|
# Perform a dry run without modifying files (default: False)
|
||||||
|
# dry_run: false
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# Fixing and committing:
|
||||||
|
|
||||||
|
# Commit all pending changes with a suitable commit message, then exit
|
||||||
|
# commit: false
|
||||||
|
|
||||||
|
# Lint and fix provided files, or dirty files if none provided
|
||||||
|
# lint: false
|
||||||
|
|
||||||
|
# Specify lint commands to run for different languages, eg: "python: flake8 --select=..." (can be used multiple times)
|
||||||
|
# lint_cmd: false
|
||||||
|
|
||||||
|
# Enable/disable automatic linting after changes (default: True)
|
||||||
|
# auto_lint: true
|
||||||
|
|
||||||
|
# Specify command to run tests
|
||||||
|
# test_cmd: false
|
||||||
|
|
||||||
|
# Enable/disable automatic testing after changes (default: False)
|
||||||
|
# auto_test: false
|
||||||
|
|
||||||
|
# Run tests and fix problems found
|
||||||
|
# test: false
|
||||||
|
|
||||||
|
################
|
||||||
|
# Other Settings:
|
||||||
|
|
||||||
|
# Specify the language for voice using ISO 639-1 code (default: auto)
|
||||||
|
# voice_language: true
|
||||||
|
|
||||||
|
# Show the version number and exit
|
||||||
|
# version: false
|
||||||
|
|
||||||
|
# Check for updates and return status in the exit code
|
||||||
|
# check_update: false
|
||||||
|
|
||||||
|
# Skips checking for the update when the program runs
|
||||||
|
# skip_check_update: false
|
||||||
|
|
||||||
|
# Apply the changes from the given file instead of running the chat (debug)
|
||||||
|
# apply: false
|
||||||
|
|
||||||
|
# Always say yes to every confirmation
|
||||||
|
# yes: false
|
||||||
|
|
||||||
|
# Enable verbose output
|
||||||
|
# verbose: false
|
||||||
|
|
||||||
|
# Print the repo map and exit (debug)
|
||||||
|
# show_repo_map: false
|
||||||
|
|
||||||
|
# Print the system prompts and exit (debug)
|
||||||
|
# show_prompts: false
|
||||||
|
|
||||||
|
# Specify a single message to send the LLM, process reply then exit (disables chat mode)
|
||||||
|
# message: false
|
||||||
|
|
||||||
|
# Specify a file containing the message to send the LLM, process reply, then exit (disables chat mode)
|
||||||
|
# message_file: false
|
||||||
|
|
||||||
|
# Specify the encoding for input and output (default: utf-8)
|
||||||
|
# encoding: true
|
||||||
|
|
||||||
|
# Specify the config file (default: search for .aider.conf.yml in git root, cwd or home directory)
|
||||||
|
# config: false
|
||||||
|
|
||||||
|
# Run aider in your browser
|
||||||
|
# gui: false
|
||||||
|
```
|
||||||
|
<!--[[[end]]]-->
|
Loading…
Add table
Add a link
Reference in a new issue