Thanks, I'll try to work through your suggestions. I took this from the nova_config stuff on github, so that was my example.
David On Mon, Aug 22, 2011 at 7:36 PM, Stefan Schulte <stefan.schu...@taunusstein.net> wrote: > On Mon, Aug 22, 2011 at 06:33:27PM -0400, David Kavanagh wrote: >> I'm working on a type/provider for the eucalyptus.conf file. What I >> have generally works for modifying properties. I have a couple of >> issues and not being very experienced with Ruby and custom providers, >> I wonder if anyone can help? >> The code is included below. The key/value constructs in the file look like: >> >> key="value" >> >> 1. I'm not getting the quotes surrounding the value, which I think I >> can figure out myself. >> 2. I get all blanks and comments replaced by "=", which is more of a problem. >> >> David >> >> >> require 'puppet/provider/parsedfile' >> >> eucaconf = "/etc/eucalyptus/eucalyptus.conf" >> >> Puppet::Type.type(:eucalyptus_config).provide( >> :parsed, >> :parent => Puppet::Provider::ParsedFile, >> :default_target => eucaconf, >> :filetype => :flat >> ) do >> >> confine :exists => eucaconf >> text_line :comment, :match => /^#/; >> text_line :blank, :match => /^\s*$/; >> >> record_line :parsed, >> :fields => %w{line}, >> :match => /(.*)/ , >> :post_parse => proc { |hash| >> Puppet.debug("eucalyptus config line:#{hash[:line]} has been parsed") >> if hash[:line] =~ /^\s*(\S+)\s*=\s*(\S+)\s*$/ >> hash[:name]=$1 >> hash[:value]=$2 >> elsif hash[:line] =~ /^\s*(\S+)\s*$/ >> hash[:name]=$1 >> hash[:value]=false >> else >> raise Puppet::Error, "Invalid line: #{hash[:line]}" >> end >> } > > instead of the post_parse hook you can probably just change your regex > :fields => %w{name value}, > :optional => %w{value}, > :match => /^\s*(.*?)(?:\s*=\s*"(\S+)")?\s*$/ > > This matches line like > > foo > > and > > foo = "bar" > >> >> def self.to_line(hash) >> "#{hash[:name]}=#{hash[:value]}" >> end > > If you just overwrite the to_line method you have to take care of the > different record_types (you defined :comment, :text and :parsed). > So you have to do > > def self.to_line(hash) > return super unless hash[:record_type] == :parsed > if hash[:value] == :absent > hash[:name] > else > "#{hash[:name]}=\"#{hash[:value]}\"" > end > end > > Nevertheless the "right" thing to do is to pass a block to the > record_line method: > > record_line :parsed, > :fields => ..., > :match => ..., > :to_line => proc { |hash| > if hash[:value] == :absent > hash[:name] > else > "#{hash[:name]}=\"#{hash[:value]}\"" > end > } > > Hope that helps. > > -Stefan > -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To post to this group, send email to puppet-users@googlegroups.com. To unsubscribe from this group, send email to puppet-users+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/puppet-users?hl=en.