public
Rubygem
Description: Liquid markup language. Save, customer facing template language for flexible web apps.
Homepage: http://www.liquidmarkup.org
Clone URL: git://github.com/tobi/liquid.git
Search Repo:
Click here to lend your support to: liquid and make a donation at www.pledgie.com !
stefanoc (author)
Wed Jun 04 08:22:47 -0700 2008
commit  82e5e8c188523336b1d5e58dd8a4153a0d5a0f05
tree    eaa46732d0a0c9a0a9727430d9f58ef831624b9b
parent  3ef9d2f4f94eb83c0f45489c75a3518bb91b4cea
liquid /
name age message
folder CHANGELOG Thu May 08 08:34:43 -0700 2008 Merged last set of changes from original SVN lo... [Tobias Lütke]
folder History.txt Thu May 08 08:34:43 -0700 2008 Merged last set of changes from original SVN lo... [Tobias Lütke]
folder MIT-LICENSE Thu May 08 08:28:13 -0700 2008 Initial github import of liquid [Tobias Lütke]
folder Manifest.txt Thu May 08 08:34:43 -0700 2008 Merged last set of changes from original SVN lo... [Tobias Lütke]
folder README.txt Thu May 08 08:34:43 -0700 2008 Merged last set of changes from original SVN lo... [Tobias Lütke]
folder Rakefile Thu May 08 08:34:43 -0700 2008 Merged last set of changes from original SVN lo... [Tobias Lütke]
folder example/ Thu May 08 08:28:13 -0700 2008 Initial github import of liquid [Tobias Lütke]
folder init.rb Thu May 08 08:28:13 -0700 2008 Initial github import of liquid [Tobias Lütke]
folder lib/ Wed Jun 04 08:22:47 -0700 2008 Ugly hack for compatibility with Rails 2.1, tak... [stefanoc]
folder test/ Wed May 21 20:58:12 -0700 2008 The if tag now raises Liquid::SyntaxError rathe... [nbibler]
README.txt
= Liquid template engine

Liquid is a template engine which I wrote for very specific requirements

* It has to have beautiful and simple markup. 
  Template engines which don't produce good looking markup are no fun to use. 
* It needs to be non evaling and secure. Liquid templates are made so that users can edit them. You don't want to run 
code on your server which your users wrote. 
* It has to be stateless. Compile and render steps have to be seperate so that the expensive parsing and compiling can 
be done once and later on you can 
  just render it   passing in a hash with local variables and objects.

== Why should i use Liquid

* You want to allow your users to edit the appearance of your application but don't want them to run insecure code on 
your server.
* You want to render templates directly from the database
* You like smarty style template engines 
* You need a template engine which does HTML just as well as Emails
* You don't like the markup of your current one

== What does it look like?

  <ul id="products">  
    {% for product in products %}
      <li>
        <h2>{{product.name}}</h2>
        Only {{product.price | price }}
  
        {{product.description | prettyprint | paragraph }}
       </li>      
    {% endfor %}  
  </ul>

== Howto use Liquid

Liquid supports a very simple API based around the Liquid::Template class.
For standard use you can just pass it the content of a file and call render with a parameters hash. 

  @template = Liquid::Template.parse("hi {{name}}") # Parses and compiles the template
  @template.render( 'name' => 'tobi' )              # => "hi tobi"