2007-11-21 22:08:34 +01:00
|
|
|
require 'yaml'
|
2007-11-21 01:13:18 +01:00
|
|
|
|
2007-11-21 22:08:34 +01:00
|
|
|
module_name = 'TestModule'
|
|
|
|
|
|
|
|
# Load the data files
|
|
|
|
files = ['data/ca.yaml']
|
|
|
|
regions = [] #wtf
|
2007-11-21 02:03:20 +01:00
|
|
|
rules_by_month = {}
|
2007-11-21 22:08:34 +01:00
|
|
|
custom_methods = {}
|
|
|
|
|
2007-11-21 02:03:20 +01:00
|
|
|
files.each do |file|
|
2007-11-21 22:08:34 +01:00
|
|
|
def_file = YAML.load_file(file)
|
|
|
|
def_file['months'].each do |month, definitions|
|
|
|
|
rules_by_month[month] = []
|
|
|
|
definitions.each do |definition|
|
|
|
|
rule = {}
|
|
|
|
definition.each do |key, val|
|
|
|
|
rule[key] = val
|
|
|
|
end
|
|
|
|
regions = rule['regions'].collect { |r| r.to_sym }
|
|
|
|
rule['regions'] = regions
|
2007-11-21 01:13:18 +01:00
|
|
|
|
2007-11-21 22:08:34 +01:00
|
|
|
existed = false
|
|
|
|
# rules_by_month[month].each do |ex|
|
|
|
|
# if ex['name'] == rule['name'] and ex['wday'] == rule['wday'] and ex['mday'] == rule['mday'] and ex['week'] == rule['week']
|
|
|
|
# ex['regions'] << rule['regions'].flatten
|
|
|
|
# existed = true
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
unless existed
|
|
|
|
rules_by_month[month] << rule
|
2007-11-21 02:03:20 +01:00
|
|
|
end
|
2007-11-21 01:13:18 +01:00
|
|
|
|
2007-11-21 22:08:34 +01:00
|
|
|
end # /defs.each
|
|
|
|
|
|
|
|
def_file['methods'].each do |name, code|
|
|
|
|
custom_methods[name] = code
|
|
|
|
end # /methods.each
|
2007-11-21 01:13:18 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
2007-11-21 22:08:34 +01:00
|
|
|
# Build the definitions
|
2007-11-21 01:13:18 +01:00
|
|
|
month_strs = []
|
|
|
|
rules_by_month.each do |month, rules|
|
2007-11-21 22:08:34 +01:00
|
|
|
month_str = " #{month.to_s} => ["
|
2007-11-21 01:13:18 +01:00
|
|
|
rule_strings = []
|
|
|
|
rules.each do |rule|
|
|
|
|
str = '{'
|
|
|
|
if rule['mday']
|
|
|
|
str << ":mday => #{rule['mday']}, "
|
2007-11-21 02:03:20 +01:00
|
|
|
elsif rule['function']
|
|
|
|
str << ":function => #{rule['function']}, "
|
2007-11-21 01:13:18 +01:00
|
|
|
else
|
|
|
|
str << ":wday => #{rule['wday']}, :week => #{rule['week']}, "
|
|
|
|
end
|
|
|
|
|
2007-11-21 02:03:20 +01:00
|
|
|
# shouldn't allow the same region twice
|
|
|
|
str << ":name => \"#{rule['name']}\", :regions => [:" + rule['regions'].uniq.join(', :') + "]}"
|
2007-11-21 01:13:18 +01:00
|
|
|
rule_strings << str
|
|
|
|
end
|
2007-11-21 22:08:34 +01:00
|
|
|
month_str << rule_strings.join(",\n ") + "]"
|
2007-11-21 01:13:18 +01:00
|
|
|
month_strs << month_str
|
|
|
|
end
|
|
|
|
|
|
|
|
month_strs.join(",\n")
|
|
|
|
|
2007-11-21 22:08:34 +01:00
|
|
|
|
|
|
|
# Build the methods
|
|
|
|
method_str = ''
|
|
|
|
custom_methods.each do |key, code|
|
|
|
|
method_str << code + "\n\n"
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
# Build the output file
|
|
|
|
out =<<-EOC
|
|
|
|
# This file is generated by the Ruby Holiday gem.
|
|
|
|
#
|
|
|
|
# To use the definitions in the file, load them right after you load the
|
|
|
|
# Holiday gem:
|
|
|
|
#
|
|
|
|
# require 'holidays'
|
|
|
|
# require 'path/to/#{module_name.downcase}'
|
|
|
|
#
|
|
|
|
# More definitions are available at http://code.dunae.ca/holidays.
|
|
|
|
#
|
|
|
|
# Definitions loaded: #{files.join(',')}
|
|
|
|
module Holidays
|
|
|
|
module #{module_name}
|
|
|
|
DEFINED_REGIONS = [:#{regions.join(', :')}]
|
|
|
|
|
|
|
|
HOLIDAYS_BY_MONTH = {
|
|
|
|
#{month_strs.join(",\n")}
|
|
|
|
}
|
|
|
|
|
|
|
|
#{method_str}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Holidays.class_eval do
|
|
|
|
new_regions = []
|
|
|
|
if const_defined?(:DEFINED_REGIONS)
|
|
|
|
new_regions = const_get(:DEFINED_REGIONS)
|
|
|
|
remove_const(:DEFINED_REGIONS)
|
|
|
|
end
|
|
|
|
const_set(:DEFINED_REGIONS, new_regions | Holidays::#{module_name}::DEFINED_REGIONS)
|
|
|
|
|
|
|
|
include Holidays::MixinModule
|
|
|
|
end
|
|
|
|
EOC
|
2007-11-21 01:13:18 +01:00
|
|
|
|
|
|
|
File.open("test_file.rb","w") do |file|
|
|
|
|
file.puts out
|
|
|
|
end
|