Module: Card::Set::Loader

Included in:
Card::Set
Defined in:
lib/card/set/loader.rb

Overview

  1. Definition: interpret each set file, creating/defining set and set_format modules
    1. Organization: have base classes include modules associated with the 'all' set, and clean up the other modules

Instance Method Summary collapse

Instance Method Details

#clean_empty_module_from_hash(hash) ⇒ Object



90
91
92
93
94
95
# File 'lib/card/set/loader.rb', line 90

def clean_empty_module_from_hash hash
  hash.each do |mod_name, modlist|
    modlist.delete_if { |x| x.instance_methods.empty? }
    hash.delete mod_name if modlist.empty?
  end
end

#clean_empty_modulesObject



83
84
85
86
87
88
# File 'lib/card/set/loader.rb', line 83

def clean_empty_modules
  clean_empty_module_from_hash modules[:nonbase]
  modules[:nonbase_format].values.each do |hash|
    clean_empty_module_from_hash hash
  end
end

#extended(mod) ⇒ Object

each set file calls extend Card::Set when loaded



16
17
18
# File 'lib/card/set/loader.rb', line 16

def extended mod
  register_set mod
end

#pattern_and_modules_from_path(path) ⇒ Object



46
47
48
49
50
51
52
# File 'lib/card/set/loader.rb', line 46

def pattern_and_modules_from_path path
  # remove file extension and number prefixes
  parts = path.gsub(/\.rb/, "").gsub(%r{(?<=\A|/)\d+_}, "")
              .split(File::SEPARATOR)
  parts.map! &:camelize
  [parts.shift, parts]
end

#process_base_modulesObject

'base modules' are modules that are permanently included on the Card or Format class 'nonbase modules' are included dynamically on singleton_classes



73
74
75
76
77
78
79
80
81
# File 'lib/card/set/loader.rb', line 73

def process_base_modules
  return unless modules[:base]
  Card.add_set_modules modules[:base]
  modules[:base_format].each do |format_class, modules_list|
    format_class.add_set_modules modules_list
  end
  modules.delete :base
  modules.delete :base_format
end

#register_set(set_module) ⇒ Object

make the set available for use



21
22
23
24
25
26
27
28
29
30
31
# File 'lib/card/set/loader.rb', line 21

def register_set set_module
  if set_module.all_set?
    # automatically included in Card class
    modules[:base] << set_module
  else
    set_type = set_module.abstract_set? ? :abstract : :nonbase
    # made ready for dynamic loading via #include_set_modules
    modules[set_type][set_module.shortname] ||= []
    modules[set_type][set_module.shortname] << set_module
  end
end

#tmp_file_template(pattern, modules, content_path) ⇒ Object



54
55
56
57
58
59
60
61
62
63
64
65
# File 'lib/card/set/loader.rb', line 54

def tmp_file_template pattern, modules, content_path
  submodules = modules.map { |m| "module #{m};" }
<<-RUBY
# -*- encoding : utf-8 -*-
class Card; module Set; class #{pattern}; #{submodules * ' '} extend Card::Set
# ~~ above autogenerated; below pulled from #{content_path} ~~
#{File.read content_path}

# ~~ below autogenerated; above pulled from #{content_path} ~~
end;end;end;#{'end;' * submodules.size}
RUBY
end

#write_tmp_file(from_file, to_file, rel_path) ⇒ Object



39
40
41
42
43
44
# File 'lib/card/set/loader.rb', line 39

def write_tmp_file from_file, to_file, rel_path
  pattern, submodules = pattern_and_modules_from_path rel_path
  FileUtils.mkdir_p File.dirname(to_file)
  File.write to_file, tmp_file_template(pattern, submodules, from_file)
  to_file
end