File size: 5,484 Bytes
6e7eaf3
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
"use strict";
/*---------------------------------------------------------------------------------------------
 *  Copyright (c) Microsoft Corporation. All rights reserved.
 *  Licensed under the MIT License. See License.txt in the project root for license information.
 *--------------------------------------------------------------------------------------------*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.makeConsoleReporter = exports.SilentReporter = exports.ProgressReportStage = void 0;
/** Stages of progress while downloading VS Code */
var ProgressReportStage;
(function (ProgressReportStage) {
    /** Initial fetch of the latest version if not explicitly given */
    ProgressReportStage["FetchingVersion"] = "fetchingVersion";
    /** Always fired when the version is determined. */
    ProgressReportStage["ResolvedVersion"] = "resolvedVersion";
    /** Fired before fetching info about the latest Insiders version, when requesting insiders builds */
    ProgressReportStage["FetchingInsidersMetadata"] = "fetchingInsidersMetadata";
    /** Fired if the current Insiders is out of date */
    ProgressReportStage["ReplacingOldInsiders"] = "replacingOldInsiders";
    /** Fired when an existing install is found which does not require a download */
    ProgressReportStage["FoundMatchingInstall"] = "foundMatchingInstall";
    /** Fired before the URL to the download zip or tarball is looked up */
    ProgressReportStage["ResolvingCDNLocation"] = "resolvingCDNLocation";
    /** Fired continuously while a download happens */
    ProgressReportStage["Downloading"] = "downloading";
    /** Fired when the command is issued to do a synchronous extraction. May not fire depending on the platform and options. */
    ProgressReportStage["ExtractingSynchonrously"] = "extractingSynchonrously";
    /** Fired when the download fails and a retry will be attempted */
    ProgressReportStage["Retrying"] = "retrying";
    /** Fired after folder is downloaded and unzipped */
    ProgressReportStage["NewInstallComplete"] = "newInstallComplete";
})(ProgressReportStage || (exports.ProgressReportStage = ProgressReportStage = {}));
/** Silent progress reporter */
class SilentReporter {
    report() {
        // no-op
    }
    error() {
        // no-op
    }
}
exports.SilentReporter = SilentReporter;
/** Default progress reporter that logs VS Code download progress to console */
const makeConsoleReporter = async () => {
    // needs to be async targeting Node 16 because ora is an es module that cannot be required
    const { default: ora } = await import('ora');
    let version;
    let spinner = ora('Resolving version...').start();
    function toMB(bytes) {
        return (bytes / 1024 / 1024).toFixed(2);
    }
    return {
        error(err) {
            if (spinner) {
                spinner?.fail(`Error: ${err}`);
                spinner = undefined;
            }
            else {
                console.error(err);
            }
        },
        report(report) {
            switch (report.stage) {
                case ProgressReportStage.ResolvedVersion:
                    version = report.version;
                    spinner?.succeed(`Validated version: ${version}`);
                    spinner = undefined;
                    break;
                case ProgressReportStage.ReplacingOldInsiders:
                    spinner?.succeed();
                    spinner = ora(`Updating Insiders ${report.oldHash} (${report.oldDate.toISOString()}) -> ${report.newHash}`).start();
                    break;
                case ProgressReportStage.FoundMatchingInstall:
                    spinner?.succeed();
                    spinner = undefined;
                    ora(`Found existing install in ${report.downloadedPath}`).succeed();
                    break;
                case ProgressReportStage.ResolvingCDNLocation:
                    spinner?.succeed();
                    spinner = ora(`Found at ${report.url}`).start();
                    break;
                case ProgressReportStage.Downloading:
                    if (report.bytesSoFar === 0) {
                        spinner?.succeed();
                        spinner = ora(`Downloading (${toMB(report.totalBytes)} MB)`).start();
                    }
                    else if (spinner) {
                        if (report.bytesSoFar === report.totalBytes) {
                            spinner.text = 'Extracting...';
                        }
                        else {
                            const percent = Math.max(0, Math.min(1, report.bytesSoFar / report.totalBytes));
                            const size = `${toMB(report.bytesSoFar)}/${toMB(report.totalBytes)}MB`;
                            spinner.text = `Downloading VS Code: ${size} (${(percent * 100).toFixed()}%)`;
                        }
                    }
                    break;
                case ProgressReportStage.Retrying:
                    spinner?.fail(`Error downloading, retrying (attempt ${report.attempt} of ${report.totalAttempts}): ${report.error.message}`);
                    spinner = undefined;
                    break;
                case ProgressReportStage.NewInstallComplete:
                    spinner?.succeed(`Downloaded VS Code into ${report.downloadedPath}`);
                    spinner = undefined;
                    break;
            }
        },
    };
};
exports.makeConsoleReporter = makeConsoleReporter;