forked from espressif/esptool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
116 lines (95 loc) · 3.53 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
from __future__ import division, print_function
import io
import os
import re
from setuptools import setup
# Example code to pull version from esptool.py with regex, taken from
# http://python-packaging-user-guide.readthedocs.org/en/latest/single_source_version/
def read(*names, **kwargs):
with io.open(
os.path.join(os.path.dirname(__file__), *names),
encoding=kwargs.get("encoding", "utf8")
) as fp:
return fp.read()
def find_version(*file_paths):
version_file = read(*file_paths)
version_match = re.search(r"^__version__ = ['\"]([^'\"]*)['\"]",
version_file, re.M)
if version_match:
return version_match.group(1)
raise RuntimeError("Unable to find version string.")
long_description = """
==========
esptool.py
==========
A command line utility to communicate with the ROM bootloader in Espressif ESP8266 & ESP32 microcontrollers.
Allows flashing firmware, reading back firmware, querying chip parameters, etc.
The esptool.py project is hosted on github: https://github.com/espressif/esptool
Installation
------------
esptool can be installed via pip:
$ pip install --upgrade esptool
Since version 1.3, esptool supports both Python 2.7 and Python 3.4 or newer.
Since version 2.0, esptool supports both ESP8266 & ESP32.
Usage
-----
Please see the `Usage section of the README.md file <https://github.com/espressif/esptool#usage>`_.
You can also get help information by running `esptool.py --help`.
Contributing
------------
Please see the `CONTRIBUTING.md file on github <https://github.com/espressif/esptool/blob/master/CONTRIBUTING.md>`_.
"""
# For Windows, we want to install esptool.py.exe, etc. so that normal Windows command line can run them
# For Linux/macOS, we can't use console_scripts with extension .py as their names will clash with the modules' names.
if os.name == "nt":
scripts = None
entry_points = {
'console_scripts': [
'esptool.py=esptool:_main',
'espsecure.py=espsecure:_main',
'espefuse.py=espefuse:_main',
],
}
else:
scripts = ['esptool.py',
'espsecure.py',
'espefuse.py']
entry_points = None
setup(
name='esptool',
py_modules=['esptool', 'espsecure', 'espefuse'],
version=find_version('esptool.py'),
description='A serial utility to communicate & flash code to Espressif ESP8266 & ESP32 chips.',
long_description=long_description,
url='https://github.com/espressif/esptool',
author='Fredrik Ahlberg (themadinventor) & Angus Gratton (projectgus)',
author_email='[email protected]',
license='GPLv2+',
classifiers=[
'Development Status :: 5 - Production/Stable',
'Intended Audience :: Developers',
'Natural Language :: English',
'Operating System :: POSIX',
'Operating System :: Microsoft :: Windows',
'Operating System :: MacOS :: MacOS X',
'Topic :: Software Development :: Embedded Systems',
'Environment :: Console',
'License :: OSI Approved :: GNU General Public License v2 or later (GPLv2+)',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3.4',
'Programming Language :: Python :: 3.5',
'Programming Language :: Python :: 3.6',
],
tests_require=[
'flake8>=3.2.0',
'flake8-future-import',
'flake8-import-order',
],
install_requires=[
'pyserial>=3.0',
'pyaes',
'ecdsa',
],
scripts=scripts,
entry_points=entry_points,
)