Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[rush] Shell tab completion #2060

Merged
merged 109 commits into from
Aug 18, 2020
Merged
Changes from 5 commits
Commits
Show all changes
109 commits
Select commit Hold shift + click to select a range
cf07cc2
Initial commit
sachinjoseph Jul 27, 2020
68a18cb
WIP
sachinjoseph Jul 28, 2020
adb2a59
WIP
sachinjoseph Jul 28, 2020
64df804
WIP
sachinjoseph Jul 28, 2020
59c60b5
WIP
sachinjoseph Jul 28, 2020
d45da59
WIP
sachinjoseph Jul 28, 2020
5e8d0f2
WIP
sachinjoseph Jul 28, 2020
d6ad7cb
Add autocomplete for common parameter values
sachinjoseph Jul 29, 2020
1d0fe7d
Move action table population to run() method so that custom commands …
sachinjoseph Jul 29, 2020
97d7303
Add support for -d/--debug switch
sachinjoseph Jul 29, 2020
35115e5
Refactor
sachinjoseph Jul 29, 2020
7fdce2f
Autocomplete for partially completed package names
sachinjoseph Jul 29, 2020
abb42e5
Refactor to remove some duplicate code
sachinjoseph Jul 29, 2020
f885dbf
Comment out logs
sachinjoseph Jul 29, 2020
9b7542f
Refactor
sachinjoseph Jul 29, 2020
86666c3
Fix minor bug
sachinjoseph Jul 29, 2020
6c7e213
Add tests
sachinjoseph Jul 29, 2020
a2cd8fa
Rush change
sachinjoseph Jul 29, 2020
4bacae4
Add more tests
sachinjoseph Jul 29, 2020
1b6bb14
Use constants
sachinjoseph Jul 29, 2020
8f4e677
Set default values for args
sachinjoseph Jul 30, 2020
fe00b9f
Refactor some code. Address comments.
sachinjoseph Jul 30, 2020
518c8bf
Change run() to runAsync()
sachinjoseph Jul 31, 2020
12ce2f1
Address David's comments
sachinjoseph Jul 31, 2020
98f9104
Address David's comments. Add a new unit test
sachinjoseph Jul 31, 2020
fffb507
Some refactoring
sachinjoseph Jul 31, 2020
cde89aa
Use importLazy to improve spin up times
sachinjoseph Aug 1, 2020
1296b78
Change _jsonSchema to a static getter
sachinjoseph Aug 1, 2020
a91fc88
Profiling in progress
sachinjoseph Aug 1, 2020
9cf5d08
Further optimization
sachinjoseph Aug 1, 2020
e6a76ad
Remove node-core-library lazyImport
sachinjoseph Aug 1, 2020
2efcac0
Remove trace logs
sachinjoseph Aug 1, 2020
b663e6a
Remove trace logs
sachinjoseph Aug 1, 2020
ea20cfa
Suppress some linter warnings
sachinjoseph Aug 1, 2020
b17f84f
Remove comments
sachinjoseph Aug 1, 2020
e3d6b4b
Rename import
sachinjoseph Aug 1, 2020
6db9624
Address comments
sachinjoseph Aug 1, 2020
38bf225
Fix some bugs. Use a lib for parsing command line sentences.
sachinjoseph Aug 1, 2020
180c363
Change the dependency specifier to ~
sachinjoseph Aug 1, 2020
819189f
Rush change
sachinjoseph Aug 1, 2020
7d05093
Remove trace logs
sachinjoseph Aug 1, 2020
f6415c9
Remove commented-out code.
sachinjoseph Aug 2, 2020
5422f4d
Get choice values from CommandLineChoiceParameter object.
sachinjoseph Aug 2, 2020
b15d4e9
Remove test logs
sachinjoseph Aug 2, 2020
c09564f
Initial commit: Move tab-completion to ts-command-line
sachinjoseph Aug 2, 2020
13c04fb
Move code entirely to ts-commandline. Implement a way to provide cust…
sachinjoseph Aug 2, 2020
114ef50
Commit tests
sachinjoseph Aug 2, 2020
d0a38c0
Rush change
sachinjoseph Aug 2, 2020
e81bc62
Move 'tab-complete' to a constant
sachinjoseph Aug 2, 2020
0b9bc44
Cache the test object
sachinjoseph Aug 3, 2020
9644cd2
Remove commented out code
sachinjoseph Aug 3, 2020
897312f
Use getOwnPackageVersion to reduce spin up times
sachinjoseph Aug 3, 2020
ba42595
Some refactoring
sachinjoseph Aug 3, 2020
719089e
Merge branch 'master' of https://github.com/microsoft/rushstack into …
sachinjoseph Aug 3, 2020
86eaa97
Rename constant. Update comment.
sachinjoseph Aug 3, 2020
3ade0cd
Update libraries/ts-command-line/src/providers/TabCompletionAction.ts
sachinjoseph Aug 3, 2020
7bab8f4
Update libraries/ts-command-line/src/providers/TabCompletionAction.ts
sachinjoseph Aug 3, 2020
d478180
Update apps/rush-lib/src/cli/actions/ListAction.ts
sachinjoseph Aug 3, 2020
7563fce
Address comments
sachinjoseph Aug 3, 2020
a2075e6
Address comments
sachinjoseph Aug 3, 2020
2b5c73b
Eslint disable - specify the rule.
sachinjoseph Aug 3, 2020
f4853c6
Document getOwnPackageJsonVersion
sachinjoseph Aug 3, 2020
ce9420d
Fix comment
sachinjoseph Aug 3, 2020
5d0a5ac
Merge branch 'master' of https://github.com/microsoft/rushstack into …
sachinjoseph Aug 4, 2020
8263b72
Address comments
sachinjoseph Aug 4, 2020
677caa2
Merge branch 'sachinjoseph/rush-shell-tab-complete' of https://github…
sachinjoseph Aug 4, 2020
468bb4b
Rush change
sachinjoseph Aug 4, 2020
147648a
Fix some bugs
sachinjoseph Aug 8, 2020
867cd2d
Update libraries/ts-command-line/src/parameters/CommandLineDefinition.ts
sachinjoseph Aug 8, 2020
72e0b35
Address comments
sachinjoseph Aug 8, 2020
f7a66fb
Merge branch 'sachinjoseph/rush-shell-tab-complete' of https://github…
sachinjoseph Aug 8, 2020
fac7836
Preserve some typing
sachinjoseph Aug 8, 2020
c87dcff
Make completions() only available to choice parameters and parameters…
sachinjoseph Aug 8, 2020
c1ae9b8
Remove completions() hook from CommandLinStringParameter
sachinjoseph Aug 8, 2020
eb0ba41
Remove commented out test code
sachinjoseph Aug 8, 2020
2a9a1b9
Use a flag to prevent adding the tab-complete action multiple times
sachinjoseph Aug 8, 2020
da061db
Get argv as a param
sachinjoseph Aug 8, 2020
e4a04ae
LazyLoad DeployArchiver
sachinjoseph Aug 8, 2020
48b58f9
Update snapshots
sachinjoseph Aug 8, 2020
68b3a84
Prototype of a basic Import API for lazy imports
octogonz Aug 8, 2020
8068c82
Convert more files to use the Import API
octogonz Aug 9, 2020
90c0997
Revert all changes to DeployManager.ts
octogonz Aug 9, 2020
71175bd
Convert DeployManager to be lazy-loaded
octogonz Aug 9, 2020
c34c07e
Revert all changes to RushInstallManager.ts
octogonz Aug 9, 2020
a1cc5d8
Convert RushInstallManager to be lazy-loaded
octogonz Aug 9, 2020
22647a6
Shave off a few hundred milliseconds from the startup time
sachinjoseph Aug 9, 2020
b171210
Update rush-lib api md
sachinjoseph Aug 9, 2020
1d1c828
Merge branch 'sachinjoseph/rush-shell-tab-complete' of https://github…
sachinjoseph Aug 9, 2020
283044d
Merge branch 'master' of https://github.com/microsoft/web-build-tools…
sachinjoseph Aug 9, 2020
dc1ee6d
Merge branch 'sachinjoseph/rush-shell-tab-complete' of https://github…
sachinjoseph Aug 9, 2020
97f926f
Reuse package.json object
sachinjoseph Aug 9, 2020
a5fd7c6
Use get() to determine if a map entry exists
sachinjoseph Aug 9, 2020
acb8b79
Use has() to determine if a map entry exists
sachinjoseph Aug 9, 2020
0f14d3d
Address comments
sachinjoseph Aug 11, 2020
e0ca132
Merge branch 'sachinjoseph/rush-shell-tab-complete' of https://github…
sachinjoseph Aug 11, 2020
7626396
Recommend the __dirname macro for dirname parameter.
sachinjoseph Aug 11, 2020
9fdcefb
Cache the static getter so that runtime perf won't be affected.
sachinjoseph Aug 11, 2020
f3ebdc1
Address comments
sachinjoseph Aug 11, 2020
6661ba8
Use Import.lazy everywhere
sachinjoseph Aug 13, 2020
f33d99f
Merge branch 'master' of https://github.com/microsoft/web-build-tools…
sachinjoseph Aug 13, 2020
7cb6b76
Merge branch 'master' of https://github.com/microsoft/rushstack into …
sachinjoseph Aug 15, 2020
82c377e
Use Import.Lazy in more places
sachinjoseph Aug 15, 2020
c343e4a
Provide a link to the PR in the changelog
sachinjoseph Aug 15, 2020
4b82b36
Merge branch 'master' of https://github.com/microsoft/rushstack into …
sachinjoseph Aug 18, 2020
aa27102
Document `Import` API
octogonz Aug 18, 2020
2ad333f
Remove getOwnPackageJsonVersion() API
sachinjoseph Aug 18, 2020
c7a47f1
Revert changes to schema loading
sachinjoseph Aug 18, 2020
bec2301
Merge remote-tracking branch 'remotes/origin/master' into sachinjosep…
octogonz Aug 18, 2020
ddbf8b6
rush update
octogonz Aug 18, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 13 additions & 3 deletions apps/rush-lib/src/cli/actions/DeployAction.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,18 @@
// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.
// See LICENSE in the project root for license information.

import { Import } from '@rushstack/node-core-library';
import { CommandLineFlagParameter, CommandLineStringParameter } from '@rushstack/ts-command-line';

import { BaseRushAction } from './BaseRushAction';
import { RushCommandLineParser } from '../RushCommandLineParser';
import { CommandLineFlagParameter, CommandLineStringParameter } from '@rushstack/ts-command-line';
import { DeployManager } from '../../logic/deploy/DeployManager';

const deployManagerModule: typeof import('../../logic/deploy/DeployManager') = Import.lazy(
'../../logic/deploy/DeployManager',
require
);
// TODO: Convert this to "import type" after we upgrade to TypeScript 3.8
import * as deployManagerTypes from '../../logic/deploy/DeployManager';

export class DeployAction extends BaseRushAction {
private _scenario: CommandLineStringParameter;
@@ -78,7 +86,9 @@ export class DeployAction extends BaseRushAction {
}

protected async runAsync(): Promise<void> {
const deployManager: DeployManager = new DeployManager(this.rushConfiguration);
const deployManager: deployManagerTypes.DeployManager = new deployManagerModule.DeployManager(
this.rushConfiguration
);
await deployManager.deployAsync(
this._project.value,
this._scenario.value,
15 changes: 13 additions & 2 deletions apps/rush-lib/src/logic/InstallManagerFactory.ts
Original file line number Diff line number Diff line change
@@ -4,14 +4,20 @@
import * as colors from 'colors';
import * as semver from 'semver';

import { Import } from '@rushstack/node-core-library';

import { BaseInstallManager, IInstallManagerOptions } from './base/BaseInstallManager';
import { RushInstallManager } from './installManager/RushInstallManager';
import { WorkspaceInstallManager } from './installManager/WorkspaceInstallManager';
import { AlreadyReportedError } from '../utilities/AlreadyReportedError';
import { PurgeManager } from './PurgeManager';
import { RushConfiguration } from '../api/RushConfiguration';
import { RushGlobalFolder } from '../api/RushGlobalFolder';

const rushInstallManagerModule: typeof import('./installManager/RushInstallManager') = Import.lazy(
'./installManager/RushInstallManager',
require
);

export class InstallManagerFactory {
public static getInstallManager(
rushConfiguration: RushConfiguration,
@@ -37,6 +43,11 @@ export class InstallManagerFactory {
return new WorkspaceInstallManager(rushConfiguration, rushGlobalFolder, purgeManager, options);
}

return new RushInstallManager(rushConfiguration, rushGlobalFolder, purgeManager, options);
return new rushInstallManagerModule.RushInstallManager(
rushConfiguration,
rushGlobalFolder,
purgeManager,
options
);
}
}
30 changes: 13 additions & 17 deletions apps/rush-lib/src/logic/deploy/DeployManager.ts
Original file line number Diff line number Diff line change
@@ -1,17 +1,11 @@
// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.
// See LICENSE in the project root for license information.

// eslint-disable-next-line @typescript-eslint/typedef
const importLazy = require('import-lazy')(require);

import * as colors from 'colors';
import * as path from 'path';
// eslint-disable-next-line @typescript-eslint/typedef
const resolve = importLazy('resolve');
// eslint-disable-next-line @typescript-eslint/typedef
const npmPacklist = importLazy('npm-packlist');
// eslint-disable-next-line @typescript-eslint/typedef
const pnpmLinkBins = importLazy('@pnpm/link-bins');
import * as resolve from 'resolve';
import * as npmPacklist from 'npm-packlist';
import pnpmLinkBins from '@pnpm/link-bins';

// (Used only by the legacy code fragment in the resolve.sync() hook below)
import * as fsForResolve from 'fs';
@@ -30,19 +24,21 @@ import {
NewlineKind,
Text
} from '@rushstack/node-core-library';
// TODO: Convert this to "import type" after we upgrade to TypeScript 3.8
import * as DeployArchiver from './DeployArchiver';
const da: typeof DeployArchiver = importLazy('./DeployArchiver');
import { DeployArchiver } from './DeployArchiver';
import { RushConfiguration } from '../../api/RushConfiguration';
import { SymlinkAnalyzer, ILinkInfo } from './SymlinkAnalyzer';
import { RushConfigurationProject } from '../../api/RushConfigurationProject';
import { DeployScenarioConfiguration, IDeployScenarioProjectJson } from './DeployScenarioConfiguration';
import { PnpmfileConfiguration } from './PnpmfileConfiguration';
import { matchesWithStar } from './Utils';

interface INpmPackListWalkerSync {
readonly result: string[];
start(): void;
// (@types/npm-packlist is missing this API)
declare module 'npm-packlist' {
export class WalkerSync {
public readonly result: string[];
public constructor(opts: { path: string });
public start(): void;
}
}

/**
@@ -390,7 +386,7 @@ export class DeployManager {
if (useNpmIgnoreFilter) {
// Use npm-packlist to filter the files. Using the WalkerSync class (instead of the sync() API) ensures
// that "bundledDependencies" are not included.
const walker: INpmPackListWalkerSync = new npmPacklist.WalkerSync({
const walker: npmPacklist.WalkerSync = new npmPacklist.WalkerSync({
path: sourceFolderPath
});
walker.start();
@@ -681,7 +677,7 @@ export class DeployManager {
alreadyExistsBehavior: AlreadyExistsBehavior.Error
});
}
await da.DeployArchiver.createArchiveAsync(deployState);
await DeployArchiver.createArchiveAsync(deployState);
}

/**
21 changes: 5 additions & 16 deletions apps/rush-lib/src/logic/installManager/RushInstallManager.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,12 @@
// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.
// See LICENSE in the project root for license information.

// eslint-disable-next-line @typescript-eslint/typedef
const importLazy = require('import-lazy')(require);

// eslint-disable-next-line @typescript-eslint/typedef
const glob = importLazy('glob');
import * as glob from 'glob';
import * as colors from 'colors';
import * as os from 'os';
import * as path from 'path';
import * as semver from 'semver';
// eslint-disable-next-line @typescript-eslint/typedef
const tar = importLazy('tar');
// TODO: Convert this to "import type" after we upgrade to TypeScript 3.8
import { CreateOptions, FileStat } from 'tar';
import * as tar from 'tar';
import * as globEscape from 'glob-escape';
import {
JsonFile,
@@ -357,20 +350,16 @@ export class RushInstallManager extends BaseInstallManager {
// NPM expects the root of the tarball to have a directory called 'package'
const npmPackageFolder: string = 'package';

const tarOptions: CreateOptions = {
const tarOptions: tar.CreateOptions = {
gzip: true,
file: tarballFile,
cwd: tempProjectFolder,
portable: true,
/**
* Set to true to omit writing mtime values for entries. Note that this prevents using other
* mtime-based features like tar.update or the keepNewer option with the resulting tar archive.
*/
noMtime: true,
noPax: true,
sync: true,
prefix: npmPackageFolder,
filter: (path: string, stat: FileStat): boolean => {
filter: (path: string, stat: tar.FileStat): boolean => {
if (
!this.rushConfiguration.experimentsConfiguration.configuration.noChmodFieldInTarHeaderNormalization
) {
@@ -380,7 +369,7 @@ export class RushInstallManager extends BaseInstallManager {
}
return true;
}
} as CreateOptions;
} as tar.CreateOptions;
// create the new tarball
tar.create(tarOptions, [FileConstants.PackageJson]);
}