node package manager

Introducing npm Enterprise add-ons. Integrate third-party dev tools into npm…


Compile Haml to HTML with Ruby Haml


This is a gulp plugin that will use the haml command line script to compile your Haml files into HTML. You need both Ruby and Haml installed to use this. Try gem install haml. If you use Bundler, add gem 'haml' to your Gemfile and run bundle install.

Specify where the haml executable is. Defaults to just haml if not provided. {hamlPath: '/path/to/haml'}

Output style. Can be indented (default) or ugly. {style: ugly}

Output format. Can be html5 (default), xhtml, or html4. {format: "xhtml"}

Require additional ruby files. Same as 'ruby -r'. {require: ["./my_haml_helpers.rb"]}

Escape HTML characters (like ampersands and angle brackets) by default. {escapeHtml: true}

Don't escape HTML characters (like ampersands and angle brackets) in attributes. {noEscapeAttrs: true}

Set attribute wrapper to double-quotes (default is single). {doubleQuote: true}

Show a full traceback on error {trace: true}

Use Unix-style newlines in written files. {unixNewlines: true}

Always add CDATA sections to javascript and css blocks. {cdata: true}

List of elements to be automatically self-closed. {autoclose: ["img", "input", "br", ...]}

specify $LOAD_PATH directory (may be used more than once). Same as 'ruby -I'. {loadPath: "my/load/path"}

Use the encodings option to specify encodings, e.g., {encodings: "UTF-8"}.

var gulp = require('gulp');
var watch = require('gulp-watch');
var haml = require('gulp-ruby-haml');

// Compile Haml into HTML
gulp.task('haml', function() {
  gulp.src('./app/assets/haml/**/*.haml', {read: false}).
       pipe(haml().on('error', function(e) { console.log(e.message); })).

// Compile Haml into HTML with double quotes around attributes
// Same as haml -q
gulp.task('haml-double-quote', function() {
  gulp.src('./app/assets/haml/**/*.haml', {read: false}).
       pipe(haml({doubleQuote: true})).

// Pipe Haml output from one command into another without writing the
// Haml to file first
     pipe(replace('albert', 'dilbert')).

// Require an additional Ruby file for compilation
     pipe(haml({require: ["./path/to/my_ruby_script.rb"]})).

// Watch for changes in Haml files
gulp.task('haml-watch', function() {
  gulp.src('./app/assets/haml/**/*.haml', {read: false}).
npm install
npm test

This largely came from gulp-ruby-sass by Sindre Sorhus.