Expand env vars for `custom_modules` build option
The order of conversion is also changed to ensure that the resulting path can be properly validated later on.
This commit is contained in:
parent
ad9e5ae984
commit
80249e7190
|
@ -217,14 +217,15 @@ void unregister_module_types() {
|
||||||
def convert_custom_modules_path(path):
|
def convert_custom_modules_path(path):
|
||||||
if not path:
|
if not path:
|
||||||
return path
|
return path
|
||||||
|
path = os.path.realpath(os.path.expanduser(os.path.expandvars(path)))
|
||||||
err_msg = "Build option 'custom_modules' must %s"
|
err_msg = "Build option 'custom_modules' must %s"
|
||||||
if not os.path.isdir(path):
|
if not os.path.isdir(path):
|
||||||
raise ValueError(err_msg % "point to an existing directory.")
|
raise ValueError(err_msg % "point to an existing directory.")
|
||||||
if os.path.realpath(path) == os.path.realpath("modules"):
|
if path == os.path.realpath("modules"):
|
||||||
raise ValueError(err_msg % "be a directory other than built-in `modules` directory.")
|
raise ValueError(err_msg % "be a directory other than built-in `modules` directory.")
|
||||||
if is_module(path):
|
if is_module(path):
|
||||||
raise ValueError(err_msg % "point to a directory with modules, not a single module.")
|
raise ValueError(err_msg % "point to a directory with modules, not a single module.")
|
||||||
return os.path.realpath(os.path.expanduser(path))
|
return path
|
||||||
|
|
||||||
|
|
||||||
def disable_module(self):
|
def disable_module(self):
|
||||||
|
|
Loading…
Reference in New Issue