Merge branch 'status'
This commit is contained in:
commit
7c4e6c96c6
@ -11,9 +11,13 @@
|
|||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@gitgraph/node": "^0.1.18",
|
"@gitgraph/node": "^0.1.18",
|
||||||
|
"chalk": "^4.1.2",
|
||||||
|
"columnify": "^1.5.4",
|
||||||
"inquirer": "^7.3.3",
|
"inquirer": "^7.3.3",
|
||||||
"lodash": "^4.17.21",
|
"lodash": "^4.17.21",
|
||||||
"simple-git": "^2.47.0",
|
"simple-git": "^2.47.0",
|
||||||
|
"stringify-tree": "^1.1.1",
|
||||||
|
"updeep": "^1.2.1",
|
||||||
"yargs": "^16.2.0",
|
"yargs": "^16.2.0",
|
||||||
"yurnalist": "^2.1.0"
|
"yurnalist": "^2.1.0"
|
||||||
}
|
}
|
||||||
|
15
src/commands/done.js
Normal file
15
src/commands/done.js
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
const Git = require('simple-git');
|
||||||
|
const inquirer = require('inquirer');
|
||||||
|
const report = require('yurnalist');
|
||||||
|
const _ = require('lodash');
|
||||||
|
const { currentBranch } = require( '../utils');
|
||||||
|
|
||||||
|
module.exports = async (yargs) => {
|
||||||
|
|
||||||
|
const current = await currentBranch();
|
||||||
|
|
||||||
|
console.log(`marking branch '$current' as done`);
|
||||||
|
|
||||||
|
await Git().addConfig( `branch.${current}.mikado-done`, true );
|
||||||
|
|
||||||
|
}
|
103
src/commands/status.js
Normal file
103
src/commands/status.js
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
const Git = require('simple-git');
|
||||||
|
const inquirer = require('inquirer');
|
||||||
|
const report = require('yurnalist');
|
||||||
|
const _ = require('lodash');
|
||||||
|
const { defaults } = require('lodash/fp');
|
||||||
|
const u = require('updeep');
|
||||||
|
const columnify = require('columnify');
|
||||||
|
const chalk = require('chalk');
|
||||||
|
|
||||||
|
module.exports = async (yargs) => {
|
||||||
|
const config = (await Git().listConfig('local')).all;
|
||||||
|
|
||||||
|
let tree = Object.entries(config).reduce(
|
||||||
|
(accum, [key,value]) => u.updateIn(key,value,accum), {}
|
||||||
|
);
|
||||||
|
|
||||||
|
const branches = {};
|
||||||
|
|
||||||
|
const normalizeArray = value => Array.isArray(value)?value: [value].filter(x=>x);
|
||||||
|
|
||||||
|
const initBranch = config => defaults({
|
||||||
|
upstream: [],
|
||||||
|
dependencies: [],
|
||||||
|
},config);
|
||||||
|
|
||||||
|
const current = (await Git().raw('branch','--show-current')).replace("\n",'');
|
||||||
|
|
||||||
|
for( const branch in tree.branch ) {
|
||||||
|
const entry = tree.branch[branch];
|
||||||
|
|
||||||
|
if( !('mikado-upstream' in entry) ) continue;
|
||||||
|
|
||||||
|
branches[branch] = initBranch({
|
||||||
|
name: branch,
|
||||||
|
upstream: normalizeArray(entry['mikado-upstream']),
|
||||||
|
base: entry['mikado-base'],
|
||||||
|
done: entry['mikado-done'],
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
for ( const branch of Object.values(branches) ) {
|
||||||
|
for( const ups of branch['upstream'] ) {
|
||||||
|
if(!branches[ups]) branches[ups] = initBranch({
|
||||||
|
name: ups,
|
||||||
|
upstream: [],
|
||||||
|
dependencies: [],
|
||||||
|
});
|
||||||
|
|
||||||
|
branches[ups].dependencies.push(branch.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( branches[ current ] ) branches[current].current = true;
|
||||||
|
|
||||||
|
const depColor = current => async ( dep ) => {
|
||||||
|
let color = branches[dep].done ? chalk.green: chalk.red;
|
||||||
|
|
||||||
|
let contains = await Git().raw('branch', '--contains', dep);
|
||||||
|
contains = contains.split("\n").map( x => x.trim().replace('* ','') );
|
||||||
|
|
||||||
|
if( contains.includes(current) )
|
||||||
|
color = color.underline;
|
||||||
|
|
||||||
|
return color(dep);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
const upstreamColor = current => async ( up ) => {
|
||||||
|
let color = branches[up].done ? chalk.green: chalk.red;
|
||||||
|
|
||||||
|
let contains = await Git().raw('branch', '--contains', current);
|
||||||
|
contains = contains.split("\n").map( x => x.trim().replace('* ','') );
|
||||||
|
|
||||||
|
if( contains.includes(up) )
|
||||||
|
color = color.underline;
|
||||||
|
|
||||||
|
return color(up);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log( "\n=== Mikado status ===\n" );
|
||||||
|
|
||||||
|
const sorted = _.sortBy(Object.values(branches), ['current'])
|
||||||
|
|
||||||
|
for( const branch of sorted ) {
|
||||||
|
console.log( chalk.blue(branch.name), branch.current ? "(current branch)" : "", branch.done ? chalk.green.bold('done'):"" );
|
||||||
|
console.log( `\tbase: ${chalk.magenta(branch.base ?? '<none>')}` );
|
||||||
|
|
||||||
|
if(branch.upstream.length) {
|
||||||
|
const ups = await Promise.all(branch.upstream.map(upstreamColor(branch.name)));
|
||||||
|
console.log( "\tupstream:", ups.join(" ") );
|
||||||
|
}
|
||||||
|
|
||||||
|
if(branch.dependencies.length) {
|
||||||
|
const deps = await Promise.all(branch.dependencies.map(depColor(branch.name)));
|
||||||
|
console.log( "\tdependencies:", deps.join(" ") );
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("\n\n");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
src/commands/upstream
Normal file
12
src/commands/upstream
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
const Git = require('simple-git');
|
||||||
|
const inquirer = require('inquirer');
|
||||||
|
const report = require('yurnalist');
|
||||||
|
const _ = require('lodash');
|
||||||
|
const { currentBranch } = require( '../utils');
|
||||||
|
|
||||||
|
module.exports = async ({ branch, upstream }) => {
|
||||||
|
|
||||||
|
console.log(`adding '${upstream}' as upstream of '${branch}'`);
|
||||||
|
|
||||||
|
await Git().addConfig( `branch.${branch}.mikado-upstream`, upstream, true );
|
||||||
|
}
|
@ -1,9 +1,51 @@
|
|||||||
const yargs = require("yargs");
|
const yargs = require("yargs");
|
||||||
const new_branch = require("./commands/new_branch");
|
const new_branch = require("./commands/new_branch");
|
||||||
|
const status = require("./commands/status");
|
||||||
|
const done = require("./commands/done");
|
||||||
|
const upstream = require("./commands/upstream");
|
||||||
|
const { currentBranch } = require('./utils');
|
||||||
|
|
||||||
|
currentBranch().then(
|
||||||
|
currentBranch => {
|
||||||
|
|
||||||
|
|
||||||
yargs
|
yargs
|
||||||
.scriptName("git-mikado")
|
.scriptName("git-mikado")
|
||||||
.showHelpOnFail(true)
|
.showHelpOnFail(true)
|
||||||
|
.command(
|
||||||
|
"status",
|
||||||
|
"show status of all mikado branches",
|
||||||
|
status
|
||||||
|
)
|
||||||
|
.command(
|
||||||
|
"done [branch]",
|
||||||
|
"set branch as done",
|
||||||
|
(yargs) => {
|
||||||
|
return yargs
|
||||||
|
.positional("branch", {
|
||||||
|
describe: "branch to mark as done",
|
||||||
|
default: currentBranch
|
||||||
|
})
|
||||||
|
},
|
||||||
|
done
|
||||||
|
)
|
||||||
|
.command(
|
||||||
|
"upstream [upstream]",
|
||||||
|
"set branch as done",
|
||||||
|
(yargs) => {
|
||||||
|
return yargs
|
||||||
|
.positional("upstream", {
|
||||||
|
describe: "upstream branch to add",
|
||||||
|
})
|
||||||
|
.option("branch", {
|
||||||
|
alias: "b",
|
||||||
|
describe: "target branch",
|
||||||
|
default: currentBranch,
|
||||||
|
})
|
||||||
|
.demandOption(["upstream"]);
|
||||||
|
},
|
||||||
|
upstream
|
||||||
|
)
|
||||||
.command(
|
.command(
|
||||||
"new [branch]",
|
"new [branch]",
|
||||||
"create new mikado branch",
|
"create new mikado branch",
|
||||||
@ -36,3 +78,5 @@ yargs
|
|||||||
.help()
|
.help()
|
||||||
.demandCommand(1, "")
|
.demandCommand(1, "")
|
||||||
.strict().argv;
|
.strict().argv;
|
||||||
|
|
||||||
|
});
|
||||||
|
10
src/utils.js
Normal file
10
src/utils.js
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
const Git = require('simple-git');
|
||||||
|
|
||||||
|
async function currentBranch() {
|
||||||
|
let branch = await Git().raw('branch', '--show-current');
|
||||||
|
return branch.replace("\n",'');
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
currentBranch,
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user