aboutsummaryrefslogtreecommitdiff
path: root/minishell_test/config.py
diff options
context:
space:
mode:
Diffstat (limited to 'minishell_test/config.py')
-rw-r--r--minishell_test/config.py14
1 files changed, 10 insertions, 4 deletions
diff --git a/minishell_test/config.py b/minishell_test/config.py
index 5a45e8b..1368740 100644
--- a/minishell_test/config.py
+++ b/minishell_test/config.py
@@ -6,7 +6,7 @@
# By: cacharle <me@cacharle.xyz> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ #
# Created: 2021/02/26 09:40:36 by cacharle #+# #+# #
-# Updated: 2021/02/27 15:13:19 by cacharle ### ########.fr #
+# Updated: 2021/02/27 16:11:46 by cacharle ### ########.fr #
# #
# ############################################################################ #
@@ -49,12 +49,17 @@ CONFIG_FILENAME = Path('minishell_test.cfg')
config = ConfigParser()
config.read(DATA_DIR / 'default.cfg')
-
-# TODO check user_config for unkown stuff
user_config = ConfigParser()
user_config.read(MINISHELL_DIR / CONFIG_FILENAME)
-config.read_dict({**config, **user_config})
+for section in user_config:
+ if section not in config:
+ raise RuntimeError(f"Unknown section name: {section}")
+ for key in user_config[section]:
+ if key not in config[section]:
+ raise RuntimeError(f"Unknown key name: {key}")
+
+config.read_dict({**config, **user_config})
BONUS = config.getboolean('minishell_test', 'bonus')
EXEC_NAME = config.get('minishell_test', 'exec_name')
@@ -68,6 +73,7 @@ CHECK_ERROR_MESSAGES = config.getboolean('minishell_test', 'check_error_mess
SHELL_AVAILABLE_COMMANDS = config.getmultiline('shell', 'available_commands')
SHELL_PATH_VARIABLE = config.get('shell', 'path_variable')
+
SHELL_REFERENCE_PATH = config.getpath('shell:reference', 'path')
SHELL_REFERENCE_ARGS = config.getargs('shell:reference', 'args')