Holger Just 0c87f611e9 Merge branch 'master' into unstable
Conflicts:
	config/locales/bg.yml
	config/locales/bs.yml
	config/locales/ca.yml
	config/locales/cs.yml
	config/locales/da.yml
	config/locales/de.yml
	config/locales/el.yml
	config/locales/en-GB.yml
	config/locales/es.yml
	config/locales/eu.yml
	config/locales/fa.yml
	config/locales/fi.yml
	config/locales/fr.yml
	config/locales/gl.yml
	config/locales/he.yml
	config/locales/hr.yml
	config/locales/hu.yml
	config/locales/id.yml
	config/locales/it.yml
	config/locales/ja.yml
	config/locales/ko.yml
	config/locales/lt.yml
	config/locales/lv.yml
	config/locales/mk.yml
	config/locales/mn.yml
	config/locales/nl.yml
	config/locales/no.yml
	config/locales/pl.yml
	config/locales/pt-BR.yml
	config/locales/pt.yml
	config/locales/ro.yml
	config/locales/ru.yml
	config/locales/sk.yml
	config/locales/sl.yml
	config/locales/sr-YU.yml
	config/locales/sr.yml
	config/locales/sv.yml
	config/locales/th.yml
	config/locales/tr.yml
	config/locales/uk.yml
	config/locales/vi.yml
	config/locales/zh-TW.yml
	config/locales/zh.yml
	db/migrate/20100217010520_add_custom_filter_to_auth_sources.rb
	lib/chili_project/version.rb
2012-01-04 16:41:10 +01:00

68 lines
2.1 KiB
Ruby

#-- encoding: UTF-8
#-- copyright
# ChiliProject is a project management system.
#
# Copyright (C) 2010-2012 the ChiliProject Team
#
# 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.
#++
# DECREACATED SINCE 3.0 - TO BE REMOVED IN 4.0
# The whole macro concept is deprecated. It is to be completely replaced by
# Liquid tags and variables.
require 'dispatcher'
module Redmine
module WikiFormatting
module Macros
@available_macros = {}
class << self
def register(&block)
ActiveSupport::Deprecation.warn("Macros are deprecated. Use Liquid filters and tags instead", caller.drop(3))
class_eval(&block) if block_given?
end
private
# Sets description for the next macro to be defined
def desc(txt)
@desc = txt
end
# Defines a new macro with the given name and block.
def macro(name, &block)
name = name.to_sym if name.is_a?(String)
@available_macros[name] = @desc || ''
@desc = nil
raise "Can not create a macro without a block!" unless block_given?
tag = Class.new(::Liquid::Tag) do
def initialize(tag_name, markup, tokens)
if markup =~ self.class::Syntax
@args = $1[1..-2].split(',').collect(&:strip)
else
raise ::Liquid::SyntaxError.new("Syntax error in tag '#{name}'")
end
end
end
tag.send :define_method, :render do |context|
context.registers[:view].instance_exec context.registers[:object], @args, &block
end
tag.const_set 'Syntax', /(#{::Liquid::QuotedFragment})/
Dispatcher.to_prepare do
ChiliProject::Liquid::Tags.register_tag(name, tag, :html => true)
ChiliProject::Liquid::Legacy.add(name, :tag)
end
end
end
end
end
end