A fork of hyde, the static site generation. Some patches will be pushed upstream.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

167 lines
5.7 KiB

  1. from setuptools import setup, find_packages
  2. from hyde.version import __version__
  3. from distutils.util import convert_path
  4. from fnmatch import fnmatchcase
  5. import os
  6. import sys
  7. PROJECT = 'hyde'
  8. try:
  9. long_description = open('README.rst', 'rt').read()
  10. except IOError:
  11. long_description = ''
  12. ##############################################################################
  13. # find_package_data is an Ian Bicking creation.
  14. # Provided as an attribute, so you can append to these instead
  15. # of replicating them:
  16. standard_exclude = ('*.py', '*.pyc', '*~', '.*', '*.bak', '*.swp*')
  17. standard_exclude_directories = ('.*', 'CVS', '_darcs', './build',
  18. './dist', 'EGG-INFO', '*.egg-info')
  19. def find_package_data(
  20. where='.', package='',
  21. exclude=standard_exclude,
  22. exclude_directories=standard_exclude_directories,
  23. only_in_packages=True,
  24. show_ignored=False):
  25. """
  26. Return a dictionary suitable for use in ``package_data``
  27. in a distutils ``setup.py`` file.
  28. The dictionary looks like::
  29. {'package': [files]}
  30. Where ``files`` is a list of all the files in that package that
  31. don't match anything in ``exclude``.
  32. If ``only_in_packages`` is true, then top-level directories that
  33. are not packages won't be included (but directories under packages
  34. will).
  35. Directories matching any pattern in ``exclude_directories`` will
  36. be ignored; by default directories with leading ``.``, ``CVS``,
  37. and ``_darcs`` will be ignored.
  38. If ``show_ignored`` is true, then all the files that aren't
  39. included in package data are shown on stderr (for debugging
  40. purposes).
  41. Note patterns use wildcards, or can be exact paths (including
  42. leading ``./``), and all searching is case-insensitive.
  43. This function is by Ian Bicking.
  44. """
  45. out = {}
  46. stack = [(convert_path(where), '', package, only_in_packages)]
  47. while stack:
  48. where, prefix, package, only_in_packages = stack.pop(0)
  49. for name in os.listdir(where):
  50. fn = os.path.join(where, name)
  51. if os.path.isdir(fn):
  52. bad_name = False
  53. for pattern in exclude_directories:
  54. if fnmatchcase(name, pattern) or \
  55. fn.lower() == pattern.lower():
  56. bad_name = True
  57. if show_ignored:
  58. print >> sys.stderr, (
  59. "Directory %s ignored by pattern %s"
  60. % (fn, pattern))
  61. break
  62. if bad_name:
  63. continue
  64. if os.path.isfile(os.path.join(fn, '__init__.py')):
  65. if not package:
  66. new_package = name
  67. else:
  68. new_package = package + '.' + name
  69. stack.append((fn, '', new_package, False))
  70. else:
  71. stack.append((fn, prefix + name + '/', package,
  72. only_in_packages))
  73. elif package or not only_in_packages:
  74. # is a file
  75. bad_name = False
  76. for pattern in exclude:
  77. if fnmatchcase(name, pattern) \
  78. or fn.lower() == pattern.lower():
  79. bad_name = True
  80. if show_ignored:
  81. print >> sys.stderr, (
  82. "File %s ignored by pattern %s"
  83. % (fn, pattern))
  84. break
  85. if bad_name:
  86. continue
  87. out.setdefault(package, []).append(prefix+name)
  88. return out
  89. ##############################################################################
  90. def read_requirements(f):
  91. reqs = []
  92. with open(f, "r") as h:
  93. reqs = [req.split('#', 1)[0].strip() for req in h]
  94. reqs = [req for req in reqs if req]
  95. return reqs
  96. install_requires = read_requirements('requirements.txt')
  97. dev_requires = read_requirements('dev-only.txt')
  98. setup(name=PROJECT,
  99. version=__version__,
  100. description='hyde is a static website generator',
  101. long_description=long_description,
  102. author='hyde developers',
  103. author_email='hyde-dev@googlegroups.com',
  104. url='http://hyde.github.io',
  105. packages=find_packages(),
  106. requires=['python (>= 2.7)'],
  107. install_requires=install_requires,
  108. tests_require=dev_requires,
  109. test_suite='nose.collector',
  110. include_package_data=True,
  111. # Scan the input for package information
  112. # to grab any data files (text, images, etc.)
  113. # associated with sub-packages.
  114. package_data=find_package_data(PROJECT,
  115. package=PROJECT,
  116. only_in_packages=False,),
  117. entry_points={
  118. 'console_scripts': [
  119. 'hyde = hyde.main:main'
  120. ]
  121. },
  122. license='MIT',
  123. classifiers=[
  124. 'Development Status :: 4 - Beta',
  125. 'Environment :: Console',
  126. 'Intended Audience :: End Users/Desktop',
  127. 'Intended Audience :: Developers',
  128. 'Intended Audience :: System Administrators',
  129. 'License :: OSI Approved :: MIT License',
  130. 'Operating System :: MacOS :: MacOS X',
  131. 'Operating System :: Unix',
  132. 'Operating System :: POSIX',
  133. 'Operating System :: Microsoft :: Windows',
  134. 'Programming Language :: Python',
  135. 'Topic :: Software Development',
  136. 'Topic :: Software Development :: Build Tools',
  137. 'Topic :: Software Development :: Code Generators',
  138. 'Topic :: Internet',
  139. 'Topic :: Internet :: WWW/HTTP :: Site Management',
  140. ],
  141. zip_safe=False,)