1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-01-25 05:58:20 +01:00
phorge-arcanist/src/workflow/ArcanistCommitWorkflow.php

341 lines
9.3 KiB
PHP
Raw Normal View History

2011-01-09 15:22:25 -08:00
<?php
/**
* Executes "svn commit" once a revision has been "Accepted".
*
* @group workflow
*/
final class ArcanistCommitWorkflow extends ArcanistBaseWorkflow {
2011-01-09 15:22:25 -08:00
private $revisionID;
public function getWorkflowName() {
return 'commit';
}
public function getCommandSynopses() {
2011-01-09 15:22:25 -08:00
return phutil_console_format(<<<EOTEXT
**commit** [--revision __revision_id__] [--show]
EOTEXT
);
}
public function getCommandHelp() {
return phutil_console_format(<<<EOTEXT
2011-01-09 15:22:25 -08:00
Supports: svn
Commit a revision which has been accepted by a reviewer.
EOTEXT
);
}
public function requiresWorkingCopy() {
return true;
}
public function requiresConduit() {
return true;
}
public function requiresAuthentication() {
return true;
}
public function requiresRepositoryAPI() {
return true;
}
public function getRevisionID() {
return $this->revisionID;
}
2011-01-09 15:22:25 -08:00
public function getArguments() {
return array(
'show' => array(
'help' =>
"Show the command which would be issued, but do not actually ".
"commit anything."
),
'revision' => array(
'param' => 'revision_id',
'help' =>
"Commit a specific revision. If you do not specify a revision, ".
"arc will look for committable revisions.",
)
);
}
public function run() {
$repository_api = $this->getRepositoryAPI();
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
if (!($repository_api instanceof ArcanistSubversionAPI)) {
throw new ArcanistUsageException(
"'arc commit' is only supported under svn.");
}
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$revision_id = $this->normalizeRevisionID($this->getArgument('revision'));
if (!$revision_id) {
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$revisions = $repository_api->loadWorkingCopyDifferentialRevisions(
$this->getConduit(),
array(
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
'authors' => array($this->getUserPHID()),
'status' => 'status-accepted',
));
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
if (count($revisions) == 0) {
throw new ArcanistUsageException(
"Unable to identify the revision in the working copy. Use ".
"'--revision <revision_id>' to select a revision.");
} else if (count($revisions) > 1) {
throw new ArcanistUsageException(
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
"More than one revision exists in the working copy:\n\n".
$this->renderRevisionList($revisions)."\n".
"Use '--revision <revision_id>' to select a revision.");
}
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
} else {
$revisions = $this->getConduit()->callMethodSynchronous(
'differential.query',
array(
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
'ids' => array($revision_id),
));
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
if (count($revisions) == 0) {
throw new ArcanistUsageException(
"Revision 'D{$revision_id}' does not exist.");
}
2011-01-09 15:22:25 -08:00
}
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$revision = head($revisions);
$this->revisionID = $revision['id'];
$revision_id = $revision['id'];
$is_show = $this->getArgument('show');
if (!$is_show) {
$this->runSanityChecks($revision);
}
2011-01-09 15:22:25 -08:00
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$message = $this->getConduit()->callMethodSynchronous(
2011-01-09 15:22:25 -08:00
'differential.getcommitmessage',
array(
'revision_id' => $revision_id,
'edit' => false,
2011-01-09 15:22:25 -08:00
));
$event = $this->dispatchEvent(
ArcanistEventType::TYPE_COMMIT_WILLCOMMITSVN,
array(
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
'message' => $message,
));
$message = $event->getValue('message');
if ($is_show) {
echo $message."\n";
2011-01-09 15:22:25 -08:00
return 0;
}
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$revision_title = $revision['title'];
echo "Committing 'D{$revision_id}: {$revision_title}'...\n";
2011-01-09 15:22:25 -08:00
$files = $this->getCommitFileList($revision);
$tmp_file = new TempFile();
Filesystem::writeFile($tmp_file, $message);
2011-01-09 15:22:25 -08:00
$command = csprintf(
'svn commit %Ls --encoding utf-8 -F %s',
$files,
$tmp_file);
// make sure to specify LANG on non-windows systems to suppress any fancy
// warnings; see @{method:getSVNLangEnvVar}.
if (!phutil_is_windows()) {
$command = csprintf('LANG=%C %C', $this->getSVNLangEnvVar(), $command);
}
2011-01-09 15:22:25 -08:00
chdir($repository_api->getPath());
$err = phutil_passthru('%C', $command);
2011-01-09 15:22:25 -08:00
if ($err) {
throw new Exception("Executing 'svn commit' failed!");
}
$mark_workflow = $this->buildChildWorkflow(
'close-revision',
array(
'--finalize',
$revision_id,
));
$mark_workflow->run();
2011-01-09 15:22:25 -08:00
return $err;
}
protected function getCommitFileList(array $revision) {
2011-01-09 15:22:25 -08:00
$repository_api = $this->getRepositoryAPI();
$revision_id = $revision['id'];
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
$commit_paths = $this->getConduit()->callMethodSynchronous(
2011-01-09 15:22:25 -08:00
'differential.getcommitpaths',
array(
'revision_id' => $revision_id,
));
$dir_paths = array();
foreach ($commit_paths as $path) {
$path = dirname($path);
while ($path != '.') {
$dir_paths[$path] = true;
$path = dirname($path);
}
}
2011-01-09 15:22:25 -08:00
$commit_paths = array_fill_keys($commit_paths, true);
$status = $repository_api->getSVNStatus();
$modified_but_not_included = array();
foreach ($status as $path => $mask) {
if (!empty($dir_paths[$path])) {
$commit_paths[$path] = true;
}
2011-01-09 15:22:25 -08:00
if (!empty($commit_paths[$path])) {
continue;
}
foreach ($commit_paths as $will_commit => $ignored) {
if (Filesystem::isDescendant($path, $will_commit)) {
throw new ArcanistUsageException(
"This commit includes the directory '{$will_commit}', but ".
"it contains a modified path ('{$path}') which is NOT included ".
"in the commit. Subversion can not handle this operation and ".
"will commit the path anyway. You need to sort out the working ".
"copy changes to '{$path}' before you may proceed with the ".
"commit.");
}
}
$modified_but_not_included[] = $path;
}
if ($modified_but_not_included) {
$prefix = pht(
'Locally modified path(s) are not included in this revision:',
count($modified_but_not_included));
$prompt = pht(
'They will NOT be committed. Commit this revision anyway?',
count($modified_but_not_included));
2011-01-09 15:22:25 -08:00
$this->promptFileWarning($prefix, $prompt, $modified_but_not_included);
}
$do_not_exist = array();
foreach ($commit_paths as $path => $ignored) {
$disk_path = $repository_api->getPath($path);
if (file_exists($disk_path)) {
continue;
}
if (is_link($disk_path)) {
continue;
}
if (idx($status, $path) & ArcanistRepositoryAPI::FLAG_DELETED) {
continue;
}
$do_not_exist[] = $path;
unset($commit_paths[$path]);
}
if ($do_not_exist) {
$prefix = pht(
'Revision includes changes to path(s) that do not exist:',
count($do_not_exist));
$prompt = "Commit this revision anyway?";
2011-01-09 15:22:25 -08:00
$this->promptFileWarning($prefix, $prompt, $do_not_exist);
}
$files = array_keys($commit_paths);
$files = ArcanistSubversionAPI::escapeFileNamesForSVN($files);
2011-01-09 15:22:25 -08:00
if (empty($files)) {
throw new ArcanistUsageException(
"There is nothing left to commit. None of the modified paths exist.");
}
return $files;
}
protected function promptFileWarning($prefix, $prompt, array $paths) {
echo $prefix."\n\n";
foreach ($paths as $path) {
echo " ".$path."\n";
}
if (!phutil_console_confirm($prompt)) {
throw new ArcanistUserAbortException();
}
}
protected function getSupportedRevisionControlSystems() {
return array('svn');
}
/**
* On some systems, we need to specify "en_US.UTF-8" instead of "en_US.utf8",
* and SVN spews some bewildering warnings if we don't:
*
* svn: warning: cannot set LC_CTYPE locale
* svn: warning: environment variable LANG is en_US.utf8
* svn: warning: please check that your locale name is correct
*
* For example, it happens on epriestley's Mac (10.6.7) with
* Subversion 1.6.15.
*/
private function getSVNLangEnvVar() {
$locale = 'en_US.utf8';
try {
list($locales) = execx('locale -a');
$locales = explode("\n", trim($locales));
$locales = array_fill_keys($locales, true);
if (isset($locales['en_US.UTF-8'])) {
$locale = 'en_US.UTF-8';
}
} catch (Exception $ex) {
// Ignore.
}
return $locale;
}
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
private function runSanityChecks(array $revision) {
$repository_api = $this->getRepositoryAPI();
$revision_id = $revision['id'];
$revision_title = $revision['title'];
$confirm = array();
if ($revision['status'] != ArcanistDifferentialRevisionStatus::ACCEPTED) {
$confirm[] =
"Revision 'D{$revision_id}: {$revision_title}' has not been accepted. ".
"Commit this revision anyway?";
}
if ($revision['authorPHID'] != $this->getUserPHID()) {
$confirm[] =
"You are not the author of 'D{$revision_id}: {$revision_title}'. ".
"Commit this revision anyway?";
}
Improve arc commit with SVN branches Summary: If you are trying to commit someone else's diff, arc commit gives warnings about path mismatch. This changes the path comparison to be based on the repo url rather than the local working directory. E.g. if both the author and committer are working in branches/release/2013_08_07 despite being checked out in ~/dev/2013_08_07 (system user being different, of course) it no longer warns that the WC path is different Original behavior: eric@Eric-MBP ~/dev/2013_07_31: arc commit --revision 21 You are not the author of 'D21: WeMerge Automatic Request'. Commit this revision anyway? [y/N] y Revision 'D21: WeMerge Automatic Request' was generated from '', but current working copy root is '/Users/eric/dev/2013_07_31/'. Commit this revision anyway? [y/N] y Committing 'D21: WeMerge Automatic Request'... Adding test Transmitting file data . Committed revision 52676. Closing revision D21 'WeMerge Automatic Request'... Exception ERR-CONDUIT-CORE: You can not mark a revision you don't own as closed. (Run with --trace for a full exception trace.) New behavior: eric@Eric-MBP ~/dev/2013_07_31: arc commit --revision 24 You are not the author of 'D24: WeMerge Automatic Request'. Commit this revision anyway? [y/N] y Committing 'D24: WeMerge Automatic Request'... Adding test Transmitting file data . Committed revision 52679. Closing revision D24 'WeMerge Automatic Request'... Exception ERR-CONDUIT-CORE: You can not mark a revision you don't own as closed. (Run with --trace for a full exception trace.) Test Plan: 'arc diff' changes with one user. 'arc patch Dxx' on a different working copy by a different user to review and test changes. accept review. 'arc commit --revision xx' as reviewer to land the patch. complaint goes away. Reviewers: epriestley, ghostwriter78 Reviewed By: epriestley CC: aran, epriestley, Korvin Differential Revision: https://secure.phabricator.com/D6665
2013-08-04 09:01:22 -07:00
$revision_source = idx($revision, 'branch');
$current_source = $repository_api->getSourceControlPath();
Use "arc which" in "arc commit", modernize checks Summary: - Use differential.query, not differential.find. - Use loadWorkingCopyDifferentialRevisions ("arc which"). - Some general cleanup. Test Plan: oh man $ arc commit --revision 999 # Does not exist Usage Exception: Revision 'D999' does not exist. $ arc commit --revision 1 # Exists, not accepted. Revision 'D1: bleorp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D1: bleorp'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y Done. $ arc commit --revision 3 # Not mine, from a git repo You are not the author of 'D3: bloop'. Commit this revision anyway? [y/N] y Revision 'D3: bloop' was generated from '/INSECURE/repos/git-working-copy/', but current working copy root is '/INSECURE/repos/svn-working-copy/'. Commit this revision anyway? [y/N] y Committing 'D3: bloop'... A locally modified path is not included in this revision: DERP It will NOT be committed. Commit this revision anyway? [y/N] y svn: Commit failed (details follow): svn: '/INSECURE/repos/svn-working-copy/derp' is not under version control Exception: Executing 'svn commit' failed! (Run with --trace for a full exception trace.) $ arc commit # Nothing accepted Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit # Now accepted Committing 'D1: bleorp'... Marking revision D1 'bleorp' committed... Done. $ svn st # Complicated test for a bizarre SVN edge case A svnderp A svnderp/A A svnderp/B $ arc diff --create Linting... LINT OKAY No lint problems. Running unit tests... No unit test engine is configured for this project. Created a new Differential revision: Revision URI: http://local.aphront.com/D28 Included changes: A (dir) svnderp A svnderp/A A svnderp/B $ touch svnderp/C $ svn add svnderp/C A svnderp/C $ arc commit Usage Exception: Unable to identify the revision in the working copy. Use '--revision <revision_id>' to select a revision. $ arc commit --revision 28 Revision 'D28: derp' has not been accepted. Commit this revision anyway? [y/N] y Committing 'D28: derp'... Usage Exception: This commit includes the directory 'svnderp', but it contains a modified path ('svnderp/C') which is NOT included in the commit. Subversion can not handle this operation and will commit the path anyway. You need to sort out the working copy changes to 'svnderp/C' before you may proceed with the commit. Reviewers: btrahan, jungejason Reviewed By: btrahan CC: aran, epriestley Differential Revision: https://secure.phabricator.com/D1491
2012-01-26 17:40:55 -08:00
if ($revision_source != $current_source) {
$confirm[] =
"Revision 'D{$revision_id}: {$revision_title}' was generated from ".
"'{$revision_source}', but current working copy root is ".
"'{$current_source}'. Commit this revision anyway?";
}
foreach ($confirm as $thing) {
if (!phutil_console_confirm($thing)) {
throw new ArcanistUserAbortException();
}
}
}
2011-01-09 15:22:25 -08:00
}