cli-stash
Version:
CLI application to manage and work with Atlassian Stash. Work with your Stash project and repositories from Command lines.
95 lines (94 loc) • 4.36 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const core_1 = require("@oclif/core");
const stash_connector_1 = require("stash-connector");
const baseCommand_1 = require("../../../../libs/core/baseCommand");
const stashResponse_1 = require("../../../../libs/core/stashResponse");
const tables_1 = require("../../../../libs/core/tables");
const ux_1 = require("../../../../libs/core/ux");
class Diffs extends baseCommand_1.BaseCommand {
async run() {
const response = new stashResponse_1.StashCLIResponse();
const connector = new stash_connector_1.StashConnector(this.localConfig.getConnectorOptions(this.flags.alias));
try {
const result = await connector.projects.repos(this.flags.project).compare(this.flags.slug).diff().list({
contextLines: this.flags['context-lines'],
srcPath: this.flags.src,
whitespace: this.flags.whitespace,
from: this.flags.from,
to: this.flags.from,
fromRepo: this.flags['from-repo'],
pageOptions: this.pageOptions,
}, this.flags.path);
response.result = result;
response.status = 0;
response.message = this.getRecordsFoundText(result.diffs.length, 'Diff');
this.ux.log(response.message);
this.ux.table(result.diffs, tables_1.CommitDiffColumns, {
csv: this.flags.csv,
});
}
catch (error) {
this.processError(response, error);
}
return response;
}
}
exports.default = Diffs;
Diffs.description = 'Retrieve changesets for the specified pull request. ' + ux_1.UX.processDocumentation('<doc:CommitDiffOutput>');
Diffs.examples = [
`$ stash projects:repos:compare:diffs -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --context-lines 5 --csv`,
`$ stash projects:repos:compare:diffs -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --src "path/to/src/path" --'without-comments' --json`,
`$ stash projects:repos:compare:diffs -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --path "path/to/file" --limit 30`,
];
Diffs.flags = {
...baseCommand_1.BaseCommand.flags,
csv: baseCommand_1.BuildFlags.csv,
alias: baseCommand_1.BuildFlags.alias,
project: core_1.Flags.string({
description: 'The Project Key (or user slug like ~userSlug) to compare diffs',
required: true,
name: 'Project'
}),
slug: core_1.Flags.string({
description: 'The Repository slug to compare diffs',
required: true,
name: 'Slug'
}),
from: core_1.Flags.string({
description: 'The source changeset (can be a partial/full changeset id or qualified/unqualified ref name)',
required: false,
name: 'From'
}),
to: core_1.Flags.string({
description: 'The target changeset (can be a partial/full changeset id or qualified/unqualified ref name)',
required: false,
name: 'To'
}),
'from-repo': core_1.Flags.string({
description: 'An optional parameter specifying the source repository containing the source changeset if that changeset is not present in the current repository; the repository can be specified by either its ID 42 or by its Project Key (or user slug like ~userSlug) plus its repo slug separated by a slash: projectKey/repoSlug',
required: false,
name: 'From Repo'
}),
'context-lines': core_1.Flags.integer({
description: 'The number of context lines to include around added/removed lines in the diff.',
required: false,
default: -1,
name: 'Context Lines',
}),
src: core_1.Flags.string({
description: 'The previous path to the file, if the file has been copied, moved or renamed.',
required: false,
name: 'Src Path',
}),
whitespace: core_1.Flags.string({
description: 'optional whitespace flag which can be set to ignore-all.',
required: false,
name: 'Whitespace',
}),
path: core_1.Flags.string({
description: 'The path to the file which should be diffed.',
required: false,
name: 'Path',
}),
};