diff options
author | David Schmitt <david.schmitt@puppetlabs.com> | 2015-09-02 09:23:46 +0100 |
---|---|---|
committer | David Schmitt <david.schmitt@puppetlabs.com> | 2015-09-02 09:23:46 +0100 |
commit | 64267eb6508bd910cb368bcaa00d7411458b0c44 (patch) | |
tree | 527e95a90e9cc026cae8ec2ff2f3e90513e51578 /README.markdown | |
parent | 9352db77a6d265f1a49ab6b4d0f9e1df2ed2b007 (diff) | |
parent | 823a352f0f47d4481844bb6b6a6c00224ed556b8 (diff) |
Merge pull request #513 from dmitryilyin/fetch
Add a new function "try_get_value"
Diffstat (limited to 'README.markdown')
-rw-r--r-- | README.markdown | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/README.markdown b/README.markdown index ccbceab..a880222 100644 --- a/README.markdown +++ b/README.markdown @@ -702,6 +702,40 @@ Returns the current Unix epoch time as an integer. For example, `time()` returns Converts the argument into bytes, for example "4 kB" becomes "4096". Takes a single string value as an argument. *Type*: rvalue. +#### `try_get_value` + +*Type*: rvalue. + +Looks up into a complex structure of arrays and hashes and returns a value +or the default value if nothing was found. + +Key can contain slashes to describe path components. The function will go down +the structure and try to extract the required value. + +$data = { + 'a' => { + 'b' => [ + 'b1', + 'b2', + 'b3', + ] + } +} + +$value = try_get_value($data, 'a/b/2', 'not_found', '/') +=> $value = 'b3' + +a -> first hash key +b -> second hash key +2 -> array index starting with 0 + +not_found -> (optional) will be returned if there is no value or the path did not match. Defaults to nil. +/ -> (optional) path delimiter. Defaults to '/'. + +In addition to the required "key" argument, "try_get_value" accepts default +argument. It will be returned if no value was found or a path component is +missing. And the fourth argument can set a variable path separator. + #### `type3x` Returns a string description of the type when passed a value. Type can be a string, array, hash, float, integer, or boolean. This function will be removed when Puppet 3 support is dropped and the new type system can be used. *Type*: rvalue. |