Compare commits

...

642 Commits

Author SHA1 Message Date
Paul Gauthier
f2b8d36d9e set version to 0.78.1.dev 2025-03-21 11:57:37 -07:00
Paul Gauthier
8d43d4ee21 version bump to 0.78.0 2025-03-21 11:57:34 -07:00
Paul Gauthier
b54af5dbe3 copy 2025-03-21 11:55:23 -07:00
Paul Gauthier (aider)
4980e901a0 feat: Add plain git log to update-history script context 2025-03-21 11:38:46 -07:00
Paul Gauthier
cd32311c1f copy 2025-03-21 11:37:49 -07:00
Paul Gauthier (aider)
b97997b009 fix: Remove unused imports in badges.py 2025-03-21 11:36:43 -07:00
Paul Gauthier (aider)
4aad9fbdd4 style: Format code with linter 2025-03-21 11:36:28 -07:00
Paul Gauthier (aider)
ac2439e25b feat: add 24-hour cache for BigQuery download stats 2025-03-21 11:36:24 -07:00
Paul Gauthier (aider)
ddc1556ae0 style: Reformat code to comply with linter rules 2025-03-21 11:25:13 -07:00
Paul Gauthier (aider)
0d75c4d0e3 test: add exponential backoff retry for help command test 2025-03-21 11:25:10 -07:00
Paul Gauthier
f3a042dcdf refactor: Simplify exception handling in platform info retrieval 2025-03-21 11:24:10 -07:00
Paul Gauthier (aider)
f9e0a99064 style: Remove trailing whitespace in base_coder.py 2025-03-21 11:23:57 -07:00
Paul Gauthier (aider)
d6906fb100 fix: Handle KeyError in platform info retrieval with clear message 2025-03-21 11:23:50 -07:00
Paul Gauthier (aider)
821662abcb style: Remove trailing whitespace in base_coder.py 2025-03-21 11:22:00 -07:00
Paul Gauthier (aider)
cf496abec0 fix: Handle platform info retrieval errors gracefully 2025-03-21 11:21:53 -07:00
Paul Gauthier
e245d39216 copy 2025-03-21 11:18:42 -07:00
paul-gauthier
44f87c2c17 Merge pull request #3553 from lentil32/main
fix: Redundant warning when `AWS_PROFILE` set for Bedrock
2025-03-21 11:16:27 -07:00
Paul Gauthier
a6fd0de762 copy 2025-03-21 11:16:10 -07:00
Carles Sala (aider)
072ecba4c5 feat: Add commands to switch main, editor, and weak models 2025-03-21 11:09:33 -07:00
Paul Gauthier (aider)
3ad5d75bee refactor: Remove unused variable in test_main.py 2025-03-21 11:05:35 -07:00
Paul Gauthier (aider)
8679c425e0 style: Remove trailing whitespace in test_main.py 2025-03-21 11:04:58 -07:00
Paul Gauthier (aider)
1ec257278e refactor: Move resolve_aiderignore_path to top level and add tests 2025-03-21 11:04:51 -07:00
paul-gauthier
ffe89362ab Merge pull request #3478 from mopemope/fix-ignore
refactor: enhance --aiderignore argument to resolve absolute and relative paths
2025-03-21 11:02:04 -07:00
paul-gauthier
a82c0f9e49 Merge pull request #3485 from codefromthecrypt/patch-1
ollama: suggest higher minimum context length
2025-03-21 09:36:06 -07:00
Paul Gauthier
413271e82a copy 2025-03-21 09:23:45 -07:00
Paul Gauthier (aider)
60b926b698 refactor: Remove redundant imports in completions methods 2025-03-21 09:21:59 -07:00
Paul Gauthier (aider)
98be67442e chore: Run linter and fix import order in commands.py 2025-03-21 09:21:01 -07:00
Paul Gauthier (aider)
8e9c75b6f8 chore: Add CommandCompletionException import to commands.py 2025-03-21 09:20:54 -07:00
Paul Gauthier (aider)
8c65604b29 style: Format docstring and multiline condition for better readability 2025-03-21 09:20:22 -07:00
Paul Gauthier (aider)
930923c211 style: Format code to comply with linter rules 2025-03-21 09:19:34 -07:00
Paul Gauthier (aider)
710d540dcd feat: Add CommandCompletionException class for autocompletion handling 2025-03-21 09:19:29 -07:00
Paul Gauthier (aider)
ddef8c2499 refactor: Add CommandCompletionException for autocompletion handling 2025-03-21 09:19:13 -07:00
Paul Gauthier
c6289c2bea refactor: Add comment for command completion handling in AutoCompleter 2025-03-21 09:19:12 -07:00
Paul Gauthier (aider)
b624bb6fb8 refactor: raise exceptions to use normal autocompleter 2025-03-21 09:18:22 -07:00
Paul Gauthier (aider)
4e03f4165d feat: Add autocompletion for /ask, /code and /architect commands 2025-03-21 09:16:26 -07:00
paul-gauthier
2f6ea2f499 Merge pull request #3579 from marcomayer/main
feat: vi-like behavior when pressing enter in multiline-mode
2025-03-21 09:06:52 -07:00
Paul Gauthier
8c47d1f9c0 copy 2025-03-21 09:03:48 -07:00
Paul Gauthier (aider)
e31be8d3c9 feat: Print source used in get_total_downloads function 2025-03-21 09:01:50 -07:00
Paul Gauthier
2069ad62d1 refactor: Remove badges markdown generation from main function 2025-03-21 09:01:48 -07:00
Paul Gauthier (aider)
2993e285c8 style: Format code in badges.py for better readability 2025-03-21 08:58:10 -07:00
Paul Gauthier (aider)
4ee9cee52a refactor: extract credentials_path from USE_BIGQUERY environment variable 2025-03-21 08:58:04 -07:00
Paul Gauthier (aider)
0e555699bd feat: exclude CI downloads from PyPI download count 2025-03-21 08:53:59 -07:00
Paul Gauthier (aider)
aad6c63206 style: Format code according to linter rules 2025-03-21 08:52:04 -07:00
Paul Gauthier (aider)
8c78e09f03 feat: Add BigQuery support for fetching PyPI download statistics 2025-03-21 08:52:00 -07:00
Paul Gauthier (aider)
25d1eac0f5 docs: Add Ctrl-Y keybinding to Emacs commands documentation 2025-03-21 08:48:28 -07:00
Paul Gauthier
26daf2cd31 copy 2025-03-21 07:38:48 -07:00
Paul Gauthier
280bd44ba3 copy 2025-03-21 07:33:00 -07:00
Paul Gauthier
c9d87fef71 copy 2025-03-21 07:31:00 -07:00
Paul Gauthier (aider)
649742f02a style: Format code according to linter rules 2025-03-21 07:27:57 -07:00
Paul Gauthier (aider)
245ee84c2d feat: Add OpenRouter support to set_thinking_tokens method 2025-03-21 07:27:52 -07:00
Paul Gauthier
76c09205d0 copy 2025-03-20 19:10:59 -07:00
Paul Gauthier
d365b5248c copy 2025-03-20 19:08:21 -07:00
Paul Gauthier
3dd91bc6f2 copy 2025-03-20 15:29:47 -07:00
Paul Gauthier (aider)
3dc5a48fcc fix: Handle newline in git commit message assertion 2025-03-20 15:23:41 -07:00
Paul Gauthier (aider)
bff077f855 style: Remove trailing whitespace in test_repo.py 2025-03-20 15:23:20 -07:00
Paul Gauthier (aider)
6022b09437 fix: Move pre-commit hook creation after initial commit in test 2025-03-20 15:23:15 -07:00
Paul Gauthier (aider)
62b52a78fe style: Remove trailing whitespace in test_repo.py 2025-03-20 15:22:07 -07:00
Paul Gauthier (aider)
e33dc9355d test: Add test for --git-commit-verify option 2025-03-20 15:22:03 -07:00
Paul Gauthier
834da07736 copy 2025-03-20 15:14:08 -07:00
Paul Gauthier (aider)
fe795cc2d5 chore: Change default git commit verify flag to False 2025-03-20 15:08:44 -07:00
Paul Gauthier (aider)
593de47438 docs: Add --no-git-commit-verify flag documentation 2025-03-20 15:07:51 -07:00
Paul Gauthier (aider)
ac231e43ad feat: Add --git-commit-verify flag to control git hook verification 2025-03-20 15:06:44 -07:00
Paul Gauthier
aca64071c8 copy 2025-03-20 14:31:03 -07:00
Paul Gauthier (aider)
5c205cd753 fix: use rounding instead of truncation for star counts 2025-03-20 14:29:57 -07:00
Paul Gauthier (aider)
57ce2c48b8 fix: round GitHub stars to whole numbers in HTML output 2025-03-20 14:28:58 -07:00
Paul Gauthier
0937b34983 chore: Update badges and stats in README and website 2025-03-20 14:25:24 -07:00
Paul Gauthier (aider)
291c4eb258 style: Remove trailing whitespace and standardize string quotes 2025-03-20 14:23:07 -07:00
Paul Gauthier (aider)
a8744708a0 feat: Add HTML-formatted badges generation function 2025-03-20 14:23:02 -07:00
Paul Gauthier (aider)
3010b94a64 refactor: move tooltip text to global constants 2025-03-20 14:21:35 -07:00
Paul Gauthier (aider)
9c4d173b1f style: Add whitespace around arithmetic operators in format_number 2025-03-20 14:20:45 -07:00
Paul Gauthier (aider)
cca155c5c6 refactor: Move tokens/week value to global constant TOKENS_PER_WEEK 2025-03-20 14:20:09 -07:00
Paul Gauthier (aider)
a93e7108e6 style: Format code with linter 2025-03-20 14:18:50 -07:00
Paul Gauthier (aider)
d26df6c178 feat: add get_badges_md() function to generate badges markdown 2025-03-20 14:18:41 -07:00
Paul Gauthier
e915964d81 style: Add noqa comment to badges.py for flake8 compliance 2025-03-20 14:18:36 -07:00
Paul Gauthier (aider)
1304ca2425 style: Remove trailing whitespace in badges.py 2025-03-20 14:15:14 -07:00
Paul Gauthier (aider)
894f6b6d1d feat: Add function to generate markdown badges with formatted stats 2025-03-20 14:15:08 -07:00
Paul Gauthier (aider)
6605a9b22a style: Remove trailing whitespace in badges.py 2025-03-20 14:12:34 -07:00
Paul Gauthier (aider)
b5d963d151 fix: properly identify latest release by parsing version numbers 2025-03-20 14:12:31 -07:00
Paul Gauthier (aider)
8f840ae0b1 refactor: Rename function and emphasize LATEST release in output 2025-03-20 14:11:08 -07:00
Paul Gauthier (aider)
7942ca9206 style: Format code and fix import order in badges.py 2025-03-20 14:10:43 -07:00
Paul Gauthier (aider)
a5614bfe40 feat: Add Aider contribution percentage to badges script 2025-03-20 14:10:39 -07:00
Paul Gauthier (aider)
eaac00ad3f style: Format code according to linter rules 2025-03-20 14:07:58 -07:00
Paul Gauthier (aider)
6687cc9465 feat: Add GitHub stars fetching to badges script 2025-03-20 14:07:52 -07:00
Paul Gauthier (aider)
5b9464ed31 style: Format code with linter in badges.py 2025-03-20 14:06:20 -07:00
Paul Gauthier (aider)
4c7d99b26c feat: Add .env support for PEPY_API_KEY in badges script 2025-03-20 14:06:16 -07:00
Paul Gauthier
5bf248164a chore: Make badges.py executable 2025-03-20 14:06:15 -07:00
Paul Gauthier (aider)
4eeae967db chore: Remove unused json import in badges.py 2025-03-20 14:05:38 -07:00
Paul Gauthier (aider)
0ac2a85a3e style: Reformat code and fix import order in badges.py 2025-03-20 14:05:26 -07:00
Paul Gauthier (aider)
71884e58d4 feat: Add script to fetch total downloads from pepy.tech API 2025-03-20 14:05:22 -07:00
Paul Gauthier
37b2f9617c feat: Add badges generation script 2025-03-20 14:05:21 -07:00
Paul Gauthier (aider)
01af14693c chore: Add Jekyll front matter to index.html for templating support 2025-03-20 13:50:37 -07:00
Paul Gauthier
90e2929fc5 copy 2025-03-20 13:47:13 -07:00
Paul Gauthier (aider)
8f260aa544 docs: Add tooltips to README badges 2025-03-20 13:44:34 -07:00
Paul Gauthier (aider)
ee72a09278 feat: Add tooltips to explain stats badges 2025-03-20 13:43:16 -07:00
Paul Gauthier
e6a422b6c2 copy 2025-03-20 11:45:50 -07:00
Paul Gauthier
d29aff919b copy 2025-03-20 11:20:01 -07:00
Paul Gauthier (aider)
5023bbe8c0 style: Fix lint issues by removing unused import and adding whitespace 2025-03-20 11:09:15 -07:00
Paul Gauthier
c08e3daf29 slim down logo svg 2025-03-20 11:08:31 -07:00
Paul Gauthier (aider)
9cf194b52b style: Format code with consistent spacing and line breaks 2025-03-20 11:07:55 -07:00
Paul Gauthier (aider)
1b0ba71ef0 refactor: Subset font to include only needed characters in SVG logo 2025-03-20 11:07:51 -07:00
Paul Gauthier
de5ab102b7 refactor: Update internal links to use relative paths 2025-03-20 11:04:16 -07:00
Paul Gauthier
4e2c7c3329 copy 2025-03-20 09:28:44 -07:00
Paul Gauthier (aider)
b62840c347 feat: Add SVG logo with progressive enhancement to Jekyll pages 2025-03-20 08:11:48 -07:00
Paul Gauthier
674379fe30 blame includes home page 2025-03-20 08:09:56 -07:00
Paul Gauthier
004ffb9f60 copy 2025-03-20 08:07:56 -07:00
Paul Gauthier (aider)
bed836b15a feat: Add progressive enhancement for SVG logo in header 2025-03-20 08:06:28 -07:00
Paul Gauthier
bbf219ecd2 refactor: Adjust Gaussian blur stdDeviation in SVG filter 2025-03-20 08:00:30 -07:00
Paul Gauthier (aider)
022bf4bdcc feat: Make SVG logo blur effect more transparent 2025-03-20 07:57:40 -07:00
Paul Gauthier
d8ed90a2c0 refactor: Adjust SVG glow filter parameters in logo_svg.py 2025-03-20 07:56:44 -07:00
Paul Gauthier (aider)
e5d9d91b01 style: Extend horizontal glow effect in logo SVG filter 2025-03-20 07:54:45 -07:00
Paul Gauthier (aider)
c8f6576cd7 feat: Add glow effect to SVG logo using Gaussian blur filter 2025-03-20 07:54:02 -07:00
Paul Gauthier
14f140fdc5 copy 2025-03-19 21:56:42 -07:00
Paul Gauthier (aider)
fdbe169423 refactor: Make SVG logo background transparent instead of white 2025-03-19 21:56:21 -07:00
Paul Gauthier (aider)
e4ec370e2a feat: Add bash syntax highlighting to code block using Prism.js 2025-03-19 21:54:34 -07:00
Paul Gauthier
dfbdb43c31 copy 2025-03-19 21:48:16 -07:00
Paul Gauthier (aider)
9b8606535d style: Vertically center text in SVG logo 2025-03-19 21:46:25 -07:00
Paul Gauthier (aider)
0b79fd0a8e style: Center text horizontally in SVG logo 2025-03-19 21:45:58 -07:00
Paul Gauthier
f032606f32 style: Change background color to black in SVG logo 2025-03-19 21:45:56 -07:00
Paul Gauthier
b652a8416d copy 2025-03-19 21:43:33 -07:00
Paul Gauthier
8f7b50f3df copy 2025-03-19 21:43:09 -07:00
Paul Gauthier
2adafad4e2 copy 2025-03-19 21:42:39 -07:00
Paul Gauthier (aider)
99a5862bc9 chore: Remove unused Path import from logo_svg.py 2025-03-19 21:40:48 -07:00
Paul Gauthier
6dda54f431 chore: Remove unused .logo-svg CSS class and add new logo SVG file 2025-03-19 21:40:37 -07:00
Paul Gauthier (aider)
8e187a913f docs: Add Aider logo to README.md 2025-03-19 21:38:48 -07:00
Paul Gauthier (aider)
8935c87d7a style: Format code with consistent quotes and line breaks 2025-03-19 21:36:20 -07:00
Paul Gauthier (aider)
c6e544750b feat: Add script to generate SVG logo with embedded font 2025-03-19 21:36:15 -07:00
Paul Gauthier
c14d406f59 feat: Add script for generating logo in SVG format 2025-03-19 21:36:14 -07:00
Paul Gauthier
4edfe39449 copy 2025-03-19 21:28:44 -07:00
Paul Gauthier (aider)
1239d77c88 docs: Add icons to feature list in README 2025-03-19 21:28:33 -07:00
Paul Gauthier
7d4b0b20e8 copy 2025-03-19 21:26:07 -07:00
Paul Gauthier
1f42cdd762 copy 2025-03-19 21:24:37 -07:00
Paul Gauthier (aider)
f182b81e0f docs: Add feature documentation links to README 2025-03-19 21:22:52 -07:00
Paul Gauthier
3f2256d4c4 rename 2025-03-19 21:21:29 -07:00
Paul Gauthier (aider)
e4b1b12b26 docs: Update README with polished content from index.html 2025-03-19 21:19:22 -07:00
Paul Gauthier
35477e0a5a docs: Add README.new.md 2025-03-19 21:19:21 -07:00
Paul Gauthier
f752c9c8a9 copy 2025-03-19 21:16:17 -07:00
Paul Gauthier (aider)
d5dd7b0a96 chore: Update badge text from "Codes Itself" to "Singularity" in README.md 2025-03-19 21:16:12 -07:00
Paul Gauthier
4e16eba6b0 docs: Update copy/paste feature description and button labels 2025-03-19 21:16:06 -07:00
Paul Gauthier (aider)
4f129e1c9d feat: Add feature cards for voice-to-code, linting/testing, and copy/paste 2025-03-19 21:06:04 -07:00
Paul Gauthier
ffbbb5539d docs: Update supported languages and API key placeholders in index.html 2025-03-19 21:06:03 -07:00
Paul Gauthier (aider)
30e5b48461 feat: Add CTA section to homepage with install and docs buttons 2025-03-19 20:45:37 -07:00
Paul Gauthier
0dc31011f5 chore: Update website text and remove redundant content 2025-03-19 20:45:35 -07:00
Paul Gauthier
479df00a3b chore: Update badge label from "Codes Itself" to "Inception" 2025-03-19 20:38:12 -07:00
Paul Gauthier (aider)
06f3e15ce9 style: Reduce vertical space between video and badges on mobile 2025-03-19 20:35:01 -07:00
Paul Gauthier
2f7fde163a docs: Update website copy for clarity and consistency 2025-03-19 20:33:06 -07:00
Paul Gauthier (aider)
71d26c2ec5 style: Reduce hero section padding on mobile devices 2025-03-19 20:32:18 -07:00
Paul Gauthier
acf8b40a28 copy 2025-03-19 18:07:56 -07:00
Paul Gauthier (aider)
318027d9e1 docs: Add icons to README badges 2025-03-19 17:49:30 -07:00
Paul Gauthier (aider)
3116e833a7 docs: Add "Codes Itself" badge to README 2025-03-19 17:46:39 -07:00
Paul Gauthier (aider)
1cb71b33fa feat: Rename "Self-Coded" badge to "Codes Itself" and link to HISTORY.html 2025-03-19 17:45:47 -07:00
Paul Gauthier (aider)
7e76b8d0c3 style: Replace self-coded icon with brain and increase stats container width 2025-03-19 17:44:51 -07:00
Paul Gauthier (aider)
e0e78cd879 feat: Add "Self-Coded: 72%" badge to stats section 2025-03-19 17:43:01 -07:00
Paul Gauthier
82e4dcf40f copy 2025-03-19 17:07:31 -07:00
Paul Gauthier
22b77ad14f copy 2025-03-19 17:04:30 -07:00
Paul Gauthier
9b23975f09 copy 2025-03-19 17:00:07 -07:00
Paul Gauthier (aider)
584c3a65f5 docs: Add FAQ link to More Info resources 2025-03-19 16:58:42 -07:00
Paul Gauthier
db4d6c4419 docs: Update feature titles and descriptions on website 2025-03-19 16:58:40 -07:00
Paul Gauthier
92cb1c60d1 copy 2025-03-19 16:05:34 -07:00
Paul Gauthier (aider)
ca72d0ca5b style: Standardize feature card title capitalization 2025-03-19 14:24:31 -07:00
Paul Gauthier (aider)
ba7f245d88 fix: Center hero content horizontally on narrow screens 2025-03-19 14:17:57 -07:00
Marco Mayer
ef67ba5cf4 feat: vi-like behavior when pressing enter in multiline-mode while in vi normal/navigation-mode 2025-03-19 22:11:26 +01:00
Paul Gauthier (aider)
1f630a03b9 style: Update feature cards with blue underline instead of shaded header 2025-03-19 14:09:21 -07:00
Paul Gauthier (aider)
5f71cdc497 style: Remove blue vertical line from hero content 2025-03-19 14:08:32 -07:00
Paul Gauthier (aider)
b85226b8a5 style: Adjust hero section alignment, spacing, and visual hierarchy 2025-03-19 14:07:43 -07:00
Paul Gauthier (aider)
af4acccf9f style: Update video container background to match gradient better 2025-03-19 14:03:24 -07:00
Paul Gauthier (aider)
3a3bc9898d fix: maintain video aspect ratio using padding-bottom technique 2025-03-19 13:59:06 -07:00
Paul Gauthier (aider)
5349c99c74 fix: Add aspect-ratio to video container and preload metadata 2025-03-19 13:55:50 -07:00
Paul Gauthier
68d175f1c5 style: Update section title capitalization in index.html 2025-03-19 13:55:48 -07:00
Paul Gauthier
352f1f31d2 copy 2025-03-19 13:49:20 -07:00
Paul Gauthier (aider)
c51ef714ad style: Remove whitespace around badge <img> tags in README.md 2025-03-19 13:49:12 -07:00
Paul Gauthier
5ae68a3c48 docs: Update README.md with clearer project description 2025-03-19 13:49:11 -07:00
Paul Gauthier
d2c7e51fac copy 2025-03-19 13:47:16 -07:00
Paul Gauthier (aider)
d9aa3fb973 style: Increase top margin of stats-container to 50px 2025-03-19 13:44:43 -07:00
Paul Gauthier
e1b79ddd69 style: Adjust hero h1 font size to 2.5rem 2025-03-19 13:43:30 -07:00
Paul Gauthier (aider)
3270a8737c refactor: Move stats-container below hero-grid in HTML layout 2025-03-19 13:42:58 -07:00
Paul Gauthier
cbe8d320fa style: Update hero heading to lowercase in website index.html 2025-03-19 13:42:57 -07:00
Paul Gauthier (aider)
78ce63e71e refactor: Move hero heading into 40% split container 2025-03-19 13:38:53 -07:00
Paul Gauthier (aider)
1bb396bea5 feat: implement two-column layout for More Information section 2025-03-19 13:37:13 -07:00
Paul Gauthier (aider)
16304beeab style: Keep buttons side-by-side on narrow screens with responsive CSS 2025-03-19 13:34:28 -07:00
Paul Gauthier
d2cfd541ed margin 2025-03-19 13:31:54 -07:00
Paul Gauthier
8b1aaf690c gradient 2025-03-19 13:31:00 -07:00
Paul Gauthier
f1ca8f594c style: Adjust gradient colors in testimonial-card 2025-03-19 13:26:59 -07:00
Paul Gauthier (aider)
78d2e0aa25 style: Reduce mobile nav bar height and adjust logo size 2025-03-19 13:08:07 -07:00
Paul Gauthier
4a3d239082 copy 2025-03-19 12:47:22 -07:00
Paul Gauthier
94eaee8d39 copy 2025-03-19 12:46:28 -07:00
Paul Gauthier (aider)
471f03ab4f style: Reduce feature card padding on mobile devices 2025-03-19 12:45:18 -07:00
Paul Gauthier
9df9af822c style: Adjust code block font size in home.css 2025-03-19 12:45:16 -07:00
Paul Gauthier (aider)
7b49623b31 style: Reduce font sizes for mobile responsiveness 2025-03-19 12:41:25 -07:00
Paul Gauthier
12bda2b8d0 copy 2025-03-19 12:37:59 -07:00
Paul Gauthier
2022f214aa Merge branch 'home' 2025-03-19 12:37:42 -07:00
Paul Gauthier (aider)
786738ba81 refactor: Move CSS styles to separate home.css file 2025-03-19 12:36:02 -07:00
Paul Gauthier
e4f1b59475 feat: Add home.css for website assets 2025-03-19 12:33:55 -07:00
Paul Gauthier
7cb302f571 move home to / 2025-03-19 12:32:54 -07:00
Paul Gauthier
8bae91cf6e initial 2025-03-19 12:30:30 -07:00
Paul Gauthier
44a145fc86 copy 2025-03-19 12:30:21 -07:00
Paul Gauthier
a1fa62adef copy 2025-03-19 12:28:51 -07:00
Paul Gauthier (aider)
fe247a8f6a style: Lighten sidebar gradient color in head_custom.html 2025-03-19 12:24:46 -07:00
Paul Gauthier (aider)
54e70eff13 style: Lighten sidebar gradient color in head_custom.html 2025-03-19 12:23:45 -07:00
Paul Gauthier (aider)
5453f4a85d style: Update sidebar gradient end color to #F5F6FA 2025-03-19 12:19:22 -07:00
Paul Gauthier (aider)
f2654390e7 style: Add gradient to sidebar matching hero section 2025-03-19 12:18:03 -07:00
Paul Gauthier
777903f7da copy 2025-03-19 12:14:29 -07:00
Paul Gauthier (aider)
2f7892561f style: update .site-title font to match "aider" logo styling 2025-03-19 12:13:36 -07:00
Paul Gauthier (aider)
6d79000d6c style: Add custom CSS for .site-title in head_custom.html 2025-03-19 12:11:20 -07:00
Paul Gauthier (aider)
284911cd6b style: Increase font size in Getting Started section for better readability 2025-03-19 12:04:46 -07:00
Paul Gauthier
70b6da108c docs: Update testimonials section title in home.html 2025-03-19 12:04:45 -07:00
Paul Gauthier (aider)
6de3b2b262 style: Adjust testimonial card gradient to use more blue with hint of green 2025-03-19 12:03:45 -07:00
Paul Gauthier (aider)
e7554c5413 refactor: Remove quotes from testimonial text in home.html 2025-03-19 11:59:34 -07:00
Paul Gauthier (aider)
2facd2ab16 style: Add fancy typographic quotes to testimonials using CSS 2025-03-19 11:59:19 -07:00
Paul Gauthier (aider)
20ba252c56 feat: Add gradient backgrounds to testimonial cards 2025-03-19 11:58:15 -07:00
Paul Gauthier (aider)
eba123e381 style: Update hero gradient to incorporate blue palette and green logo color 2025-03-19 11:45:59 -07:00
Paul Gauthier (aider)
3bb57af331 style: Darken main "aider" logo font color 2025-03-19 11:44:02 -07:00
Paul Gauthier
aeb991fdf3 chore: Update logo text to lowercase in home.html 2025-03-19 11:44:00 -07:00
Paul Gauthier
75a14380ef refactor: Update font path in home.html to use assets directory 2025-03-19 11:42:55 -07:00
Paul Gauthier (aider)
0aeecf4d9a style: Update "Aider" logo to use terminal font and green color 2025-03-19 11:39:18 -07:00
Paul Gauthier (aider)
447347c760 style: Enhance hero section background with richer gradient and effects 2025-03-19 11:36:43 -07:00
Paul Gauthier
79619de045 docs: Update language support description in home.html 2025-03-19 11:36:42 -07:00
Paul Gauthier (aider)
1af423e2df style: Adjust hero section layout and background for better visual emphasis 2025-03-19 11:27:41 -07:00
Paul Gauthier
92fcf9a159 badges in main readme 2025-03-19 11:23:33 -07:00
Paul Gauthier (aider)
d1b1cc5c14 docs: Add stats badges to README.md 2025-03-19 11:19:17 -07:00
Paul Gauthier (aider)
b9514ad82a style: Update language support icon to use styled "</>" 2025-03-19 11:15:35 -07:00
Paul Gauthier (aider)
7b3411b236 docs: Update feature card to highlight language support 2025-03-19 11:13:23 -07:00
Paul Gauthier (aider)
915e87e88e feat: Make feature cards fully clickable with external links 2025-03-19 11:12:08 -07:00
Paul Gauthier (aider)
face505f0d style: Enhance feature card visual hierarchy with borders and spacing 2025-03-19 11:10:27 -07:00
Paul Gauthier
dada307e79 refactor: Simplify feature titles in home.html 2025-03-19 11:10:26 -07:00
Paul Gauthier (aider)
5124c512c9 style: Replace header border with shaded background in feature cards 2025-03-19 11:08:36 -07:00
Paul Gauthier (aider)
89f579c1ba refactor: add card header with icon and title for better visual integration 2025-03-19 11:07:49 -07:00
Paul Gauthier (aider)
0035f28035 chore: Update Git integration icon from 🔄 to 🔀 2025-03-19 11:02:42 -07:00
Paul Gauthier
4d556d9235 chore: Update token statistics label and value in home.html 2025-03-19 11:02:41 -07:00
Paul Gauthier (aider)
dd5ef29355 refactor: Reorder feature cards with LLM, Map, Multifile in first row 2025-03-19 10:59:51 -07:00
Paul Gauthier
ca9922ef0a refactor: Simplify paragraph in home.html 2025-03-19 10:59:50 -07:00
Paul Gauthier (aider)
b674a0a5e8 feat: Replace Voice Coding card with LLM compatibility card using brain icon 2025-03-19 10:57:49 -07:00
Paul Gauthier (aider)
541d0e6f5c docs: Add installation and usage links to home page paragraph 2025-03-19 10:56:29 -07:00
Paul Gauthier (aider)
fc96e980fb docs: Add link to LLM connection documentation in home page 2025-03-19 10:55:42 -07:00
Paul Gauthier
1425e3e6c7 chore: Update documentation links to point to install.html 2025-03-19 10:54:52 -07:00
Paul Gauthier (aider)
b9d3c11032 chore: Update documentation links to point to /docs/usage.html 2025-03-19 10:52:21 -07:00
Paul Gauthier
81b65e0de3 refactor: Remove "Top Tier Performance" section from home.html 2025-03-19 10:52:20 -07:00
Paul Gauthier
0f80f6af27 copy 2025-03-19 10:48:40 -07:00
Paul Gauthier (aider)
5eedf98aae refactor: Restructure hero section layout with full-width title and badges 2025-03-19 10:33:34 -07:00
Paul Gauthier (aider)
8f45a2ef3d style: Update responsive layout for mobile devices in home.html 2025-03-19 10:31:36 -07:00
Paul Gauthier (aider)
9d51d4a572 refactor: Reorganize hero section into two-column layout 2025-03-19 10:31:22 -07:00
Paul Gauthier (aider)
9978c8ea48 refactor: Replace link with div for Token Processed badge 2025-03-19 10:29:00 -07:00
Paul Gauthier
e779358429 chore: Update token badge label and value in home.html 2025-03-19 10:28:59 -07:00
Paul Gauthier (aider)
8d663cc3d6 style: restyle stats section to use GitHub badges format 2025-03-19 10:23:55 -07:00
Paul Gauthier (aider)
a98ca30438 fix: prevent recently removed testimonials from immediate reuse 2025-03-19 10:16:44 -07:00
Paul Gauthier (aider)
589cb2ac79 feat: prevent consecutive flips of the same testimonial card 2025-03-19 10:14:59 -07:00
Paul Gauthier (aider)
d973be8fea feat: Add 3D card flip animation to testimonials 2025-03-19 10:14:11 -07:00
Paul Gauthier (aider)
41c3b59755 refactor: change testimonial rotation to random selection 2025-03-19 10:12:51 -07:00
Paul Gauthier (aider)
8bf168da47 feat: Update testimonials to rotate one at a time with fade animation 2025-03-19 10:11:30 -07:00
Paul Gauthier
0d85c06be2 refactor: Adjust testimonial rotation interval in home.html 2025-03-19 10:11:26 -07:00
Paul Gauthier (aider)
fadede7305 feat: Add dynamic rotating testimonials with user links 2025-03-19 10:09:21 -07:00
Paul Gauthier
a24d31fbba docs: Update feature title in home.html to "Map Of Your Code" 2025-03-19 10:09:08 -07:00
Paul Gauthier (aider)
c9d463443a style: Update IDE feature card icon to desktop emoji 2025-03-19 10:03:51 -07:00
Paul Gauthier (aider)
0e3d486658 docs: Update feature card to highlight IDE integration 2025-03-19 10:02:24 -07:00
Paul Gauthier (aider)
574ab6bdda feat: Add links to feature descriptions in home.html 2025-03-19 09:29:47 -07:00
Paul Gauthier
a172d15463 refactor: Update stats section in home.html with new icons and labels 2025-03-19 09:29:45 -07:00
Paul Gauthier (aider)
a1362b946a style: Enhance stats section with modern cards and hover effects 2025-03-19 09:04:05 -07:00
Paul Gauthier (aider)
6ecb4c5ece feat: Add stats section to home page 2025-03-19 09:02:36 -07:00
Paul Gauthier
63c1320f36 feat: Add initial home.html for Aider website 2025-03-19 09:02:34 -07:00
Paul Gauthier
bf484ce4c4 chore: Remove home.html file 2025-03-19 08:59:59 -07:00
Paul Gauthier
1700212f30 copy 2025-03-19 08:54:22 -07:00
Paul Gauthier
751ca3bf75 copy 2025-03-19 08:22:46 -07:00
Paul Gauthier (aider)
01be8bc64e style: Make macos-backdrop padding responsive using clamp() 2025-03-19 08:20:07 -07:00
Paul Gauthier
a9e8005b14 style: Adjust padding comment in macos-backdrop CSS class 2025-03-19 08:20:05 -07:00
Paul Gauthier (aider)
871cff6232 feat: Add stylish HTML landing page for Aider 2025-03-19 08:16:25 -07:00
Paul Gauthier
1de8f5ceda feat: Add home.html for website 2025-03-19 08:16:21 -07:00
Paul Gauthier
dd4d2420df copy 2025-03-18 19:07:03 -07:00
Paul Gauthier (aider)
e9b1a98314 fix: Adjust z-index and opacity for backdrop decorative lines 2025-03-18 19:00:24 -07:00
Paul Gauthier (aider)
f0f48e8e30 fix: Ensure decorative lines only appear in backdrop, not terminal area 2025-03-18 18:59:29 -07:00
Paul Gauthier (aider)
89b008e1eb style: Add decorative curved lines to macos-backdrop background 2025-03-18 18:58:05 -07:00
Paul Gauthier (aider)
fb3f8439e2 style: Increase top/bottom padding of .macos-backdrop by 50% 2025-03-18 18:57:30 -07:00
Paul Gauthier (aider)
f0e66d2bfb feat: Add macOS-like colorful backdrop to terminal display 2025-03-18 18:53:11 -07:00
Paul Gauthier
65ec254c1b copy 2025-03-18 18:42:23 -07:00
Paul Gauthier
47c0d95bd4 refactor: Add missing --read flag in update-history.py 2025-03-18 18:26:08 -07:00
Paul Gauthier
55d7bed563 copy 2025-03-18 18:25:57 -07:00
Paul Gauthier (aider)
9a4f3b8d8e style: Format code and add whitespace for readability 2025-03-18 18:23:45 -07:00
Paul Gauthier (aider)
d9c5ce15f3 refactor: Separate git log and diff in update-history script 2025-03-18 18:23:42 -07:00
Paul Gauthier (aider)
292908288b chore: Remove unused import of __version__ from aider 2025-03-18 18:18:51 -07:00
Paul Gauthier (aider)
7fec2661fc style: Standardize string quotes in update-history.py 2025-03-18 18:18:39 -07:00
Paul Gauthier (aider)
0cee8bc6ac refactor: Use latest version header in HISTORY.md for git log range 2025-03-18 18:18:34 -07:00
Paul Gauthier
37d867e47e better 2025-03-18 18:15:08 -07:00
Paul Gauthier
c1338fe92f copy 2025-03-18 18:09:25 -07:00
Paul Gauthier
1e90a679c0 copy 2025-03-18 18:06:41 -07:00
Paul Gauthier (aider)
ddb7b9cb8b docs: Expand explanation of accepts_settings behavior in reasoning docs 2025-03-18 17:45:19 -07:00
Paul Gauthier (aider)
31e1604d99 docs: Update reasoning settings documentation for accepts_settings and --no-check-model-accepts-settings 2025-03-18 17:45:06 -07:00
Paul Gauthier
e11c32bca5 refactor: Simplify model setting warning message in main.py 2025-03-18 17:43:57 -07:00
Paul Gauthier
16309dc077 test: Update test assertions and model in test_main.py 2025-03-18 17:40:26 -07:00
Paul Gauthier (aider)
8a1b496cd5 style: Format test_main.py with linter 2025-03-18 17:37:01 -07:00
Paul Gauthier (aider)
99cf99e014 test: update test for --check-model-accepts-settings flag 2025-03-18 17:36:55 -07:00
Paul Gauthier (aider)
f2e9b06dbd fix: Update tests and logic for model settings acceptance checks 2025-03-18 17:36:30 -07:00
Paul Gauthier (aider)
6cce7c34c2 style: Format test_main.py with linter 2025-03-18 17:33:58 -07:00
Paul Gauthier (aider)
dd2efac3ae test: verify Model.set_ methods are called appropriately in tests 2025-03-18 17:33:52 -07:00
Paul Gauthier (aider)
14c0e50721 style: Format warning message in main.py for readability 2025-03-18 17:22:31 -07:00
Paul Gauthier (aider)
68e218d002 refactor: ignore unsupported model parameters with warning instead of prompt 2025-03-18 17:22:25 -07:00
Paul Gauthier
0a026e71b7 copy 2025-03-18 14:43:36 -07:00
Paul Gauthier
5175a8c7ca copy 2025-03-18 14:42:12 -07:00
Paul Gauthier
661e0cfc71 copy 2025-03-18 14:30:22 -07:00
Paul Gauthier
9ff6f35330 copy 2025-03-18 14:13:08 -07:00
Paul Gauthier
ab5a066780 feat: Add controls to video player in recording.js 2025-03-18 14:05:06 -07:00
Paul Gauthier (aider)
c2d649e655 refactor: Use Jekyll templating for recordings list generation 2025-03-18 14:04:29 -07:00
Paul Gauthier (aider)
f82bb65810 docs: Add descriptions to recording pages using text from index 2025-03-18 14:03:03 -07:00
Paul Gauthier
e76c54b18e docs: Add empty description field to model-accepts-settings.md 2025-03-18 14:03:02 -07:00
Paul Gauthier
43658055d3 copy 2025-03-18 13:58:31 -07:00
Paul Gauthier (aider)
0b71fded7f docs: Add entry for model-accepts-settings recording to index 2025-03-18 13:56:43 -07:00
Paul Gauthier
03d1bada2a add model-accepts-settings recording 2025-03-18 13:53:16 -07:00
Paul Gauthier (aider)
ad76355299 feat: make toast notifications persist until audio/speech completes 2025-03-18 13:32:59 -07:00
Paul Gauthier (aider)
c98d409f0a fix: prevent duplicate speech synthesis fallback 2025-03-18 13:30:31 -07:00
Paul Gauthier
9084673fd7 copy 2025-03-18 12:39:01 -07:00
Paul Gauthier
8d7300a522 docs: Update reasoning model compatibility and settings documentation 2025-03-18 12:36:27 -07:00
Paul Gauthier (aider)
7c10600044 docs: Update reasoning model settings documentation with compatibility details 2025-03-18 12:32:22 -07:00
Paul Gauthier
277da37047 refactor: Simplify warning message in main.py 2025-03-18 12:30:47 -07:00
Paul Gauthier (aider)
f6d697ed2b refactor: rename warned to warn_setting for clarity 2025-03-18 12:28:41 -07:00
Paul Gauthier (aider)
f247927244 style: Format code to comply with linter rules 2025-03-18 12:27:54 -07:00
Paul Gauthier (aider)
7097e62582 refactor: Consolidate model setting checks into a loop 2025-03-18 12:27:48 -07:00
Paul Gauthier (aider)
e577bab263 refactor: Improve model settings warning logic and fix tmux recording script 2025-03-18 12:27:33 -07:00
Paul Gauthier (aider)
274c40793f refactor: Use warn_setting variable for model setting warnings 2025-03-18 12:27:28 -07:00
Paul Gauthier
afbe9266e7 refactor: Simplify warning messages and confirmation prompt 2025-03-18 12:27:27 -07:00
Paul Gauthier (aider)
195ed3e6b6 style: Remove trailing whitespace and format confirm_ask call 2025-03-18 12:24:13 -07:00
Paul Gauthier (aider)
ed8ace7884 feat: Add confirmation prompt for unsupported model parameters 2025-03-18 12:24:06 -07:00
Paul Gauthier (aider)
14761ebec2 fix: Update test_thinking_tokens_option to check correct thinking tokens location 2025-03-18 12:22:13 -07:00
Paul Gauthier (aider)
50d8a19397 style: Format test_main.py with consistent line breaks 2025-03-18 12:18:57 -07:00
Paul Gauthier (aider)
719324981d test: Add tests for accepts_settings configuration and thinking_tokens option 2025-03-18 12:18:52 -07:00
Paul Gauthier (aider)
182c06107f fix: move model setting warnings after settings are resolved 2025-03-18 12:13:55 -07:00
Paul Gauthier (aider)
d4d4852a0c feat: Add thinking_tokens and reasoning_effort settings to models 2025-03-18 12:08:52 -07:00
Paul Gauthier (aider)
f352fed313 style: Remove trailing whitespace in models.py 2025-03-18 12:05:23 -07:00
Paul Gauthier (aider)
5dfce2d199 feat: Add reasoning_effort and thinking_tokens settings to specific models 2025-03-18 12:05:17 -07:00
Paul Gauthier
6aafac544b refactor: Remove accepts_settings from model configurations 2025-03-18 12:05:11 -07:00
Paul Gauthier (aider)
2589c29b1c style: Format code to comply with linter rules 2025-03-18 12:01:55 -07:00
Paul Gauthier (aider)
076c38526a feat: Add --check-model-accepts-settings flag with default true 2025-03-18 12:01:45 -07:00
Paul Gauthier (aider)
9fd5cfa777 fix: warn when model settings are empty or missing specific keys 2025-03-18 12:00:36 -07:00
Paul Gauthier (aider)
c01db8783d style: Format warning messages to adhere to line length limit 2025-03-18 11:57:38 -07:00
Paul Gauthier (aider)
77101a96a1 feat: Add model setting validation for reasoning features 2025-03-18 11:57:31 -07:00
Paul Gauthier (aider)
46863b470c feat: Add terminal size output to tmux_record.sh 2025-03-18 11:53:28 -07:00
Paul Gauthier
736c1f7e1e chore: Make tmux_record.sh executable 2025-03-18 11:53:26 -07:00
Paul Gauthier (aider)
4cf9679334 feat: add check for exactly one active tmux window 2025-03-18 11:50:12 -07:00
Paul Gauthier
89c9290602 refactor: Simplify asciinema command in tmux_record.sh 2025-03-18 11:50:10 -07:00
Paul Gauthier (aider)
3ba75c5a62 feat: Add dynamic tmux window size detection to recording script 2025-03-18 11:49:25 -07:00
Paul Gauthier
4ceaed7183 feat: Add tmux recording script 2025-03-18 11:49:24 -07:00
Paul Gauthier
f310497d47 copy 2025-03-18 09:55:47 -07:00
Paul Gauthier
94bcaa71e6 copy 2025-03-17 21:24:34 -07:00
Paul Gauthier
67bdccbda6 refactor: Adjust padding in NoInsetCodeBlock syntax rendering 2025-03-17 21:17:02 -07:00
Paul Gauthier (aider)
f89dabbd0a refactor: Replace make_elements() with class var in NoInsetMarkdown 2025-03-17 21:15:30 -07:00
Paul Gauthier
76eee60ad5 refactor: Update NoInsetMarkdown to use NoInsetCodeBlock for fence elements 2025-03-17 21:15:28 -07:00
Paul Gauthier (aider)
ac4e4959eb style: Format code according to linter rules 2025-03-17 21:10:17 -07:00
Paul Gauthier (aider)
7316635aba feat: Remove padding from markdown code blocks using NoInsetMarkdown 2025-03-17 21:10:12 -07:00
Paul Gauthier
feb277049f copy 2025-03-17 19:43:50 -07:00
Paul Gauthier
35d5febd7d copy 2025-03-17 19:05:31 -07:00
Paul Gauthier
97a3bfca4e set version to 0.77.2.dev 2025-03-17 18:07:22 -07:00
Paul Gauthier
cf58133e06 version bump to 0.77.1 2025-03-17 18:07:19 -07:00
Paul Gauthier
0d1811a4ae chore: Update exclude patterns in help_pats.py 2025-03-17 18:03:59 -07:00
Paul Gauthier
2a8bb715f0 copy 2025-03-17 17:29:54 -07:00
Paul Gauthier
cf93869d3f gemma3b 2025-03-17 16:39:45 -07:00
Paul Gauthier
77976a5253 copy 2025-03-17 10:24:07 -07:00
Paul Gauthier
5af46aaa2e bump deps 2025-03-17 10:23:21 -07:00
lentil32 (aider)
679c634459 test: Add tests for AWS credential handling with AWS_PROFILE 2025-03-16 16:09:32 +09:00
lentil32 (aider)
cc33fc2822 feat: Handle AWS_PROFILE for Bedrock models in validate_environment 2025-03-16 16:00:15 +09:00
Paul Gauthier (aider)
4f4b10fd86 feat: Hide keyboard shortcuts on devices without physical keyboards 2025-03-14 19:43:16 -07:00
Paul Gauthier (aider)
26789115b6 fix: improve iOS audio playback with global audio element and better fallback 2025-03-14 19:40:27 -07:00
Paul Gauthier
87a28dcb9f copy 2025-03-14 19:17:51 -07:00
Paul Gauthier
1ad99f39e2 formatting 2025-03-14 19:14:22 -07:00
Paul Gauthier (aider)
dfbeec199e style: Properly indent HTML divs in recording.md 2025-03-14 19:13:32 -07:00
Paul Gauthier
41a99ec29d use better TTS 2025-03-14 19:10:35 -07:00
Paul Gauthier (aider)
7cee3aa1f1 fix: prevent duplicate speech synthesis fallback in recording.js 2025-03-14 19:07:53 -07:00
Paul Gauthier (aider)
b86d8099f1 fix: Remove unused import and convert f-strings without placeholders 2025-03-14 18:55:58 -07:00
Paul Gauthier (aider)
9c4a0043dd style: Format code to comply with linter rules 2025-03-14 18:55:36 -07:00
Paul Gauthier (aider)
5cde755976 feat: compress MP3 files using FFmpeg with configurable bitrate 2025-03-14 18:55:31 -07:00
Paul Gauthier (aider)
51aab7b656 feat: Print audio directory path on script launch 2025-03-14 18:53:31 -07:00
Paul Gauthier (aider)
791dc213fa style: Format code with linter 2025-03-14 18:52:47 -07:00
Paul Gauthier (aider)
8404165db3 feat: Add metadata tracking and TTS fallback improvements 2025-03-14 18:52:41 -07:00
Paul Gauthier (aider)
aee52c01a3 style: Remove trailing whitespace in recording_audio.py 2025-03-14 18:49:16 -07:00
Paul Gauthier (aider)
58e16b0c48 fix: Remove global VOICE usage and pass voice parameter directly 2025-03-14 18:49:12 -07:00
Paul Gauthier
3225ac88c0 chore: Make recording_audio.py executable 2025-03-14 18:49:10 -07:00
Paul Gauthier (aider)
38b8b85ec2 style: Format code with linter 2025-03-14 18:47:12 -07:00
Paul Gauthier (aider)
278f748c1c feat: Add OpenAI TTS audio generation and playback for recordings 2025-03-14 18:47:06 -07:00
Paul Gauthier
874df40303 feat: Add audio recording script 2025-03-14 18:47:04 -07:00
Paul Gauthier
0465d8ce80 chore: Simplify recording markdown files and update model settings 2025-03-14 18:37:13 -07:00
Paul Gauthier (aider)
e9b3f5fd43 refactor: Move recording code to shared include file 2025-03-14 18:34:19 -07:00
Paul Gauthier
c49bc2418b chore: Refactor recording script and comments into separate file 2025-03-14 18:34:17 -07:00
Paul Gauthier
fd21f5195d chore: Update polyglot leaderboard entry with new test results 2025-03-14 18:19:20 -07:00
Paul Gauthier
a1aa63fa06 copy 2025-03-14 15:15:34 -07:00
Paul Gauthier
b0a619c714 copy 2025-03-14 14:19:51 -07:00
Paul Gauthier
ec648f2c6f copy 2025-03-14 14:14:54 -07:00
Paul Gauthier
7ac7c72e03 refactor: Simplify terminal event processing in redact-cast.py 2025-03-14 13:34:21 -07:00
Paul Gauthier
f1d00dbd7f better 2025-03-14 11:59:25 -07:00
Paul Gauthier (aider)
f644aba7a8 docs: Suppress Jekyll TOC in recordings index 2025-03-14 11:53:40 -07:00
Paul Gauthier (aider)
ed75287c8c docs: Add detailed descriptions to screen recordings index 2025-03-14 11:53:06 -07:00
Paul Gauthier
a035c73c41 docs: Add screen recordings index page 2025-03-14 11:53:03 -07:00
Paul Gauthier
781a619262 moved 2025-03-14 11:43:52 -07:00
Paul Gauthier
e08b63cc9f initial 2025-03-14 11:42:05 -07:00
Paul Gauthier
97ed57a252 initial 2025-03-14 11:25:24 -07:00
Paul Gauthier
71f1779c8c refac 2025-03-14 11:18:19 -07:00
Paul Gauthier (aider)
116f44cade feat: Focus player on page load for immediate keyboard control 2025-03-14 10:05:14 -07:00
Paul Gauthier (aider)
2ebdd689ab chore: Replace double dashes with em dashes in keyboard shortcuts 2025-03-14 10:03:08 -07:00
Paul Gauthier
beecc1a718 docs: Update keyboard shortcuts formatting in tree-sitter-language-pack.md 2025-03-14 10:03:07 -07:00
Paul Gauthier
557ba2adc1 copy 2025-03-14 10:01:31 -07:00
Paul Gauthier (aider)
89780c1283 feat: Add keyboard shortcuts info below terminal with styling 2025-03-14 10:00:21 -07:00
Paul Gauthier
411e7f86c1 copy 2025-03-14 09:56:32 -07:00
Paul Gauthier
610fce67e1 copy 2025-03-14 09:49:26 -07:00
Paul Gauthier
d9350cd3ed Merge branch 'main' of github.com:Aider-AI/aider 2025-03-14 09:41:54 -07:00
Paul Gauthier
54d6643a1f copy 2025-03-14 09:41:37 -07:00
Paul Gauthier (aider)
f664420628 refactor: Update JavaScript to use "Commentary" instead of "Transcript" 2025-03-14 09:40:11 -07:00
Paul Gauthier (aider)
d4d4c6de68 style: Add margin-top to terminal-container class 2025-03-14 09:38:10 -07:00
Paul Gauthier
b4313599f8 rename 2025-03-14 09:37:27 -07:00
Paul Gauthier (aider)
6866f8f0a9 style: Add whitespace above terminal-container in HTML 2025-03-14 09:37:23 -07:00
Paul Gauthier
3cb478214b docs: Add tree-sitter-language-pack example transcript 2025-03-14 09:37:21 -07:00
Paul Gauthier
8d7b4d6446 copy 2025-03-14 09:35:29 -07:00
Paul Gauthier
cc6b0bcd72 copy 2025-03-14 09:33:05 -07:00
Paul Gauthier (aider)
831564cf48 fix: prevent auto-scroll when highlighting playback timestamps 2025-03-14 09:23:10 -07:00
Paul Gauthier
4e59b62026 docs: Update recording transcript with language pack integration details 2025-03-14 08:58:33 -07:00
Paul Gauthier (aider)
f345b9b0ff feat: Make entire transcript list items clickable 2025-03-14 08:56:30 -07:00
Paul Gauthier (aider)
d4fb88a8c4 feat: Highlight last-played marker in transcript 2025-03-14 08:55:15 -07:00
Paul Gauthier (aider)
2cb1b6be46 feat: Add toast and speech triggers on timestamp click 2025-03-14 08:54:08 -07:00
Paul Gauthier (aider)
feda315c2b feat: make transcript timestamps clickable to seek player 2025-03-14 08:53:07 -07:00
Paul Gauthier (aider)
41219a7d85 feat: Automatically parse transcript section to generate markers 2025-03-14 08:27:21 -07:00
Paul Gauthier
813a201b6a refactor: Move markers definition to recording.md and simplify recording.js 2025-03-14 08:27:20 -07:00
Paul Gauthier (aider)
1bc40d48fe refactor: Move CSS and JS to separate files and include them using Jekyll 2025-03-14 08:22:32 -07:00
Paul Gauthier
ddb4e51938 feat: Add recording.js and recording.css for website 2025-03-14 08:22:30 -07:00
Paul Gauthier (aider)
9ee67c343d fix: Show toast notifications in fullscreen mode 2025-03-14 08:13:11 -07:00
Paul Gauthier
bb816eae83 style: Adjust button min-width and update video markers in recording.md 2025-03-14 08:10:26 -07:00
Paul Gauthier (aider)
92bd446d09 style: Adjust toast notification size to fit marker text 2025-03-14 08:06:06 -07:00
Paul Gauthier
a7526fa9c4 docs: Update example recording marker text 2025-03-14 08:06:05 -07:00
Paul Gauthier (aider)
9b6ff487da fix: Prevent line breaks in toast notifications with CSS adjustments 2025-03-14 08:03:35 -07:00
Paul Gauthier (aider)
9d61490743 style: Make toast width adapt to text content 2025-03-14 07:52:24 -07:00
paul-gauthier
9cce6e41fa Merge pull request #3528 from bexelbie/patch-1 2025-03-14 06:49:10 -07:00
Brian Exelbierd
a56dbdf502 Update Benchmark README.md
Use a consistent clone url to help those who don't use ssh with GitHub.  This should not break for those who do.
2025-03-14 09:05:04 +01:00
Paul Gauthier (aider)
7d5f27fa34 style: Adjust toast notification width, padding, and font size 2025-03-13 19:42:51 -07:00
Paul Gauthier (aider)
a61ba0db22 feat: Replace transcript box with toast notifications for marker text 2025-03-13 19:42:19 -07:00
Paul Gauthier
7f02a889e2 style: Remove flexbox styling from recording.md layout 2025-03-13 19:42:17 -07:00
Paul Gauthier (aider)
88d388a574 refactor: Move page-container inline styles to CSS section 2025-03-13 19:39:59 -07:00
Paul Gauthier
4d5a659e1e style: Adjust container styles in recording.md 2025-03-13 19:39:55 -07:00
Paul Gauthier
ecfcf1071d style: Simplify page-container styling in recording.md 2025-03-13 19:30:14 -07:00
Paul Gauthier (aider)
ec385d45e9 style: Replace fixed max-width with aspect-ratio in page container 2025-03-13 19:29:08 -07:00
Paul Gauthier (aider)
985107bb4b style: Limit page-container width to 1200px and center it 2025-03-13 19:28:12 -07:00
Paul Gauthier
eb340c74ac style: Adjust max-height styling in recording example page 2025-03-13 19:28:09 -07:00
Paul Gauthier (aider)
9a16b33f00 feat: Add speech synthesis for marker labels in transcript 2025-03-13 19:14:54 -07:00
Paul Gauthier (aider)
0acebc5916 fix: resolve null reference in AsciinemaPlayer initialization 2025-03-13 18:05:14 -07:00
Paul Gauthier (aider)
8442d9fe5f feat: Add marker labels to transcript on separate lines 2025-03-13 18:04:16 -07:00
Paul Gauthier
5318dd1a80 feat: Add markers and event listener to recording example 2025-03-13 18:04:16 -07:00
Paul Gauthier
d916180ec8 refactor: Simplify transcript content in recording.md 2025-03-13 17:54:42 -07:00
Paul Gauthier (aider)
6e5aa08ee0 feat: Add transcript section below demo div in recording.md 2025-03-13 17:50:21 -07:00
Paul Gauthier
83e115cde5 docs: Add poster time to recording example 2025-03-13 17:50:19 -07:00
Paul Gauthier (aider)
a3a92cd5dd style: Reduce terminal header height and button sizes 2025-03-13 17:46:29 -07:00
Paul Gauthier
16fc10fb0f docs: Update terminal title in recording example 2025-03-13 17:46:27 -07:00
Paul Gauthier (aider)
6bba8b57d4 feat: Add macOS-style terminal header to demo div 2025-03-13 17:44:13 -07:00
Paul Gauthier (aider)
f45c75a137 style: Update demo div styling and background color 2025-03-13 17:42:39 -07:00
Paul Gauthier
3348df0652 style: Update terminal background color and theme in recording example 2025-03-13 17:42:37 -07:00
Paul Gauthier (aider)
3b6a01b63d fix: bind Jekyll to all interfaces in docker container 2025-03-13 17:39:51 -07:00
Paul Gauthier (aider)
a3554a95c5 perf: optimize Jekyll build with incremental and livereload options 2025-03-13 17:38:25 -07:00
Paul Gauthier (aider)
6fa9af20c0 style: Wrap CSS in <style> tags in recording.md 2025-03-13 17:37:31 -07:00
Paul Gauthier (aider)
e23437dfa4 style: Update terminal colors to match tmux window style 2025-03-13 17:37:06 -07:00
Paul Gauthier
dcf9eaad77 style: Add custom Asciinema player theme and set default theme 2025-03-13 17:37:05 -07:00
Paul Gauthier (aider)
768df05692 style: Limit asciinema player height to 80% of viewport 2025-03-13 17:30:07 -07:00
Paul Gauthier
e0d5d35e32 docs: Update recording example with new asciinema player config 2025-03-13 17:30:05 -07:00
Paul Gauthier
a718a05414 initial 2025-03-13 17:20:47 -07:00
Paul Gauthier
953391d9d0 refactor: Optimize terminal emulator initialization in redact-cast.py 2025-03-13 16:30:41 -07:00
Paul Gauthier (aider)
4ca229fd42 refactor: Use regex to check for ordered "Atuin" characters in line 2025-03-13 16:19:31 -07:00
Paul Gauthier
693a43efc8 refactor: Simplify JSON parsing logic in redact-cast.py 2025-03-13 16:19:29 -07:00
Paul Gauthier (aider)
f3d4c931f5 style: Remove trailing whitespace in redact-cast.py 2025-03-13 16:14:00 -07:00
Paul Gauthier (aider)
ece21315b1 perf: Skip JSON parsing when terminal checking isn't needed 2025-03-13 16:13:56 -07:00
Paul Gauthier
318cc57ffe refactor: Simplify terminal feed logic in redact-cast.py 2025-03-13 16:13:55 -07:00
Paul Gauthier (aider)
ba17924174 style: Remove trailing whitespace in redact-cast.py 2025-03-13 16:11:44 -07:00
Paul Gauthier (aider)
6bc9daa6ee perf: Optimize terminal emulation by checking for "Atuin" first 2025-03-13 16:11:41 -07:00
Paul Gauthier (aider)
2d8bc95bae style: Format code with consistent quotes and spacing 2025-03-13 16:08:57 -07:00
Paul Gauthier (aider)
520eb4a932 perf: Optimize asciinema cast processing with line-by-line streaming and early exit 2025-03-13 16:08:53 -07:00
Paul Gauthier
03733516cc refactor: Simplify "Atuin" visibility check in redact-cast.py 2025-03-13 16:08:52 -07:00
Paul Gauthier (aider)
e561130336 style: Remove trailing whitespace in redact-cast.py 2025-03-13 16:04:16 -07:00
Paul Gauthier (aider)
169fa2e7b7 feat: Print terminal dimensions after parsing header 2025-03-13 16:04:12 -07:00
Paul Gauthier (aider)
6d6db996fb style: Remove trailing whitespace in redact-cast.py 2025-03-13 16:03:30 -07:00
Paul Gauthier (aider)
f8642bfd94 perf: Stream filtered events directly to output file for memory efficiency 2025-03-13 16:03:27 -07:00
Paul Gauthier (aider)
dfdd6bf533 style: Remove trailing whitespace in redact-cast.py 2025-03-13 16:02:52 -07:00
Paul Gauthier (aider)
91cef71048 feat: set screen size from asciinema cast header 2025-03-13 16:02:48 -07:00
Paul Gauthier (aider)
3daf632384 feat: Add tqdm progress bar for event processing 2025-03-13 16:01:47 -07:00
Paul Gauthier (aider)
dba5fb9dfa style: Format code with consistent quotes and spacing 2025-03-13 16:00:40 -07:00
Paul Gauthier (aider)
70d10a0bb2 feat: Add script to filter asciinema cast files for "Atuin" visibility 2025-03-13 16:00:35 -07:00
Paul Gauthier
97291b806a refactor: Simplify redact-cast.py by removing custom logic and importing pyte 2025-03-13 16:00:34 -07:00
Paul Gauthier (aider)
c583f008e9 style: Make demo div full width in recording.md 2025-03-13 15:31:48 -07:00
Paul Gauthier
b182eba56f docs: Add recording example to website 2025-03-13 15:31:47 -07:00
Paul Gauthier
de5da0e7ce copy 2025-03-13 15:06:00 -07:00
Paul Gauthier
f2a893c0d4 set version to 0.77.1.dev 2025-03-13 14:44:50 -07:00
Paul Gauthier
371a03c794 version bump to 0.77.0 2025-03-13 14:44:47 -07:00
Paul Gauthier
88e3d48be5 copy 2025-03-13 14:24:19 -07:00
Paul Gauthier
e8a8681a75 chore: Update polyglot leaderboard YAML files with new test case data 2025-03-13 14:16:20 -07:00
Paul Gauthier
b541eec3b8 chore: Add new model settings to model-settings.yml 2025-03-13 14:08:36 -07:00
Paul Gauthier (aider)
ce3f732645 style: Format Model class constructor for readability 2025-03-13 14:00:27 -07:00
Paul Gauthier (aider)
1b3cae1ed5 feat: Add verbose flag to conditionally dump kwargs in Model.send 2025-03-13 14:00:20 -07:00
Paul Gauthier
024b9130a0 copy 2025-03-12 16:22:26 -07:00
Paul Gauthier
61a8b6020f copy 2025-03-12 16:07:38 -07:00
Paul Gauthier
d25877aace Merge branch 'tsl-pack-add' 2025-03-12 15:58:28 -07:00
Paul Gauthier
c3c2d4dc22 bump deps 2025-03-12 15:57:21 -07:00
Paul Gauthier
7454154599 copy 2025-03-12 15:56:33 -07:00
Paul Gauthier (aider)
04ecea614b refactor: Simplify _test_language_repo_map signature and use self.fixtures_dir 2025-03-12 15:38:07 -07:00
Paul Gauthier (aider)
084a14b640 style: Remove unnecessary blank lines in test_repomap.py 2025-03-12 15:36:18 -07:00
Paul Gauthier (aider)
a477759a49 refactor: Update fixtures_dir references to use self.fixtures_dir 2025-03-12 15:36:13 -07:00
Paul Gauthier
d4df207612 refactor: Move fixtures_dir initialization to setUp in TestRepoMapAllLanguages 2025-03-12 15:36:12 -07:00
Paul Gauthier (aider)
57d492d4b8 style: Remove trailing whitespace in test_repomap.py 2025-03-12 15:34:28 -07:00
Paul Gauthier (aider)
fb7413436c refactor: Split language tests into individual test methods 2025-03-12 15:34:24 -07:00
Paul Gauthier
2cc8105e68 refactor: Split language tests into individual cases in test_repomap.py 2025-03-12 15:34:22 -07:00
Paul Gauthier (aider)
a83d5ff123 style: Format test_repomap.py with linter 2025-03-12 15:32:20 -07:00
Paul Gauthier (aider)
a709d650df refactor: Extract language test loop into helper method 2025-03-12 15:32:16 -07:00
Paul Gauthier
570e8eae31 refactor: Extract loop logic into helper method in test_repomap.py 2025-03-12 15:32:15 -07:00
Paul Gauthier (aider)
22f1703bee test: Update udev fixture to match query patterns 2025-03-12 15:30:23 -07:00
Paul Gauthier (aider)
14037eaeb8 test: add udev test case to TestRepoMapAllLanguages 2025-03-12 15:22:56 -07:00
Paul Gauthier (aider)
189d64dc3d test: Add Swift test case to TestRepoMapAllLanguages 2025-03-12 15:22:16 -07:00
Paul Gauthier (aider)
315f8093c6 test: Add Solidity test case and fixture to TestRepoMapAllLanguages 2025-03-12 15:21:45 -07:00
Paul Gauthier (aider)
a776d70e0d test: add Racket test case and fixture 2025-03-12 15:18:47 -07:00
Paul Gauthier (aider)
1ab6c70ac7 feat: Add R language test case and fixture for repository mapping 2025-03-12 15:16:02 -07:00
Paul Gauthier (aider)
73eb8701dd feat: Add properties language test case and fixture file 2025-03-12 15:13:56 -07:00
Paul Gauthier (aider)
a503f291e7 feat: Add Pony language test case and fixture 2025-03-12 15:12:56 -07:00
Paul Gauthier (aider)
b54d800024 feat: Add Lua language support to TestRepoMapAllLanguages 2025-03-12 15:11:31 -07:00
Paul Gauthier (aider)
d74068464d feat: Add Gleam language support to TestRepoMapAllLanguages 2025-03-12 15:09:43 -07:00
Paul Gauthier (aider)
86a5e8dbe1 feat: Add Elm fixture with Person type and main function 2025-03-12 15:08:36 -07:00
Paul Gauthier (aider)
24d2b683c8 feat: Add Dart language support to TestRepoMapAllLanguages 2025-03-12 15:06:27 -07:00
Paul Gauthier (aider)
9451f0abe4 feat: Add D language test fixture and update test mapping 2025-03-12 15:05:05 -07:00
Paul Gauthier (aider)
544d58ddbd feat: Add CommonLisp language support to TestRepoMapAllLanguages 2025-03-12 15:02:55 -07:00
Paul Gauthier (aider)
7c1d2d75e0 feat: Add chatito language support with test fixture 2025-03-12 14:40:43 -07:00
Paul Gauthier (aider)
0b949f47d9 feat: Add C language test fixture for repository mapping 2025-03-12 14:39:59 -07:00
Paul Gauthier (aider)
393b45dd21 feat: Add Arduino fixture file for language recognition test 2025-03-12 14:38:43 -07:00
Paul Gauthier (aider)
6bb43555dc feat: Add Arduino language support to TestRepoMapAllLanguages 2025-03-12 14:37:55 -07:00
Paul Gauthier (aider)
ba03b07602 refactor: Update udev-tags.scm with more specific @name tags 2025-03-12 14:27:50 -07:00
Paul Gauthier (aider)
0ac4c0b97d refactor: Update swift-tags.scm to use more specific @name.definition tags 2025-03-12 14:27:29 -07:00
Paul Gauthier
41e93a4d94 initial 2025-03-12 14:27:11 -07:00
Paul Gauthier (aider)
a0b5b19d38 refactor: Update solidity-tags.scm with more specific @name tags 2025-03-12 14:27:04 -07:00
Paul Gauthier (aider)
65fad5ae30 refactor: Update Rust tags to use more specific @name.definition and @name.reference tags 2025-03-12 14:26:32 -07:00
Paul Gauthier (aider)
a689f2116c refactor: Update ruby-tags.scm to use more specific tag names 2025-03-12 14:25:57 -07:00
Paul Gauthier (aider)
68b5c90d95 refactor: Update Racket tags to use @name.definition and @name.reference formats 2025-03-12 14:25:30 -07:00
Paul Gauthier (aider)
44eb9af7bc refactor: Update r-tags.scm to use more specific name tags 2025-03-12 14:25:12 -07:00
Paul Gauthier (aider)
9e824e6070 refactor: Update python-tags.scm with more specific name tags 2025-03-12 14:24:53 -07:00
Paul Gauthier (aider)
ba6bb527a7 refactor: Update properties-tags.scm to use more specific name tags 2025-03-12 14:24:32 -07:00
Paul Gauthier (aider)
3525eeae54 refactor: Update Pony tags to use .reference and .definition prefixes 2025-03-12 14:24:14 -07:00
Paul Gauthier (aider)
e535e01e83 refactor: Update Lua tags to use more specific reference and definition tags 2025-03-12 14:23:45 -07:00
Paul Gauthier (aider)
3b1c81e50e refactor: Enhance Java tags with specific definition and reference annotations 2025-03-12 14:23:12 -07:00
Paul Gauthier (aider)
89406e5b7d refactor: Update go-tags.scm to use more specific @name tags 2025-03-12 14:22:49 -07:00
Paul Gauthier (aider)
d5cc855c0f refactor: Update gleam-tags.scm to use more specific @name tags 2025-03-12 14:22:16 -07:00
Paul Gauthier (aider)
2ed61eaf92 refactor: Update Elm tags to use .reference and .definition namespaces 2025-03-12 14:21:35 -07:00
Paul Gauthier (aider)
865f71e2cc refactor: Update elixir-tags.scm to use more specific @name.reference and @name.definition tags 2025-03-12 14:21:05 -07:00
Paul Gauthier (aider)
08a75808df refactor: Update elisp-tags.scm to use more specific name tags 2025-03-12 14:20:39 -07:00
Paul Gauthier (aider)
c9dd37db8e refactor: Update dart-tags.scm to use @name.reference and @name.definition tags 2025-03-12 14:20:23 -07:00
Paul Gauthier (aider)
7e86c8a90c refactor: Update d-tags.scm to use more specific @name.reference and @name.definition tags 2025-03-12 14:19:38 -07:00
Paul Gauthier (aider)
b87a5496e9 refactor: Update cpp-tags.scm to use more specific name tags 2025-03-12 14:19:06 -07:00
Paul Gauthier (aider)
9a88363437 refactor: Update CommonLisp tags to use more specific @name.* tags 2025-03-12 14:18:40 -07:00
Paul Gauthier (aider)
c0b9665cfc refactor: Update chatito-tags.scm with explicit definition and reference tags 2025-03-12 14:18:12 -07:00
Paul Gauthier (aider)
70284ce1c2 refactor: Update c-tags.scm to use more specific @name.definition tags 2025-03-12 14:17:54 -07:00
Paul Gauthier (aider)
48621dadaa refactor: Update Arduino tags to use more specific @name.reference and @name.definition tags 2025-03-12 14:17:35 -07:00
Paul Gauthier
e69bad57e4 initial 2025-03-12 14:14:13 -07:00
Paul Gauthier (aider)
f55099e969 feat: Update script to download Tree-Sitter language tags to specific directory 2025-03-12 14:10:14 -07:00
Paul Gauthier (aider)
76994facec style: Apply linter formatting to tsl_pack_langs.py script 2025-03-12 13:55:52 -07:00
Paul Gauthier (aider)
2d843f6e79 feat: Add skip mechanism for existing tags.scm files in language download script 2025-03-12 13:55:47 -07:00
Paul Gauthier (aider)
e15518dd29 style: Fix linter formatting in tsl_pack_langs.py 2025-03-12 13:55:23 -07:00
Paul Gauthier (aider)
011e0fd109 feat: Print GitHub URL when processing each language 2025-03-12 13:55:17 -07:00
Paul Gauthier (aider)
5f125c1812 style: Format Python script with linter 2025-03-12 13:54:36 -07:00
Paul Gauthier (aider)
a6ebed8d16 feat: Improve language tag download script with multi-branch support 2025-03-12 13:54:31 -07:00
Paul Gauthier
849e02cbfb chore: Make tsl_pack_langs.py script executable 2025-03-12 13:54:27 -07:00
Paul Gauthier (aider)
1ab5238405 refactor: Simplify tags URL construction and remove unused import 2025-03-12 13:52:55 -07:00
Paul Gauthier (aider)
ae6192111d style: Format Python script with linter 2025-03-12 13:52:44 -07:00
Paul Gauthier (aider)
59af4114dd feat: Add script to fetch tags.scm files from GitHub repositories 2025-03-12 13:52:39 -07:00
Paul Gauthier
4491b88763 feat: Add script for packing translation languages 2025-03-12 13:52:35 -07:00
Paul Gauthier
92377fc390 fix: Add missing MagicMock import in test_coder.py 2025-03-12 13:45:10 -07:00
Paul Gauthier (aider)
79b8e50412 fix: Mock InputOutput object correctly in test_architect_coder_auto_accept_true 2025-03-12 13:42:27 -07:00
Paul Gauthier (aider)
b5cd39cc50 fix: Add mock for confirm_ask method in test_architect_coder_auto_accept_true 2025-03-12 13:41:39 -07:00
Paul Gauthier (aider)
63c2a98f3c fix: Add missing summarizer mock to ArchitectCoder tests 2025-03-12 13:41:10 -07:00
Paul Gauthier (aider)
c168f78a13 fix: Initialize cur_messages and done_messages in ArchitectCoder test cases 2025-03-12 13:40:15 -07:00
Paul Gauthier (aider)
42d45b4037 fix: Remove unused import of ANY from unittest.mock 2025-03-12 13:39:42 -07:00
Paul Gauthier (aider)
c41df63629 style: Reorder imports and fix whitespace in test_coder.py 2025-03-12 13:38:48 -07:00
Paul Gauthier (aider)
330bb81206 test: Add tests for auto_accept_architect feature in ArchitectCoder 2025-03-12 13:38:41 -07:00
Paul Gauthier (aider)
d84c755ee8 style: Apply linter formatting to redact-cast.py script 2025-03-12 13:28:06 -07:00
Paul Gauthier (aider)
a24ff28031 refactor: Remove 'env' key from .cast file header 2025-03-12 13:28:01 -07:00
Paul Gauthier (aider)
3a837c472e style: Apply linter formatting to redact-cast.py script 2025-03-12 13:25:08 -07:00
Paul Gauthier (aider)
f4880e2ef3 feat: Add ANSI escape sequence stripping for Atuin version detection 2025-03-12 13:25:03 -07:00
Paul Gauthier
a2e4022e31 copy 2025-03-12 13:12:18 -07:00
Paul Gauthier (aider)
5668b41daa feat: Add auto-accept option for architect coder edits 2025-03-12 13:09:41 -07:00
Paul Gauthier (aider)
c052270048 feat: Add --auto-accept-architect option with default true 2025-03-12 13:08:59 -07:00
Paul Gauthier (aider)
70547171ca style: Fix linter formatting in io.py 2025-03-12 12:50:04 -07:00
Paul Gauthier (aider)
881868bf17 refactor: Require 3 characters for autocomplete, except for commands 2025-03-12 12:49:57 -07:00
Paul Gauthier (aider)
e90eb39a9b style: Add whitespace around arithmetic operator in redact-cast.py 2025-03-11 19:30:57 -07:00
Paul Gauthier
9513d307a1 refactor: Reorganize redact script and improve code formatting 2025-03-11 19:30:46 -07:00
Paul Gauthier
533e5ec03f Merge remote-tracking branch 'source-repo/main' into redact 2025-03-11 19:29:57 -07:00
Paul Gauthier (aider)
55f63395c7 fix: Remove unused mock variables and split long comment lines in test_commands.py 2025-03-11 19:25:46 -07:00
Paul Gauthier (aider)
4253d98a73 style: Remove trailing whitespaces in test_commands.py 2025-03-11 19:25:24 -07:00
Paul Gauthier (aider)
0c4af58866 test: Add tests for /reset preserving original read-only files 2025-03-11 19:25:17 -07:00
Paul Gauthier
a5919bd27d copy 2025-03-11 19:12:35 -07:00
Paul Gauthier
5e40974fdd fix: Ensure default model is set only if not already specified 2025-03-11 19:07:53 -07:00
Paul Gauthier (aider)
a27f4d0e04 feat: Add speed-up factor to recording timestamps in redact.py 2025-03-11 17:54:12 -07:00
Paul Gauthier (aider)
1bb3041298 feat: Compress long timestamp gaps to 0.5 seconds in asciinema cast processing 2025-03-11 17:44:20 -07:00
Paul Gauthier
dc6040adda copy 2025-03-11 17:39:08 -07:00
Paul Gauthier
864725ff3d feat: Add command aliases and preserve read-only files in /drop 2025-03-11 17:38:13 -07:00
Paul Gauthier (aider)
0fcbea03e5 style: Format code and remove trailing whitespaces 2025-03-11 17:35:28 -07:00
Paul Gauthier (aider)
2ce63e6ad3 test: Add tests for preserving original read-only files during drop command 2025-03-11 17:35:21 -07:00
Paul Gauthier (aider)
d45af94cee refactor: Simplify original read-only files check in _drop_all_files method 2025-03-11 17:33:57 -07:00
Paul Gauthier (aider)
1f874b654d style: Format code with linter and improve readability 2025-03-11 17:31:22 -07:00
Paul Gauthier (aider)
a7a21757bc feat: Preserve original read-only files when using bare /drop command 2025-03-11 17:31:14 -07:00
Paul Gauthier (aider)
1bed4e8972 feat: Add 0.5 second pause after skipped sections in redaction script 2025-03-11 17:05:54 -07:00
Paul Gauthier (aider)
efcda12dda refactor: Maintain consistent timestamps during section skipping 2025-03-11 17:04:47 -07:00
Paul Gauthier (aider)
d7b4079ab5 refactor: Update redact.py to handle asciinema cast v2 JSON format 2025-03-11 17:03:19 -07:00
Paul Gauthier
2eb1513612 initial 2025-03-11 17:01:26 -07:00
Paul Gauthier
87bcbe0420 copy 2025-03-11 13:00:33 -07:00
Paul Gauthier (aider)
26b0c6e6da style: Add mobile-friendly CSS to hide command and edit columns 2025-03-11 12:51:38 -07:00
Paul Gauthier
8cfbc9b827 Revert "refactor: Improve chart responsiveness with dynamic mobile height"
This reverts commit 46eee9e642.
2025-03-11 12:37:56 -07:00
Paul Gauthier (aider)
46eee9e642 refactor: Improve chart responsiveness with dynamic mobile height 2025-03-11 12:33:45 -07:00
Paul Gauthier
7d902d2f3e test: Update token budget parsing test cases 2025-03-11 12:24:42 -07:00
Paul Gauthier
3d05007024 fix: Correct token budget message formatting in test case 2025-03-11 12:20:47 -07:00
Paul Gauthier (aider)
a2bf2e2910 style: Format long line in test_commands.py for better readability 2025-03-11 12:18:18 -07:00
Paul Gauthier (aider)
9cf4286cee fix: Update test to handle lowercase token budget input 2025-03-11 12:18:10 -07:00
Paul Gauthier (aider)
c9ddca3a16 feat: Update tests for /think and /reason to handle no-argument case 2025-03-11 12:16:54 -07:00
Paul Gauthier
06370cb096 copy 2025-03-11 12:14:47 -07:00
Paul Gauthier (aider)
342586519d fix: Update method calls to use main_model for get_thinking_tokens and get_reasoning_effort 2025-03-11 12:13:52 -07:00
Paul Gauthier (aider)
89174bb524 style: Format code with linter and improve whitespace 2025-03-11 12:12:20 -07:00
Paul Gauthier (aider)
1fa3bc4018 feat: Add display of current values for /think and /reason commands when called without arguments 2025-03-11 12:12:12 -07:00
Paul Gauthier (aider)
d68e2b33fb style: Remove trailing whitespaces in commands.py 2025-03-11 12:11:15 -07:00
Paul Gauthier (aider)
1313cd8216 refactor: Update thinking tokens and reasoning effort display with helper methods 2025-03-11 12:11:08 -07:00
Paul Gauthier (aider)
7afc8c760c feat: Add /think and /reason command aliases for think-tokens and reasoning-effort 2025-03-11 12:10:19 -07:00
Paul Gauthier (aider)
79f714ab16 refactor: Extract thinking tokens and reasoning effort methods into separate functions 2025-03-11 12:09:41 -07:00
Paul Gauthier
e21bab2d17 copy 2025-03-11 11:52:02 -07:00
Paul Gauthier (aider)
4288cf2a39 style: Apply linter formatting to test_commands.py 2025-03-11 11:49:46 -07:00
Paul Gauthier (aider)
9d570a9cb1 feat: Update test values to use 1024 base for k and M suffixes 2025-03-11 11:49:39 -07:00
Paul Gauthier (aider)
333ddfb37a style: Format Python code with linter 2025-03-11 11:48:21 -07:00
Paul Gauthier (aider)
10a5250527 test: Add tests for /think-tokens and /reasoning-effort commands 2025-03-11 11:48:13 -07:00
Paul Gauthier (aider)
fd57eccdca style: Remove trailing whitespaces in commands.py 2025-03-11 11:45:30 -07:00
Paul Gauthier (aider)
1432be9be6 feat: Add announcements output for /think and /reason commands 2025-03-11 11:45:23 -07:00
Paul Gauthier (aider)
1773bbf759 style: Shorten docstring to fix line length flake8 error 2025-03-11 11:43:59 -07:00
Paul Gauthier (aider)
5c94624186 style: Format code with linter 2025-03-11 11:43:47 -07:00
Paul Gauthier (aider)
dc06c2fab3 refactor: Update reasoning effort command to accept string values 2025-03-11 11:43:40 -07:00
Paul Gauthier (aider)
f37799b39c style: Fix linter formatting in base_coder.py 2025-03-11 11:42:46 -07:00
Paul Gauthier (aider)
cc84f590fe feat: Add reasoning effort display in get_announcements output 2025-03-11 11:42:38 -07:00
Paul Gauthier
afcf3e77b5 refactor: Reorder model info output for better readability 2025-03-11 11:42:36 -07:00
Paul Gauthier (aider)
0406dda2a6 feat: Add /reasoning-effort command to set model reasoning effort level 2025-03-11 11:41:46 -07:00
Paul Gauthier (aider)
935227f7e7 refactor: Use 1024 instead of 1000 for token budget formatting 2025-03-11 11:38:11 -07:00
Paul Gauthier (aider)
67ebb2566d style: Use lowercase 'k' for token budget display 2025-03-11 11:37:30 -07:00
Paul Gauthier (aider)
1c736161c5 feat: Omit decimal point for whole number token budget values 2025-03-11 11:37:01 -07:00
Paul Gauthier (aider)
a348c2d013 feat: Change --thinking-tokens argument type to string 2025-03-11 11:36:17 -07:00
Paul Gauthier (aider)
444a95bc6c style: Add whitespace around arithmetic operators in budget formatting 2025-03-11 11:35:49 -07:00
Paul Gauthier (aider)
c38cdef220 style: Format code with linter and improve readability 2025-03-11 11:35:31 -07:00
Paul Gauthier (aider)
5608db0892 feat: Add thinking token budget display in model details 2025-03-11 11:35:23 -07:00
Paul Gauthier
98b3722a02 refactor: Simplify thinking token budget display logic 2025-03-11 11:33:45 -07:00
Paul Gauthier (aider)
2d623ff196 style: Apply linter formatting to commands.py 2025-03-11 11:32:39 -07:00
Paul Gauthier (aider)
703e124277 feat: Add /think-tokens command to set thinking token budget 2025-03-11 11:32:32 -07:00
Paul Gauthier (aider)
68c27f885f style: Fix linting issues in test_models.py 2025-03-11 11:30:28 -07:00
Paul Gauthier (aider)
58cd190ca9 test: Add comprehensive tests for token parsing and thinking tokens methods 2025-03-11 11:30:23 -07:00
Paul Gauthier (aider)
2c5c2b2f67 style: Format code with linter and fix whitespace 2025-03-11 11:29:44 -07:00
Paul Gauthier (aider)
e10fe50c6f feat: Add flexible token parsing for set_thinking_tokens method 2025-03-11 11:29:38 -07:00
Paul Gauthier
b8ad0b15e8 copy 2025-03-11 09:38:28 -07:00
Paul Gauthier (aider)
1b81fb0fdf refactor: Modify git push to stream output directly to terminal 2025-03-11 09:25:44 -07:00
Adrian Cole
10d599f26a ollama: suggest higher minimum context length
This updates the doc with the new ENV variable ollama supports since [v0.5.13](https://github.com/ollama/ollama/releases/tag/v0.5.13)
2025-03-10 15:32:53 +08:00
Yutaka Matsubara
6b76ed8098 refactor: enhance --aiderignore argument to resolve absolute and relative paths 2025-03-10 08:41:49 +09:00
234 changed files with 10645 additions and 1514 deletions

View File

@@ -1,5 +1,50 @@
# Release history # Release history
### Aider v0.78.0
- Added model setting validation to ignore `--reasoning-effort` and `--thinking-tokens` if the model doesn't support them.
- Added `--check-model-accepts-settings` flag (default: true) to force unsupported model settings.
- Annotated which models support reasoning_effort and thinking_tokens settings in the model settings data.
- Improved code block rendering in markdown output with better padding using NoInsetMarkdown.
- Added `--git-commit-verify` flag (default: False) to control whether git commit hooks are bypassed.
- Added support for thinking tokens for OpenRouter Sonnet 3.7.
- Fixed autocompletion for `/ask`, `/code`, and `/architect` commands, by shladnik.
- Added vi-like behavior when pressing enter in multiline-mode while in vi normal/navigation-mode, by Marco Mayer.
- Added commands to switch between model types: `/editor-model` for Editor Model, and `/weak-model` for Weak Model, by csala.
- Added AWS_PROFILE support for Bedrock models, allowing use of AWS profiles instead of explicit credentials, by lentil32.
- Enhanced `--aiderignore` argument to resolve both absolute and relative paths, by mopemope.
- Improved platform information handling to gracefully handle retrieval errors.
- Aider wrote 92% of the code in this release.
### Aider v0.77.1
- Bumped dependencies to pickup litellm fix for Ollama.
- Added support for `openrouter/google/gemma-3-27b-it` model.
- Updated exclude patterns for documentation.
### Aider v0.77.0
- Big upgrade in [programming languages supported](https://aider.chat/docs/languages.html) by adopting [tree-sitter-language-pack](https://github.com/Goldziher/tree-sitter-language-pack/).
- 130 new languages with linter support.
- 20 new languages with repo-map support.
- Added `/think-tokens` command to set thinking token budget with support for human-readable formats (8k, 10.5k, 0.5M).
- Added `/reasoning-effort` command to control model reasoning level.
- The `/think-tokens` and `/reasoning-effort` commands display current settings when called without arguments.
- Display of thinking token budget and reasoning effort in model information.
- Changed `--thinking-tokens` argument to accept string values with human-readable formats.
- Added `--auto-accept-architect` flag (default: true) to automatically accept changes from architect coder format without confirmation.
- Added support for `cohere_chat/command-a-03-2025` and `gemini/gemma-3-27b-it`
- The bare `/drop` command now preserves original read-only files provided via args.read.
- Fixed a bug where default model would be set by deprecated `--shortcut` switches even when already specified in the command line.
- Improved AutoCompleter to require 3 characters for autocompletion to reduce noise.
- Aider wrote 72% of the code in this release.
### Aider v0.76.2
- Fixed handling of JSONDecodeError when loading model cache file.
- Fixed handling of GitCommandError when retrieving git user configuration.
- Aider wrote 75% of the code in this release.
### Aider v0.76.1 ### Aider v0.76.1
- Added ignore_permission_denied option to file watcher to prevent errors when accessing restricted files, by Yutaka Matsubara. - Added ignore_permission_denied option to file watcher to prevent errors when accessing restricted files, by Yutaka Matsubara.

187
README.md
View File

@@ -1,144 +1,111 @@
<p align="center">
<a href="https://aider.chat/"><img src="https://aider.chat/assets/logo.svg" alt="Aider Logo" width="300"></a>
</p>
<!-- Edit README.md, not index.md --> <h1 align="center">
AI Pair Programming in Your Terminal
</h1>
# Aider is AI pair programming in your terminal
Aider lets you pair program with LLMs, <p align="center">
to edit code in your local git repository. Aider lets you pair program with LLMs to start a new project or build on your existing codebase.
Start a new project or work with an existing code base. </p>
Aider works best with Claude 3.7 Sonnet, DeepSeek R1 & Chat V3, OpenAI o1, o3-mini & GPT-4o. Aider can [connect to almost any LLM, including local models](https://aider.chat/docs/llms.html).
<!-- SCREENCAST START -->
<p align="center"> <p align="center">
<img <img
src="https://aider.chat/assets/screencast.svg" src="https://aider.chat/assets/screencast.svg"
alt="aider screencast" alt="aider screencast"
> >
</p> </p>
<!-- SCREENCAST END -->
<!-- VIDEO START
<p align="center">
<video style="max-width: 100%; height: auto;" autoplay loop muted playsinline>
<source src="/assets/shell-cmds-small.mp4" type="video/mp4">
Your browser does not support the video tag.
</video>
</p>
VIDEO END -->
<p align="center"> <p align="center">
<a href="https://discord.gg/Tv2uQnR88V">
<img src="https://img.shields.io/badge/Join-Discord-blue.svg"/>
</a>
<a href="https://aider.chat/docs/install.html">
<img src="https://img.shields.io/badge/Read-Docs-green.svg"/>
</a>
</p>
## Getting started
<!--[[[cog <!--[[[cog
# We can't "include" here. from scripts.badges import get_badges_md
# Because this page is rendered by GitHub as the repo README text = get_badges_md()
cog.out(open("aider/website/_includes/get-started.md").read()) cog.out(text)
]]]--> ]]]-->
<a href="https://github.com/Aider-AI/aider/stargazers"><img alt="GitHub Stars" title="Total number of GitHub stars the Aider project has received"
src="https://img.shields.io/github/stars/Aider-AI/aider?style=flat-square&logo=github&color=f1c40f&labelColor=555555"/></a>
<a href="https://pypi.org/project/aider-chat/"><img alt="PyPI Downloads" title="Total number of installations via pip from PyPI"
src="https://img.shields.io/badge/📦%20Installs-1.7M-2ecc71?style=flat-square&labelColor=555555"/></a>
<img alt="Tokens per week" title="Number of tokens processed weekly by Aider users"
src="https://img.shields.io/badge/📈%20Tokens%2Fweek-15B-e74c3c?style=flat-square&labelColor=555555"/>
<a href="https://openrouter.ai/"><img alt="OpenRouter Ranking" title="Aider's ranking among applications on the OpenRouter platform"
src="https://img.shields.io/badge/🏆%20OpenRouter-Top%2020-9b59b6?style=flat-square&labelColor=555555"/></a>
<a href="https://aider.chat/HISTORY.html"><img alt="Singularity" title="Percentage of the new code in Aider's last release written by Aider itself"
src="https://img.shields.io/badge/🔄%20Singularity-72%25-3498db?style=flat-square&labelColor=555555"/></a>
<!--[[[end]]]-->
</p>
If you already have python 3.8-3.13 installed, you can get started quickly like this: ## Features
- 🧠 **[Cloud and local LLMs](https://aider.chat/docs/llms.html)** - Aider works best with Claude 3.7 Sonnet, DeepSeek R1 & Chat V3, OpenAI o1, o3-mini & GPT-4o, but can connect to almost any LLM, including local models.
- 🗺️ **[Maps your codebase](https://aider.chat/docs/repomap.html)** - Aider makes a map of your entire codebase, which helps it work well in larger projects.
- `</>` **[100+ code languages](https://aider.chat/docs/languages.html)** - Aider works with most popular programming languages: python, javascript, rust, ruby, go, cpp, php, html, css, and dozens more.
- 🔀 **[Git integration](https://aider.chat/docs/git.html)** - Aider automatically commits changes with sensible commit messages. Use familiar git tools to easily diff, manage and undo AI changes.
- 🖥️ **[Use in your IDE](https://aider.chat/docs/usage/watch.html)** - Use aider from within your favorite IDE or editor. Ask for changes by adding comments to your code and aider will get to work.
- 🖼️ **[Images & web pages](https://aider.chat/docs/usage/images-urls.html)** - Add images and web pages to the chat to provide visual context, screenshots, reference docs, etc.
- 🎤 **[Voice-to-code](https://aider.chat/docs/usage/voice.html)** - Speak with aider about your code! Request new features, test cases or bug fixes using your voice and let aider implement the changes.
-**[Linting & testing](https://aider.chat/docs/usage/lint-test.html)** - Automatically lint and test your code every time aider makes changes. Aider can fix problems detected by your linters and test suites.
- 📋 **[Copy/paste to web chat](https://aider.chat/docs/usage/copypaste.html)** - Work with any LLM via its web chat interface. Aider streamlines copy/pasting code context and edits back and forth with a browser.
## Getting Started
```bash ```bash
python -m pip install aider-install python -m pip install aider-install
aider-install aider-install
# Change directory into your code base # Change directory into your codebase
cd /to/your/project cd /to/your/project
# Work with DeepSeek via DeepSeek's API # DeepSeek
aider --model deepseek --api-key deepseek=your-key-goes-here aider --model deepseek --api-key deepseek=<key>
# Work with Claude 3.7 Sonnet via Anthropic's API # Claude 3.7 Sonnet
aider --model sonnet --api-key anthropic=your-key-goes-here aider --model sonnet --api-key anthropic=<key>
# Work with GPT-4o via OpenAI's API # o3-mini
aider --model gpt-4o --api-key openai=your-key-goes-here aider --model o3-mini --api-key openai=<key>
# Work with Sonnet via OpenRouter's API
aider --model openrouter/anthropic/claude-3.7-sonnet --api-key openrouter=your-key-goes-here
# Work with DeepSeek via OpenRouter's API
aider --model openrouter/deepseek/deepseek-chat --api-key openrouter=your-key-goes-here
``` ```
<!--[[[end]]]-->
See the See the [installation instructions](https://aider.chat/docs/install.html) and [usage documentation](https://aider.chat/docs/usage.html) for more details.
[installation instructions](https://aider.chat/docs/install.html)
and
[usage documentation](https://aider.chat/docs/usage.html)
for more details.
## Features ## More Information
- Run aider with the files you want to edit: `aider <file1> <file2> ...` ### Documentation
- Ask for changes: - [Installation Guide](https://aider.chat/docs/install.html)
- Add new features or test cases. - [Usage Guide](https://aider.chat/docs/usage.html)
- Describe a bug. - [Tutorial Videos](https://aider.chat/docs/usage/tutorials.html)
- Paste in an error message or GitHub issue URL.
- Refactor code.
- Update docs.
- Aider will edit your files to complete your request.
- Aider [automatically git commits](https://aider.chat/docs/git.html) changes with a sensible commit message.
- [Use aider inside your favorite editor or IDE](https://aider.chat/docs/usage/watch.html).
- Aider works with [most popular languages](https://aider.chat/docs/languages.html): python, javascript, typescript, php, html, css, and more...
- Aider can edit multiple files at once for complex requests.
- Aider uses a [map of your entire git repo](https://aider.chat/docs/repomap.html), which helps it work well in larger codebases.
- Edit files in your editor or IDE while chatting with aider,
and it will always use the latest version.
Pair program with AI.
- [Add images to the chat](https://aider.chat/docs/usage/images-urls.html) (GPT-4o, Claude 3.5 Sonnet, etc).
- [Add URLs to the chat](https://aider.chat/docs/usage/images-urls.html) and aider will read their content.
- [Code with your voice](https://aider.chat/docs/usage/voice.html).
- Aider works best with Claude 3.7 Sonnet, DeepSeek V3, o1 & GPT-4o and can [connect to almost any LLM](https://aider.chat/docs/llms.html).
## Top tier performance
[Aider has one of the top scores on SWE Bench](https://aider.chat/2024/06/02/main-swe-bench.html).
SWE Bench is a challenging software engineering benchmark where aider
solved *real* GitHub issues from popular open source
projects like django, scikitlearn, matplotlib, etc.
## More info
- [Documentation](https://aider.chat/)
- [Installation](https://aider.chat/docs/install.html)
- [Usage](https://aider.chat/docs/usage.html)
- [Tutorial videos](https://aider.chat/docs/usage/tutorials.html)
- [Connecting to LLMs](https://aider.chat/docs/llms.html) - [Connecting to LLMs](https://aider.chat/docs/llms.html)
- [Configuration](https://aider.chat/docs/config.html) - [Configuration Options](https://aider.chat/docs/config.html)
- [Troubleshooting](https://aider.chat/docs/troubleshooting.html) - [Troubleshooting](https://aider.chat/docs/troubleshooting.html)
- [FAQ](https://aider.chat/docs/faq.html)
### Community & Resources
- [LLM Leaderboards](https://aider.chat/docs/leaderboards/) - [LLM Leaderboards](https://aider.chat/docs/leaderboards/)
- [GitHub](https://github.com/Aider-AI/aider) - [GitHub Repository](https://github.com/Aider-AI/aider)
- [Discord](https://discord.gg/Tv2uQnR88V) - [Discord Community](https://discord.gg/Tv2uQnR88V)
- [Blog](https://aider.chat/blog/) - [Blog](https://aider.chat/blog/)
## Kind Words From Users
## Kind words from users - *"The best free open source AI coding assistant."* — [IndyDevDan](https://youtu.be/YALpX8oOn78)
- *"The best AI coding assistant so far."* — [Matthew Berman](https://www.youtube.com/watch?v=df8afeb1FY8)
- *The best free open source AI coding assistant.* -- [IndyDevDan](https://youtu.be/YALpX8oOn78) - *"Aider ... has easily quadrupled my coding productivity."* — [SOLAR_FIELDS](https://news.ycombinator.com/item?id=36212100)
- *The best AI coding assistant so far.* -- [Matthew Berman](https://www.youtube.com/watch?v=df8afeb1FY8) - *"It's a cool workflow... Aider's ergonomics are perfect for me."* — [qup](https://news.ycombinator.com/item?id=38185326)
- *Aider ... has easily quadrupled my coding productivity.* -- [SOLAR_FIELDS](https://news.ycombinator.com/item?id=36212100) - *"It's really like having your senior developer live right in your Git repo - truly amazing!"* — [rappster](https://github.com/Aider-AI/aider/issues/124)
- *It's a cool workflow... Aider's ergonomics are perfect for me.* -- [qup](https://news.ycombinator.com/item?id=38185326) - *"What an amazing tool. It's incredible."* [valyagolev](https://github.com/Aider-AI/aider/issues/6#issue-1722897858)
- *It's really like having your senior developer live right in your Git repo - truly amazing!* -- [rappster](https://github.com/Aider-AI/aider/issues/124) - *"Aider is such an astounding thing!"* [cgrothaus](https://github.com/Aider-AI/aider/issues/82#issuecomment-1631876700)
- *What an amazing tool. It's incredible.* -- [valyagolev](https://github.com/Aider-AI/aider/issues/6#issue-1722897858) - *"It was WAY faster than I would be getting off the ground and making the first few working versions."* — [Daniel Feldman](https://twitter.com/d_feldman/status/1662295077387923456)
- *Aider is such an astounding thing!* -- [cgrothaus](https://github.com/Aider-AI/aider/issues/82#issuecomment-1631876700) - *"THANK YOU for Aider! It really feels like a glimpse into the future of coding."* — [derwiki](https://news.ycombinator.com/item?id=38205643)
- *It was WAY faster than I would be getting off the ground and making the first few working versions.* -- [Daniel Feldman](https://twitter.com/d_feldman/status/1662295077387923456) - *"It's just amazing. It is freeing me to do things I felt were out my comfort zone before."* — [Dougie](https://discord.com/channels/1131200896827654144/1174002618058678323/1174084556257775656)
- *THANK YOU for Aider! It really feels like a glimpse into the future of coding.* -- [derwiki](https://news.ycombinator.com/item?id=38205643) - *"This project is stellar."* — [funkytaco](https://github.com/Aider-AI/aider/issues/112#issuecomment-1637429008)
- *It's just amazing. It is freeing me to do things I felt were out my comfort zone before.* -- [Dougie](https://discord.com/channels/1131200896827654144/1174002618058678323/1174084556257775656) - *"Amazing project, definitely the best AI coding assistant I've used."* — [joshuavial](https://github.com/Aider-AI/aider/issues/84)
- *This project is stellar.* -- [funkytaco](https://github.com/Aider-AI/aider/issues/112#issuecomment-1637429008) - *"I absolutely love using Aider ... It makes software development feel so much lighter as an experience."* — [principalideal0](https://discord.com/channels/1131200896827654144/1133421607499595858/1229689636012691468)
- *Amazing project, definitely the best AI coding assistant I've used.* -- [joshuavial](https://github.com/Aider-AI/aider/issues/84) - *"I have been recovering from multiple shoulder surgeries ... and have used aider extensively. It has allowed me to continue productivity."* — [codeninja](https://www.reddit.com/r/OpenAI/s/nmNwkHy1zG)
- *I absolutely love using Aider ... It makes software development feel so much lighter as an experience.* -- [principalideal0](https://discord.com/channels/1131200896827654144/1133421607499595858/1229689636012691468) - *"I am an aider addict. I'm getting so much more work done, but in less time."* [dandandan](https://discord.com/channels/1131200896827654144/1131200896827654149/1135913253483069470)
- *I have been recovering from multiple shoulder surgeries ... and have used aider extensively. It has allowed me to continue productivity.* -- [codeninja](https://www.reddit.com/r/OpenAI/s/nmNwkHy1zG) - *"After wasting $100 on tokens trying to find something better, I'm back to Aider. It blows everything else out of the water hands down, there's no competition whatsoever."* — [SystemSculpt](https://discord.com/channels/1131200896827654144/1131200896827654149/1178736602797846548)
- *I am an aider addict. I'm getting so much more work done, but in less time.* -- [dandandan](https://discord.com/channels/1131200896827654144/1131200896827654149/1135913253483069470) - *"Aider is amazing, coupled with Sonnet 3.5 it's quite mind blowing."* — [Josh Dingus](https://discord.com/channels/1131200896827654144/1133060684540813372/1262374225298198548)
- *After wasting $100 on tokens trying to find something better, I'm back to Aider. It blows everything else out of the water hands down, there's no competition whatsoever.* -- [SystemSculpt](https://discord.com/channels/1131200896827654144/1131200896827654149/1178736602797846548) - *"Hands down, this is the best AI coding assistant tool so far."* [IndyDevDan](https://www.youtube.com/watch?v=MPYFPvxfGZs)
- *Aider is amazing, coupled with Sonnet 3.5 its quite mind blowing.* -- [Josh Dingus](https://discord.com/channels/1131200896827654144/1133060684540813372/1262374225298198548) - *"[Aider] changed my daily coding workflows. It's mind-blowing how a single Python application can change your life."* — [maledorak](https://discord.com/channels/1131200896827654144/1131200896827654149/1258453375620747264)
- *Hands down, this is the best AI coding assistant tool so far.* -- [IndyDevDan](https://www.youtube.com/watch?v=MPYFPvxfGZs) - *"Best agent for actual dev work in existing codebases."* — [Nick Dobos](https://twitter.com/NickADobos/status/1690408967963652097?s=20)
- *[Aider] changed my daily coding workflows. It's mind-blowing how a single Python application can change your life.* -- [maledorak](https://discord.com/channels/1131200896827654144/1131200896827654149/1258453375620747264)
- *Best agent for actual dev work in existing codebases.* -- [Nick Dobos](https://twitter.com/NickADobos/status/1690408967963652097?s=20)

View File

@@ -1,6 +1,6 @@
from packaging import version from packaging import version
__version__ = "0.76.3.dev" __version__ = "0.78.1.dev"
safe_version = __version__ safe_version = __version__
try: try:

View File

@@ -3,6 +3,7 @@
import argparse import argparse
import os import os
import sys import sys
from pathlib import Path
import configargparse import configargparse
@@ -17,6 +18,15 @@ from aider.deprecated import add_deprecated_model_args
from .dump import dump # noqa: F401 from .dump import dump # noqa: F401
def resolve_aiderignore_path(path_str, git_root=None):
path = Path(path_str)
if path.is_absolute():
return str(path)
elif git_root:
return str(Path(git_root) / path)
return str(path)
def default_env_file(git_root): def default_env_file(git_root):
return os.path.join(git_root, ".env") if git_root else ".env" return os.path.join(git_root, ".env") if git_root else ".env"
@@ -119,7 +129,7 @@ def get_parser(default_config_files, git_root):
) )
group.add_argument( group.add_argument(
"--thinking-tokens", "--thinking-tokens",
type=int, type=str,
help="Set the thinking token budget for models that support it (default: not set)", help="Set the thinking token budget for models that support it (default: not set)",
) )
group.add_argument( group.add_argument(
@@ -148,6 +158,12 @@ def get_parser(default_config_files, git_root):
const="architect", const="architect",
help="Use architect edit format for the main chat", help="Use architect edit format for the main chat",
) )
group.add_argument(
"--auto-accept-architect",
action=argparse.BooleanOptionalAction,
default=True,
help="Enable/disable automatic acceptance of architect changes (default: True)",
)
group.add_argument( group.add_argument(
"--weak-model", "--weak-model",
metavar="WEAK_MODEL", metavar="WEAK_MODEL",
@@ -175,6 +191,14 @@ def get_parser(default_config_files, git_root):
default=True, default=True,
help="Only work with models that have meta-data available (default: True)", help="Only work with models that have meta-data available (default: True)",
) )
group.add_argument(
"--check-model-accepts-settings",
action=argparse.BooleanOptionalAction,
default=True,
help=(
"Check if model accepts settings like reasoning_effort/thinking_tokens (default: True)"
),
)
group.add_argument( group.add_argument(
"--max-chat-history-tokens", "--max-chat-history-tokens",
type=int, type=int,
@@ -374,9 +398,11 @@ def get_parser(default_config_files, git_root):
default_aiderignore_file = ( default_aiderignore_file = (
os.path.join(git_root, ".aiderignore") if git_root else ".aiderignore" os.path.join(git_root, ".aiderignore") if git_root else ".aiderignore"
) )
group.add_argument( group.add_argument(
"--aiderignore", "--aiderignore",
metavar="AIDERIGNORE", metavar="AIDERIGNORE",
type=lambda path_str: resolve_aiderignore_path(path_str, git_root),
default=default_aiderignore_file, default=default_aiderignore_file,
help="Specify the aider ignore file (default: .aiderignore in git root)", help="Specify the aider ignore file (default: .aiderignore in git root)",
) )
@@ -422,6 +448,12 @@ def get_parser(default_config_files, git_root):
default=False, default=False,
help="Prefix all commit messages with 'aider: ' (default: False)", help="Prefix all commit messages with 'aider: ' (default: False)",
) )
group.add_argument(
"--git-commit-verify",
action=argparse.BooleanOptionalAction,
default=False,
help="Enable/disable git pre-commit hooks with --no-verify (default: False)",
)
group.add_argument( group.add_argument(
"--commit", "--commit",
action="store_true", action="store_true",

View File

@@ -6,6 +6,7 @@ from .base_coder import Coder
class ArchitectCoder(AskCoder): class ArchitectCoder(AskCoder):
edit_format = "architect" edit_format = "architect"
gpt_prompts = ArchitectPrompts() gpt_prompts = ArchitectPrompts()
auto_accept_architect = False
def reply_completed(self): def reply_completed(self):
content = self.partial_response_content content = self.partial_response_content
@@ -13,7 +14,7 @@ class ArchitectCoder(AskCoder):
if not content or not content.strip(): if not content or not content.strip():
return return
if not self.io.confirm_ask("Edit the files?"): if not self.auto_accept_architect and not self.io.confirm_ask("Edit the files?"):
return return
kwargs = dict() kwargs = dict()

View File

@@ -207,10 +207,22 @@ class Coder:
prefix = "Model" prefix = "Model"
output = f"{prefix}: {main_model.name} with {self.edit_format} edit format" output = f"{prefix}: {main_model.name} with {self.edit_format} edit format"
# Check for thinking token budget
thinking_tokens = main_model.get_thinking_tokens(main_model)
if thinking_tokens:
output += f", {thinking_tokens} think tokens"
# Check for reasoning effort
reasoning_effort = main_model.get_reasoning_effort(main_model)
if reasoning_effort:
output += f", reasoning {reasoning_effort}"
if self.add_cache_headers or main_model.caches_by_default: if self.add_cache_headers or main_model.caches_by_default:
output += ", prompt cache" output += ", prompt cache"
if main_model.info.get("supports_assistant_prefill"): if main_model.info.get("supports_assistant_prefill"):
output += ", infinite output" output += ", infinite output"
lines.append(output) lines.append(output)
if self.edit_format == "architect": if self.edit_format == "architect":
@@ -310,6 +322,7 @@ class Coder:
ignore_mentions=None, ignore_mentions=None,
file_watcher=None, file_watcher=None,
auto_copy_context=False, auto_copy_context=False,
auto_accept_architect=True,
): ):
# Fill in a dummy Analytics if needed, but it is never .enable()'d # Fill in a dummy Analytics if needed, but it is never .enable()'d
self.analytics = analytics if analytics is not None else Analytics() self.analytics = analytics if analytics is not None else Analytics()
@@ -322,6 +335,7 @@ class Coder:
self.abs_root_path_cache = {} self.abs_root_path_cache = {}
self.auto_copy_context = auto_copy_context self.auto_copy_context = auto_copy_context
self.auto_accept_architect = auto_accept_architect
self.ignore_mentions = ignore_mentions self.ignore_mentions = ignore_mentions
if not self.ignore_mentions: if not self.ignore_mentions:
@@ -1016,7 +1030,13 @@ class Coder:
return None return None
def get_platform_info(self): def get_platform_info(self):
platform_text = f"- Platform: {platform.platform()}\n" platform_text = ""
try:
platform_text = f"- Platform: {platform.platform()}\n"
except KeyError:
# Skip platform info if it can't be retrieved
platform_text = "- Platform information unavailable\n"
shell_var = "COMSPEC" if os.name == "nt" else "SHELL" shell_var = "COMSPEC" if os.name == "nt" else "SHELL"
shell_val = os.getenv(shell_var) shell_val = os.getenv(shell_var)
platform_text += f"- Shell: {shell_var}={shell_val}\n" platform_text += f"- Shell: {shell_var}={shell_val}\n"

View File

@@ -17,6 +17,7 @@ from aider import models, prompts, voice
from aider.editor import pipe_editor from aider.editor import pipe_editor
from aider.format_settings import format_settings from aider.format_settings import format_settings
from aider.help import Help, install_help_extra from aider.help import Help, install_help_extra
from aider.io import CommandCompletionException
from aider.llm import litellm from aider.llm import litellm
from aider.repo import ANY_GIT_ERROR from aider.repo import ANY_GIT_ERROR
from aider.run_cmd import run_cmd from aider.run_cmd import run_cmd
@@ -59,6 +60,7 @@ class Commands:
parser=None, parser=None,
verbose=False, verbose=False,
editor=None, editor=None,
original_read_only_fnames=None,
): ):
self.io = io self.io = io
self.coder = coder self.coder = coder
@@ -77,11 +79,42 @@ class Commands:
self.help = None self.help = None
self.editor = editor self.editor = editor
# Store the original read-only filenames provided via args.read
self.original_read_only_fnames = set(original_read_only_fnames or [])
def cmd_model(self, args): def cmd_model(self, args):
"Switch to a new LLM" "Switch the Main Model to a new LLM"
model_name = args.strip() model_name = args.strip()
model = models.Model(model_name, weak_model=self.coder.main_model.weak_model.name) model = models.Model(
model_name,
editor_model=self.coder.main_model.editor_model.name,
weak_model=self.coder.main_model.weak_model.name,
)
models.sanity_check_models(self.io, model)
raise SwitchCoder(main_model=model)
def cmd_editor_model(self, args):
"Switch the Editor Model to a new LLM"
model_name = args.strip()
model = models.Model(
self.coder.main_model.name,
editor_model=model_name,
weak_model=self.coder.main_model.weak_model.name,
)
models.sanity_check_models(self.io, model)
raise SwitchCoder(main_model=model)
def cmd_weak_model(self, args):
"Switch the Weak Model to a new LLM"
model_name = args.strip()
model = models.Model(
self.coder.main_model.name,
editor_model=self.coder.main_model.editor_model.name,
weak_model=model_name,
)
models.sanity_check_models(self.io, model) models.sanity_check_models(self.io, model)
raise SwitchCoder(main_model=model) raise SwitchCoder(main_model=model)
@@ -355,7 +388,21 @@ class Commands:
def _drop_all_files(self): def _drop_all_files(self):
self.coder.abs_fnames = set() self.coder.abs_fnames = set()
self.coder.abs_read_only_fnames = set()
# When dropping all files, keep those that were originally provided via args.read
if self.original_read_only_fnames:
# Keep only the original read-only files
to_keep = set()
for abs_fname in self.coder.abs_read_only_fnames:
rel_fname = self.coder.get_rel_fname(abs_fname)
if (
abs_fname in self.original_read_only_fnames
or rel_fname in self.original_read_only_fnames
):
to_keep.add(abs_fname)
self.coder.abs_read_only_fnames = to_keep
else:
self.coder.abs_read_only_fnames = set()
def _clear_chat_history(self): def _clear_chat_history(self):
self.coder.done_messages = [] self.coder.done_messages = []
@@ -822,7 +869,12 @@ class Commands:
"Remove files from the chat session to free up context space" "Remove files from the chat session to free up context space"
if not args.strip(): if not args.strip():
self.io.tool_output("Dropping all files from the chat session.") if self.original_read_only_fnames:
self.io.tool_output(
"Dropping all files from the chat session except originally read-only files."
)
else:
self.io.tool_output("Dropping all files from the chat session.")
self._drop_all_files() self._drop_all_files()
return return
@@ -1065,6 +1117,15 @@ class Commands:
show_announcements=False, show_announcements=False,
) )
def completions_ask(self):
raise CommandCompletionException()
def completions_code(self):
raise CommandCompletionException()
def completions_architect(self):
raise CommandCompletionException()
def cmd_ask(self, args): def cmd_ask(self, args):
"""Ask questions about the code base without editing any files. If no prompt provided, switches to ask mode.""" # noqa """Ask questions about the code base without editing any files. If no prompt provided, switches to ask mode.""" # noqa
return self._generic_chat_command(args, "ask") return self._generic_chat_command(args, "ask")
@@ -1411,6 +1472,58 @@ class Commands:
if user_input.strip(): if user_input.strip():
self.io.set_placeholder(user_input.rstrip()) self.io.set_placeholder(user_input.rstrip())
def cmd_think_tokens(self, args):
"Set the thinking token budget (supports formats like 8096, 8k, 10.5k, 0.5M)"
model = self.coder.main_model
if not args.strip():
# Display current value if no args are provided
formatted_budget = model.get_thinking_tokens(model)
if formatted_budget is None:
self.io.tool_output("Thinking tokens are not currently set.")
else:
budget = model.extra_params["thinking"].get("budget_tokens")
self.io.tool_output(
f"Current thinking token budget: {budget:,} tokens ({formatted_budget})."
)
return
value = args.strip()
model.set_thinking_tokens(value)
formatted_budget = model.get_thinking_tokens(model)
budget = model.extra_params["thinking"].get("budget_tokens")
self.io.tool_output(f"Set thinking token budget to {budget:,} tokens ({formatted_budget}).")
self.io.tool_output()
# Output announcements
announcements = "\n".join(self.coder.get_announcements())
self.io.tool_output(announcements)
def cmd_reasoning_effort(self, args):
"Set the reasoning effort level (values: number or low/medium/high depending on model)"
model = self.coder.main_model
if not args.strip():
# Display current value if no args are provided
reasoning_value = model.get_reasoning_effort(model)
if reasoning_value is None:
self.io.tool_output("Reasoning effort is not currently set.")
else:
self.io.tool_output(f"Current reasoning effort: {reasoning_value}")
return
value = args.strip()
model.set_reasoning_effort(value)
reasoning_value = model.get_reasoning_effort(model)
self.io.tool_output(f"Set reasoning effort to {reasoning_value}")
self.io.tool_output()
# Output announcements
announcements = "\n".join(self.coder.get_announcements())
self.io.tool_output(announcements)
def cmd_copy_context(self, args=None): def cmd_copy_context(self, args=None):
"""Copy the current chat context as markdown, suitable to paste into a web UI""" """Copy the current chat context as markdown, suitable to paste into a web UI"""

View File

@@ -121,5 +121,6 @@ def handle_deprecated_model_args(args, io):
) )
# Set the model # Set the model
args.model = model_name if not args.model:
args.model = model_name
break break

View File

@@ -10,4 +10,10 @@ exclude_website_pats = [
"docs/unified-diffs.md", "docs/unified-diffs.md",
"docs/leaderboards/index.md", "docs/leaderboards/index.md",
"assets/**", "assets/**",
".jekyll-metadata",
"Gemfile.lock",
"Gemfile",
"_config.yml",
"**/OLD/**",
"OLD/**",
] ]

View File

@@ -18,6 +18,7 @@ from prompt_toolkit.enums import EditingMode
from prompt_toolkit.filters import Condition, is_searching from prompt_toolkit.filters import Condition, is_searching
from prompt_toolkit.history import FileHistory from prompt_toolkit.history import FileHistory
from prompt_toolkit.key_binding import KeyBindings from prompt_toolkit.key_binding import KeyBindings
from prompt_toolkit.key_binding.vi_state import InputMode
from prompt_toolkit.keys import Keys from prompt_toolkit.keys import Keys
from prompt_toolkit.lexers import PygmentsLexer from prompt_toolkit.lexers import PygmentsLexer
from prompt_toolkit.output.vt100 import is_dumb_terminal from prompt_toolkit.output.vt100 import is_dumb_terminal
@@ -68,6 +69,13 @@ def restore_multiline(func):
return wrapper return wrapper
class CommandCompletionException(Exception):
"""Raised when a command should use the normal autocompleter instead of
command-specific completion."""
pass
@dataclass @dataclass
class ConfirmGroup: class ConfirmGroup:
preference: str = None preference: str = None
@@ -186,14 +194,23 @@ class AutoCompleter(Completer):
return return
if text[0] == "/": if text[0] == "/":
yield from self.get_command_completions(document, complete_event, text, words) try:
return yield from self.get_command_completions(document, complete_event, text, words)
return
except CommandCompletionException:
# Fall through to normal completion
pass
candidates = self.words candidates = self.words
candidates.update(set(self.fname_to_rel_fnames)) candidates.update(set(self.fname_to_rel_fnames))
candidates = [word if type(word) is tuple else (word, word) for word in candidates] candidates = [word if type(word) is tuple else (word, word) for word in candidates]
last_word = words[-1] last_word = words[-1]
# Only provide completions if the user has typed at least 3 characters
if len(last_word) < 3:
return
completions = [] completions = []
for word_match, word_insert in candidates: for word_match, word_insert in candidates:
if word_match.lower().startswith(last_word.lower()): if word_match.lower().startswith(last_word.lower()):
@@ -538,8 +555,11 @@ class InputOutput:
@kb.add("enter", eager=True, filter=~is_searching) @kb.add("enter", eager=True, filter=~is_searching)
def _(event): def _(event):
"Handle Enter key press" "Handle Enter key press"
if self.multiline_mode: if self.multiline_mode and not (
# In multiline mode, Enter adds a newline self.editingmode == EditingMode.VI
and event.app.vi_state.input_mode == InputMode.NAVIGATION
):
# In multiline mode and if not in vi-mode or vi navigation/normal mode, Enter adds a newline
event.current_buffer.insert_text("\n") event.current_buffer.insert_text("\n")
else: else:
# In normal mode, Enter submits # In normal mode, Enter submits

View File

@@ -778,6 +778,7 @@ def main(argv=None, input=None, output=None, force_git_root=None, return_coder=F
weak_model=args.weak_model, weak_model=args.weak_model,
editor_model=args.editor_model, editor_model=args.editor_model,
editor_edit_format=args.editor_edit_format, editor_edit_format=args.editor_edit_format,
verbose=args.verbose,
) )
# Check if deprecated remove_reasoning is set # Check if deprecated remove_reasoning is set
@@ -786,13 +787,40 @@ def main(argv=None, input=None, output=None, force_git_root=None, return_coder=F
"Model setting 'remove_reasoning' is deprecated, please use 'reasoning_tag' instead." "Model setting 'remove_reasoning' is deprecated, please use 'reasoning_tag' instead."
) )
# Set reasoning effort if specified # Set reasoning effort and thinking tokens if specified
if args.reasoning_effort is not None: if args.reasoning_effort is not None:
main_model.set_reasoning_effort(args.reasoning_effort) # Apply if check is disabled or model explicitly supports it
if not args.check_model_accepts_settings or (
main_model.accepts_settings and "reasoning_effort" in main_model.accepts_settings
):
main_model.set_reasoning_effort(args.reasoning_effort)
# Set thinking tokens if specified
if args.thinking_tokens is not None: if args.thinking_tokens is not None:
main_model.set_thinking_tokens(args.thinking_tokens) # Apply if check is disabled or model explicitly supports it
if not args.check_model_accepts_settings or (
main_model.accepts_settings and "thinking_tokens" in main_model.accepts_settings
):
main_model.set_thinking_tokens(args.thinking_tokens)
# Show warnings about unsupported settings that are being ignored
if args.check_model_accepts_settings:
settings_to_check = [
{"arg": args.reasoning_effort, "name": "reasoning_effort"},
{"arg": args.thinking_tokens, "name": "thinking_tokens"},
]
for setting in settings_to_check:
if setting["arg"] is not None and (
not main_model.accepts_settings
or setting["name"] not in main_model.accepts_settings
):
io.tool_warning(
f"Warning: {main_model.name} does not support '{setting['name']}', ignoring."
)
io.tool_output(
f"Use --no-check-model-accepts-settings to force the '{setting['name']}'"
" setting."
)
if args.copy_paste and args.edit_format is None: if args.copy_paste and args.edit_format is None:
if main_model.edit_format in ("diff", "whole"): if main_model.edit_format in ("diff", "whole"):
@@ -841,6 +869,7 @@ def main(argv=None, input=None, output=None, force_git_root=None, return_coder=F
attribute_commit_message_committer=args.attribute_commit_message_committer, attribute_commit_message_committer=args.attribute_commit_message_committer,
commit_prompt=args.commit_prompt, commit_prompt=args.commit_prompt,
subtree_only=args.subtree_only, subtree_only=args.subtree_only,
git_commit_verify=args.git_commit_verify,
) )
except FileNotFoundError: except FileNotFoundError:
pass pass
@@ -866,6 +895,7 @@ def main(argv=None, input=None, output=None, force_git_root=None, return_coder=F
parser=parser, parser=parser,
verbose=args.verbose, verbose=args.verbose,
editor=args.editor, editor=args.editor,
original_read_only_fnames=read_only_fnames,
) )
summarizer = ChatSummary( summarizer = ChatSummary(
@@ -920,6 +950,7 @@ def main(argv=None, input=None, output=None, force_git_root=None, return_coder=F
chat_language=args.chat_language, chat_language=args.chat_language,
detect_urls=args.detect_urls, detect_urls=args.detect_urls,
auto_copy_context=args.copy_paste, auto_copy_context=args.copy_paste,
auto_accept_architect=args.auto_accept_architect,
) )
except UnknownEditFormat as err: except UnknownEditFormat as err:
io.tool_error(str(err)) io.tool_error(str(err))

View File

@@ -5,7 +5,8 @@ import time
from rich.console import Console from rich.console import Console
from rich.live import Live from rich.live import Live
from rich.markdown import Markdown from rich.markdown import CodeBlock, Markdown
from rich.syntax import Syntax
from rich.text import Text from rich.text import Text
from aider.dump import dump # noqa: F401 from aider.dump import dump # noqa: F401
@@ -46,6 +47,25 @@ The end.
""" # noqa: E501 """ # noqa: E501
class NoInsetCodeBlock(CodeBlock):
"""A code block with syntax highlighting and no padding."""
def __rich_console__(self, console, options):
code = str(self.text).rstrip()
syntax = Syntax(code, self.lexer_name, theme=self.theme, word_wrap=True, padding=(1, 0))
yield syntax
class NoInsetMarkdown(Markdown):
"""Markdown with code blocks that have no padding."""
elements = {
**Markdown.elements,
"fence": NoInsetCodeBlock,
"code_block": NoInsetCodeBlock,
}
class MarkdownStream: class MarkdownStream:
"""Streaming markdown renderer that progressively displays content with a live updating window. """Streaming markdown renderer that progressively displays content with a live updating window.
@@ -88,7 +108,7 @@ class MarkdownStream:
# Render the markdown to a string buffer # Render the markdown to a string buffer
string_io = io.StringIO() string_io = io.StringIO()
console = Console(file=string_io, force_terminal=True) console = Console(file=string_io, force_terminal=True)
markdown = Markdown(text, **self.mdargs) markdown = NoInsetMarkdown(text, **self.mdargs)
console.print(markdown) console.print(markdown)
output = string_io.getvalue() output = string_io.getvalue()
@@ -186,6 +206,7 @@ if __name__ == "__main__":
_text = _text * 10 _text = _text * 10
pm = MarkdownStream() pm = MarkdownStream()
print("Using NoInsetMarkdown for code blocks with padding=0")
for i in range(6, len(_text), 5): for i in range(6, len(_text), 5):
pm.update(_text[:i]) pm.update(_text[:i])
time.sleep(0.01) time.sleep(0.01)

View File

@@ -116,6 +116,7 @@ class ModelSettings:
reasoning_tag: Optional[str] = None reasoning_tag: Optional[str] = None
remove_reasoning: Optional[str] = None # Deprecated alias for reasoning_tag remove_reasoning: Optional[str] = None # Deprecated alias for reasoning_tag
system_prompt_prefix: Optional[str] = None system_prompt_prefix: Optional[str] = None
accepts_settings: Optional[list] = None
# Load model settings from package resource # Load model settings from package resource
@@ -230,11 +231,14 @@ model_info_manager = ModelInfoManager()
class Model(ModelSettings): class Model(ModelSettings):
def __init__(self, model, weak_model=None, editor_model=None, editor_edit_format=None): def __init__(
self, model, weak_model=None, editor_model=None, editor_edit_format=None, verbose=False
):
# Map any alias to its canonical name # Map any alias to its canonical name
model = MODEL_ALIASES.get(model, model) model = MODEL_ALIASES.get(model, model)
self.name = model self.name = model
self.verbose = verbose
self.max_chat_history_tokens = 1024 self.max_chat_history_tokens = 1024
self.weak_model = None self.weak_model = None
@@ -292,6 +296,10 @@ class Model(ModelSettings):
exact_match = True exact_match = True
break # Continue to apply overrides break # Continue to apply overrides
# Initialize accepts_settings if it's None
if self.accepts_settings is None:
self.accepts_settings = []
model = model.lower() model = model.lower()
# If no exact match, try generic settings # If no exact match, try generic settings
@@ -319,6 +327,8 @@ class Model(ModelSettings):
self.use_repo_map = True self.use_repo_map = True
self.use_temperature = False self.use_temperature = False
self.system_prompt_prefix = "Formatting re-enabled. " self.system_prompt_prefix = "Formatting re-enabled. "
if "reasoning_effort" not in self.accepts_settings:
self.accepts_settings.append("reasoning_effort")
return # <-- return # <--
if "/o1-mini" in model: if "/o1-mini" in model:
@@ -340,6 +350,8 @@ class Model(ModelSettings):
self.use_temperature = False self.use_temperature = False
self.streaming = False self.streaming = False
self.system_prompt_prefix = "Formatting re-enabled. " self.system_prompt_prefix = "Formatting re-enabled. "
if "reasoning_effort" not in self.accepts_settings:
self.accepts_settings.append("reasoning_effort")
return # <-- return # <--
if "deepseek" in model and "v3" in model: if "deepseek" in model and "v3" in model:
@@ -355,7 +367,6 @@ class Model(ModelSettings):
self.examples_as_sys_msg = True self.examples_as_sys_msg = True
self.use_temperature = False self.use_temperature = False
self.reasoning_tag = "think" self.reasoning_tag = "think"
self.reasoning_tag = "think"
return # <-- return # <--
if ("llama3" in model or "llama-3" in model) and "70b" in model: if ("llama3" in model or "llama-3" in model) and "70b" in model:
@@ -381,6 +392,15 @@ class Model(ModelSettings):
self.reminder = "sys" self.reminder = "sys"
return # <-- return # <--
if "3-7-sonnet" in model:
self.edit_format = "diff"
self.use_repo_map = True
self.examples_as_sys_msg = True
self.reminder = "user"
if "thinking_tokens" not in self.accepts_settings:
self.accepts_settings.append("thinking_tokens")
return # <--
if "3.5-sonnet" in model or "3-5-sonnet" in model: if "3.5-sonnet" in model or "3-5-sonnet" in model:
self.edit_format = "diff" self.edit_format = "diff"
self.use_repo_map = True self.use_repo_map = True
@@ -569,6 +589,21 @@ class Model(ModelSettings):
model = self.name model = self.name
res = litellm.validate_environment(model) res = litellm.validate_environment(model)
# If missing AWS credential keys but AWS_PROFILE is set, consider AWS credentials valid
if res["missing_keys"] and any(
key in ["AWS_ACCESS_KEY_ID", "AWS_SECRET_ACCESS_KEY"] for key in res["missing_keys"]
):
if model.startswith("bedrock/") or model.startswith("us.anthropic."):
if os.environ.get("AWS_PROFILE"):
res["missing_keys"] = [
k
for k in res["missing_keys"]
if k not in ["AWS_ACCESS_KEY_ID", "AWS_SECRET_ACCESS_KEY"]
]
if not res["missing_keys"]:
res["keys_in_environment"] = True
if res["keys_in_environment"]: if res["keys_in_environment"]:
return res return res
if res["missing_keys"]: if res["missing_keys"]:
@@ -602,13 +637,97 @@ class Model(ModelSettings):
self.extra_params["extra_body"] = {} self.extra_params["extra_body"] = {}
self.extra_params["extra_body"]["reasoning_effort"] = effort self.extra_params["extra_body"]["reasoning_effort"] = effort
def set_thinking_tokens(self, num): def parse_token_value(self, value):
"""Set the thinking token budget for models that support it""" """
if num is not None: Parse a token value string into an integer.
Accepts formats: 8096, "8k", "10.5k", "0.5M", "10K", etc.
Args:
value: String or int token value
Returns:
Integer token value
"""
if isinstance(value, int):
return value
if not isinstance(value, str):
return int(value) # Try to convert to int
value = value.strip().upper()
if value.endswith("K"):
multiplier = 1024
value = value[:-1]
elif value.endswith("M"):
multiplier = 1024 * 1024
value = value[:-1]
else:
multiplier = 1
# Convert to float first to handle decimal values like "10.5k"
return int(float(value) * multiplier)
def set_thinking_tokens(self, value):
"""
Set the thinking token budget for models that support it.
Accepts formats: 8096, "8k", "10.5k", "0.5M", "10K", etc.
"""
if value is not None:
num_tokens = self.parse_token_value(value)
self.use_temperature = False self.use_temperature = False
if not self.extra_params: if not self.extra_params:
self.extra_params = {} self.extra_params = {}
self.extra_params["thinking"] = {"type": "enabled", "budget_tokens": num}
# OpenRouter models use 'reasoning' instead of 'thinking'
if self.name.startswith("openrouter/"):
self.extra_params["reasoning"] = {"max_tokens": num_tokens}
else:
self.extra_params["thinking"] = {"type": "enabled", "budget_tokens": num_tokens}
def get_thinking_tokens(self, model):
"""Get formatted thinking token budget if available"""
budget = None
if model.extra_params:
# Check for OpenRouter reasoning format
if (
"reasoning" in model.extra_params
and "max_tokens" in model.extra_params["reasoning"]
):
budget = model.extra_params["reasoning"]["max_tokens"]
# Check for standard thinking format
elif (
"thinking" in model.extra_params
and "budget_tokens" in model.extra_params["thinking"]
):
budget = model.extra_params["thinking"]["budget_tokens"]
if budget is not None:
# Format as xx.yK for thousands, xx.yM for millions
if budget >= 1024 * 1024:
value = budget / (1024 * 1024)
if value == int(value):
return f"{int(value)}M"
else:
return f"{value:.1f}M"
else:
value = budget / 1024
if value == int(value):
return f"{int(value)}k"
else:
return f"{value:.1f}k"
return None
def get_reasoning_effort(self, model):
"""Get reasoning effort value if available"""
if (
model.extra_params
and "extra_body" in model.extra_params
and "reasoning_effort" in model.extra_params["extra_body"]
):
return model.extra_params["extra_body"]["reasoning_effort"]
return None
def is_deepseek_r1(self): def is_deepseek_r1(self):
name = self.name.lower() name = self.name.lower()
@@ -657,6 +776,8 @@ class Model(ModelSettings):
hash_object = hashlib.sha1(key) hash_object = hashlib.sha1(key)
if "timeout" not in kwargs: if "timeout" not in kwargs:
kwargs["timeout"] = request_timeout kwargs["timeout"] = request_timeout
if self.verbose:
dump(kwargs)
res = litellm.completion(**kwargs) res = litellm.completion(**kwargs)
return hash_object, res return hash_object, res

View File

@@ -0,0 +1,7 @@
These scm files are all adapted from the github repositories listed here:
https://github.com/Goldziher/tree-sitter-language-pack/blob/main/sources/language_definitions.json
See this URL for information on the licenses of each repo:
https://github.com/Goldziher/tree-sitter-language-pack/

View File

@@ -0,0 +1,5 @@
(function_declarator
declarator: (identifier) @name.definition.function) @definition.function
(call_expression
function: (identifier) @name.reference.call) @reference.call

View File

@@ -0,0 +1,9 @@
(struct_specifier name: (type_identifier) @name.definition.class body:(_)) @definition.class
(declaration type: (union_specifier name: (type_identifier) @name.definition.class)) @definition.class
(function_declarator declarator: (identifier) @name.definition.function) @definition.function
(type_definition declarator: (type_identifier) @name.definition.type) @definition.type
(enum_specifier name: (type_identifier) @name.definition.type) @definition.type

View File

@@ -0,0 +1,16 @@
; Definitions
(intent_def
(intent) @name.definition.intent) @definition.intent
(slot_def
(slot) @name.definition.slot) @definition.slot
(alias_def
(alias) @name.definition.alias) @definition.alias
; References
(slot_ref
(slot) @name.reference.slot) @reference.slot
(alias_ref
(alias) @name.reference.alias) @reference.alias

View File

@@ -0,0 +1,122 @@
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; Function Definitions ;;;;;;;;;;;;;;;;;;;;;;;
(defun_header
function_name: (sym_lit) @name.definition.function) @definition.function
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; Function Calls ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;
;;; Basically, we consider every list literal with symbol as the
;;; first element to be a call to a function named by that element.
;;; But we must exclude some cases. Note, tree-sitter @ignore
;;; cases only work if they are declared before the cases
;;; we want to include.
;; Exclude lambda lists for function definitions
;; For example:
;;
;; (defun my-func (arg1 arg2) ...)
;;
;; do not treat (arg1 arg2) as a call of function arg1
;;
(defun_header
lambda_list: (list_lit . [(sym_lit) (package_lit)] @ignore))
;; Similar to the above, but for
;;
;; (defmethod m ((type1 param1) (type2 param2)) ...)
;;
;; where list literals having symbol as their first element
;; are nested inside the lambda list.
(defun_header
lambda_list: (list_lit (list_lit . [(sym_lit) (package_lit)] @ignore)))
;;
;; (let ((var ...) (var2 ...)) ...)
;;
;; - exclude var, var2
;; - the same for let*, flet, labels, macrolet, symbol-macrolet
(list_lit . [(sym_lit) (package_lit)] @name.reference.call
. (list_lit (list_lit . [(sym_lit) (package_lit)] @ignore))
(#match? @name.reference.call
"(?i)^(cl:)?(let|let\\*|flet|labels|macrolet|symbol-macrolet)$")
)
;; TODO:
;; - exclude also:
;; - (defclass name (parent parent2)
;; ((slot1 ...)
;; (slot2 ...))
;; exclude the parent, slot1, slot2
;; - (flet ((func-1 (param1 param2))) ...)
;; - we already exclude func-1, but param1 is still recognized
;; as a function call - exclude it too
;; - the same for labels
;; - the same macrolet
;; - what else?
;; (that's a non-goal to completely support all macros
;; and special operators, but every one we support
;; makes the solution a little bit better)
;; - (flet ((func-1 (param1 param2))) ...)
;; - instead of simply excluding it, as we do today,
;; tag func-1 as @local.definition.function (I suppose)
;; - the same for labels, macrolet
;; - @local.scope for let, let*, flet, labels, macrolet
;; - I guess the whole span of the scope text,
;; till the closing paren, should be tagged as @local.scope;
;; Hopefully, combined with @local.definition.function
;; within the scope, the usual @reference.call within
;; that scope will refer to the local definition,
;; and there will be no need to use @local.reference.call
;; (which is more difficult to implement).
;; - When implementing, remember the scope rules differences
;; of let vs let*, flet vs labels.
;; Include all other cases - list literal with symbol as the
;; first element
(list_lit . [(sym_lit) (package_lit)] @name.reference.call) @reference.call
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; classes
(list_lit . [(sym_lit) (package_lit)] @ignore
. [(sym_lit) (package_lit)] @name.definition.class
(#match? @ignore "(?i)^(cl:)?defclass$")
) @definition.class
(list_lit . [(sym_lit) (package_lit)] @ignore
. (quoting_lit [(sym_lit) (package_lit)] @name.reference.class)
(#match? @ignore "(?i)^(cl:)?make-instance$")
) @reference.class
;;; TODO:
;; - @reference.class for base classes
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; TODO:
;; - Symbols referenced in defpackage
;;
;; (defpackage ...
;; (:export (symbol-a :symbol-b #:symbol-c "SYMBOL-D")))
;;
;; The goal is to allow quick navigation from the API
;; overview in the form of defpackage, to the definition
;; where user can read parameters, docstring, etc.
;; - The @name must not include the colon, or sharpsign colon, quotes,
;; just symbol-a, symbol-b, symbol-c, sybmol-d
;; - Downcase the names specified as string literals?
;; ("SYMBOL-D" -> symbol-d)
;; - We don't know if the exported symbol is a function, variable,
;; class or something else. The official doc
;; (https://tree-sitter.github.io/tree-sitter/code-navigation-systems)
;; does not even suggest a tag for variable reference.
;; (Although in practice, the `tree-sitter tags` command
;; allows any @reference.* and @definition.* tags)
;; Probably it's better to just use @reference.call for all
;; the symbols in the :export clause.
;;
;; - The same for the export function call:
;;
;; (export '(symbol-a :symbol-b #:symbol-c "SYMBOL-D"))

View File

@@ -0,0 +1,15 @@
(struct_specifier name: (type_identifier) @name.definition.class body:(_)) @definition.class
(declaration type: (union_specifier name: (type_identifier) @name.definition.class)) @definition.class
(function_declarator declarator: (identifier) @name.definition.function) @definition.function
(function_declarator declarator: (field_identifier) @name.definition.function) @definition.function
(function_declarator declarator: (qualified_identifier scope: (namespace_identifier) @local.scope name: (identifier) @name.definition.method)) @definition.method
(type_definition declarator: (type_identifier) @name.definition.type) @definition.type
(enum_specifier name: (type_identifier) @name.definition.type) @definition.type
(class_specifier name: (type_identifier) @name.definition.class) @definition.class

View File

@@ -0,0 +1,26 @@
(module_def (module_declaration (module_fqn) @name.definition.module)) @definition.module
(struct_declaration (struct) . (identifier) @name.definition.class) @definition.class
(interface_declaration (interface) . (identifier) @name.definition.interface) @definition.interface
(enum_declaration (enum) . (identifier) @name.definition.type) @definition.type
(class_declaration (class) . (identifier) @name.definition.class) @definition.class
(constructor (this) @name.definition.method) @definition.method
(destructor (this) @name.definition.method) @definition.method
(postblit (this) @name.definition.method) @definition.method
(manifest_declarator . (identifier) @name.definition.type) @definition.type
(function_declaration (identifier) @name.definition.function) @definition.function
(union_declaration (union) . (identifier) @name.definition.type) @definition.type
(anonymous_enum_declaration (enum_member . (identifier) @name.definition.constant)) @definition.constant
(enum_declaration (enum_member . (identifier) @name.definition.constant)) @definition.constant
(call_expression (identifier) @name.reference.call) @reference.call
(call_expression (type (template_instance (identifier) @name.reference.call))) @reference.call
(parameter (type (identifier) @name.reference.class) @reference.class (identifier))
(variable_declaration (type (identifier) @name.reference.class) @reference.class (declarator))

View File

@@ -0,0 +1,92 @@
(class_definition
name: (identifier) @name.definition.class) @definition.class
(method_signature
(function_signature)) @definition.method
(type_alias
(type_identifier) @name.definition.type) @definition.type
(method_signature
(getter_signature
name: (identifier) @name.definition.method)) @definition.method
(method_signature
(setter_signature
name: (identifier) @name.definition.method)) @definition.method
(method_signature
(function_signature
name: (identifier) @name.definition.method)) @definition.method
(method_signature
(factory_constructor_signature
(identifier) @name.definition.method)) @definition.method
(method_signature
(constructor_signature
name: (identifier) @name.definition.method)) @definition.method
(method_signature
(operator_signature)) @definition.method
(method_signature) @definition.method
(mixin_declaration
(mixin)
(identifier) @name.definition.mixin) @definition.mixin
(extension_declaration
name: (identifier) @name.definition.extension) @definition.extension
(new_expression
(type_identifier) @name.reference.class) @reference.class
(enum_declaration
name: (identifier) @name.definition.enum) @definition.enum
(function_signature
name: (identifier) @name.definition.function) @definition.function
(initialized_variable_definition
name: (identifier)
value: (identifier) @name.reference.class
value: (selector
"!"?
(argument_part
(arguments
(argument)*))?)?) @reference.class
(assignment_expression
left: (assignable_expression
(identifier)
(unconditional_assignable_selector
"."
(identifier) @name.reference.send))) @reference.call
(assignment_expression
left: (assignable_expression
(identifier)
(conditional_assignable_selector
"?."
(identifier) @name.reference.send))) @reference.call
((identifier) @name.reference.send
(selector
"!"?
(conditional_assignable_selector
"?." (identifier) @name.reference.send)?
(unconditional_assignable_selector
"."? (identifier) @name.reference.send)?
(argument_part
(arguments
(argument)*))?)*
(cascade_section
(cascade_selector
(identifier)) @name.reference.send
(argument_part
(arguments
(argument)*))?)?) @reference.call

View File

@@ -0,0 +1,5 @@
;; defun/defsubst
(function_definition name: (symbol) @name.definition.function) @definition.function
;; Treat macros as function definitions for the sake of TAGS.
(macro_definition name: (symbol) @name.definition.function) @definition.function

View File

@@ -0,0 +1,54 @@
; Definitions
; * modules and protocols
(call
target: (identifier) @ignore
(arguments (alias) @name.definition.module)
(#any-of? @ignore "defmodule" "defprotocol")) @definition.module
; * functions/macros
(call
target: (identifier) @ignore
(arguments
[
; zero-arity functions with no parentheses
(identifier) @name.definition.function
; regular function clause
(call target: (identifier) @name.definition.function)
; function clause with a guard clause
(binary_operator
left: (call target: (identifier) @name.definition.function)
operator: "when")
])
(#any-of? @ignore "def" "defp" "defdelegate" "defguard" "defguardp" "defmacro" "defmacrop" "defn" "defnp")) @definition.function
; References
; ignore calls to kernel/special-forms keywords
(call
target: (identifier) @ignore
(#any-of? @ignore "def" "defp" "defdelegate" "defguard" "defguardp" "defmacro" "defmacrop" "defn" "defnp" "defmodule" "defprotocol" "defimpl" "defstruct" "defexception" "defoverridable" "alias" "case" "cond" "else" "for" "if" "import" "quote" "raise" "receive" "require" "reraise" "super" "throw" "try" "unless" "unquote" "unquote_splicing" "use" "with"))
; ignore module attributes
(unary_operator
operator: "@"
operand: (call
target: (identifier) @ignore))
; * function call
(call
target: [
; local
(identifier) @name.reference.call
; remote
(dot
right: (identifier) @name.reference.call)
]) @reference.call
; * pipe into function call
(binary_operator
operator: "|>"
right: (identifier) @name.reference.call) @reference.call
; * modules
(alias) @name.reference.module @reference.module

View File

@@ -0,0 +1,19 @@
(value_declaration (function_declaration_left (lower_case_identifier) @name.definition.function)) @definition.function
(function_call_expr (value_expr (value_qid) @name.reference.function)) @reference.function
(exposed_value (lower_case_identifier) @name.reference.function) @reference.function
(type_annotation ((lower_case_identifier) @name.reference.function) (colon)) @reference.function
(type_declaration ((upper_case_identifier) @name.definition.type) ) @definition.type
(type_ref (upper_case_qid (upper_case_identifier) @name.reference.type)) @reference.type
(exposed_type (upper_case_identifier) @name.reference.type) @reference.type
(type_declaration (union_variant (upper_case_identifier) @name.definition.union)) @definition.union
(value_expr (upper_case_qid (upper_case_identifier) @name.reference.union)) @reference.union
(module_declaration
(upper_case_qid (upper_case_identifier)) @name.definition.module
) @definition.module

View File

@@ -0,0 +1,41 @@
; Modules
(module) @name.reference.module @reference.module
(import alias: (identifier) @name.reference.module) @reference.module
(remote_type_identifier
module: (identifier) @name.reference.module) @reference.module
((field_access
record: (identifier) @name.reference.module)
(#is-not? local)) @reference.module
; Functions
(function
name: (identifier) @name.definition.function) @definition.function
(external_function
name: (identifier) @name.definition.function) @definition.function
(unqualified_import (identifier) @name.reference.function) @reference.function
((function_call
function: (identifier) @name.reference.function) @reference.function
(#is-not? local))
((field_access
record: (identifier) @ignore
field: (label) @name.reference.function)
(#is-not? local)) @reference.function
((binary_expression
operator: "|>"
right: (identifier) @name.reference.function)
(#is-not? local)) @reference.function
; Types
(type_definition
(type_name
name: (type_identifier) @name.definition.type)) @definition.type
(type_definition
(data_constructors
(data_constructor
name: (constructor_name) @name.definition.constructor))) @definition.constructor
(external_type
(type_name
name: (type_identifier) @name.definition.type)) @definition.type
(type_identifier) @name.reference.type @reference.type
(constructor_name) @name.reference.constructor @reference.constructor

View File

@@ -0,0 +1,42 @@
(
(comment)* @doc
.
(function_declaration
name: (identifier) @name.definition.function) @definition.function
(#strip! @doc "^//\\s*")
(#set-adjacent! @doc @definition.function)
)
(
(comment)* @doc
.
(method_declaration
name: (field_identifier) @name.definition.method) @definition.method
(#strip! @doc "^//\\s*")
(#set-adjacent! @doc @definition.method)
)
(call_expression
function: [
(identifier) @name.reference.call
(parenthesized_expression (identifier) @name.reference.call)
(selector_expression field: (field_identifier) @name.reference.call)
(parenthesized_expression (selector_expression field: (field_identifier) @name.reference.call))
]) @reference.call
(type_spec
name: (type_identifier) @name.definition.type) @definition.type
(type_identifier) @name.reference.type @reference.type
(package_clause "package" (package_identifier) @name.definition.module)
(type_declaration (type_spec name: (type_identifier) @name.definition.interface type: (interface_type)))
(type_declaration (type_spec name: (type_identifier) @name.definition.class type: (struct_type)))
(import_declaration (import_spec) @name.reference.module)
(var_declaration (var_spec name: (identifier) @name.definition.variable))
(const_declaration (const_spec name: (identifier) @name.definition.constant))

View File

@@ -0,0 +1,20 @@
(class_declaration
name: (identifier) @name.definition.class) @definition.class
(method_declaration
name: (identifier) @name.definition.method) @definition.method
(method_invocation
name: (identifier) @name.reference.method
arguments: (argument_list) @reference.call)
(interface_declaration
name: (identifier) @name.definition.interface) @definition.interface
(type_list
(type_identifier) @name.reference.interface) @reference.implementation
(object_creation_expression
type: (type_identifier) @name.reference.class) @reference.class
(superclass (type_identifier) @name.reference.class) @reference.class

View File

@@ -0,0 +1,34 @@
(function_declaration
name: [
(identifier) @name.definition.function
(dot_index_expression
field: (identifier) @name.definition.function)
]) @definition.function
(function_declaration
name: (method_index_expression
method: (identifier) @name.definition.method)) @definition.method
(assignment_statement
(variable_list .
name: [
(identifier) @name.definition.function
(dot_index_expression
field: (identifier) @name.definition.function)
])
(expression_list .
value: (function_definition))) @definition.function
(table_constructor
(field
name: (identifier) @name.definition.function
value: (function_definition))) @definition.function
(function_call
name: [
(identifier) @name.reference.call
(dot_index_expression
field: (identifier) @name.reference.call)
(method_index_expression
method: (identifier) @name.reference.method)
]) @reference.call

View File

@@ -0,0 +1,39 @@
;Class definitions @definition.class
;Function definitions @definition.function
;Interface definitions @definition.interface
;Method definitions @definition.method
;Module definitions @definition.module
;Function/method calls @reference.call
;Class reference @reference.class
;Interface implementation @reference.implementation
(
(identifier) @reference.class
(#match? @reference.class "^_*[A-Z][a-zA-Z0-9_]*$")
)
(class_definition (identifier) @name.definition.class) @definition.class
(actor_definition (identifier) @name.definition.class) @definition.class
(primitive_definition (identifier) @name.definition.class) @definition.class
(struct_definition (identifier) @name.definition.class) @definition.class
(type_alias (identifier) @name.definition.class) @definition.class
(trait_definition (identifier) @name.definition.interface) @definition.interface
(interface_definition (identifier) @name.definition.interface) @definition.interface
(constructor (identifier) @name.definition.method) @definition.method
(method (identifier) @name.definition.method) @definition.method
(behavior (identifier) @name.definition.method) @definition.method
(class_definition (type) @name.reference.implementation) @reference.implementation
(actor_definition (type) @name.reference.implementation) @reference.implementation
(primitive_definition (type) @name.reference.implementation) @reference.implementation
(struct_definition (type) @name.reference.implementation) @reference.implementation
(type_alias (type) @name.reference.implementation) @reference.implementation
; calls - not catching all possible call cases of callees for capturing the method name
(call_expression callee: [(identifier) (ffi_identifier)] @name.reference.call) @reference.call
(call_expression callee: (generic_expression [(identifier) (ffi_identifier)] @name.reference.call)) @reference.call
(call_expression callee: (member_expression (identifier) @name.reference.call .)) @reference.call
(call_expression callee: (member_expression (generic_expression [(identifier) (ffi_identifier)] @name.reference.call) .)) @reference.call
; TODO: add more possible callee expressions
(call_expression) @reference.call

View File

@@ -0,0 +1,5 @@
(property
(key) @name.definition.property) @definition.property
(substitution
(key) @name.reference.property) @reference.property

View File

@@ -0,0 +1,14 @@
(module (expression_statement (assignment left: (identifier) @name.definition.constant) @definition.constant))
(class_definition
name: (identifier) @name.definition.class) @definition.class
(function_definition
name: (identifier) @name.definition.function) @definition.function
(call
function: [
(identifier) @name.reference.call
(attribute
attribute: (identifier) @name.reference.call)
]) @reference.call

View File

@@ -0,0 +1,21 @@
(binary_operator
lhs: (identifier) @name.definition.function
operator: "<-"
rhs: (function_definition)
) @definition.function
(binary_operator
lhs: (identifier) @name.definition.function
operator: "="
rhs: (function_definition)
) @definition.function
(call
function: (identifier) @name.reference.call
) @reference.call
(call
function: (namespace_operator
rhs: (identifier) @name.reference.call
)
) @reference.call

View File

@@ -0,0 +1,12 @@
(list
.
(symbol) @reference._define
(#match? @reference._define "^(define|define/contract)$")
.
(list
.
(symbol) @name.definition.function) @definition.function)
(list
.
(symbol) @name.reference.call)

View File

@@ -0,0 +1,64 @@
; Method definitions
(
(comment)* @doc
.
[
(method
name: (_) @name.definition.method) @definition.method
(singleton_method
name: (_) @name.definition.method) @definition.method
]
(#strip! @doc "^#\\s*")
(#select-adjacent! @doc @definition.method)
)
(alias
name: (_) @name.definition.method) @definition.method
(setter
(identifier) @ignore)
; Class definitions
(
(comment)* @doc
.
[
(class
name: [
(constant) @name.definition.class
(scope_resolution
name: (_) @name.definition.class)
]) @definition.class
(singleton_class
value: [
(constant) @name.definition.class
(scope_resolution
name: (_) @name.definition.class)
]) @definition.class
]
(#strip! @doc "^#\\s*")
(#select-adjacent! @doc @definition.class)
)
; Module definitions
(
(module
name: [
(constant) @name.definition.module
(scope_resolution
name: (_) @name.definition.module)
]) @definition.module
)
; Calls
(call method: (identifier) @name.reference.call) @reference.call
(
[(identifier) (constant)] @name.reference.call @reference.call
(#is-not? local)
(#not-match? @name.reference.call "^(lambda|load|require|require_relative|__FILE__|__LINE__)$")
)

View File

@@ -0,0 +1,60 @@
; ADT definitions
(struct_item
name: (type_identifier) @name.definition.class) @definition.class
(enum_item
name: (type_identifier) @name.definition.class) @definition.class
(union_item
name: (type_identifier) @name.definition.class) @definition.class
; type aliases
(type_item
name: (type_identifier) @name.definition.class) @definition.class
; method definitions
(declaration_list
(function_item
name: (identifier) @name.definition.method) @definition.method)
; function definitions
(function_item
name: (identifier) @name.definition.function) @definition.function
; trait definitions
(trait_item
name: (type_identifier) @name.definition.interface) @definition.interface
; module definitions
(mod_item
name: (identifier) @name.definition.module) @definition.module
; macro definitions
(macro_definition
name: (identifier) @name.definition.macro) @definition.macro
; references
(call_expression
function: (identifier) @name.reference.call) @reference.call
(call_expression
function: (field_expression
field: (field_identifier) @name.reference.call)) @reference.call
(macro_invocation
macro: (identifier) @name.reference.call) @reference.call
; implementations
(impl_item
trait: (type_identifier) @name.reference.implementation) @reference.implementation
(impl_item
type: (type_identifier) @name.reference.implementation
!trait) @reference.implementation

View File

@@ -0,0 +1,43 @@
;; Method and Function declarations
(contract_declaration (_
(function_definition
name: (identifier) @name.definition.function) @definition.method))
(source_file
(function_definition
name: (identifier) @name.definition.function) @definition.function)
;; Contract, struct, enum and interface declarations
(contract_declaration
name: (identifier) @name.definition.class) @definition.class
(interface_declaration
name: (identifier) @name.definition.interface) @definition.interface
(library_declaration
name: (identifier) @name.definition.class) @definition.interface
(struct_declaration name: (identifier) @name.definition.class) @definition.class
(enum_declaration name: (identifier) @name.definition.class) @definition.class
(event_definition name: (identifier) @name.definition.class) @definition.class
;; Function calls
(call_expression (expression (identifier)) @name.reference.call ) @reference.call
(call_expression
(expression (member_expression
property: (_) @name.reference.method ))) @reference.call
;; Log emit
(emit_statement name: (_) @name.reference.class) @reference.class
;; Inheritance
(inheritance_specifier
ancestor: (user_defined_type (_) @name.reference.class . )) @reference.class
;; Imports ( note that unknown is not standardised )
(import_directive
import_name: (_) @name.reference.module ) @reference.unknown

View File

@@ -0,0 +1,51 @@
(class_declaration
name: (type_identifier) @name.definition.class) @definition.class
(protocol_declaration
name: (type_identifier) @name.definition.interface) @definition.interface
(class_declaration
(class_body
[
(function_declaration
name: (simple_identifier) @name.definition.method
)
(subscript_declaration
(parameter (simple_identifier) @name.definition.method)
)
(init_declaration "init" @name.definition.method)
(deinit_declaration "deinit" @name.definition.method)
]
)
) @definition.method
(protocol_declaration
(protocol_body
[
(protocol_function_declaration
name: (simple_identifier) @name.definition.method
)
(subscript_declaration
(parameter (simple_identifier) @name.definition.method)
)
(init_declaration "init" @name.definition.method)
]
)
) @definition.method
(class_declaration
(class_body
[
(property_declaration
(pattern (simple_identifier) @name.definition.property)
)
]
)
) @definition.property
(property_declaration
(pattern (simple_identifier) @name.definition.property)
) @definition.property
(function_declaration
name: (simple_identifier) @name.definition.function) @definition.function

View File

@@ -0,0 +1,20 @@
(assignment
key: "LABEL"
(value
(content) @name.definition.label)) @definition.label
(assignment
key: "GOTO"
(value
(content) @name.reference.label)) @reference.label
(assignment
key: "ENV"
(env_var) @name.definition.variable) @definition.variable
(match
key: "ENV"
(env_var) @name.reference.variable) @reference.variable
(var_sub
(env_var) @name.reference.variable) @reference.variable

View File

@@ -56,6 +56,7 @@ class GitRepo:
attribute_commit_message_committer=False, attribute_commit_message_committer=False,
commit_prompt=None, commit_prompt=None,
subtree_only=False, subtree_only=False,
git_commit_verify=True,
): ):
self.io = io self.io = io
self.models = models self.models = models
@@ -69,6 +70,7 @@ class GitRepo:
self.attribute_commit_message_committer = attribute_commit_message_committer self.attribute_commit_message_committer = attribute_commit_message_committer
self.commit_prompt = commit_prompt self.commit_prompt = commit_prompt
self.subtree_only = subtree_only self.subtree_only = subtree_only
self.git_commit_verify = git_commit_verify
self.ignore_file_cache = {} self.ignore_file_cache = {}
if git_dname: if git_dname:
@@ -133,7 +135,9 @@ class GitRepo:
# if context: # if context:
# full_commit_message += "\n\n# Aider chat conversation:\n\n" + context # full_commit_message += "\n\n# Aider chat conversation:\n\n" + context
cmd = ["-m", full_commit_message, "--no-verify"] cmd = ["-m", full_commit_message]
if not self.git_commit_verify:
cmd.append("--no-verify")
if fnames: if fnames:
fnames = [str(self.abs_root_path(fn)) for fn in fnames] fnames = [str(self.abs_root_path(fn)) for fn in fnames]
for fname in fnames: for fname in fnames:

View File

@@ -196,6 +196,7 @@
cache_control: true cache_control: true
editor_model_name: anthropic/claude-3-7-sonnet-20250219 editor_model_name: anthropic/claude-3-7-sonnet-20250219
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: anthropic/claude-3-7-sonnet-latest - name: anthropic/claude-3-7-sonnet-latest
edit_format: diff edit_format: diff
@@ -209,6 +210,7 @@
cache_control: true cache_control: true
editor_model_name: anthropic/claude-3-7-sonnet-latest editor_model_name: anthropic/claude-3-7-sonnet-latest
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: claude-3-7-sonnet-20250219 - name: claude-3-7-sonnet-20250219
edit_format: diff edit_format: diff
@@ -222,6 +224,7 @@
cache_control: true cache_control: true
editor_model_name: claude-3-7-sonnet-20250219 editor_model_name: claude-3-7-sonnet-20250219
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: claude-3-7-sonnet-latest - name: claude-3-7-sonnet-latest
edit_format: diff edit_format: diff
@@ -235,6 +238,7 @@
cache_control: true cache_control: true
editor_model_name: claude-3-7-sonnet-latest editor_model_name: claude-3-7-sonnet-latest
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: bedrock/anthropic.claude-3-7-sonnet-20250219-v1:0 - name: bedrock/anthropic.claude-3-7-sonnet-20250219-v1:0
edit_format: diff edit_format: diff
@@ -248,6 +252,7 @@
cache_control: true cache_control: true
editor_model_name: bedrock/anthropic.claude-3-7-sonnet-20250219-v1:0 editor_model_name: bedrock/anthropic.claude-3-7-sonnet-20250219-v1:0
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: bedrock/us.anthropic.claude-3-7-sonnet-20250219-v1:0 - name: bedrock/us.anthropic.claude-3-7-sonnet-20250219-v1:0
edit_format: diff edit_format: diff
@@ -261,6 +266,7 @@
cache_control: true cache_control: true
editor_model_name: bedrock/us.anthropic.claude-3-7-sonnet-20250219-v1:0 editor_model_name: bedrock/us.anthropic.claude-3-7-sonnet-20250219-v1:0
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: bedrock_converse/anthropic.claude-3-7-sonnet-20250219-v1:0 - name: bedrock_converse/anthropic.claude-3-7-sonnet-20250219-v1:0
edit_format: diff edit_format: diff
@@ -274,6 +280,7 @@
cache_control: true cache_control: true
editor_model_name: bedrock_converse/anthropic.claude-3-7-sonnet-20250219-v1:0 editor_model_name: bedrock_converse/anthropic.claude-3-7-sonnet-20250219-v1:0
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: bedrock_converse/us.anthropic.claude-3-7-sonnet-20250219-v1:0 - name: bedrock_converse/us.anthropic.claude-3-7-sonnet-20250219-v1:0
edit_format: diff edit_format: diff
@@ -287,6 +294,7 @@
cache_control: true cache_control: true
editor_model_name: bedrock_converse/us.anthropic.claude-3-7-sonnet-20250219-v1:0 editor_model_name: bedrock_converse/us.anthropic.claude-3-7-sonnet-20250219-v1:0
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: vertex_ai/claude-3-7-sonnet@20250219 - name: vertex_ai/claude-3-7-sonnet@20250219
edit_format: diff edit_format: diff
@@ -297,6 +305,7 @@
max_tokens: 64000 max_tokens: 64000
editor_model_name: vertex_ai/claude-3-7-sonnet@20250219 editor_model_name: vertex_ai/claude-3-7-sonnet@20250219
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: vertex_ai-anthropic_models/vertex_ai/claude-3-7-sonnet@20250219 - name: vertex_ai-anthropic_models/vertex_ai/claude-3-7-sonnet@20250219
edit_format: diff edit_format: diff
@@ -307,6 +316,7 @@
max_tokens: 64000 max_tokens: 64000
editor_model_name: vertex_ai-anthropic_models/vertex_ai/claude-3-7-sonnet@20250219 editor_model_name: vertex_ai-anthropic_models/vertex_ai/claude-3-7-sonnet@20250219
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: openrouter/anthropic/claude-3.7-sonnet - name: openrouter/anthropic/claude-3.7-sonnet
edit_format: diff edit_format: diff
@@ -320,6 +330,7 @@
cache_control: true cache_control: true
editor_model_name: openrouter/anthropic/claude-3.7-sonnet editor_model_name: openrouter/anthropic/claude-3.7-sonnet
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: openrouter/anthropic/claude-3.7-sonnet:beta - name: openrouter/anthropic/claude-3.7-sonnet:beta
edit_format: diff edit_format: diff
@@ -333,6 +344,7 @@
cache_control: true cache_control: true
editor_model_name: openrouter/anthropic/claude-3.7-sonnet editor_model_name: openrouter/anthropic/claude-3.7-sonnet
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["thinking_tokens"]
- name: bedrock/anthropic.claude-3-5-sonnet-20241022-v2:0 - name: bedrock/anthropic.claude-3-5-sonnet-20241022-v2:0
edit_format: diff edit_format: diff
@@ -694,6 +706,7 @@
streaming: false streaming: false
editor_model_name: azure/gpt-4o editor_model_name: azure/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
accepts_settings: ["reasoning_effort"]
- name: o1-preview - name: o1-preview
edit_format: architect edit_format: architect
@@ -732,6 +745,7 @@
editor_model_name: openrouter/openai/gpt-4o editor_model_name: openrouter/openai/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: openai/o1 - name: openai/o1
edit_format: diff edit_format: diff
@@ -742,6 +756,7 @@
editor_model_name: openai/gpt-4o editor_model_name: openai/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: o1 - name: o1
edit_format: diff edit_format: diff
@@ -752,6 +767,7 @@
editor_model_name: gpt-4o editor_model_name: gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: openrouter/qwen/qwen-2.5-coder-32b-instruct - name: openrouter/qwen/qwen-2.5-coder-32b-instruct
edit_format: diff edit_format: diff
@@ -800,6 +816,7 @@
editor_model_name: gpt-4o editor_model_name: gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: o3-mini - name: o3-mini
edit_format: diff edit_format: diff
@@ -809,6 +826,7 @@
editor_model_name: gpt-4o editor_model_name: gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: openrouter/openai/o3-mini - name: openrouter/openai/o3-mini
edit_format: diff edit_format: diff
@@ -818,6 +836,7 @@
editor_model_name: openrouter/openai/gpt-4o editor_model_name: openrouter/openai/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: openrouter/openai/o3-mini-high - name: openrouter/openai/o3-mini-high
edit_format: diff edit_format: diff
@@ -827,6 +846,7 @@
editor_model_name: openrouter/openai/gpt-4o editor_model_name: openrouter/openai/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: azure/o3-mini - name: azure/o3-mini
edit_format: diff edit_format: diff
@@ -836,6 +856,7 @@
editor_model_name: azure/gpt-4o editor_model_name: azure/gpt-4o
editor_edit_format: editor-diff editor_edit_format: editor-diff
system_prompt_prefix: "Formatting re-enabled. " system_prompt_prefix: "Formatting re-enabled. "
accepts_settings: ["reasoning_effort"]
- name: gpt-4.5-preview - name: gpt-4.5-preview
edit_format: diff edit_format: diff
@@ -883,3 +904,18 @@
max_tokens: 128000 max_tokens: 128000
top_p: 0.95 top_p: 0.95
- name: cohere_chat/command-a-03-2025
examples_as_sys_msg: true
- name: openrouter/cohere/command-a-03-2025
examples_as_sys_msg: true
- name: gemini/gemma-3-27b-it
use_system_prompt: false
- name: openrouter/google/gemma-3-27b-it:free
use_system_prompt: false
- name: openrouter/google/gemma-3-27b-it
use_system_prompt: false

View File

@@ -7,12 +7,13 @@ description: Release notes and stats on aider writing its own code.
# Release history # Release history
{% include blame.md %} Aider writes most of its own code, usually about 70-80% of the new code in each release.
These
The above [statistics are based on the git commit history](/docs/faq.html#how-are-the-aider-wrote-xx-of-code-stats-computed)
[stats are based on the git commit history](/docs/faq.html#how-are-the-aider-wrote-xx-of-code-stats-computed)
of the aider repo. of the aider repo.
{% include blame.md %}
## Release notes ## Release notes
<!--[[[cog <!--[[[cog
@@ -23,6 +24,51 @@ cog.out(text)
]]]--> ]]]-->
### Aider v0.78.0
- Added model setting validation to ignore `--reasoning-effort` and `--thinking-tokens` if the model doesn't support them.
- Added `--check-model-accepts-settings` flag (default: true) to force unsupported model settings.
- Annotated which models support reasoning_effort and thinking_tokens settings in the model settings data.
- Improved code block rendering in markdown output with better padding using NoInsetMarkdown.
- Added `--git-commit-verify` flag (default: False) to control whether git commit hooks are bypassed.
- Added support for thinking tokens for OpenRouter Sonnet 3.7.
- Fixed autocompletion for `/ask`, `/code`, and `/architect` commands, by shladnik.
- Added vi-like behavior when pressing enter in multiline-mode while in vi normal/navigation-mode, by Marco Mayer.
- Added commands to switch between model types: `/editor-model` for Editor Model, and `/weak-model` for Weak Model, by csala.
- Added AWS_PROFILE support for Bedrock models, allowing use of AWS profiles instead of explicit credentials, by lentil32.
- Enhanced `--aiderignore` argument to resolve both absolute and relative paths, by mopemope.
- Improved platform information handling to gracefully handle retrieval errors.
- Aider wrote 92% of the code in this release.
### Aider v0.77.1
- Bumped dependencies to pickup litellm fix for Ollama.
- Added support for `openrouter/google/gemma-3-27b-it` model.
- Updated exclude patterns for documentation.
### Aider v0.77.0
- Big upgrade in [programming languages supported](https://aider.chat/docs/languages.html) by adopting [tree-sitter-language-pack](https://github.com/Goldziher/tree-sitter-language-pack/).
- 130 new languages with linter support.
- 20 new languages with repo-map support.
- Added `/think-tokens` command to set thinking token budget with support for human-readable formats (8k, 10.5k, 0.5M).
- Added `/reasoning-effort` command to control model reasoning level.
- The `/think-tokens` and `/reasoning-effort` commands display current settings when called without arguments.
- Display of thinking token budget and reasoning effort in model information.
- Changed `--thinking-tokens` argument to accept string values with human-readable formats.
- Added `--auto-accept-architect` flag (default: true) to automatically accept changes from architect coder format without confirmation.
- Added support for `cohere_chat/command-a-03-2025` and `gemini/gemma-3-27b-it`
- The bare `/drop` command now preserves original read-only files provided via args.read.
- Fixed a bug where default model would be set by deprecated `--shortcut` switches even when already specified in the command line.
- Improved AutoCompleter to require 3 characters for autocompletion to reduce noise.
- Aider wrote 72% of the code in this release.
### Aider v0.76.2
- Fixed handling of JSONDecodeError when loading model cache file.
- Fixed handling of GitCommandError when retrieving git user configuration.
- Aider wrote 75% of the code in this release.
### Aider v0.76.1 ### Aider v0.76.1
- Added ignore_permission_denied option to file watcher to prevent errors when accessing restricted files, by Yutaka Matsubara. - Added ignore_permission_denied option to file watcher to prevent errors when accessing restricted files, by Yutaka Matsubara.

View File

@@ -4017,3 +4017,161 @@
gmoz22: 4 gmoz22: 4
start_tag: v0.75.0 start_tag: v0.75.0
total_lines: 1875 total_lines: 1875
- aider_percentage: 71.93
aider_total: 1399
end_date: '2025-03-13'
end_tag: v0.77.0
file_counts:
aider/__init__.py:
Paul Gauthier: 1
aider/args.py:
Paul Gauthier (aider): 5
aider/coders/architect_coder.py:
Paul Gauthier (aider): 2
aider/coders/base_coder.py:
Paul Gauthier (aider): 14
aider/commands.py:
Paul Gauthier: 4
Paul Gauthier (aider): 71
aider/deprecated.py:
Paul Gauthier: 2
aider/io.py:
Paul Gauthier (aider): 5
aider/main.py:
Paul Gauthier (aider): 12
aider/models.py:
Paul Gauthier (aider): 83
aider/queries/tree-sitter-language-pack/arduino-tags.scm:
Paul Gauthier: 3
Paul Gauthier (aider): 2
aider/queries/tree-sitter-language-pack/c-tags.scm:
Paul Gauthier: 4
Paul Gauthier (aider): 5
aider/queries/tree-sitter-language-pack/chatito-tags.scm:
Paul Gauthier: 11
Paul Gauthier (aider): 5
aider/queries/tree-sitter-language-pack/commonlisp-tags.scm:
Paul Gauthier: 116
Paul Gauthier (aider): 6
aider/queries/tree-sitter-language-pack/cpp-tags.scm:
Paul Gauthier: 7
Paul Gauthier (aider): 8
aider/queries/tree-sitter-language-pack/d-tags.scm:
Paul Gauthier: 9
Paul Gauthier (aider): 17
aider/queries/tree-sitter-language-pack/dart-tags.scm:
Paul Gauthier: 42
Paul Gauthier (aider): 19
aider/queries/tree-sitter-language-pack/elisp-tags.scm:
Paul Gauthier: 1
Paul Gauthier (aider): 2
aider/queries/tree-sitter-language-pack/elixir-tags.scm:
Paul Gauthier: 10
Paul Gauthier (aider): 8
aider/queries/tree-sitter-language-pack/elm-tags.scm:
Paul Gauthier: 8
Paul Gauthier (aider): 11
aider/queries/tree-sitter-language-pack/gleam-tags.scm:
Paul Gauthier: 26
Paul Gauthier (aider): 15
aider/queries/tree-sitter-language-pack/go-tags.scm:
Paul Gauthier: 14
Paul Gauthier (aider): 14
aider/queries/tree-sitter-language-pack/java-tags.scm:
Paul Gauthier: 10
Paul Gauthier (aider): 7
aider/queries/tree-sitter-language-pack/lua-tags.scm:
Paul Gauthier: 25
Paul Gauthier (aider): 9
aider/queries/tree-sitter-language-pack/pony-tags.scm:
Paul Gauthier: 20
Paul Gauthier (aider): 19
aider/queries/tree-sitter-language-pack/properties-tags.scm:
Paul Gauthier: 3
Paul Gauthier (aider): 2
aider/queries/tree-sitter-language-pack/python-tags.scm:
Paul Gauthier: 9
Paul Gauthier (aider): 5
aider/queries/tree-sitter-language-pack/r-tags.scm:
Paul Gauthier: 17
Paul Gauthier (aider): 4
aider/queries/tree-sitter-language-pack/racket-tags.scm:
Paul Gauthier: 10
Paul Gauthier (aider): 2
aider/queries/tree-sitter-language-pack/ruby-tags.scm:
Paul Gauthier: 23
Paul Gauthier (aider): 12
aider/queries/tree-sitter-language-pack/rust-tags.scm:
Paul Gauthier: 41
Paul Gauthier (aider): 14
aider/queries/tree-sitter-language-pack/solidity-tags.scm:
Paul Gauthier: 30
Paul Gauthier (aider): 13
aider/queries/tree-sitter-language-pack/swift-tags.scm:
Paul Gauthier: 39
Paul Gauthier (aider): 12
aider/queries/tree-sitter-language-pack/udev-tags.scm:
Paul Gauthier: 15
Paul Gauthier (aider): 5
aider/resources/model-settings.yml:
Paul Gauthier: 9
aider/watch.py:
Yutaka Matsubara: 4
aider/website/docs/leaderboards/index.md:
Paul Gauthier: 3
Paul Gauthier (aider): 8
scripts/redact-cast.py:
Paul Gauthier: 27
Paul Gauthier (aider): 98
scripts/tsl_pack_langs.py:
Paul Gauthier (aider): 145
scripts/versionbump.py:
Paul Gauthier (aider): 1
tests/basic/test_coder.py:
Paul Gauthier (aider): 104
tests/basic/test_commands.py:
Paul Gauthier: 2
Paul Gauthier (aider): 190
tests/basic/test_models.py:
Paul Gauthier (aider): 44
tests/basic/test_repomap.py:
Paul Gauthier: 1
Paul Gauthier (aider): 125
tests/fixtures/languages/arduino/test.ino:
Paul Gauthier (aider): 21
tests/fixtures/languages/c/test.c:
Paul Gauthier (aider): 12
tests/fixtures/languages/chatito/test.chatito:
Paul Gauthier (aider): 20
tests/fixtures/languages/commonlisp/test.lisp:
Paul Gauthier (aider): 17
tests/fixtures/languages/d/test.d:
Paul Gauthier (aider): 26
tests/fixtures/languages/dart/test.dart:
Paul Gauthier (aider): 21
tests/fixtures/languages/elm/test.elm:
Paul Gauthier (aider): 16
tests/fixtures/languages/gleam/test.gleam:
Paul Gauthier (aider): 10
tests/fixtures/languages/lua/test.lua:
Paul Gauthier (aider): 25
tests/fixtures/languages/pony/test.pony:
Paul Gauthier (aider): 8
tests/fixtures/languages/properties/test.properties:
Paul Gauthier (aider): 14
tests/fixtures/languages/r/test.r:
Paul Gauthier (aider): 17
tests/fixtures/languages/racket/test.rkt:
Paul Gauthier (aider): 8
tests/fixtures/languages/solidity/test.sol:
Paul Gauthier (aider): 21
tests/fixtures/languages/swift/test.swift:
Paul Gauthier (aider): 18
tests/fixtures/languages/udev/test.rules:
Paul Gauthier (aider): 22
grand_total:
Paul Gauthier: 542
Paul Gauthier (aider): 1399
Yutaka Matsubara: 4
start_tag: v0.76.0
total_lines: 1945

View File

@@ -728,3 +728,55 @@
versions: 0.75.3.dev versions: 0.75.3.dev
seconds_per_case: 137.4 seconds_per_case: 137.4
total_cost: 0 total_cost: 0
- dirname: 2025-03-14-23-40-00--cmda-quality-whole2
test_cases: 225
model: command-a-03-2025-quality
edit_format: whole
commit_hash: a1aa63f
pass_rate_1: 2.2
pass_rate_2: 12.0
pass_num_1: 5
pass_num_2: 27
percent_cases_well_formed: 99.6
error_outputs: 2
num_malformed_responses: 1
num_with_malformed_responses: 1
user_asks: 215
lazy_comments: 0
syntax_errors: 0
indentation_errors: 0
exhausted_context_windows: 1
test_timeouts: 4
total_tests: 225
command: OPENAI_API_BASE=https://api.cohere.ai/compatibility/v1 aider --model openai/command-a-03-2025-quality
date: 2025-03-14
versions: 0.77.1.dev
seconds_per_case: 85.1
total_cost: 0.0000
- dirname: 2025-03-15-01-21-24--gemma3-27b-or
test_cases: 225
model: gemma-3-27b-it
edit_format: whole
commit_hash: fd21f51-dirty
pass_rate_1: 1.8
pass_rate_2: 4.9
pass_num_1: 4
pass_num_2: 11
percent_cases_well_formed: 100.0
error_outputs: 3
num_malformed_responses: 0
num_with_malformed_responses: 0
user_asks: 181
lazy_comments: 0
syntax_errors: 0
indentation_errors: 0
exhausted_context_windows: 1
test_timeouts: 3
total_tests: 225
command: aider --model openrouter/google/gemma-3-27b-it
date: 2025-03-15
versions: 0.77.1.dev
seconds_per_case: 79.7
total_cost: 0.0000

View File

@@ -5,21 +5,15 @@ If you already have python 3.8-3.13 installed, you can get started quickly like
python -m pip install aider-install python -m pip install aider-install
aider-install aider-install
# Change directory into your code base # Change directory into your codebase
cd /to/your/project cd /to/your/project
# Work with DeepSeek via DeepSeek's API # DeepSeek
aider --model deepseek --api-key deepseek=your-key-goes-here aider --model deepseek --api-key deepseek=<key>
# Work with Claude 3.7 Sonnet via Anthropic's API # Claude 3.7 Sonnet
aider --model sonnet --api-key anthropic=your-key-goes-here aider --model sonnet --api-key anthropic=<key>
# Work with GPT-4o via OpenAI's API # o3-mini
aider --model gpt-4o --api-key openai=your-key-goes-here aider --model o3-mini --api-key openai=<key>
# Work with Sonnet via OpenRouter's API
aider --model openrouter/anthropic/claude-3.7-sonnet --api-key openrouter=your-key-goes-here
# Work with DeepSeek via OpenRouter's API
aider --model openrouter/deepseek/deepseek-chat --api-key openrouter=your-key-goes-here
``` ```

View File

@@ -5,10 +5,66 @@
<meta property="og:image" content="{{ site.url }}/assets/aider.jpg"> <meta property="og:image" content="{{ site.url }}/assets/aider.jpg">
<meta property="twitter:image" content="{{ site.url }}/assets/aider-square.jpg"> <meta property="twitter:image" content="{{ site.url }}/assets/aider-square.jpg">
{% endif %} {% endif %}
<!-- Custom site title styling -->
<style>
@font-face {
font-family: GlassTTYVT220;
src: local("Glass TTY VT220"), local("Glass TTY VT220 Medium"), url(/assets/Glass_TTY_VT220.ttf) format("truetype");
}
.site-title {
font-size: 1.8rem;
font-weight: 700;
font-family: 'GlassTTYVT220', monospace;
color: #14b014; /* terminal green color */
text-decoration: none;
letter-spacing: 0.5px;
}
/* For SVG logo inside site-title */
.site-title img {
height: 1.8rem;
vertical-align: middle;
}
/* Sidebar gradient styling to match hero section */
.side-bar {
background: linear-gradient(135deg, #ffffff 0%, rgba(20, 176, 20, 0.01) 25%, rgba(20, 176, 20, 0.04) 40%, rgba(220, 230, 255, 0.4) 60%, rgba(205, 218, 255, 0.4) 80%, #F5F6FA 100%);
}
</style>
<link rel="alternate" type="application/rss+xml" title="RSS Feed" href="{{ site.url }}/feed.xml"> <link rel="alternate" type="application/rss+xml" title="RSS Feed" href="{{ site.url }}/feed.xml">
<link rel="preconnect" href="https://fonts.gstatic.com"> <link rel="preconnect" href="https://fonts.gstatic.com">
<link rel="preload" href="https://fonts.googleapis.com/css?family=Open+Sans:400,700&display=swap" as="style" type="text/css" crossorigin> <link rel="preload" href="https://fonts.googleapis.com/css?family=Open+Sans:400,700&display=swap" as="style" type="text/css" crossorigin>
<meta name="viewport" content="width=device-width, initial-scale=1"> <meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Logo Progressive Enhancement for Jekyll pages -->
<script>
document.addEventListener('DOMContentLoaded', function() {
const siteTitle = document.querySelector('.site-title');
if (siteTitle) {
const textContent = siteTitle.textContent; // Save the text for fallback
// Create new image element
const logoImg = new Image();
logoImg.src = '/assets/logo.svg';
logoImg.alt = 'Aider Logo';
logoImg.style.height = '1.8rem';
logoImg.style.verticalAlign = 'middle';
// Only replace if image loads successfully
logoImg.onload = function() {
siteTitle.textContent = ''; // Clear text
siteTitle.appendChild(logoImg);
};
// If image fails to load, do nothing (keep the text)
logoImg.onerror = function() {
console.log('SVG logo failed to load, keeping text fallback');
};
}
});
</script>
<meta name="theme-color" content="#157878"> <meta name="theme-color" content="#157878">
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
<link rel="icon" type="image/png" sizes="32x32" href="{{ '/assets/icons/favicon-32x32.png' | relative_url }}"> <link rel="icon" type="image/png" sizes="32x32" href="{{ '/assets/icons/favicon-32x32.png' | relative_url }}">

View File

@@ -0,0 +1,228 @@
/* Terminal header styling */
.terminal-header {
background-color: #e0e0e0;
border-top-left-radius: 6px;
border-top-right-radius: 6px;
padding: 4px 10px;
display: flex;
align-items: center;
border-bottom: 1px solid #c0c0c0;
}
.terminal-buttons {
display: flex;
gap: 4px;
margin-right: 10px;
}
.terminal-button {
width: 10px;
height: 10px;
border-radius: 50%;
}
.terminal-close {
background-color: #ff5f56;
border: 1px solid #e0443e;
}
.terminal-minimize {
background-color: #ffbd2e;
border: 1px solid #dea123;
}
.terminal-expand {
background-color: #27c93f;
border: 1px solid #1aab29;
}
.terminal-title {
flex-grow: 1;
text-align: center;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
font-size: 11px;
color: #666;
}
/* Toast notification styling */
.toast-container {
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 9999;
pointer-events: none;
}
.toast-notification {
background-color: rgba(0, 0, 0, 0.7);
color: white;
padding: 12px 25px;
border-radius: 8px;
margin-bottom: 10px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
opacity: 0;
transition: opacity 0.3s ease-in-out;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
font-size: 18px;
text-align: center;
display: inline-block;
min-width: 200px;
max-width: 90%;
}
/* Page container styling */
.page-container {
max-width: 950px;
margin-left: auto;
margin-right: auto;
position: relative;
}
/* macOS backdrop styling */
.macos-backdrop {
background: linear-gradient(135deg, #ff9966, #ff5e62, #6666ff, #0066ff);
border-radius: 12px;
padding: clamp(5px, 5vw, 50px) clamp(5px, 2.5vw, 50px);
margin: 20px 0;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
position: relative;
overflow: hidden;
}
/* Add subtle wave animation to backdrop */
.macos-backdrop::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: radial-gradient(circle at center, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 70%);
opacity: 0.7;
pointer-events: none;
}
/* Add decorative curved lines to the backdrop */
.macos-backdrop::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-image:
radial-gradient(circle at 20% 30%, transparent 0%, transparent 60%, rgba(255,255,255,0.2) 61%, transparent 62%),
radial-gradient(circle at 80% 70%, transparent 0%, transparent 40%, rgba(255,255,255,0.2) 41%, transparent 42%),
radial-gradient(circle at 40% 90%, transparent 0%, transparent 70%, rgba(255,255,255,0.2) 71%, transparent 72%),
radial-gradient(circle at 60% 10%, transparent 0%, transparent 50%, rgba(255,255,255,0.2) 51%, transparent 52%);
background-size: 100% 100%;
opacity: 1;
pointer-events: none;
z-index: 0;
}
.terminal-container {
border-radius: 8px;
overflow: hidden;
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
margin-top: 0;
margin-bottom: 0;
position: relative;
background-color: white; /* Add background color to terminal container */
z-index: 2; /* Ensure terminal appears above the backdrop effects */
}
/* Timestamp link styling */
.timestamp-link {
color: #0366d6;
text-decoration: none;
font-weight: bold;
cursor: pointer;
}
.timestamp-link:hover {
text-decoration: underline;
}
/* Active timestamp styling */
.timestamp-active {
background-color: #f0f8ff; /* Light blue background */
border-radius: 3px;
padding: 2px 4px;
margin: -2px -4px;
}
/* Highlight the list item containing the active timestamp */
li.active-marker {
background-color: #f6f8fa;
border-radius: 4px;
padding: 4px 8px;
margin-left: -8px;
}
/* Make list items clickable */
.transcript-item {
cursor: pointer;
transition: background-color 0.2s ease;
padding: 4px 8px;
margin-left: -8px;
border-radius: 4px;
}
.transcript-item:hover {
background-color: #f0f0f0;
}
/* Keyboard shortcuts styling */
.keyboard-shortcuts {
text-align: center;
font-size: 14px;
color: #666;
margin-top: 10px;
margin-bottom: 20px;
}
/* Hide keyboard shortcuts on devices likely without physical keyboards */
.no-physical-keyboard .keyboard-shortcuts {
display: none;
}
.keyboard-shortcuts kbd {
background-color: #f7f7f7;
border: 1px solid #ccc;
border-radius: 3px;
box-shadow: 0 1px 0 rgba(0,0,0,0.2);
color: #333;
display: inline-block;
font-family: monospace;
line-height: 1;
margin: 0 2px;
padding: 3px 5px;
white-space: nowrap;
}
.asciinema-player-theme-aider {
/* Foreground (default text) color */
--term-color-foreground: #444444; /* colour238 */
/* Background color */
--term-color-background: #dadada; /* colour253 */
/* Palette of 16 standard ANSI colors */
--term-color-0: #21222c;
--term-color-1: #ff5555;
--term-color-2: #50fa7b;
--term-color-3: #f1fa8c;
--term-color-4: #bd93f9;
--term-color-5: #ff79c6;
--term-color-6: #8be9fd;
--term-color-7: #f8f8f2;
--term-color-8: #6272a4;
--term-color-9: #ff6e6e;
--term-color-10: #69ff94;
--term-color-11: #ffffa5;
--term-color-12: #d6acff;
--term-color-13: #ff92df;
--term-color-14: #a4ffff;
--term-color-15: #ffffff;
}

View File

@@ -0,0 +1,428 @@
document.addEventListener('DOMContentLoaded', function() {
let player; // Store player reference to make it accessible to click handlers
let globalAudio; // Global audio element to be reused
// Detect if device likely has no physical keyboard
function detectNoKeyboard() {
// Check if it's a touch device (most mobile devices)
const isTouchDevice = ('ontouchstart' in window) ||
(navigator.maxTouchPoints > 0) ||
(navigator.msMaxTouchPoints > 0);
// Check common mobile user agents as additional signal
const isMobileUA = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
// If it's a touch device and has a mobile user agent, likely has no physical keyboard
if (isTouchDevice && isMobileUA) {
document.body.classList.add('no-physical-keyboard');
}
}
// Run detection
detectNoKeyboard();
// Parse the transcript section to create markers and convert timestamps to links
function parseTranscript() {
const markers = [];
// Find the Commentary heading
const transcriptHeading = Array.from(document.querySelectorAll('h2')).find(el => el.textContent.trim() === 'Commentary');
if (transcriptHeading) {
// Get all list items after the transcript heading
let currentElement = transcriptHeading.nextElementSibling;
while (currentElement && currentElement.tagName === 'UL') {
const listItems = currentElement.querySelectorAll('li');
listItems.forEach(item => {
const text = item.textContent.trim();
const match = text.match(/(\d+):(\d+)\s+(.*)/);
if (match) {
const minutes = parseInt(match[1], 10);
const seconds = parseInt(match[2], 10);
const timeInSeconds = minutes * 60 + seconds;
const formattedTime = `${minutes}:${seconds.toString().padStart(2, '0')}`;
const message = match[3].trim();
// Create link for the timestamp
const timeLink = document.createElement('a');
timeLink.href = '#';
timeLink.textContent = formattedTime;
timeLink.className = 'timestamp-link';
timeLink.dataset.time = timeInSeconds;
timeLink.dataset.message = message;
// Add click event to seek the player
timeLink.addEventListener('click', function(e) {
e.preventDefault();
if (player && typeof player.seek === 'function') {
player.seek(timeInSeconds);
player.play();
// Also trigger toast and speech
showToast(message);
speakText(message, timeInSeconds);
// Highlight this timestamp
highlightTimestamp(timeInSeconds);
}
});
// Replace text with the link + message
item.textContent = '';
item.appendChild(timeLink);
item.appendChild(document.createTextNode(' ' + message));
// Add class and click handler to the entire list item
item.classList.add('transcript-item');
item.dataset.time = timeInSeconds;
item.dataset.message = message;
item.addEventListener('click', function(e) {
// Prevent click event if the user clicked directly on the timestamp link
// This prevents double-firing of the event
if (e.target !== timeLink) {
e.preventDefault();
if (player && typeof player.seek === 'function') {
player.seek(timeInSeconds);
player.play();
// Also trigger toast and speech
showToast(message);
speakText(message, timeInSeconds);
// Highlight this timestamp
highlightTimestamp(timeInSeconds);
}
}
});
markers.push([timeInSeconds, message]);
}
});
currentElement = currentElement.nextElementSibling;
}
}
return markers;
}
// Parse transcript and create markers
const markers = parseTranscript();
// Create player with a single call
player = AsciinemaPlayer.create(
recording_url,
document.getElementById('demo'),
{
speed: 1.25,
idleTimeLimit: 1,
theme: "aider",
poster: "npt:0:01",
markers: markers,
controls: true
}
);
// Focus on the player element so keyboard shortcuts work immediately
setTimeout(() => {
// Use setTimeout to ensure the player is fully initialized
if (player && typeof player.focus === 'function') {
player.focus();
} else {
// If player doesn't have a focus method, try to find and focus the terminal element
const playerElement = document.querySelector('.asciinema-terminal');
if (playerElement) {
playerElement.focus();
} else {
// Last resort - try to find element with tabindex
const tabbableElement = document.querySelector('[tabindex]');
if (tabbableElement) {
tabbableElement.focus();
}
}
}
}, 100);
// Track active toast elements
let activeToast = null;
// Function to display toast notification
function showToast(text) {
// Get the appropriate container based on fullscreen state
let container = document.getElementById('toast-container');
const isFullscreen = document.fullscreenElement ||
document.webkitFullscreenElement ||
document.mozFullScreenElement ||
document.msFullscreenElement;
// If in fullscreen, check if we need to create a fullscreen toast container
if (isFullscreen) {
// Target the fullscreen element as the container parent
const fullscreenElement = document.fullscreenElement ||
document.webkitFullscreenElement ||
document.mozFullScreenElement ||
document.msFullscreenElement;
// Look for an existing fullscreen toast container
let fsContainer = fullscreenElement.querySelector('.fs-toast-container');
if (!fsContainer) {
// Create a new container for fullscreen mode
fsContainer = document.createElement('div');
fsContainer.className = 'toast-container fs-toast-container';
fsContainer.id = 'fs-toast-container';
fullscreenElement.appendChild(fsContainer);
}
container = fsContainer;
}
// Remove any existing toast
if (activeToast) {
hideToast(activeToast);
}
// Create toast element
const toast = document.createElement('div');
toast.className = 'toast-notification';
toast.textContent = text;
// Add to container
container.appendChild(toast);
// Store reference to active toast
activeToast = {
element: toast,
container: container
};
// Trigger animation
setTimeout(() => {
toast.style.opacity = '1';
}, 10);
return activeToast;
}
// Function to hide a toast
function hideToast(toastInfo) {
if (!toastInfo || !toastInfo.element) return;
toastInfo.element.style.opacity = '0';
setTimeout(() => {
if (toastInfo.container && toastInfo.container.contains(toastInfo.element)) {
toastInfo.container.removeChild(toastInfo.element);
}
// If this was the active toast, clear the reference
if (activeToast === toastInfo) {
activeToast = null;
}
}, 300); // Wait for fade out animation
}
// Track if TTS is currently in progress to prevent duplicates
let ttsInProgress = false;
let currentToast = null;
// Improved browser TTS function
function useBrowserTTS(text) {
// Don't start new speech if already in progress
if (ttsInProgress) {
console.log('Speech synthesis already in progress, skipping');
return false;
}
if ('speechSynthesis' in window) {
console.log('Using browser TTS fallback');
// Set flag to prevent duplicate speech
ttsInProgress = true;
// Cancel any ongoing speech
window.speechSynthesis.cancel();
const utterance = new SpeechSynthesisUtterance(text);
utterance.rate = 1.0;
utterance.pitch = 1.0;
utterance.volume = 1.0;
// For iOS, use a shorter utterance if possible
if (/iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream) {
utterance.text = text.length > 100 ? text.substring(0, 100) + '...' : text;
}
utterance.onstart = () => console.log('Speech started');
utterance.onend = () => {
console.log('Speech ended');
ttsInProgress = false; // Reset flag when speech completes
// Hide toast when speech ends
if (currentToast) {
hideToast(currentToast);
currentToast = null;
}
};
utterance.onerror = (e) => {
console.warn('Speech error:', e);
ttsInProgress = false; // Reset flag on error
// Also hide toast on error
if (currentToast) {
hideToast(currentToast);
currentToast = null;
}
};
window.speechSynthesis.speak(utterance);
return true;
}
console.warn('SpeechSynthesis not supported');
return false;
}
// Function to play pre-generated TTS audio files
function speakText(text, timeInSeconds) {
// Show the toast and keep reference
currentToast = showToast(text);
// Format time for filename (MM-SS)
const minutes = Math.floor(timeInSeconds / 60);
const seconds = timeInSeconds % 60;
const formattedTime = `${minutes.toString().padStart(2, '0')}-${seconds.toString().padStart(2, '0')}`;
// Get recording_id from the page or use default from the URL
const recordingId = typeof recording_id !== 'undefined' ? recording_id :
window.location.pathname.split('/').pop().replace('.html', '');
// Construct audio file path
const audioPath = `/assets/audio/${recordingId}/${formattedTime}.mp3`;
// Log for debugging
console.log(`Attempting to play audio: ${audioPath}`);
// Detect iOS
const isIOS = /iPad|iPhone|iPod/.test(navigator.userAgent) && !window.MSStream;
console.log(`Device is iOS: ${isIOS}`);
// Flag to track if we've already fallen back to TTS
let fallenBackToTTS = false;
try {
// Create or reuse audio element
if (!globalAudio) {
globalAudio = new Audio();
console.log("Created new global Audio element");
}
// Set up event handlers
globalAudio.onended = () => {
console.log('Audio playback ended');
// Hide toast when audio ends
if (currentToast) {
hideToast(currentToast);
currentToast = null;
}
};
globalAudio.onerror = (e) => {
console.warn(`Audio error: ${e.type}`, e);
if (!fallenBackToTTS) {
fallenBackToTTS = true;
useBrowserTTS(text);
} else if (currentToast) {
// If we've already tried TTS and that failed too, hide the toast
hideToast(currentToast);
currentToast = null;
}
};
// For iOS, preload might help with subsequent plays
if (isIOS) {
globalAudio.preload = "auto";
}
// Set the new source
globalAudio.src = audioPath;
// Play with proper error handling
const playPromise = globalAudio.play();
if (playPromise !== undefined) {
playPromise.catch(error => {
console.warn(`Play error: ${error.message}`);
// On iOS, a user gesture might be required
if (isIOS) {
console.log("iOS playback failed, trying SpeechSynthesis");
}
if (!fallenBackToTTS) {
fallenBackToTTS = true;
useBrowserTTS(text);
}
});
}
} catch (e) {
console.error(`Exception in audio playback: ${e.message}`);
useBrowserTTS(text);
}
}
// Function to highlight the active timestamp in the transcript
function highlightTimestamp(timeInSeconds) {
// Remove previous highlights
document.querySelectorAll('.timestamp-active').forEach(el => {
el.classList.remove('timestamp-active');
});
document.querySelectorAll('.active-marker').forEach(el => {
el.classList.remove('active-marker');
});
// Find the timestamp link with matching time
const timestampLinks = document.querySelectorAll('.timestamp-link');
let activeLink = null;
for (const link of timestampLinks) {
if (parseInt(link.dataset.time) === timeInSeconds) {
activeLink = link;
break;
}
}
if (activeLink) {
// Add highlight class to the link
activeLink.classList.add('timestamp-active');
// Also highlight the parent list item
const listItem = activeLink.closest('li');
if (listItem) {
listItem.classList.add('active-marker');
// No longer scrolling into view to avoid shifting focus
}
}
}
// Add event listener with safety checks
if (player && typeof player.addEventListener === 'function') {
player.addEventListener('marker', function(event) {
try {
const { index, time, label } = event;
console.log(`marker! ${index} - ${time} - ${label}`);
// Speak the marker label (toast is now shown within speakText)
speakText(label, time);
// Highlight the corresponding timestamp in the transcript
highlightTimestamp(time);
} catch (error) {
console.error('Error in marker event handler:', error);
}
});
}
});

View File

@@ -0,0 +1,34 @@
<link rel="stylesheet" type="text/css" href="/assets/asciinema/asciinema-player.css" />
<style>
{% include recording.css %}
</style>
<script src="/assets/asciinema/asciinema-player.min.js"></script>
<script>
{% include recording.js %}
</script>
<div class="page-container">
<div class="toast-container" id="toast-container"></div>
<div class="macos-backdrop">
<div class="terminal-container">
<div class="terminal-header">
<div class="terminal-buttons">
<div class="terminal-button terminal-close"></div>
<div class="terminal-button terminal-minimize"></div>
<div class="terminal-button terminal-expand"></div>
</div>
<div class="terminal-title">aider</div>
</div>
<div id="demo"></div>
</div>
</div>
</div>
<div class="keyboard-shortcuts">
<kbd>Space</kbd> Play/pause —
<kbd>f</kbd> Fullscreen —
<kbd>←</kbd><kbd>→</kbd> ±5s
</div>

Binary file not shown.

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,11 @@
{
"00-01": "We're going to add a new feature to automatically accept edits proposed by the architect model.",
"00-11": "First, let's add the new switch.",
"00-40": "Aider figured out that it should be passed to the Coder class.",
"00-48": "Now we need to implement the functionality.",
"01-00": "Let's do some manual testing.",
"01-28": "That worked. Let's make sure we can turn it off too.",
"02-00": "Let's quickly tidy up the changes to HISTORY.",
"02-05": "All done!",
"01-42": "That worked too. Let's have aider update the HISTORY file to document the new feature."
}

View File

@@ -0,0 +1,11 @@
{
"00-10": "We've added files that handle the main CLI and in-chat slash commands like /drop.",
"00-20": "Let's explain the needed change to aider.",
"01-20": "Ok, let's look at the code.",
"01-30": "I'd prefer not to use \"hasattr()\", let's ask for improvements.",
"01-45": "Let's try some manual testing.",
"02-10": "Looks good. Let's check the existing test suite to ensure we didn't break anything.",
"02-19": "Let's ask aider to add tests for this.",
"02-50": "Tests look reasonable, we're done!",
"00-01": "We're going to update the /drop command to keep any read only files that were originally specified at launch."
}

Some files were not shown because too many files have changed in this diff Show More