Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Setting up rake-pipeline for use with handlebars alongside Google App Engine

So here's what I'm attempting to do. I'm building an ember.js application, with a java backend running on GAE.

I'm using handlebars, but I want them divided up into separate files, not just all pasted into the index.html.

Via the ember.js irc I was turned on to rake-pipeline along with minispade

Along with the web filters and a custom handlebars filter I started building the assetfile. I don't know Ruby, or gem files, etc.

So I'm trying to figure out the best way to be able to compile my coffeescript/handlebars files on the fly, minispade them, but keep the individual files accessible while in dev mode so I can debug them. What makes that hard is that the rake pipeline is running on a different port than GAE. So I'm not sure exactly how to handle this. Do I make my index file in GAE point to individual files at the 9292 port (rakep) during development, but in production mode point to the fully concatenated version? I'm not sure.

So I was attempting to do that here: https://gist.github.com/1495740 by having only one section that was triggered by the 'build' flag. Not even sure if that works that way.

I know there's a lot of confusion here. Apologies, like I said I'm not even remotely familiar with the Ruby style of doing things.

like image 928
Bob Spryn Avatar asked Dec 19 '11 06:12

Bob Spryn


2 Answers

Since you're not a Ruby person, here are the most reliable steps for getting a stock OSX environment set up with rake pipeline:

Step 1: Install bundler

# on OSX, using built-in Ruby
$ sudo gem install bundler --pre

Step 2: Create a Gemfile

# inside your app directory
$ bundle init

# will create a file named Gemfile in the root

Step 3: Add rake-pipeline to the Gemfile

# inside the Gemfile
gem "rake-pipeline-web-filters"

Step 4: Install your gems

$ bundle install --binstubs

Step 5: Set up Assetfile

However you were already doing it...

Step 6: Run Rake::Pipeline

# to run the preview server
$ bin/rakep

# to build your assets
$ bin/rakep build
like image 60
Yehuda Katz Avatar answered Oct 23 '22 13:10

Yehuda Katz


Rake::Pipeline.build is the method that evaluates an Assetfile. You can imagine that your entire Assetfile is wrapped inside a Rake::Pipeline.build {} block; you shouldn't ever need to write one inside an Assetfile.

Some of the filters in the docs are hypothetical, most of those docs were written before there were any filters at all. A CoffeeScript compiler has been recently added, though.

As to your main question, I'm not sure there's a clean way to do it with the current rakep implementation. An Assetfile is just Ruby, though, so it's possible to hack something together that should work. Here's how I would write yours:

require "json"
require "rake-pipeline-web-filters"
require "rake-pipeline-web-filters/helpers"

class HandlebarsFilter < Rake::Pipeline::Filter
  def initialize(&block)
    block ||= proc { |input| input.sub(/\.handlebars$/, '.js') }
    super(&block)
  end

  def generate_output(inputs, output)
    inputs.each do |input|
      output.write "return Ember.Handlebars.compile(#{input.read.to_json})"
    end
  end
end

# process all js, css and html files in app/assets
input "assets"

# processed files should be outputted to public
output "public"

# process all coffee files
match "**/*.coffee" do
  # compile all CoffeeScript files. the output file
  # for the compilation should be the input name
  # with the .coffee extension replaced with .js
  coffee_script

  # The coffee_script helper is exactly equivalent to:
  # filter Rake::Pipeline::Web::Filters::CoffeeScriptCompiler
end

match "**/*.js" do
  minispade
  if ENV['RAKEP_ENV'] == "production"
    concat "application.js"
  else
    concat
  end
end

match "**/*.handlebars" do
  filter HandlebarsFilter
  minispade
  concat "templates.js"
end

The if ENV['RAKEP_ENV'] bit reads an environment variable to decide whether to concatenate your JS to a single file.

So now you can run RAKEP_ENV="production" rakep build for a concatenated build, or just rakep build for a development build.

like image 37
dudleyf Avatar answered Oct 23 '22 14:10

dudleyf