mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-11-04 08:01:38 +01:00 
			
		
		
		
	- get.exe is clickable and will soon download binary form of esptool, which will really simplify installation on Windows - get.py does not require any extra modules on Linux and Mac - ```pip install requests``` required only on Windows (if not using get.exe) - Paths are made relative to the file in order to make the windows executable clickable.
		
			
				
	
	
		
			140 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/env python
 | 
						|
# This script will download and extract required tools into the current directory.
 | 
						|
# Tools list is obtained from package/package_esp8266com_index.template.json file.
 | 
						|
# Written by Ivan Grokhotkov, 2015.
 | 
						|
#
 | 
						|
from __future__ import print_function
 | 
						|
import os
 | 
						|
import shutil
 | 
						|
import errno
 | 
						|
import os.path
 | 
						|
import hashlib
 | 
						|
import json
 | 
						|
import platform
 | 
						|
import sys
 | 
						|
import tarfile
 | 
						|
import zipfile
 | 
						|
import re
 | 
						|
if sys.version_info[0] == 3:
 | 
						|
    from urllib.request import urlretrieve
 | 
						|
else:
 | 
						|
    # Not Python 3 - today, it is most likely to be Python 2
 | 
						|
    from urllib import urlretrieve
 | 
						|
 | 
						|
if 'Windows' in platform.system():
 | 
						|
    import requests
 | 
						|
 | 
						|
current_dir = os.path.dirname(os.path.realpath(__file__))
 | 
						|
dist_dir = current_dir + '/dist/'
 | 
						|
 | 
						|
def sha256sum(filename, blocksize=65536):
 | 
						|
    hash = hashlib.sha256()
 | 
						|
    with open(filename, "rb") as f:
 | 
						|
        for block in iter(lambda: f.read(blocksize), b""):
 | 
						|
            hash.update(block)
 | 
						|
    return hash.hexdigest()
 | 
						|
 | 
						|
def mkdir_p(path):
 | 
						|
    try:
 | 
						|
        os.makedirs(path)
 | 
						|
    except OSError as exc:
 | 
						|
        if exc.errno != errno.EEXIST or not os.path.isdir(path):
 | 
						|
            raise
 | 
						|
 | 
						|
def report_progress(count, blockSize, totalSize):
 | 
						|
    percent = int(count*blockSize*100/totalSize)
 | 
						|
    percent = min(100, percent)
 | 
						|
    sys.stdout.write("\r%d%%" % percent)
 | 
						|
    sys.stdout.flush()
 | 
						|
 | 
						|
def unpack(filename, destination):
 | 
						|
    dirname = ''
 | 
						|
    print('Extracting {0}'.format(os.path.basename(filename)))
 | 
						|
    sys.stdout.flush()
 | 
						|
    if filename.endswith('tar.gz'):
 | 
						|
        tfile = tarfile.open(filename, 'r:gz')
 | 
						|
        tfile.extractall(destination)
 | 
						|
        dirname= tfile.getnames()[0]
 | 
						|
    elif filename.endswith('zip'):
 | 
						|
        zfile = zipfile.ZipFile(filename)
 | 
						|
        zfile.extractall(destination)
 | 
						|
        dirname = zfile.namelist()[0]
 | 
						|
    else:
 | 
						|
        raise NotImplementedError('Unsupported archive type')
 | 
						|
 | 
						|
    # a little trick to rename tool directories so they don't contain version number
 | 
						|
    rename_to = re.match(r'^([a-z][^\-]*\-*)+', dirname).group(0).strip('-')
 | 
						|
    if rename_to != dirname:
 | 
						|
        print('Renaming {0} to {1}'.format(dirname, rename_to))
 | 
						|
        if os.path.isdir(rename_to):
 | 
						|
            shutil.rmtree(rename_to)
 | 
						|
        shutil.move(dirname, rename_to)
 | 
						|
 | 
						|
def get_tool(tool):
 | 
						|
    sys_name = platform.system()
 | 
						|
    archive_name = tool['archiveFileName']
 | 
						|
    local_path = dist_dir + archive_name
 | 
						|
    url = tool['url']
 | 
						|
    #real_hash = tool['checksum'].split(':')[1]
 | 
						|
    if not os.path.isfile(local_path):
 | 
						|
        print('Downloading ' + archive_name);
 | 
						|
        sys.stdout.flush()
 | 
						|
        if 'CYGWIN_NT' in sys_name:
 | 
						|
            ctx = ssl.create_default_context()
 | 
						|
            ctx.check_hostname = False
 | 
						|
            ctx.verify_mode = ssl.CERT_NONE
 | 
						|
            urlretrieve(url, local_path, report_progress, context=ctx)
 | 
						|
        elif 'Windows' in sys_name:
 | 
						|
            r = requests.get(url)
 | 
						|
            f = open(local_path, 'wb')
 | 
						|
            f.write(r.content)
 | 
						|
            f.close()
 | 
						|
        else:
 | 
						|
            urlretrieve(url, local_path, report_progress)
 | 
						|
        sys.stdout.write("\rDone\n")
 | 
						|
        sys.stdout.flush()
 | 
						|
    else:
 | 
						|
        print('Tool {0} already downloaded'.format(archive_name))
 | 
						|
        sys.stdout.flush()
 | 
						|
    #local_hash = sha256sum(local_path)
 | 
						|
    #if local_hash != real_hash:
 | 
						|
    #    print('Hash mismatch for {0}, delete the file and try again'.format(local_path))
 | 
						|
    #    raise RuntimeError()
 | 
						|
    unpack(local_path, '.')
 | 
						|
 | 
						|
def load_tools_list(filename, platform):
 | 
						|
    tools_info = json.load(open(filename))['packages'][0]['tools']
 | 
						|
    tools_to_download = []
 | 
						|
    for t in tools_info:
 | 
						|
        tool_platform = [p for p in t['systems'] if p['host'] == platform]
 | 
						|
        if len(tool_platform) == 0:
 | 
						|
            continue
 | 
						|
        tools_to_download.append(tool_platform[0])
 | 
						|
    return tools_to_download
 | 
						|
 | 
						|
def identify_platform():
 | 
						|
    arduino_platform_names = {'Darwin'  : {32 : 'i386-apple-darwin',   64 : 'x86_64-apple-darwin'},
 | 
						|
                              'Linux'   : {32 : 'i686-pc-linux-gnu',   64 : 'x86_64-pc-linux-gnu'},
 | 
						|
                              'LinuxARM': {32 : 'arm-linux-gnueabihf', 64 : 'aarch64-linux-gnu'},
 | 
						|
                              'Windows' : {32 : 'i686-mingw32',        64 : 'i686-mingw32'}}
 | 
						|
    bits = 32
 | 
						|
    if sys.maxsize > 2**32:
 | 
						|
        bits = 64
 | 
						|
    sys_name = platform.system()
 | 
						|
    sys_platform = platform.platform()
 | 
						|
    print('System: %s, Info: %s' % (sys_name, sys_platform))
 | 
						|
    if 'Linux' in sys_name and sys_platform.find('arm') > 0:
 | 
						|
        sys_name = 'LinuxARM'
 | 
						|
    if 'CYGWIN_NT' in sys_name:
 | 
						|
        sys_name = 'Windows'
 | 
						|
    return arduino_platform_names[sys_name][bits]
 | 
						|
 | 
						|
if __name__ == '__main__':
 | 
						|
    identified_platform = identify_platform()
 | 
						|
    print('Platform: {0}'.format(identified_platform))
 | 
						|
    tools_to_download = load_tools_list(current_dir + '/../package/package_esp32_index.template.json', identified_platform)
 | 
						|
    mkdir_p(dist_dir)
 | 
						|
    for tool in tools_to_download:
 | 
						|
        get_tool(tool)
 | 
						|
    print('Done')
 |