22
22
import sys, re, getopt
24
from deployment import Deployment
23
from command import Command
24
import stdhome.the as the
25
from stdhome.deployment import Deployment
28
class ResolveCommand( Command ):
30
31
def __init__( self ):
34
35
def print_help( self ):
47
48
print " " + the.program.name + " conflicts"
51
print " --quiet do not report changes to the home directory"
50
52
print " -r, --repo=REPO select the repo to check-out or create (defaults to 'home')"
51
53
print " -v, --verbose display information about what is being done"
52
54
print " --help display help and exit"
56
58
def parse_command_line( self ):
57
59
opts, args = getopt.gnu_getopt(
58
60
sys.argv[ 1: ], "r:v",
59
[ "repo=", "verbose", "help" ] )
61
[ "quiet", "repo=", "verbose", "help" ] )
60
62
for opt, optarg in opts:
61
if opt in [ '--repo', '-r' ]:
62
if not re.match( '^[-a-zA-z0-9.]+$', optarg ):
65
elif opt in [ '--repo', '-r' ]:
66
if not re.search( '^[-a-zA-z0-9.]+$', optarg ):
63
67
raise the.program.FatalError(
64
68
'invalid repository name: ' + optarg )
66
70
elif opt in [ '--verbose', '-v' ]:
68
72
elif opt == "--help":
71
75
# discard first argument (the command)
81
85
# set up repo and check it exists
82
the.set_repo( self.repo )
83
86
the.repo.check_dir_exists()
85
88
# initialise deployment (check it's valid)
86
89
deployment = Deployment()
87
90
deployment.check_ongoing( True )
91
conflicts = the.repo.vcs.has_conflicts()
93
message += 'Conflicts in %s:\n %s' % \
94
( the.repo.name, '\n '.join( conflicts ) )
95
conflicts = deployment.check_conflicts()
97
message += 'Deployment conflicts:\n %s' % \
94
# check for conflicts in repo
95
files = the.repo.vcs.get_conflicts()
97
message += 'conflicts in %s:\n %s' % \
98
( the.repo.name, '\n '.join( files ) )
100
# check for deployment conclicts
101
conflicts = deployment.get_conflicts()
103
message += 'deployment conflicts:\n %s' % \
98
104
'\n '.join( conflicts )
106
# stop if there are conflicts
100
raise the.program.FatalError( 'there are conflicts:\n' + message )
108
raise the.program.FatalError(
109
'there were conflicts...\n' + message )
102
111
# copy-out changes from repo
104
deployment.copy_out()
105
except deployment.Conflict as e:
106
raise the.program.FatalError( e.msg )
112
deployment.copy_out( self.quiet )
108
114
# now we've copied-out, revert any copied-in changes!
109
if the.verbose: print "reverting %s" % the.repo.dir
115
if the.verbose >= 1: print "reverting %s" % the.repo.dir
110
116
the.repo.vcs.revert()