Updated 'phing changelog' to work with new commit tags

This commit is contained in:
Ingo Schommer 2012-06-27 00:29:38 +02:00 committed by Sam Minnee
parent 17303c6e9f
commit 1ca61a5c22

View File

@ -18,11 +18,10 @@ class CreateChangelog extends SilverStripeBuildTask {
* Order of the array keys determines order of the lists. * Order of the array keys determines order of the lists.
*/ */
public $types = array( public $types = array(
'API Changes' => array('/^API CHANGE:?/i','/^APICHANGE?:?/i'), 'API Changes' => array('/^(APICHANGE|API-CHANGE|API CHANGE|API)\s?:?/i'),
'Features and Enhancements' => array('/^(ENHANCEMENT|ENHNACEMENT):?/i', '/^FEATURE:?/i'), 'Features and Enhancements' => array('/^(ENHANCEMENT|ENHNACEMENT|FEATURE|NEW)\s?:?/i'),
'Bugfixes' => array('/^(BUGFIX|BUGFUX):?/i','/^BUG FIX:?/i'), 'Bugfixes' => array('/^(BUGFIX|BUGFUX|BUG)\s?:?/i','/^(BUG FIX)\s?:?/i'),
'Minor changes' => array('/^MINOR:?/i'), 'Other' => array('/^(MINOR)\s?:?/i')
'Other' => array('/^[^A-Z][^A-Z][^A-Z]/') // dirty trick: check for uppercase characters
); );
public $commitUrls = array( public $commitUrls = array(
@ -144,9 +143,9 @@ class CreateChangelog extends SilverStripeBuildTask {
foreach($this->types as $name => $rules) { foreach($this->types as $name => $rules) {
if(!isset($groupedByType[$name])) $groupedByType[$name] = array(); if(!isset($groupedByType[$name])) $groupedByType[$name] = array();
foreach($rules as $rule) { foreach($rules as $rule) {
if(!$matched && preg_match($rule, $commit['message'])) { if(!$matched && preg_match($rule, $commit['message'], $matches)) {
// @todo The fallback rule on other can't be replaced, as it doesn't match a full prefix // @todo The fallback rule on other can't be replaced, as it doesn't match a full prefix
$commit['message'] = ($name != 'Other') ? trim(preg_replace($rule, '', $commit['message'])) : $commit['message']; $commit['message'] = trim(preg_replace($rule, '', $commit['message']));
$groupedByType[$name][] = $commit; $groupedByType[$name][] = $commit;
$matched = true; $matched = true;
} }