Harp is awesome. Only missing two things my workflow has grown accustomed to -- Compass and livereload. The former would be available eventually on top of libsass... The original sass
syntax could arrive perhaps sooner. All this because of the yet incomplete feature parity between the Ruby and Node versions of Sass. For now it simply makes more sense to compile styles with Ruby / Compass. It appears livereload will happen as well. I just couldn't wait for either.
Gulp automates the extra step of compiling to css and live-reloading any changes. Building sites for static deployment is another possible use. Have a look at its plugins for ideas.
Statica can also help with development of any web apps, beyond the static / Harp-served. The compass
and livereload
tasks would be just as applicable to any webdev workflow. As for the server
, given node
apps, Katon is simply fantastic.
Clone or fork the project and npm install
its node modules. Harp projects are served by default in multihost mode from a git-ignored harp
directory, any of which may of-course be git repositories themselves. The defaults coming from options.coffee
can be overridden with an options.json
. For example, to change the harp
projects directory to sites
create an options.json with contents of {"harp": {"path": "sites"}}
. It's where I actually keep my non-harp sites, so that directory is already git-ignored and watched by default.
Start the default tasks (harp server
, compass
and livereload
) using either npm run server
or after npm install -g gulp
just with the gulp
command.
Compass projects are identified through the presence of their config.rb
(or compass.rb
) files. Exact compass.config
paths can optionally be supplied. Configure what is watched and reloaded with livereload.watch
. It's the configuration value most likely to vary between projects. If a single minimatch glob pattern isn't good-enough, gulp can take an array of strings, possibly excluding paths too.
Override the gulp.default
to run extra tasks, skip compass
, etc.
If you need some custom tasks that aren't meant for sharing, make a tasks
directory and put the code in it. Using gulp-load which looks for ./tasks/*.js
. Here is an example test task:
module.exports = function(gulp) {
gulp.task("test", function() {
console.log("console-logged: 'test'");
});
};
Run it with gulp test
, add it to the gulp.default
, etc.
Happy gulp-harping!
This is free and unencumbered public domain software. For more information, see UNLICENSE.