class Viperaptor::ContentGenerator
Responsible for generating code using provided liquid templates
Public Class Methods
create_file(file, scope, template)
click to toggle source
Generates and returns a filename and a body of a specific code file. @param file [Hash<String,String>] A hashmap with template's filename and filepath @param scope [Hash<String,String>] A hashmap with module info @param template [ModuleTemplate] The model describing a Viperaptor
template used for code generation @param variables [Hash<String,String>] Custom variables of template
@return [String], [String] The generated file_name and body
# File lib/viperaptor/code_generation/content_generator.rb, line 15 def self.create_file(file, scope, template) custom_parameters = template.custom_parameters || {} scope['custom_parameters'] = (scope['custom_parameters'] || {}).merge(custom_parameters) file_source = IO.read(template.template_path.join(file[TEMPLATE_FILE_PATH_KEY])) Liquid::Template.file_system = Liquid::LocalFileSystem.new(template.template_path.join('snippets'), '%s.liquid') template = Liquid::Template.parse(file_source) filename_template = self.file_name_template(file) file_basename = File.basename(file[TEMPLATE_FILE_NAME_KEY]) module_info = scope['module_info'] module_info['file_basename'] = file_basename file_name = filename_template.render(scope) module_info['file_name'] = file_name module_info.delete('file_basename') content = template.render(scope) return file_name, content end
file_name_template(file)
click to toggle source
# File lib/viperaptor/code_generation/content_generator.rb, line 42 def self.file_name_template(file) template_default_text = '{{ prefix }}{{ module_info.name }}{{ module_info.file_basename }}' template_text = file[TEMPLATE_FILE_CUSTOM_NAME_KEY] || template_default_text return Liquid::Template.parse(template_text) end