Top Level Namespace
- Includes:
- Config, RbConfig
Defined Under Namespace
Classes: GemHadar
Instance Method Summary collapse
-
#GemHadar(&block) ⇒ GemHadar
The GemHadar method serves as the primary entry point for configuring and initializing a gem project using the GemHadar framework.
-
#template(pathname) {|block| ... } ⇒ Pathname
The template method processes an ERB template file and creates a Rake task for its compilation.
Instance Method Details
#GemHadar(&block) ⇒ GemHadar
The GemHadar method serves as the primary entry point for configuring and initializing a gem project using the GemHadar framework.
This method creates a new instance of the GemHadar class, passes the provided block to configure the gem settings, and then invokes the create_all_tasks method to set up all the necessary Rake tasks for the project.
2008 2009 2010 |
# File 'lib/gem_hadar.rb', line 2008 def GemHadar(&block) GemHadar.new(&block).create_all_tasks end |
#template(pathname) {|block| ... } ⇒ Pathname
The template method processes an ERB template file and creates a Rake task for its compilation.
This method takes a template file path, removes its extension to determine the output file name, and sets up a Rake file task that compiles the template using the provided block configuration. It ensures the source file has an extension and raises an error if not.
2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 |
# File 'lib/gem_hadar.rb', line 2025 def template(pathname, &block) template_src = Pathname.new(pathname) template_dst = template_src.sub_ext('') # ignore ext, we just support erb anyway template_src == template_dst and raise ArgumentError, "pathname #{pathname.inspect} needs to have a file extension" file template_dst.to_s => template_src.to_s do GemHadar::TemplateCompiler.new(&block).compile(template_src, template_dst) end template_dst end |