# This file declares various requirements for this version of repo.  The
# launcher script will load it and check the constraints before trying to run
# us.  This avoids issues of the launcher using an old version of Python (e.g.
# 3.5) while the codebase has moved on to requiring something much newer (e.g.
# 3.8).  If the launcher tried to import us, it would fail with syntax errors.

# This is a JSON file with line-level comments allowed.

# Always keep backwards compatibility in mine.  The launcher script is robust
# against missing values, but when a field is renamed/removed, it means older
# versions of the launcher script won't be able to enforce the constraint.

# When requiring versions, always use lists as they are easy to parse & compare
# in Python.  Strings would require futher processing to turn into a list.

# Version constraints should be expressed in pairs: soft & hard.  Soft versions
# are when we start warning users that their software too old and we're planning
# on dropping support for it, so they need to start planning system upgrades.
# Hard versions are when we refuse to work the tool.  Users will be shown an
# error message before we abort entirely.

# When deciding whether to upgrade a version requirement, check out the distro
# lists to see who will be impacted:
# https://gerrit.googlesource.com/git-repo/+/HEAD/docs/release-process.md#Project-References

{
  # The repo launcher itself.  This allows us to force people to upgrade as some
  # ignore the warnings about it being out of date, or install ancient versions
  # to start with for whatever reason.
  #
  # NB: Repo launchers started checking this file with repo-2.12, so listing
  # versions older than that won't make a difference.
  "repo": {
    "hard": [2, 11],
    "soft": [2, 11]
  },

  # Supported Python versions.
  #
  # python-3.6 is in Ubuntu Bionic.
  # python-3.7 is in Debian Buster.
  "python": {
    "hard": [3, 6],
    "soft": [3, 6]
  },

  # Supported git versions.
  #
  # git-1.7.2 is in Debian Squeeze.
  # git-1.7.9 is in Ubuntu Precise.
  # git-1.9.1 is in Ubuntu Trusty.
  # git-1.7.10 is in Debian Wheezy.
  "git": {
    "hard": [1, 7, 2],
    "soft": [1, 9, 1]
  }
}