r"""
Here consists tools for downloading datasets.
https://github.com/snap-stanford/ogb/blob/master/ogb/utils/url.py
"""

import urllib.request as ur
import zipfile
import os
import os.path as osp
import errno
from tqdm import tqdm

GBFACTOR = float(1 << 30)


def decide_download(url, is_raw):
    d = ur.urlopen(url)
    size = int(d.info()["Content-Length"]) / GBFACTOR
    if is_raw:
        return input(
            "Download %.3fGB raw files? Enter n if you want the processed data only. (y/n)\n" % (size)).lower() == "y"
    else:
        return "Download %.3fGB processed data...\n" % (size)
        # return input("Download %.3fGB processed data to skip processing raw files? (y/n)\n" % (size)).lower() == "y"


def makedirs(path):
    try:
        os.makedirs(osp.expanduser(osp.normpath(path)))
    except OSError as e:
        if e.errno != errno.EEXIST and osp.isdir(path):
            raise e


def download_url(url, folder, log=True):
    r"""Downloads the content of an URL to a specific folder.
    Args:
        url (string): The url.
        folder (string): The folder.
        log (bool, optional): If :obj:`False`, will not print anything to the
            console. (default: :obj:`True`)
    """

    filename = url.rpartition('/')[2]
    path = osp.join(folder, filename)

    if osp.exists(path) and osp.getsize(path) > 0:  # pragma: no cover
        if log:
            print('Using exist file', filename)
        return path

    if log:
        print('Downloading', url)

    makedirs(folder)
    data = ur.urlopen(url)

    size = int(data.info()["Content-Length"])

    chunk_size = 1024 * 1024
    num_iter = int(size / chunk_size) + 2

    downloaded_size = 0

    try:
        with open(path, 'wb') as f:
            pbar = tqdm(range(num_iter))
            for i in pbar:
                chunk = data.read(chunk_size)
                downloaded_size += len(chunk)
                pbar.set_description("Downloaded {:.2f} GB".format(float(downloaded_size) / GBFACTOR))
                f.write(chunk)
    except:
        if os.path.exists(path):
            os.remove(path)
        raise RuntimeError('Stopped downloading due to interruption.')

    return path


def maybe_log(path, log=True):
    if log:
        print('Extracting', path)


def extract_zip(path, folder, log=True):
    r"""Extracts a zip archive to a specific folder.
    Args:
        path (string): The path to the tar archive.
        folder (string): The folder.
        log (bool, optional): If :obj:`False`, will not print anything to the
            console. (default: :obj:`True`)
    """
    maybe_log(path, log)
    with zipfile.ZipFile(path, 'r') as f:
        f.extractall(folder)
