ConfigData: overload GetBlockPath() with default value
This commit is contained in:
@@ -96,24 +96,37 @@ config_param::DupBlockString(const char *name, const char *default_value) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
Path
|
Path
|
||||||
config_param::GetBlockPath(const char *name, GError **error_r) const
|
config_param::GetBlockPath(const char *name, const char *default_value,
|
||||||
|
GError **error_r) const
|
||||||
{
|
{
|
||||||
assert(error_r != nullptr);
|
assert(error_r != nullptr);
|
||||||
assert(*error_r == nullptr);
|
assert(*error_r == nullptr);
|
||||||
|
|
||||||
const block_param *bp = GetBlockParam(name);
|
int line2 = line;
|
||||||
if (bp == nullptr)
|
const char *s;
|
||||||
return Path::Null();
|
|
||||||
|
|
||||||
Path path = ParsePath(bp->value.c_str(), error_r);
|
const block_param *bp = GetBlockParam(name);
|
||||||
|
if (bp != nullptr) {
|
||||||
|
line2 = bp->line;
|
||||||
|
s = bp->value.c_str();
|
||||||
|
} else
|
||||||
|
s = default_value;
|
||||||
|
|
||||||
|
Path path = ParsePath(s, error_r);
|
||||||
if (gcc_unlikely(path.IsNull()))
|
if (gcc_unlikely(path.IsNull()))
|
||||||
g_prefix_error(error_r,
|
g_prefix_error(error_r,
|
||||||
"Invalid path in \"%s\" at line %i: ",
|
"Invalid path in \"%s\" at line %i: ",
|
||||||
name, bp->line);
|
name, line2);
|
||||||
|
|
||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Path
|
||||||
|
config_param::GetBlockPath(const char *name, GError **error_r) const
|
||||||
|
{
|
||||||
|
return GetBlockPath(name, nullptr, error_r);
|
||||||
|
}
|
||||||
|
|
||||||
unsigned
|
unsigned
|
||||||
config_param::GetBlockValue(const char *name, unsigned default_value) const
|
config_param::GetBlockValue(const char *name, unsigned default_value) const
|
||||||
{
|
{
|
||||||
|
@@ -112,6 +112,9 @@ struct config_param {
|
|||||||
* Same as config_dup_path(), but looks up the setting in the
|
* Same as config_dup_path(), but looks up the setting in the
|
||||||
* specified block.
|
* specified block.
|
||||||
*/
|
*/
|
||||||
|
Path GetBlockPath(const char *name, const char *default_value,
|
||||||
|
GError **error_r) const;
|
||||||
|
|
||||||
Path GetBlockPath(const char *name, GError **error_r) const;
|
Path GetBlockPath(const char *name, GError **error_r) const;
|
||||||
|
|
||||||
gcc_pure
|
gcc_pure
|
||||||
|
Reference in New Issue
Block a user