|
|
|
# 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 = {}
|