Skip to content

Blerg is designed to take the headache out of boilerplate code. Just write up an eRB template for the boilerplate and pass variables into it on the command line.

License

Notifications You must be signed in to change notification settings

patgannon/blerg

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Blerg

Blerg is designed to take the headache out of boilerplate code. Just write up an ERB template for the boilerplate and pass variables into it on the command line.

Using

Blerg can be used directly from from the command line, or can be invoked by your own ruby scripts. The first step is to install the gem:

gem install blerg

Command line

Create an ERB template file for the boilerplate you'd like to generate, like the following:

class <%= @foo %> {
  public int id;
  public String name;

  public <% @foo %>(int id, String name) {
    this.id = id;
    this.name = name;
  }
}

Now run the blerg against your template, specifying the value you'd like to use for @foo (where mytemplate.erb is the file you created above)

blerg mytemplate.erb foo Bar

Blerg will execute the template, using the value "Bar" for the @foo variable (command-line variables are specified as sequences of key value pairs, like: key1 value1 key2 value2, etc.), and you would get the following

class Bar {
  public int id;
  public String name;

  public Bar(int id, String name) {
    this.id = id;
    this.name = name;
  }
}

In your ruby script

You can also invoke Blerg in your own ruby scripts, as in the following examples:

require 'rubygems'
require 'blerg'

generator = Blerg::Generator.new(:name => "Pat")
outputs = generator.generate(["Hello, my name is <%= @name %>"])

Calling Blerg in this way provides a bit more flexibility. You can invoke multiple templates using the same set of variables, and your templates don't need to be defined in a file.

Advanced Usage

Blerg depends on ActiveSupport, so you can use inflection methods like camelcase and underscore to handle common differences between naming conventions in DBs and those in programming languages, eg <%= @foo.underscore %>. For a list of all these methods, see: http://as.rubyonrails.org/classes/ActiveSupport/CoreExtensions/String/Inflections.html

In ERB you can define variables, or even methods to make your templates as sophisticated as you'd like. You can read more about ERB here: http://www.ruby-doc.org/stdlib-1.9.3/libdoc/erb/rdoc/ERB.html

About

Blerg is designed to take the headache out of boilerplate code. Just write up an eRB template for the boilerplate and pass variables into it on the command line.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages