table of contents
| Catmandu::Fix::Bind::visitor(3pm) | User Contributed Perl Documentation | Catmandu::Fix::Bind::visitor(3pm) | 
NAME¶
Catmandu::Fix::Bind::visitor - a binder that computes Fix-es for every element in recordSYNOPSIS¶
 # If data is like:
 
   numbers:
      - one
      - two
      - three
   person:
      name: jennie
      age: 44
      color:
         - green
         - purple
         - brown
         - more:
            foo: bar
 do visitor()
    upcase(scalar)  # upcase every scalar value in the record
 end
 # will produce
   numbers:
      - ONE
      - TWO
      - THREE
   person:
      name: JENNIE
      age: 44
      color:
         - GREEN
         - PURPLE
         - BROWN
         - more:
            foo: BAR
  do visitor()
    # upcase all the 'name' fields in the record
    if all_match(key,name)
      upcase(scalar)
    end
  end
DESCRIPTION¶
The visitor binder will iterate over all the elements in a record and perform fixes on them.Special node names are available to process every visited element:
- scalar
- Process a Fix on every scalar value. E.g.
    
    upcase(scalar) replace_all(scalar,'$','tested')
- array
- Process a Fix on every array value. E.g.
    
    sort_field(array)Values need to be put in the 'array' field to be available for fixes. The scope of the array is limited to the array visited. 
- hash
- Process a Fix on every hash value. E.g.
    
    copy_field(hash.age,hash.age2)Values need to be put in the 'hash' field to be available for fixes. The scope of the hash is limited to the hash visited. 
- key
- Provides access to the key on which the scalar,array or hash value is
      found. Eg.
    
    # Upcase all 'name' fields in the record if all_match(key,name) upcase(scalar) end
CONFIGURATION¶
path¶
A path in the data to visit:  # Visit any field
  do visitor()
    ...
  end
  # Visit only the fields at my.deep.field
  do visitor(-path => my.deep.field )
    ...
  end
SEE ALSO¶
Catmandu::Fix::Bind| 2017-01-04 | perl v5.24.1 |