Sha256: f69e08a27e26b2e109bcb21dc8e38154b7997b63b43f123571c343c1e468db71
Contents?: true
Size: 1.93 KB
Versions: 1
Compression:
Stored size: 1.93 KB
Contents
# FolderTemplate [data:image/s3,"s3://crabby-images/cc844/cc84447d84f4aa6db1c8cccee38bc66214d16d86" alt="Gem Version"](http://badge.fury.io/rb/rr) [data:image/s3,"s3://crabby-images/d5d0d/d5d0d3213197c186cf63a493b09cef0656a489a9" alt="Build Status"](https://travis-ci.org/rr/rr) [data:image/s3,"s3://crabby-images/edf25/edf254bef51fac37b670f52ea0af604ea89b47f2" alt="Code Climate GPA"](https://codeclimate.com/github/rr/rr) FolderTemplate is a minimalistic template engine that generates files and folders structure from a template folder layout. It includes a simple variable expansion syntax, automatically injects variables for filename and basename, and can optionally append content to existing files. ## Template definitions - Templates are defined as files and folders on disk - Variables are surrounded with double curly: `{{variable}}` - Variables can be part of filenames, folder names, and file content - Template filename with a `>>` prefix will append their content to an existing file ## Usage ```ruby require 'folder_template' template = FolderTemplate::TemplateFolder.new( template_path ) fs = FolderTemplate::FsAdapter.new( output_path, opts... ) env = Hash.new.merge( project_name:"my_project", ... ) template.generate( fs, env ) ``` ## FsAdapter All filesystem operation are abstracted through an `FsAdapter` object that performs final filename expansion, and execute all filesystem manipulations. The `FsAdapter` interface is composed of 3 methods; any class implementing those 3 methods can be used in place of the default `FsAdapter` object to perform the necessary filesystem operations. ```ruby def makedirs( dirname ) def write_to_file( filename, content ) def append_to_file( filename, content ) ``` Default implementation of `FsAdapter` accepts a few options: | Option | Default | Description | | ------------------ |---------|-----------------------| | `verbose` | `false` | When `true`, log each operation that is performed | | `overwrite_files` | `false` | When `true`, replace existing files with content generated from template |
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
folder_template-0.1.1 | README.md |