mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-22 14:52:40 +01:00
Add output-json option to arc feature
Summary: The current format of arc feature is not very friendly to parsing. This adds a json output format. Test Plan: Run the command and ensure output is valid Reviewers: lifeihuang, #blessed_reviewers, epriestley Reviewed By: epriestley CC: epriestley, aran, Korvin Differential Revision: https://secure.phabricator.com/D7647
This commit is contained in:
parent
799841a0d8
commit
d30c77d0a8
1 changed files with 25 additions and 10 deletions
|
@ -60,6 +60,13 @@ EOTEXT
|
|||
'by-status' => array(
|
||||
'help' => 'Sort branches by status instead of time.',
|
||||
),
|
||||
'output' => array(
|
||||
'param' => 'format',
|
||||
'support' => array(
|
||||
'json'
|
||||
),
|
||||
'help' => "With 'json', show features in machine-readable JSON format.",
|
||||
),
|
||||
'*' => 'branch',
|
||||
);
|
||||
}
|
||||
|
@ -324,8 +331,10 @@ EOTEXT
|
|||
'current' => $branch['current'],
|
||||
'status' => $status,
|
||||
'desc' => $desc,
|
||||
'revision' => $revision ? $revision['id'] : null,
|
||||
'color' => $color,
|
||||
'esort' => $epoch,
|
||||
'epoch' => $epoch,
|
||||
'ssort' => $ssort,
|
||||
);
|
||||
}
|
||||
|
@ -338,7 +347,12 @@ EOTEXT
|
|||
} else {
|
||||
$out = isort($out, 'esort');
|
||||
}
|
||||
|
||||
if ($this->getArgument('output') == 'json') {
|
||||
foreach ($out as &$feature) {
|
||||
unset($feature['color'], $feature['ssort'], $feature['esort']);
|
||||
}
|
||||
echo json_encode(ipull($out, null, 'name')) . "\n";
|
||||
} else {
|
||||
$console = PhutilConsole::getConsole();
|
||||
foreach ($out as $line) {
|
||||
$color = $line['color'];
|
||||
|
@ -350,5 +364,6 @@ EOTEXT
|
|||
$line['desc']);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue