# Aider chat conversation:
USER: we need to parse `current_version` and ignore the -dev if it is present
ASSISTANT: To implement this, we need to modify the `scripts/versionbump.py` file.
Here is the proposed change:
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
current_version = re.search(r'__version__ = "(.+?)"', content).group(1)
if new_version <= version.parse(current_version):
raise ValueError(
f"New version {new_version} must be greater than the current version {current_version}"
)
=======
current_version = re.search(r'__version__ = "(.+?)"', content).group(1).split('-dev')[0]
if new_version <= version.parse(current_version):
raise ValueError(
f"New version {new_version} must be greater than the current version {current_version}"
)
>>>>>>> UPDATED
```
This change will ensure that the '-dev' suffix is discarded when parsing the `current_version`.
# Aider chat conversation:
USER: I did `git reset --hard HEAD~1` to discard the last edits.
ASSISTANT: Okay, that command will undo the last commit and discard the changes. If you need to make any further changes or need assistance with anything else, feel free to ask.
USER: we need to commit __init__ with x.y.z, tag it, push it. and THEN write a new __init__ with the -dev version, and then commit that.
ASSISTANT: Understood. We need to modify the `scripts/versionbump.py` file to implement this.
Here are the proposed changes:
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
updated_content = re.sub(r'__version__ = ".+?"', f'__version__ = "{new_version}"', content)
if dry_run:
print("Updating aider/__init__.py with new version:")
print(updated_content)
else:
with open("aider/__init__.py", "w") as f:
f.write(updated_content)
git_commands = [
["git", "add", "aider/__init__.py"],
["git", "commit", "-m", f"version bump to {new_version}"],
["git", "tag", f"v{new_version}"],
["git", "push", "origin"],
["git", "push", "origin", f"v{new_version}"],
]
=======
updated_content = re.sub(r'__version__ = ".+?"', f'__version__ = "{new_version}"', content)
if dry_run:
print("Updating aider/__init__.py with new version:")
print(updated_content)
else:
with open("aider/__init__.py", "w") as f:
f.write(updated_content)
git_commands = [
["git", "add", "aider/__init__.py"],
["git", "commit", "-m", f"version bump to {new_version}"],
["git", "tag", f"v{new_version}"],
["git", "push", "origin"],
["git", "push", "origin", f"v{new_version}"],
]
for cmd in git_commands:
if dry_run:
print(f"Running: {' '.join(cmd)}")
else:
subprocess.run(cmd, check=True)
updated_dev_content = re.sub(r'__version__ = ".+?"', f'__version__ = "{new_version}-dev"', content)
if dry_run:
print("Updating aider/__init__.py with new dev version:")
print(updated_dev_content)
else:
with open("aider/__init__.py", "w") as f:
f.write(updated_dev_content)
git_commands_dev = [
["git", "add", "aider/__init__.py"],
["git", "commit", "-m", f"set version to {new_version}-dev"],
["git", "push", "origin"],
]
for cmd in git_commands_dev:
if dry_run:
print(f"Running: {' '.join(cmd)}")
else:
subprocess.run(cmd, check=True)
>>>>>>> UPDATED
```
These changes will ensure that the version in `aider/__init__.py` is set to 'x.y.z', committed, tagged, and pushed. Then, it will be updated to 'x.y.z-dev', committed, and pushed.
# Context:
USER: make sure `new_version` is a 3 piece semver
ASSISTANT: I will update the `scripts/versionbump.py` script to ensure that `new_version` is a 3-piece semver.
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
new_version = version.parse(args.new_version)
if not isinstance(new_version, version.Version):
raise ValueError("Invalid version format")
=======
new_version_str = args.new_version
if not re.match(r'^\d+\.\d+\.\d+$', new_version_str):
raise ValueError("Invalid version format, must be x.y.z")
new_version = version.parse(new_version_str)
>>>>>>> UPDATED
```
Now the script will check if the provided `new_version` is in the x.y.z format before proceeding.
# Context:
USER: add a --dry-run arg that just prints each step, so it won't overwrite __init__.py or actually rnu the git cmds
ASSISTANT: I will add a `--dry-run` argument to the `scripts/versionbump.py` script. When this argument is provided, the script will print each step without actually modifying the `__init__.py` file or running the git commands.
Here are the changes:
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
def main():
parser = argparse.ArgumentParser(description="Bump version")
parser.add_argument("new_version", help="New version in x.y.z format")
=======
def main():
parser = argparse.ArgumentParser(description="Bump version")
parser.add_argument("new_version", help="New version in x.y.z format")
parser.add_argument("--dry-run", action="store_true", help="Print each step without actually executing them")
>>>>>>> UPDATED
scripts/versionbump.py
<<<<<<< ORIGINAL
args = parser.parse_args()
=======
args = parser.parse_args()
dry_run = args.dry_run
>>>>>>> UPDATED
scripts/versionbump.py
<<<<<<< ORIGINAL
with open("aider/__init__.py", "w") as f:
f.write(updated_content)
=======
if dry_run:
print("Updating aider/__init__.py with new version")
else:
with open("aider/__init__.py", "w") as f:
f.write(updated_content)
>>>>>>> UPDATED
scripts/versionbump.py
<<<<<<< ORIGINAL
subprocess.run(["git", "add", "aider/__init__.py"], check=True)
subprocess.run(["git", "commit", "-m", f"version bump to {new_version}"], check=True)
subprocess.run(["git", "tag", f"v{new_version}"], check=True)
subprocess.run(["git", "push", "origin"], check=True)
subprocess.run(["git", "push", "origin", f"v{new_version}"], check=True)
=======
git_commands = [
["git", "add", "aider/__init__.py"],
["git", "commit", "-m", f"version bump to {new_version}"],
["git", "tag", f"v{new_version}"],
["git", "push", "origin"],
["git", "push", "origin", f"v{new_version}"],
]
for cmd in git_commands:
if dry_run:
print(f"Running: {' '.join(cmd)}")
else:
subprocess.run(cmd, check=True)
>>>>>>> UPDATED
```
Now you can run the script with the `--dry-run` argument to see the steps without actually executing them:
```bash
python scripts/versionbump.py x.y.z --dry-run
```
# Context:
USER: will those `subprocess` calls raise exceptions if the git commands error?
ASSISTANT: Yes, by default, the `subprocess.run()` function will not raise an exception if the command returns a non-zero exit code. However, you can add the `check=True` parameter to the `subprocess.run()` calls to make them raise a `CalledProcessError` exception if the command returns a non-zero exit code. Here's the updated `scripts/versionbump.py` with the `check=True` parameter added:
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
subprocess.run(["git", "add", "aider/__init__.py"])
subprocess.run(["git", "commit", "-m", f"version bump to {new_version}"])
subprocess.run(["git", "tag", f"v{new_version}"])
subprocess.run(["git", "push", "origin"])
subprocess.run(["git", "push", "origin", f"v{new_version}"])
=======
subprocess.run(["git", "add", "aider/__init__.py"], check=True)
subprocess.run(["git", "commit", "-m", f"version bump to {new_version}"], check=True)
subprocess.run(["git", "tag", f"v{new_version}"], check=True)
subprocess.run(["git", "push", "origin"], check=True)
subprocess.run(["git", "push", "origin", f"v{new_version}"], check=True)
>>>>>>> UPDATED
```
With these changes, if any of the git commands fail, the script will raise a `CalledProcessError` exception and terminate.
# Context:
USER: write a dcript that takes x.y.z semver on the cmd line. it should:
1. verify that the version is greater than `__version__`
2. wupdate the `__version__` in init.py
3. git commit that change with msg `version bump to x.y.z`
4. git tag that new commit with "vx.y.z" (note the leading v)
5. git push to origin
6. git push the new tag to origin
ASSISTANT: I will create a new script called `scripts/versionbump.py` to handle the version bumping process. Here are the changes:
```python
scripts/versionbump.py
<<<<<<< ORIGINAL
=======
import argparse
import os
import re
import subprocess
from packaging import version
def main():
parser = argparse.ArgumentParser(description="Bump version")
parser.add_argument("new_version", help="New version in x.y.z format")
args = parser.parse_args()
new_version = version.parse(args.new_version)
if not isinstance(new_version, version.Version):
raise ValueError("Invalid version format")
with open("aider/__init__.py", "r") as f:
content = f.read()
current_version = re.search(r'__version__ = "(.+?)"', content).group(1)
if new_version <= version.parse(current_version):
raise ValueError("New version must be greater than the current version")
updated_content = re.sub(r'__version__ = ".+?"', f'__version__ = "{new_version}"', content)
with open("aider/__init__.py", "w") as f:
f.write(updated_content)
subprocess.run(["git", "add", "aider/__init__.py"])
subprocess.run(["git", "commit", "-m", f"version bump to {new_version}"])
subprocess.run(["git", "tag", f"v{new_version}"])
subprocess.run(["git", "push", "origin"])
subprocess.run(["git", "push", "origin", f"v{new_version}"])
if __name__ == "__main__":
main()
>>>>>>> UPDATED
```
This script will perform the requested actions. Make sure to install the `packaging` library if you haven't already:
```bash
pip install packaging
```
You can run the script with the new version as an argument:
```bash
python scripts/versionbump.py x.y.z
```