Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Gradual typing #1217

Open
wants to merge 11 commits into
base: main
Choose a base branch
from
43 changes: 43 additions & 0 deletions .github/workflows/lint.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
---
name: Linting

on:
push:
paths-ignore:
- 'aider/website/**'
- README.md
- HISTORY.md
branches:
- main
pull_request:
paths-ignore:
- 'aider/website/**'
- README.md
branches:
- main

jobs:
mypy:
runs-on: ubuntu-latest

steps:
- name: Check out repository
uses: actions/checkout@v4

- name: Set up Python 3.12
uses: actions/setup-python@v5
with:
python-version: "3.12"

- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install '.[browser,dev,playwright,mypy]'

- name: Run Mypy
uses: wearerequired/[email protected]
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
mypy: true
mypy_args: "."
continue_on_error: false
22 changes: 11 additions & 11 deletions aider/coders/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,15 @@
# from .single_wholefile_func_coder import SingleWholeFileFunctionCoder

__all__ = [
HelpCoder,
AskCoder,
Coder,
EditBlockCoder,
EditBlockFencedCoder,
WholeFileCoder,
UnifiedDiffCoder,
# SingleWholeFileFunctionCoder,
ArchitectCoder,
EditorEditBlockCoder,
EditorWholeFileCoder,
"HelpCoder",
"AskCoder",
"Coder",
"EditBlockCoder",
"EditBlockFencedCoder",
"WholeFileCoder",
"UnifiedDiffCoder",
# "SingleWholeFileFunctionCoder",
"ArchitectCoder",
"EditorEditBlockCoder",
"EditorWholeFileCoder",
]
3 changes: 2 additions & 1 deletion aider/coders/ask_coder.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
from .ask_prompts import AskPrompts
from .base_coder import Coder
from .base_prompts import CoderPrompts


class AskCoder(Coder):
"""Ask questions about code without making any changes."""

edit_format = "ask"
gpt_prompts = AskPrompts()
gpt_prompts: CoderPrompts = AskPrompts()
2 changes: 1 addition & 1 deletion aider/coders/base_coder.py
Original file line number Diff line number Diff line change
Expand Up @@ -879,7 +879,7 @@ def check_and_open_urls(self, exc, friendly_msg=None):
self.io.offer_url(url)
return urls

def check_for_urls(self, inp: str) -> List[str]:
def check_for_urls(self, inp: str) -> str:
"""Check input for URLs and offer to add them to the chat."""
if not self.detect_urls:
return inp
Expand Down
5 changes: 4 additions & 1 deletion aider/coders/base_prompts.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
from __future__ import annotations


class CoderPrompts:
system_reminder = ""

Expand Down Expand Up @@ -37,7 +40,7 @@ class CoderPrompts:
" stop and wait for your approval."
)

repo_content_prefix = """Here are summaries of some files present in my git repository.
repo_content_prefix: str | None = """Here are summaries of some files present in my git repository.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The type union syntax X | Y is only available in Python 3.10, but Aider still supports Python 3.9.
Instead, this should be

Suggested change
repo_content_prefix: str | None = """Here are summaries of some files present in my git repository.
repo_content_prefix: typing.Optional[str] = """Here are summaries of some files present in my git repository.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On line 1 of this file, I've added

from __future__ import annotations

which makes sure X | Y is supported on Python 3.9.

Do not propose changes to these files, treat them as *read-only*.
If you need to edit any of these files, ask me to *add them to the chat* first.
"""
Expand Down
10 changes: 7 additions & 3 deletions aider/coders/search_replace.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,15 @@

import sys
from pathlib import Path
from typing import TYPE_CHECKING

try:
if TYPE_CHECKING:
import git
except ImportError:
git = None
else:
try:
import git
except ImportError:
git = None

from diff_match_patch import diff_match_patch
from tqdm import tqdm
Expand Down
2 changes: 1 addition & 1 deletion aider/exceptions.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
class ExInfo:
name: str
retry: bool
description: str
description: str | None


EXCEPTIONS = [
Expand Down
4 changes: 3 additions & 1 deletion aider/io.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
from __future__ import annotations

import base64
import os
import signal
Expand Down Expand Up @@ -35,7 +37,7 @@

@dataclass
class ConfirmGroup:
preference: str = None
preference: str | None = None
show_group: bool = True

def __init__(self, items=None):
Expand Down
2 changes: 1 addition & 1 deletion aider/llm.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,4 @@ def _load_litellm(self):

litellm = LazyLiteLLM()

__all__ = [litellm]
__all__ = ["litellm"]
10 changes: 7 additions & 3 deletions aider/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,15 @@
import webbrowser
from dataclasses import fields
from pathlib import Path
from typing import TYPE_CHECKING

try:
if TYPE_CHECKING:
import git
except ImportError:
git = None
else:
try:
import git
except ImportError:
git = None

import importlib_resources
from dotenv import load_dotenv
Expand Down
8 changes: 4 additions & 4 deletions aider/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
DEFAULT_MODEL_NAME = "gpt-4o"
ANTHROPIC_BETA_HEADER = "prompt-caching-2024-07-31,pdfs-2024-09-25"

OPENAI_MODELS = """
_OPENAI_MODELS = """
gpt-4
gpt-4o
gpt-4o-2024-05-13
Expand All @@ -46,9 +46,9 @@
gpt-3.5-turbo-16k-0613
"""

OPENAI_MODELS = [ln.strip() for ln in OPENAI_MODELS.splitlines() if ln.strip()]
OPENAI_MODELS = [ln.strip() for ln in _OPENAI_MODELS.splitlines() if ln.strip()]

ANTHROPIC_MODELS = """
_ANTHROPIC_MODELS = """
claude-2
claude-2.1
claude-3-haiku-20240307
Expand All @@ -59,7 +59,7 @@
claude-3-5-sonnet-20241022
"""

ANTHROPIC_MODELS = [ln.strip() for ln in ANTHROPIC_MODELS.splitlines() if ln.strip()]
ANTHROPIC_MODELS = [ln.strip() for ln in _ANTHROPIC_MODELS.splitlines() if ln.strip()]

# Mapping of model aliases to their canonical names
MODEL_ALIASES = {
Expand Down
28 changes: 16 additions & 12 deletions aider/repo.py
Original file line number Diff line number Diff line change
@@ -1,17 +1,22 @@
import os
import time
from pathlib import Path, PurePosixPath
from typing import TYPE_CHECKING

try:
if TYPE_CHECKING:
import git

ANY_GIT_ERROR = [
git.exc.ODBError,
git.exc.GitError,
]
except ImportError:
git = None
ANY_GIT_ERROR = []
_ANY_GIT_ERROR = []
else:
try:
import git

_ANY_GIT_ERROR = [
git.exc.ODBError,
git.exc.GitError,
]
except ImportError:
git = None
_ANY_GIT_ERROR = []

import pathspec

Expand All @@ -20,15 +25,14 @@

from .dump import dump # noqa: F401

ANY_GIT_ERROR += [
_ANY_GIT_ERROR += [
OSError,
IndexError,
BufferError,
TypeError,
ValueError,
]
ANY_GIT_ERROR = tuple(ANY_GIT_ERROR)

ANY_GIT_ERROR = tuple(_ANY_GIT_ERROR)

class GitRepo:
repo = None
Expand Down
2 changes: 1 addition & 1 deletion aider/repomap.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@
warnings.simplefilter("ignore", category=FutureWarning)
from tree_sitter_languages import get_language, get_parser # noqa: E402

Tag = namedtuple("Tag", "rel_fname fname line name kind".split())
Tag = namedtuple("Tag", ("rel_fname", "fname", "line", "name", "kind"))


SQLITE_ERRORS = (sqlite3.OperationalError, sqlite3.DatabaseError, OSError)
Expand Down
46 changes: 46 additions & 0 deletions mypy.ini
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
[mypy]
exclude = (?x)(
^\.git/
| ^benchmark/$
| ^build/$
| ^dist/$
| ^scripts/$
)
allow_untyped_globals = True
check_untyped_defs = False

[mypy-configargparse]
ignore_missing_imports = True

[mypy-diff_match_patch]
ignore_missing_imports = True

[mypy-diskcache]
ignore_missing_imports = True

[mypy-grep_ast.*]
ignore_missing_imports = True

[mypy-imgcat]
ignore_missing_imports = True

[mypy-llama_index.*]
ignore_missing_imports = True

[mypy-mixpanel]
ignore_missing_imports = True

[mypy-pydub]
ignore_missing_imports = True

[mypy-pypandoc]
ignore_missing_imports = True

[mypy-pyperclip]
ignore_missing_imports = True

[mypy-soundfile]
ignore_missing_imports = True

[mypy-sounddevice]
ignore_missing_imports = True
1 change: 1 addition & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ dev = { file = "requirements/requirements-dev.txt" }
help = { file = "requirements/requirements-help.txt" }
browser = { file = "requirements/requirements-browser.txt" }
playwright = { file = "requirements/requirements-playwright.txt" }
mypy = { file = "requirements/requirements-mypy.txt" }

[tool.setuptools]
include-package-data = true
Expand Down
13 changes: 13 additions & 0 deletions requirements/requirements-mypy.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
-c ../requirements.txt

mypy
types-Pygments
types-PyYAML
types-beautifulsoup4
types-jsonschema
types-networkx
types-pexpect
types-psutil
types-requests
types-tqdm
types-tree-sitter-languages
Loading
Loading