grep
Table of contents
Prototype: grep(regex, list)
Return type: slist
Description: Returns the sub-list if items in list
matching the
anchored regular expression regex
.
This function can accept many types of data parameters.
Arguments:
regex
: regular expression - Regular expression - in the range:.*
list
:string
- CFEngine variable identifier or inline JSON - in the range:.*
Example:
code
body common control
{
bundlesequence => { "test" };
}
bundle agent test
{
vars:
"mylist" slist => { "One", "Two", "Three", "Four", "Five" };
"Tlist" slist => grep("T.*","mylist");
"empty_list" slist => grep("ive","mylist");
"datalist" data => parsejson('[1,2,3, "Tab", "chive"]');
"data_Tlist" slist => grep("T.*","datalist");
"data_empty_list" slist => grep("ive","datalist");
"todo" slist => { "mylist", "Tlist", "empty_list", "datalist", "data_Tlist", "data_empty_list" };
"$(todo)_str" string => format("%S", $(todo));
reports:
"$(todo): $($(todo)_str)";
}
Output:
code
R: mylist: { "One", "Two", "Three", "Four", "Five" }
R: Tlist: { "Two", "Three" }
R: empty_list: { }
R: datalist: [1,2,3,"Tab","chive"]
R: data_Tlist: { "Tab" }
R: data_empty_list: { }
History: The collecting function behavior was added in 3.9.
See also: About collecting functions, filter()
, every()
, some()
, and none()
.