From 54669f5635cbb75ab569820dc22bdacb143e203e Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Fri, 7 Aug 2009 08:47:47 +0000 Subject: In config.__setitem__(), convert keys/values to unicode in order to avoid potential UnicodeDecodeError exceptions later. svn path=/main/trunk/; revision=13946 --- pym/portage/__init__.py | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'pym') diff --git a/pym/portage/__init__.py b/pym/portage/__init__.py index 276f8852d..af908f041 100644 --- a/pym/portage/__init__.py +++ b/pym/portage/__init__.py @@ -3197,8 +3197,15 @@ class config(object): "set a value; will be thrown away at reset() time" if not isinstance(myvalue, basestring): raise ValueError("Invalid type being used as a value: '%s': '%s'" % (str(mykey),str(myvalue))) + + # Avoid potential UnicodeDecodeError exceptions later. + if not isinstance(mykey, unicode): + mykey = unicode(mykey, encoding='utf_8', errors='replace') + if not isinstance(myvalue, unicode): + myvalue = unicode(myvalue, encoding='utf_8', errors='replace') + self.modifying() - self.modifiedkeys += [mykey] + self.modifiedkeys.append(mykey) self.configdict["env"][mykey]=myvalue def environ(self): -- cgit v1.2.3-1-g7c22