__meta__.py 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. """
  2. Python Markdown
  3. A Python implementation of John Gruber's Markdown.
  4. Documentation: https://python-markdown.github.io/
  5. GitHub: https://github.com/Python-Markdown/markdown/
  6. PyPI: https://pypi.org/project/Markdown/
  7. Started by Manfred Stienstra (http://www.dwerg.net/).
  8. Maintained for a few years by Yuri Takhteyev (http://www.freewisdom.org).
  9. Currently maintained by Waylan Limberg (https://github.com/waylan),
  10. Dmitry Shachnev (https://github.com/mitya57) and Isaac Muse (https://github.com/facelessuser).
  11. Copyright 2007-2018 The Python Markdown Project (v. 1.7 and later)
  12. Copyright 2004, 2005, 2006 Yuri Takhteyev (v. 0.2-1.6b)
  13. Copyright 2004 Manfred Stienstra (the original version)
  14. License: BSD (see LICENSE.md for details).
  15. """
  16. # __version_info__ format:
  17. # (major, minor, patch, dev/alpha/beta/rc/final, #)
  18. # (1, 1, 2, 'dev', 0) => "1.1.2.dev0"
  19. # (1, 1, 2, 'alpha', 1) => "1.1.2a1"
  20. # (1, 2, 0, 'beta', 2) => "1.2b2"
  21. # (1, 2, 0, 'rc', 4) => "1.2rc4"
  22. # (1, 2, 0, 'final', 0) => "1.2"
  23. __version_info__ = (3, 2, 2, 'final', 0)
  24. def _get_version(version_info):
  25. " Returns a PEP 440-compliant version number from version_info. "
  26. assert len(version_info) == 5
  27. assert version_info[3] in ('dev', 'alpha', 'beta', 'rc', 'final')
  28. parts = 2 if version_info[2] == 0 else 3
  29. v = '.'.join(map(str, version_info[:parts]))
  30. if version_info[3] == 'dev':
  31. v += '.dev' + str(version_info[4])
  32. elif version_info[3] != 'final':
  33. mapping = {'alpha': 'a', 'beta': 'b', 'rc': 'rc'}
  34. v += mapping[version_info[3]] + str(version_info[4])
  35. return v
  36. __version__ = _get_version(__version_info__)