Skip to content

Latest commit

 

History

History
59 lines (38 loc) · 2.18 KB

README.md

File metadata and controls

59 lines (38 loc) · 2.18 KB

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