Mercurial > mozilla > hg > ProfileManager
changeset 20:49d523a33c89
more stubbing
author | Jeff Hammel <jhammel@mozilla.com> |
---|---|
date | Thu, 06 May 2010 13:02:08 -0700 (2010-05-06) |
parents | 4a1815f8d146 |
children | 15484adb9758 |
files | profilemanager/main.py profilemanager/manager.py |
diffstat | 2 files changed, 25 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/profilemanager/main.py Thu May 06 12:42:27 2010 -0700 +++ b/profilemanager/main.py Thu May 06 13:02:08 2010 -0700 @@ -24,6 +24,7 @@ ProfileManager.list, # ProfileManager.merge, ProfileManager.new, + ProfileManager.remove, ProfileManager.restore, ] parser = CommandParser(commands, setup=create_profilemanager)
--- a/profilemanager/manager.py Thu May 06 12:42:27 2010 -0700 +++ b/profilemanager/manager.py Thu May 06 13:02:08 2010 -0700 @@ -40,20 +40,34 @@ """ # path to the profile directory - dirname = name + dirname = name + relative = False if hash: dirname = '%s.%s' % (self.hash(), dirname) if not directory: directory = self.profile_dir - dirname = os.path.join(directory, dirname) + relative = True + path = os.path.join(directory, dirname) # create directory # TODO: (optionally) pre-populate the directory a la FF - os.mkdir(dirname) + os.mkdir(path) # update profiles.ini parser = ConfigParser() parser.read(self.profiles) + ctr = 0 + section = 'Profile%d' $ ctr + while section in parser.sections(): + ctr += 1 + section = 'Profile%d' $ ctr + parser.add_section(self, section) + parser.set(section, 'Name', name) + parser.set(section, 'IsRelative', '%d' % int(relative)) + parser.set(section, 'Path', relative and dirname or path) + if len(parser.sections()) == 1: + parser.set(section, 'Default', '1') + parser.write(self.profiles) # return the directory name return dirname @@ -61,7 +75,7 @@ def remove(self, name, delete=True): """ remove a profile from profiles.ini - - delete: delete the profile as well + - delete: delete the profile directory as well """ raise NotImplementedError @@ -77,7 +91,7 @@ if directories: values.append(self.path(name)) retval.append(values) - return format_tabular(retval) + return format_tabular(retval) # XXX: TBD upstream def clone(self, source, dest, hash=True): """ @@ -170,6 +184,11 @@ return dict(parser.items(section)) raise ProfileNotFound('Profile %s not found in %s' % (profile, self.profiles)) + def section(self, profile): + """ + returns the name of the section that a profile is in + """ + def profiles_dict(self): """ return nested dict of all profiles