|
@ -3,14 +3,21 @@ |
|
|
import { QuickInputButton, QuickInputButtons, QuickPickItem, Uri, window } from 'vscode'; |
|
|
import { QuickInputButton, QuickInputButtons, QuickPickItem, Uri, window } from 'vscode'; |
|
|
import { Container } from '../../container'; |
|
|
import { Container } from '../../container'; |
|
|
import { GitStashCommit, GitUri, Repository, SearchPattern } from '../../git/gitService'; |
|
|
import { GitStashCommit, GitUri, Repository, SearchPattern } from '../../git/gitService'; |
|
|
import { BreakQuickCommand, QuickCommandBase, StepAsyncGenerator, StepSelection, StepState } from '../quickCommand'; |
|
|
|
|
|
|
|
|
import { |
|
|
|
|
|
BreakQuickCommand, |
|
|
|
|
|
QuickCommandBase, |
|
|
|
|
|
QuickPickStep, |
|
|
|
|
|
StepAsyncGenerator, |
|
|
|
|
|
StepSelection, |
|
|
|
|
|
StepState |
|
|
|
|
|
} from '../quickCommand'; |
|
|
import { |
|
|
import { |
|
|
CommandQuickPickItem, |
|
|
CommandQuickPickItem, |
|
|
CommitQuickPick, |
|
|
CommitQuickPick, |
|
|
CommitQuickPickItem, |
|
|
CommitQuickPickItem, |
|
|
Directive, |
|
|
Directive, |
|
|
DirectiveQuickPickItem, |
|
|
DirectiveQuickPickItem, |
|
|
GitFlagsQuickPickItem, |
|
|
|
|
|
|
|
|
FlagsQuickPickItem, |
|
|
QuickPickItemOfT, |
|
|
QuickPickItemOfT, |
|
|
RepositoryQuickPickItem |
|
|
RepositoryQuickPickItem |
|
|
} from '../../quickpicks'; |
|
|
} from '../../quickpicks'; |
|
@ -23,14 +30,12 @@ interface ApplyState { |
|
|
subcommand: 'apply'; |
|
|
subcommand: 'apply'; |
|
|
repo: Repository; |
|
|
repo: Repository; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
flags: string[]; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
interface DropState { |
|
|
interface DropState { |
|
|
subcommand: 'drop'; |
|
|
subcommand: 'drop'; |
|
|
repo: Repository; |
|
|
repo: Repository; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
flags: string[]; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
interface ListState { |
|
|
interface ListState { |
|
@ -42,15 +47,16 @@ interface PopState { |
|
|
subcommand: 'pop'; |
|
|
subcommand: 'pop'; |
|
|
repo: Repository; |
|
|
repo: Repository; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
stash: { stashName: string; message: string; ref: string; repoPath: string }; |
|
|
flags: string[]; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
type PushFlags = '--include-untracked' | '--keep-index'; |
|
|
|
|
|
|
|
|
interface PushState { |
|
|
interface PushState { |
|
|
subcommand: 'push'; |
|
|
subcommand: 'push'; |
|
|
repo: Repository; |
|
|
repo: Repository; |
|
|
message?: string; |
|
|
message?: string; |
|
|
uris?: Uri[]; |
|
|
uris?: Uri[]; |
|
|
flags: string[]; |
|
|
|
|
|
|
|
|
flags: PushFlags[]; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
type State = ApplyState | DropState | ListState | PopState | PushState; |
|
|
type State = ApplyState | DropState | ListState | PopState | PushState; |
|
@ -373,7 +379,7 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
? `${state.stash.message.substring(0, 80)}${GlyphChars.Ellipsis}` |
|
|
? `${state.stash.message.substring(0, 80)}${GlyphChars.Ellipsis}` |
|
|
: state.stash.message; |
|
|
: state.stash.message; |
|
|
|
|
|
|
|
|
const step = this.createConfirmStep<GitFlagsQuickPickItem & { command: 'apply' | 'pop' }>( |
|
|
|
|
|
|
|
|
const step = this.createConfirmStep<QuickPickItem & { command: 'apply' | 'pop' }>( |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
state.repo.formattedName |
|
|
state.repo.formattedName |
|
|
}`,
|
|
|
}`,
|
|
@ -389,8 +395,7 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
: `Will apply the changes from ${state.stash!.stashName} to the working tree of ${ |
|
|
: `Will apply the changes from ${state.stash!.stashName} to the working tree of ${ |
|
|
state.repo.formattedName |
|
|
state.repo.formattedName |
|
|
}`,
|
|
|
}`,
|
|
|
command: state.subcommand!, |
|
|
|
|
|
item: [] |
|
|
|
|
|
|
|
|
command: state.subcommand! |
|
|
}, |
|
|
}, |
|
|
// Alternate confirmation (if pop then apply, and vice versa)
|
|
|
// Alternate confirmation (if pop then apply, and vice versa)
|
|
|
{ |
|
|
{ |
|
@ -404,8 +409,7 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
: `Will delete ${ |
|
|
: `Will delete ${ |
|
|
state.stash!.stashName |
|
|
state.stash!.stashName |
|
|
} and apply the changes to the working tree of ${state.repo.formattedName}`,
|
|
|
} and apply the changes to the working tree of ${state.repo.formattedName}`,
|
|
|
command: state.subcommand === 'pop' ? 'apply' : 'pop', |
|
|
|
|
|
item: [] |
|
|
|
|
|
|
|
|
command: state.subcommand === 'pop' ? 'apply' : 'pop' |
|
|
} |
|
|
} |
|
|
], |
|
|
], |
|
|
undefined, |
|
|
undefined, |
|
@ -429,9 +433,6 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
state.subcommand = selection[0].command; |
|
|
state.subcommand = selection[0].command; |
|
|
state.flags = selection[0].item; |
|
|
|
|
|
} else { |
|
|
|
|
|
state.flags = state.flags || []; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void Container.git.stashApply(state.repo.path, state.stash!.stashName, state.subcommand === 'pop'); |
|
|
void Container.git.stashApply(state.repo.path, state.stash!.stashName, state.subcommand === 'pop'); |
|
@ -504,7 +505,7 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
? `${state.stash.message.substring(0, 80)}${GlyphChars.Ellipsis}` |
|
|
? `${state.stash.message.substring(0, 80)}${GlyphChars.Ellipsis}` |
|
|
: state.stash.message; |
|
|
: state.stash.message; |
|
|
|
|
|
|
|
|
const step = this.createConfirmStep<QuickPickItem>( |
|
|
|
|
|
|
|
|
const step = this.createConfirmStep( |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
state.repo.formattedName |
|
|
state.repo.formattedName |
|
|
}`,
|
|
|
}`,
|
|
@ -648,6 +649,10 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
|
|
|
|
|
|
// eslint-disable-next-line @typescript-eslint/require-await
|
|
|
// eslint-disable-next-line @typescript-eslint/require-await
|
|
|
private async *push(state: StashStepState<PushState>): StepAsyncGenerator { |
|
|
private async *push(state: StashStepState<PushState>): StepAsyncGenerator { |
|
|
|
|
|
if (state.flags == null) { |
|
|
|
|
|
state.flags = []; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
while (true) { |
|
|
while (true) { |
|
|
if (state.message === undefined || state.counter < 3) { |
|
|
if (state.message === undefined || state.counter < 3) { |
|
|
const step = this.createInputStep({ |
|
|
const step = this.createInputStep({ |
|
@ -668,52 +673,47 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (this.confirm(state.confirm)) { |
|
|
if (this.confirm(state.confirm)) { |
|
|
const step = this.createConfirmStep<GitFlagsQuickPickItem>( |
|
|
|
|
|
|
|
|
const step: QuickPickStep<FlagsQuickPickItem<PushFlags>> = this.createConfirmStep( |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
`Confirm ${this.title} ${getSubtitle(state.subcommand)}${Strings.pad(GlyphChars.Dot, 2, 2)}${ |
|
|
state.repo.formattedName |
|
|
state.repo.formattedName |
|
|
}`,
|
|
|
}`,
|
|
|
state.uris === undefined || state.uris.length === 0 |
|
|
state.uris === undefined || state.uris.length === 0 |
|
|
? [ |
|
|
? [ |
|
|
{ |
|
|
|
|
|
|
|
|
FlagsQuickPickItem.create<PushFlags>(state.flags, [], { |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)}`, |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)}`, |
|
|
description: state.message, |
|
|
description: state.message, |
|
|
detail: 'Will stash uncommitted changes', |
|
|
|
|
|
item: [] |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
|
|
|
detail: 'Will stash uncommitted changes' |
|
|
|
|
|
}), |
|
|
|
|
|
FlagsQuickPickItem.create<PushFlags>(state.flags, ['--include-untracked'], { |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Include Untracked`, |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Include Untracked`, |
|
|
description: `--include-untracked ${state.message}`, |
|
|
description: `--include-untracked ${state.message}`, |
|
|
detail: 'Will stash uncommitted changes, including untracked files', |
|
|
|
|
|
item: ['--include-untracked'] |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
|
|
|
detail: 'Will stash uncommitted changes, including untracked files' |
|
|
|
|
|
}), |
|
|
|
|
|
FlagsQuickPickItem.create<PushFlags>(state.flags, ['--keep-index'], { |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Keep Staged`, |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Keep Staged`, |
|
|
description: `--keep-index ${state.message}`, |
|
|
description: `--keep-index ${state.message}`, |
|
|
detail: 'Will stash uncommitted changes, but will keep staged files intact', |
|
|
|
|
|
item: ['--keep-index'] |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
detail: 'Will stash uncommitted changes, but will keep staged files intact' |
|
|
|
|
|
}) |
|
|
] |
|
|
] |
|
|
: [ |
|
|
: [ |
|
|
{ |
|
|
|
|
|
|
|
|
FlagsQuickPickItem.create<PushFlags>(state.flags, [], { |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)}`, |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)}`, |
|
|
description: state.message, |
|
|
description: state.message, |
|
|
detail: `Will stash changes in ${ |
|
|
detail: `Will stash changes in ${ |
|
|
state.uris.length === 1 |
|
|
state.uris.length === 1 |
|
|
? GitUri.getFormattedPath(state.uris[0], { relativeTo: state.repo.path }) |
|
|
? GitUri.getFormattedPath(state.uris[0], { relativeTo: state.repo.path }) |
|
|
: `${state.uris.length} files` |
|
|
: `${state.uris.length} files` |
|
|
}`,
|
|
|
|
|
|
item: [] |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
|
|
|
}`
|
|
|
|
|
|
}), |
|
|
|
|
|
FlagsQuickPickItem.create<PushFlags>(state.flags, ['--keep-index'], { |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Keep Staged`, |
|
|
label: `${this.title} ${getSubtitle(state.subcommand)} & Keep Staged`, |
|
|
description: `--keep-index ${state.message}`, |
|
|
description: `--keep-index ${state.message}`, |
|
|
detail: `Will stash changes in ${ |
|
|
detail: `Will stash changes in ${ |
|
|
state.uris.length === 1 |
|
|
state.uris.length === 1 |
|
|
? GitUri.getFormattedPath(state.uris[0], { relativeTo: state.repo.path }) |
|
|
? GitUri.getFormattedPath(state.uris[0], { relativeTo: state.repo.path }) |
|
|
: `${state.uris.length} files` |
|
|
: `${state.uris.length} files` |
|
|
}, but will keep staged files intact`,
|
|
|
|
|
|
item: ['--keep-index'] |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
}, but will keep staged files intact`
|
|
|
|
|
|
}) |
|
|
], |
|
|
], |
|
|
undefined, |
|
|
undefined, |
|
|
{ placeholder: `Confirm ${this.title} ${getSubtitle(state.subcommand)}` } |
|
|
{ placeholder: `Confirm ${this.title} ${getSubtitle(state.subcommand)}` } |
|
@ -725,8 +725,6 @@ export class StashGitCommand extends QuickCommandBase { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
state.flags = selection[0].item; |
|
|
state.flags = selection[0].item; |
|
|
} else { |
|
|
|
|
|
state.flags = state.flags || []; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void Container.git.stashSave(state.repo.path, state.message, state.uris, { |
|
|
void Container.git.stashSave(state.repo.path, state.message, state.uris, { |
|
|