diff options
| author | Sebastian Thiel <byronimo@gmail.com> | 2009-10-19 21:32:34 +0200 | 
|---|---|---|
| committer | Sebastian Thiel <byronimo@gmail.com> | 2009-10-19 21:32:34 +0200 | 
| commit | 985093bae160419782b3d3cb9151e2e58625fd52 (patch) | |
| tree | 2f19b97289d9d0af2eeea894dcc1f51e627261cf /lib/git/config.py | |
| parent | 8f42db54c6b2cfbd7d68e6d34ac2ed70578402f7 (diff) | |
| parent | 53d26977f1aff8289f13c02ee672349d78eeb2f0 (diff) | |
| download | gitpython-985093bae160419782b3d3cb9151e2e58625fd52.tar.gz | |
Merge branch 'remotes' into improvements
* remotes:
  remote: added tests for creation and removal, finishing the remote interface
  remote: base tests succeed now
  config: fixed serious issues that would cause it to see initial tabs as continuation lines - this leads to very incorrect results when parsing git config files. Now the complete reading is overridden to make it work as there was no other way
  Added configuration access including tests to remote
  Added remote module and test cases - about to implement remote option handling
  added initial frame for remote handling- remotes are somewhat related to either parsing the command output or to reading the repo configuration which would be faster
Diffstat (limited to 'lib/git/config.py')
| -rw-r--r-- | lib/git/config.py | 83 | 
1 files changed, 80 insertions, 3 deletions
| diff --git a/lib/git/config.py b/lib/git/config.py index b555677e..6f979c73 100644 --- a/lib/git/config.py +++ b/lib/git/config.py @@ -13,6 +13,7 @@ import os  import ConfigParser as cp  from git.odict import OrderedDict  import inspect +import cStringIO  class _MetaParserBuilder(type):  	""" @@ -221,15 +222,88 @@ class GitConfigParser(cp.RawConfigParser, object):  		"""  		return optionstr +	def _read(self, fp, fpname): +		""" +		A direct copy of the py2.4 version of the super class's _read method +		to assure it uses ordered dicts. Had to change one line to make it work. +		 +		Future versions have this fixed, but in fact its quite embarassing for the  +		guys not to have done it right in the first place ! +		 +		Removed big comments to make it more compact. +		 +		Made sure it ignores initial whitespace as git uses tabs +		""" +		cursect = None							  # None, or a dictionary +		optname = None +		lineno = 0 +		e = None								  # None, or an exception +		while True: +			line = fp.readline() +			if not line: +				break +			lineno = lineno + 1 +			# comment or blank line? +			if line.strip() == '' or line[0] in '#;': +				continue +			if line.split(None, 1)[0].lower() == 'rem' and line[0] in "rR": +				# no leading whitespace +				continue +			else: +				# is it a section header? +				mo = self.SECTCRE.match(line) +				if mo: +					sectname = mo.group('header') +					if sectname in self._sections: +						cursect = self._sections[sectname] +					elif sectname == cp.DEFAULTSECT: +						cursect = self._defaults +					else: +						# THE ONLY LINE WE CHANGED ! +						cursect = OrderedDict((('__name__', sectname),)) +						self._sections[sectname] = cursect +					# So sections can't start with a continuation line +					optname = None +				# no section header in the file? +				elif cursect is None: +					raise cp.MissingSectionHeaderError(fpname, lineno, line) +				# an option line? +				else: +					mo = self.OPTCRE.match(line) +					if mo: +						optname, vi, optval = mo.group('option', 'vi', 'value') +						if vi in ('=', ':') and ';' in optval: +							pos = optval.find(';') +							if pos != -1 and optval[pos-1].isspace(): +								optval = optval[:pos] +						optval = optval.strip() +						if optval == '""': +							optval = '' +						optname = self.optionxform(optname.rstrip()) +						cursect[optname] = optval +					else: +						if not e: +							e = cp.ParsingError(fpname) +						e.append(lineno, repr(line)) +					# END   +				# END ?  +			# END ? +		# END while reading  +		# if any parsing errors occurred, raise an exception +		if e: +			raise e +	 +	  	def read(self):  		""" -		Reads the data stored in the files we have been initialized with +		Reads the data stored in the files we have been initialized with. It will  +		ignore files that cannot be read, possibly leaving an empty configuration  		Returns  			Nothing  		Raises -			IOError if not all files could be read +			IOError if a file cannot be handled  		"""  		if self._is_initialized:  			return @@ -244,7 +318,10 @@ class GitConfigParser(cp.RawConfigParser, object):  			close_fp = False  			# assume a path if it is not a file-object  			if not hasattr(file_object, "seek"): -				fp = open(file_object) +				try: +					fp = open(file_object) +				except IOError,e: +					continue  				close_fp = True  			# END fp handling | 
