From: Zac Medico Date: Wed, 23 Sep 2009 06:35:55 +0000 (-0000) Subject: Optimize vardbapi.getpath(). Thanks to Marat Radchenko X-Git-Tag: v2.2_rc42~32 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=6d895f047e7d2947aab862de3f6103440f248fc4;p=portage.git Optimize vardbapi.getpath(). Thanks to Marat Radchenko for this patch. svn path=/main/trunk/; revision=14392 --- diff --git a/pym/portage/dbapi/vartree.py b/pym/portage/dbapi/vartree.py index 2bbc0f88a..d2160896e 100644 --- a/pym/portage/dbapi/vartree.py +++ b/pym/portage/dbapi/vartree.py @@ -50,6 +50,7 @@ from portage.cache.mappings import slot_dict_class import codecs import re, shutil, stat, errno, copy, subprocess import logging +import os as _os import sys import warnings @@ -839,9 +840,13 @@ class vardbapi(dbapi): self._owners = self._owners_db(self) def getpath(self, mykey, filename=None): - rValue = os.path.join(self.root, VDB_PATH, mykey) - if filename != None: - rValue = os.path.join(rValue, filename) + # This is an optimized hotspot, so don't use unicode-wrapped + # os module and don't use os.path.join(). + rValue = self.root + _os.sep + VDB_PATH + _os.sep + mykey + if filename is not None: + # If filename is always relative, we can do just + # rValue += _os.sep + filename + rValue = _os.path.join(rValue, filename) return rValue def cpv_exists(self, mykey):