Use portable OS error codes so program doesn't crash (#318)
Hard-coding OS error numbers that differ between different platforms caused the program to crash at platforms using a different error number. Using the Standard errno system symbols will avoid this problem. Co-authored-by: kvid <kvid@users.noreply.github.com>
This commit is contained in:
parent
f9d1dd0148
commit
6f9007f45d
@ -390,10 +390,11 @@ def _get_yaml_data_and_path(inp: Union[str, Path, Dict]) -> (Dict, Path):
|
|||||||
# if no FileNotFoundError exception happens, get file contents
|
# if no FileNotFoundError exception happens, get file contents
|
||||||
yaml_str = open_file_read(yaml_path).read()
|
yaml_str = open_file_read(yaml_path).read()
|
||||||
except (FileNotFoundError, OSError) as e:
|
except (FileNotFoundError, OSError) as e:
|
||||||
# if inp is a long YAML string, Pathlib will raise OSError: [Errno 63]
|
# if inp is a long YAML string, Pathlib will raise OSError: [errno.ENAMETOOLONG]
|
||||||
# when trying to expand and resolve it as a path.
|
# when trying to expand and resolve it as a path.
|
||||||
# Catch this error, but raise any others
|
# Catch this error, but raise any others
|
||||||
if type(e) is OSError and e.errno != 63:
|
from errno import ENAMETOOLONG
|
||||||
|
if type(e) is OSError and e.errno != ENAMETOOLONG:
|
||||||
raise e
|
raise e
|
||||||
# file does not exist; assume inp is a YAML string
|
# file does not exist; assume inp is a YAML string
|
||||||
yaml_str = inp
|
yaml_str = inp
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user