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
|
# File 'lib/csv2plist/cli.rb', line 5
def self.execute(stdout, arguments=[])
options = {
:outputfile => nil
}
mandatory_options = %w( )
parser = OptionParser.new do |opts|
opts.banner = <<-BANNER.gsub(/^ /,'')
csv2plist converts a comma-separated variable (CSV) file to a property
list (PLIST) xml file structured as an array of dictionary elements. Each
dictionary will have a mapping from the column heading to the value on
the corresponding row.
Usage: #{File.basename($0)} [options] <csvfile>
Options are:
BANNER
opts.separator ""
opts.on("-o", "--output PATH", String,
"Specify the output file.",
"Default: source file, with .plist extension") { |arg| options[:outputfile] = arg }
opts.on("-h", "--help",
"Show this help message.") { stdout.puts opts; exit }
opts.parse!(arguments)
if arguments.empty? || mandatory_options && mandatory_options.find { |option| options[option.to_sym].nil? }
stdout.puts opts;
exit
end
end
srcfile = arguments[0]
outputfile = options[:outputfile] || srcfile.gsub(/.csv/i, ".plist")
outputfile = outputfile + ".plist" if outputfile == srcfile
Csv2plist.convert(srcfile, outputfile)
end
|