From d95a0f4df52eb025a181df90faf07d67de45d761 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Tue, 4 Aug 2009 21:12:22 +0000 Subject: Always return unicode from vardbapi.aux_get(). svn path=/main/trunk/; revision=13907 --- pym/portage/dbapi/vartree.py | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'pym') diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index e759a9b15..72c829271 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -1173,6 +1173,12 @@ class vardbapi(dbapi): cache_mtime, metadata = pkg_data cache_valid = cache_mtime == mydir_mtime if cache_valid: + for k, v in metadata.iteritems(): + if not isinstance(v, unicode): + # Migrate old metadata to unicode. + metadata[k] = unicode(v, + encoding='utf_8', errors='replace') + mydata.update(metadata) pull_me.difference_update(mydata) @@ -1193,7 +1199,7 @@ class vardbapi(dbapi): if not mydata['SLOT']: # Empty slot triggers InvalidAtom exceptions when generating slot # atoms for packages, so translate it to '0' here. - mydata['SLOT'] = '0' + mydata['SLOT'] = u'0' return [mydata[x] for x in wants] def _aux_get(self, mycpv, wants, st=None): @@ -1216,7 +1222,8 @@ class vardbapi(dbapi): results.append(long(st.st_mtime)) continue try: - myf = open(os.path.join(mydir, x), "r") + myf = codecs.open(os.path.join(mydir, x), + mode='r', encoding='utf_8', errors='replace') try: myd = myf.read() finally: -- cgit v1.2.3-1-g7c22