File: edit_xml.cf

package info (click to toggle)
cfengine3 3.24.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 37,552 kB
  • sloc: ansic: 163,161; sh: 10,296; python: 2,950; makefile: 1,744; lex: 784; yacc: 633; perl: 211; pascal: 157; xml: 21; sed: 13
file content (85 lines) | stat: -rw-r--r-- 1,910 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# edit_xml bundles

bundle edit_xml xml_insert_tree_nopath(treestring)
# @brief Insert XML tree with no path
#
# This `edit_xml` bundle inserts the given XML tree.  Use with an
# empty XML document.
#
# @param treestring The XML tree, as a string
#
# **Example:**
#
# ```cf3
#  files:
#      "/newfile" edit_xml => xml_insert_tree_nopath('<x>y</x>');
# ```
{
  insert_tree:
      '$(treestring)';
}

bundle edit_xml xml_insert_tree(treestring, xpath)
# @brief Insert XML tree at the given XPath
#
# This `edit_xml` bundle inserts the given XML tree at a specific
# XPath.  Uses `insert_tree`.
#
# @param treestring The XML tree, as a string
# @param xpath A valid XPath string
#
# **Example:**
#
# ```cf3
#  files:
#      "/file.xml" edit_xml => xml_insert_tree('<x>y</x>', '/a/b/c');
# ```
{
  insert_tree:
      '$(treestring)' select_xpath => "$(xpath)";
}

bundle edit_xml xml_set_value(value, xpath)
# @brief Sets or replaces a value in XML at the given XPath
#
# This `edit_xml` bundle sets or replaces the value at a specific
# XPath with the given value.  Uses `set_text`.
#
# @param value The new value
# @param xpath A valid XPath string
#
# **Example:**
#
# ```cf3
#  files:
#      "/file.xml" edit_xml => xml_set_value('hello', '/a/b/c');
# ```
{
  set_text:
      "$(value)"
      select_xpath => "$(xpath)";
}

bundle edit_xml xml_set_attribute(attr, value, xpath)
# @brief Sets or replaces an attribute in XML at the given XPath
#
# This `edit_xml` bundle sets or replaces an attribute at a specific
# XPath with the given value.  Uses `set_attribute`.
#
# @param attr The attribute name
# @param value The new attribute value
# @param xpath A valid XPath string
#
# **Example:**
#
# ```cf3
#  files:
#      "/file.xml" edit_xml => xml_set_attribute('parameter', 'ha', '/a/b/c');
# ```
{
  set_attribute:
      "$(attr)"
      attribute_value => "$(value)",
      select_xpath => "$(xpath)";

}