obsolete.ChilliProject/lib/chili_project/liquid/variables.rb

62 lines
1.8 KiB
Ruby
Raw Normal View History

2011-12-19 00:19:01 +04:00
#-- encoding: UTF-8
2011-12-18 03:50:52 +04:00
#-- copyright
# ChiliProject is a project management system.
#
2012-01-18 22:25:13 +04:00
# Copyright (C) 2010-2012 the ChiliProject Team
2011-12-18 03:50:52 +04:00
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
module ChiliProject
module Liquid
module Variables
2011-12-26 16:12:05 +04:00
class LazyVariable
def initialize(context, &block)
@block = block
@context = context
end
def to_liquid()
(@block.arity == 0) ? @block.call : @block.call(@context)
end
end
# Register a Liquid variable.
# Pass a value to register a fixed variable or a block to create a lazy
# evaluated variable. The block can take the current context
def self.register(name, value=nil, &block)
var = block_given? ? Proc.new(){|ctx| LazyVariable.new(ctx, &block)} : value
all[name.to_s] = var
end
2011-12-26 16:12:05 +04:00
def self.all
@variables ||= {}
end
register "tags" do
::Liquid::Template.tags.keys.sort
end
register "variables" do |context|
vars = []
vars = context.environments.first.keys.reject do |var|
# internal variable
var == "text"
end if context.environments.present?
vars += context.scopes.collect(&:keys).flatten
vars.uniq.sort
end
2011-12-26 16:12:05 +04:00
# DEPRACATED: This is just a hint on how to use Liquid introspection
register "macro_list",
"Use '{{ variables | to_list: \"Variables:\" }}' to see all Liquid variables and '{{ tags | to_list: \"Tags:\" }}' to see all of the Liquid tags."
end
end
end