1 package org.apache.maven.scm.provider.tfs.command;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import java.util.ArrayList;
23
24 import org.apache.maven.scm.ScmException;
25 import org.apache.maven.scm.ScmFile;
26 import org.apache.maven.scm.ScmFileSet;
27 import org.apache.maven.scm.ScmResult;
28 import org.apache.maven.scm.command.branch.AbstractBranchCommand;
29 import org.apache.maven.scm.command.branch.BranchScmResult;
30 import org.apache.maven.scm.provider.ScmProviderRepository;
31 import org.apache.maven.scm.provider.tfs.TfsScmProviderRepository;
32 import org.apache.maven.scm.provider.tfs.command.consumer.ErrorStreamConsumer;
33 import org.codehaus.plexus.util.cli.CommandLineUtils.StringStreamConsumer;
34
35
36
37
38 public class TfsBranchCommand
39 extends AbstractBranchCommand
40 {
41
42 protected ScmResult executeBranchCommand( ScmProviderRepository r, ScmFileSet f, String branch, String message )
43 throws ScmException
44 {
45 TfsCommand command = createCommand( r, f, branch );
46 StringStreamConsumer out = new StringStreamConsumer();
47 ErrorStreamConsumer err = new ErrorStreamConsumer();
48 int status = command.execute( out, err );
49 getLogger().info( "status of branch command is= " + status + "; err= " + err.getOutput() );
50 if ( status != 0 || err.hasBeenFed() )
51 {
52 return new BranchScmResult( command.getCommandString(), "Error code for TFS branch command - " + status,
53 err.getOutput(), false );
54 }
55 return new BranchScmResult( command.getCommandString(), new ArrayList<ScmFile>( 0 ) );
56 }
57
58 public TfsCommand createCommand( ScmProviderRepository r, ScmFileSet f, String branch )
59 {
60 TfsCommand command = new TfsCommand( "branch", r, f, getLogger() );
61
62
63
64 String serverPath = ( (TfsScmProviderRepository) r ).getServerPath();
65 command.addArgument( serverPath );
66
67
68 command.addArgument( "-checkin" );
69 command.addArgument( branch );
70 return command;
71 }
72
73
74 }