123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- # Copyright (c) 2011 The Chromium OS Authors.
- #
- # See file CREDITS for list of people who contributed to this
- # project.
- #
- # This program is free software; you can redistribute it and/or
- # modify it under the terms of the GNU General Public License as
- # published by the Free Software Foundation; either version 2 of
- # the License, or (at your option) any later version.
- #
- # This program is distributed in the hope that it will be useful,
- # but WITHOUT ANY WARRANTY; without even the implied warranty of
- # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- # GNU General Public License for more details.
- #
- # You should have received a copy of the GNU General Public License
- # along with this program; if not, write to the Free Software
- # Foundation, Inc., 59 Temple Place, Suite 330, Boston,
- # MA 02111-1307 USA
- #
- import ConfigParser
- import os
- import re
- import command
- import gitutil
- def ReadGitAliases(fname):
- """Read a git alias file. This is in the form used by git:
- alias uboot u-boot@lists.denx.de
- alias wd Wolfgang Denk <wd@denx.de>
- Args:
- fname: Filename to read
- """
- try:
- fd = open(fname, 'r')
- except IOError:
- print "Warning: Cannot find alias file '%s'" % fname
- return
- re_line = re.compile('alias\s+(\S+)\s+(.*)')
- for line in fd.readlines():
- line = line.strip()
- if not line or line[0] == '#':
- continue
- m = re_line.match(line)
- if not m:
- print "Warning: Alias file line '%s' not understood" % line
- continue
- list = alias.get(m.group(1), [])
- for item in m.group(2).split(','):
- item = item.strip()
- if item:
- list.append(item)
- alias[m.group(1)] = list
- fd.close()
- def CreatePatmanConfigFile(config_fname):
- """Creates a config file under $(HOME)/.patman if it can't find one.
- Args:
- config_fname: Default config filename i.e., $(HOME)/.patman
- Returns:
- None
- """
- name = gitutil.GetDefaultUserName()
- if name == None:
- name = raw_input("Enter name: ")
- email = gitutil.GetDefaultUserEmail()
- if email == None:
- email = raw_input("Enter email: ")
- try:
- f = open(config_fname, 'w')
- except IOError:
- print "Couldn't create patman config file\n"
- raise
- print >>f, "[alias]\nme: %s <%s>" % (name, email)
- f.close();
- def Setup(config_fname=''):
- """Set up the settings module by reading config files.
- Args:
- config_fname: Config filename to read ('' for default)
- """
- settings = ConfigParser.SafeConfigParser()
- if config_fname == '':
- config_fname = '%s/.patman' % os.getenv('HOME')
- if not os.path.exists(config_fname):
- print "No config file found ~/.patman\nCreating one...\n"
- CreatePatmanConfigFile(config_fname)
- settings.read(config_fname)
- for name, value in settings.items('alias'):
- alias[name] = value.split(',')
- # These are the aliases we understand, indexed by alias. Each member is a list.
- alias = {}
|