28
28
class InitCommand( Command ):
33
self.vcs = the.config.default_vcs
31
36
def print_help( self ):
32
print "Usage: " + the.program.name + " init [URL] [--repo=REPO]"
37
print("Usage: " + the.program.name + " init [URL] [--repo=REPO]")
34
39
# 01234567890123456789012345678901234567890123456789012345678901234567890123456789
35
print "Initialise a local repository."
37
print "If an URL is given, the local reposity is a checkout of it (i.e., you can"
38
print "receive updates from it and changes you commit will be sent to it). The URL"
39
print "can take the form of a simple hostname, such as \"example.com\", or it can be a"
40
print "fully-qualified bazaar URL. (Actually, in the first case, where it is a simple"
41
print "hostname, it is internally expanded to scp://HOSTNAME/~/.stdhome/REPO)."
44
print " -r, --repo=REPO select the repo to check-out or create (defaults to 'home')"
45
print " -v, --verbose display information about what is being done"
46
print " --help display help and exit"
40
print("Initialise a local repository.")
42
print("If an URL is given, the local reposity is a checkout of it (i.e., you can")
43
print("receive updates from it and changes you commit will be sent to it). The URL")
44
print("can take the form of a simple hostname, such as \"example.com\", or it can be a")
45
print("fully-qualified bazaar URL. (Actually, in the first case, where it is a simple")
46
print("hostname, it is internally expanded to scp://HOSTNAME/~/.stdhome/REPO).")
49
print(" --quiet do not report changes to the home directory")
50
print(" -r, --repo=REPO select the repo to check-out or create (defaults to 'home')")
51
print(" -v, --verbose display information about what is being done")
52
print(" --vcs=VCS select the version control system")
53
print(" --help display help and exit")
50
57
def parse_command_line( self ):
51
58
opts, args = getopt.gnu_getopt(
52
59
sys.argv[ 1: ], "r:v",
53
[ "repo=", "verbose", "help" ] )
60
[ "quiet", "repo=", "vcs=", "verbose", "help" ] )
54
61
for opt, optarg in opts:
55
if opt in [ '--repo', '-r' ]:
56
if not re.match( '^[-a-zA-z0-9.]+$', optarg ):
64
elif opt in [ '--repo', '-r' ]:
65
if not re.search( '^[-a-zA-z0-9.]+$', optarg ):
57
66
raise the.program.FatalError(
58
67
'invalid repository name: ' + optarg )
60
71
elif opt in [ '--verbose', '-v' ]:
62
73
elif opt == "--help":
65
76
# discard first argument (the command)
88
100
# expand url if it's a simple hostname
89
if re.match( '^[0-9a-zA-z.]+$', self.url ):
90
self.url = 'bzr+ssh://%s/%s/%s' % \
91
( self.url, the.dir, the.repo.name )
101
if re.search( '^[0-9a-zA-z.]+$', self.url ):
102
self.url = the.repo.vcs.expand_repo_url( self.url )
93
104
# initialise deployment (with an empty repo)
94
105
deployment = Deployment()
95
106
deployment.copy_in()
97
108
# perform bzr checkout
98
if the.verbose >= 1: print "checking out %s" % the.repo.dir
109
if the.verbose >= 1: print("checking out %s" % the.repo.dir)
100
111
the.repo.vcs.checkout( self.url )
101
except Exception as e:
103
114
# attempt to clean-up repo dir
105
shutil.rmtree( the.repo.full_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 )
111
136
# perform deployment
113
deployment.copy_out()
114
except deployment.Conflict as e:
115
raise the.program.FatalError( e.msg )
137
deployment.copy_out( self.quiet )
119
141
# perform bzr init
120
if the.verbose >= 1: print 'initialising %s' % the.repo.dir
142
if the.verbose >= 1: print('initialising %s' % the.repo.dir)
122
144
the.repo.vcs.init()
123
except Exception as e:
125
147
# attempt to clean-up repo dir, and die
127
shutil.rmtree( the.repo.full_dir )
148
if os.path.exists( the.repo.full_dir ):
150
shutil.rmtree( the.repo.full_dir )