Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
avocado
提交
2db2ee43
A
avocado
项目概览
openeuler
/
avocado
通知
0
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
avocado
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
2db2ee43
编写于
4月 03, 2014
作者:
L
Lucas Meneghel Rodrigues
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
avocado.settings: Introduce docstrings
Signed-off-by:
N
Lucas Meneghel Rodrigues
<
lmr@redhat.com
>
上级
95c2336f
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
47 addition
and
0 deletion
+47
-0
avocado/settings.py
avocado/settings.py
+47
-0
未找到文件。
avocado/settings.py
浏览文件 @
2db2ee43
...
...
@@ -18,15 +18,27 @@ config_path_intree = os.path.join(_config_path_intree, config_filename)
class
SettingsError
(
Exception
):
"""
Base settings error.
"""
pass
class
SettingsValueError
(
SettingsError
):
"""
Error thrown when we could not convert successfully a key to a value.
"""
pass
class
ConfigFileNotFound
(
SettingsError
):
"""
Error thrown when the main settings file could not be found.
"""
def
__init__
(
self
,
path_list
):
super
(
ConfigFileNotFound
,
self
).
__init__
()
self
.
path_list
=
path_list
...
...
@@ -79,9 +91,18 @@ def convert_value_type(key, section, value, value_type):
class
Settings
(
object
):
"""
Simple wrapper around ConfigParser, with a key type conversion available.
"""
no_default
=
object
()
def
__init__
(
self
,
config_path
=
None
):
"""
Constructor. Tries to find the main settings file and load it.
:param config_path: Path to a config file. Useful for unittesting.
"""
self
.
config
=
ConfigParser
.
ConfigParser
()
self
.
intree
=
False
if
config_path
is
None
:
...
...
@@ -105,6 +126,17 @@ class Settings(object):
self
.
config
.
read
(
self
.
config_path
)
def
_handle_no_value
(
self
,
section
,
key
,
default
):
"""
What to do if key in section has no value.
:param section: Config file section.
:param key: Config file key, relative to section.
:param default: Default value for key, in case it does not exist.
:returns: Default value, if a default value was provided.
:raises: SettingsError, in case no default was provided.
"""
if
default
is
self
.
no_default
:
msg
=
(
"Value '%s' not found in section '%s'"
%
(
key
,
section
))
...
...
@@ -114,6 +146,21 @@ class Settings(object):
def
get_value
(
self
,
section
,
key
,
key_type
=
str
,
default
=
no_default
,
allow_blank
=
False
):
"""
Get value from key in a given config file section.
:param section: Config file section.
:param key: Config file key, relative to section.
:param key_type: Type of key.
It can be either of: str, int, float, bool, list
:param default: Default value for the key, if none found.
:param allow_blank: Whether an empty value for the key is allowed.
:returns: value, if one available in the config.
default value, if one provided.
:raises: SettingsError, in case no default was provided.
"""
try
:
val
=
self
.
config
.
get
(
section
,
key
)
except
ConfigParser
.
Error
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录