Commit 1c823e9d authored by Max Kellermann's avatar Max Kellermann

ConfigData: overload GetBlockPath() with default value

parent 25e338a0
...@@ -96,24 +96,37 @@ config_param::DupBlockString(const char *name, const char *default_value) const ...@@ -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);
int line2 = line;
const char *s;
const block_param *bp = GetBlockParam(name); const block_param *bp = GetBlockParam(name);
if (bp == nullptr) if (bp != nullptr) {
return Path::Null(); line2 = bp->line;
s = bp->value.c_str();
} else
s = default_value;
Path path = ParsePath(bp->value.c_str(), error_r); 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 { ...@@ -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
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment