57
52
def parse_command_line( self ):
58
53
opts, args = getopt.gnu_getopt(
59
54
sys.argv[ 1: ], "r:v",
60
[ "quiet", "repo=", "vcs=", "verbose", "help" ] )
55
[ "repo=", "verbose", "help" ] )
61
56
for opt, optarg in opts:
64
elif opt in [ '--repo', '-r' ]:
65
if not re.search( '^[-a-zA-z0-9.]+$', optarg ):
66
raise the.program.FatalError(
57
if [ '--repo', '-r' ].count( opt ):
58
if not re.match( '^[-a-zA-z0-9.]+$', optarg ):
67
60
'invalid repository name: ' + optarg )
71
elif opt in [ '--verbose', '-v' ]:
62
elif [ '--verbose', '-v' ].count( opt ):
73
64
elif opt == "--help":
76
67
# discard first argument (the command)
80
71
self.url = args[ 0 ].strip() if len( args ) else None
82
# check remaining arguments
83
74
if len( args ) > 1:
84
75
raise the.program.UsageError( 'too many arguments' )
79
the.set_repo( self.repo )
89
# set up repo and check it *doesn't* already exists
81
# repo dir must not already exist
90
82
the.repo.check_dir_exists( False )
91
the.repo.set_vcs( self.vcs )
93
84
# ensure our top-level directory exists
94
if not os.path.exists( the.full_dir ):
95
os.mkdir( the.full_dir )
85
if not os.path.exists( the.expanded_dir ):
86
os.mkdir( the.expanded_dir )
97
# checkout a remote repo, or create an empty local one?
100
90
# expand url if it's a simple hostname
101
if re.search( '^[0-9a-zA-z.]+$', self.url ):
102
self.url = the.repo.vcs.expand_repo_url( self.url )
91
if re.match( '^[0-9a-zA-z.]+$', self.url ):
92
self.url = 'sftp://%s/%s/%s' % \
93
( self.url, the.dir, the.repo.name )
104
95
# initialise deployment (with an empty repo)
105
deployment = Deployment()
96
deployment = Deployment( self.repo )
106
97
deployment.copy_in()
108
99
# perform bzr checkout
109
if the.verbose >= 1: print "checking out %s" % the.repo.dir
111
the.repo.vcs.checkout( self.url )
114
# attempt to clean-up repo dir
115
if os.path.exists( the.repo.full_dir ):
117
shutil.rmtree( the.repo.full_dir )
125
# check for deployment conclicts
126
conflicts = deployment.get_conflicts()
128
message += 'deployment conflicts:\n %s' % \
129
'\n '.join( conflicts )
131
# stop if there are conflicts
133
raise the.program.FatalError(
134
'there were conflicts...\n' + message )
100
print "checking out %s" % the.repo.dir
101
p = Popen( [ 'bzr', 'co', self.url, the.repo.name ],
102
cwd = the.expanded_dir,
103
stdout = subprocess.PIPE, stderr = subprocess.STDOUT )
104
out = p.communicate()[ 0 ]
107
# attempt to clean-up repo dir, and die
109
shutil.rmtree( the.repo.expanded_dir )
112
raise the.program.FatalError( 'checkout failed', out )
136
114
# perform deployment
137
deployment.copy_out( self.quiet )
115
deployment.copy_out()
141
119
# perform bzr init
142
if the.verbose >= 1: print 'initialising %s' % the.repo.dir
120
print 'creating %s' % the.repo.dir
121
p = Popen( [ 'bzr', 'init', the.repo.name ],
122
cwd = the.expanded_dir,
123
stdout = subprocess.PIPE, stderr = subprocess.STDOUT )
124
out = p.communicate()[ 0 ]
147
127
# attempt to clean-up repo dir, and die
148
if os.path.exists( the.repo.full_dir ):
150
shutil.rmtree( the.repo.full_dir )
129
shutil.rmtree( the.repo.expanded_dir )
132
raise the.program.FatalError( 'init failed', out )