config: Rework the SysPaths functions into functors.

These functions were already being treated as psuedo objects and had
properties assigned to them setting what their paths were. That's a bit
unusual and made it less obvious what the code was doing, but also
forced the "system" function to know what all the possible path
searching functions were so that they'd have their "path" property
initialized properly in a central location.

This change introduces a PathSearcFunc class which encapsulates the
mechanisms of the old code and makes it implicitly extensible so that
other path searching functions which might look in other directories
can be added in other places.

Change-Id: I7be28e51481a06ec83997677af99927709b18003
Reviewed-on: https://gem5-review.googlesource.com/5341
Reviewed-by: Andreas Sandberg <andreas.sandberg@arm.com>
Maintainer: Andreas Sandberg <andreas.sandberg@arm.com>
This commit is contained in:
Gabe Black
2017-10-30 18:31:07 -07:00
parent fd16487b71
commit 97c68e8fc5

View File

@@ -27,55 +27,41 @@
# Authors: Ali Saidi
import os, sys
from os.path import join as joinpath
from os import environ as env
config_path = os.path.dirname(os.path.abspath(__file__))
config_root = os.path.dirname(config_path)
def searchpath(path, filename):
for p in path:
f = joinpath(p, filename)
if os.path.exists(f):
return f
raise IOError, "Can't find file '%s' on path." % filename
class PathSearchFunc(object):
_sys_paths = None
def disk(filename):
system()
return searchpath(disk.path, filename)
def __init__(self, *subdirs):
self._subdir = os.path.join(*subdirs)
def binary(filename):
system()
return searchpath(binary.path, filename)
def __call__(self, filename):
if self._sys_paths is None:
try:
paths = os.environ['M5_PATH'].split(':')
except KeyError:
paths = [ '/dist/m5/system', '/n/poolfs/z/dist/m5/system' ]
def script(filename):
system()
return searchpath(script.path, filename)
# expand '~' and '~user' in paths
paths = map(os.path.expanduser, paths)
def system():
if not system.path:
# filter out non-existent directories
paths = filter(os.path.isdir, paths)
if not paths:
raise IOError, "Can't find a path to system files."
self._sys_paths = paths
filepath = os.path.join(self._subdir, filename)
paths = (os.path.join(p, filepath) for p in self._sys_paths)
try:
path = env['M5_PATH'].split(':')
except KeyError:
path = [ '/dist/m5/system', '/n/poolfs/z/dist/m5/system' ]
return next(p for p in paths if os.path.exists(p))
except StopIteration:
raise IOError, "Can't find file '%s' on path." % filename
# expand '~' and '~user' in paths
path = map(os.path.expanduser, path)
# filter out non-existent directories
system.path = filter(os.path.isdir, path)
if not system.path:
raise IOError, "Can't find a path to system files."
if not binary.path:
binary.path = [joinpath(p, 'binaries') for p in system.path]
if not disk.path:
disk.path = [joinpath(p, 'disks') for p in system.path]
if not script.path:
script.path = [joinpath(config_root, 'boot')]
system.path = None
binary.path = None
disk.path = None
script.path = None
disk = PathSearchFunc('disks')
binary = PathSearchFunc('binaries')
script = PathSearchFunc('boot')