2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Redmine - project management software  
						 
					
						
							
								
									
										
										
										
											2012-05-05 12:56:53 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# Copyright (C) 2006-2012  Jean-Philippe Lang  
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00: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.  
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#  
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# This program is distributed in the hope that it will be useful,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# but WITHOUT ANY WARRANTY; without even the implied warranty of  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# GNU General Public License for more details.  
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#  
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# You should have received a copy of the GNU General Public License  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# along with this program; if not, write to the Free Software  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								module  Redmine  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  module  WikiFormatting 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    module  Macros 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      module  Definitions 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        def  exec_macro ( name ,  obj ,  args ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          method_name  =  " macro_ #{ name } " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          send ( method_name ,  obj ,  args )  if  respond_to? ( method_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-22 11:44:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        def  extract_macro_options ( args ,  * keys ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          options  =  { } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          while  args . last . to_s . strip  =~  %r{ ^(.+) \ =(.+)$ }  &&  keys . include? ( $1 . downcase . to_sym ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            options [ $1 . downcase . to_sym ]  =  $2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            args . pop 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          return  [ args ,  options ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      @@available_macros  =  { } 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      class  <<  self 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Called with a block to define additional macros. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Macro blocks accept 2 arguments: 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # * obj: the object that is rendered 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # * args: macro arguments 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        # Plugins can use this method to define new macros: 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        #   Redmine::WikiFormatting::Macros.register do 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #     desc "This is my macro" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #     macro :my_macro do |obj, args| 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #       "My macro output" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #     end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #   end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        def  register ( & block ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          class_eval ( & block )  if  block_given? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      private 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # 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? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          Definitions . send  :define_method ,  " macro_ #{ name } " . downcase ,  & block 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        # Sets description for the next macro to be defined 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        def  desc ( txt ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          @@desc  =  txt 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      # Builtin macros 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-16 15:34:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      desc  " Sample macro. " 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      macro  :hello_world  do  | obj ,  args | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " Hello world! Object:  #{ obj . class . name } ,  "  +  ( args . empty?  ?  " Called with no argument. "  :  " Arguments:  #{ args . join ( ', ' ) } " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      desc  " Displays a list of all available macros, including description if available. " 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-10 13:55:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      macro  :macro_list  do  | obj ,  args | 
							 
						 
					
						
							
								
									
										
										
										
											2011-12-26 16:58:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        out  =  '' . html_safe 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        @@available_macros . keys . collect ( & :to_s ) . sort . each  do  | macro | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          out  <<  content_tag ( 'dt' ,  content_tag ( 'code' ,  macro ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-16 15:34:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          out  <<  content_tag ( 'dd' ,  textilizable ( @@available_macros [ macro . to_sym ] ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        content_tag ( 'dl' ,  out ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-11-22 11:44:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      desc  " Displays a list of child pages. With no argument, it displays the child pages of the current wiki page. Examples: \n \n "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             "   !{{child_pages}} -- can be used from a wiki page only \n "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             "   !{{child_pages(Foo)}} -- lists all children of page Foo \n "  + 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             "   !{{child_pages(Foo, parent=1)}} -- same as above with a link to page Foo " 
							 
						 
					
						
							
								
									
										
										
										
											2008-07-26 12:54:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      macro  :child_pages  do  | obj ,  args | 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-22 11:44:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        args ,  options  =  extract_macro_options ( args ,  :parent ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        page  =  nil 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  args . size  >  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          page  =  Wiki . find_page ( args . first . to_s ,  :project  = >  @project ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-11-04 12:36:45 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        elsif  obj . is_a? ( WikiContent )  ||  obj . is_a? ( WikiContent :: Version ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-22 11:44:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								          page  =  obj . page 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          raise  'With no argument, this macro can be called from wiki pages only.' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        raise  'Page not found'  if  page . nil?  ||  ! User . current . allowed_to? ( :view_wiki_pages ,  page . wiki . project ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pages  =  ( [ page ]  +  page . descendants ) . group_by ( & :parent_id ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        render_page_hierarchy ( pages ,  options [ :parent ]  ?  page . parent_id  :  page . id ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-07-26 12:54:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2011-09-01 02:04:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-04-13 16:22:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      desc  " Include a wiki page. Example: \n \n   !{{include(Foo)}} \n \n or to include a page of a specific project wiki: \n \n   !{{include(projectname:Foo)}} " 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-16 15:34:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      macro  :include  do  | obj ,  args | 
							 
						 
					
						
							
								
									
										
										
										
											2008-11-22 11:44:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        page  =  Wiki . find_page ( args . first . to_s ,  :project  = >  @project ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        raise  'Page not found'  if  page . nil?  ||  ! User . current . allowed_to? ( :view_wiki_pages ,  page . wiki . project ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-04-13 16:22:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        @included_wiki_pages  || =  [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        raise  'Circular inclusion detected'  if  @included_wiki_pages . include? ( page . title ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        @included_wiki_pages  <<  page . title 
							 
						 
					
						
							
								
									
										
										
										
											2010-11-06 17:47:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        out  =  textilizable ( page . content ,  :text ,  :attachments  = >  page . attachments ,  :headings  = >  false ) 
							 
						 
					
						
							
								
									
										
										
										
											2008-04-13 16:22:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        @included_wiki_pages . pop 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        out 
							 
						 
					
						
							
								
									
										
										
										
											2008-02-16 15:34:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2012-07-16 17:15:40 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      desc  " Displays a clickable thumbnail of an attached image. Examples: \n \n <pre>{{thumbnail(image.png)}} \n {{thumbnail(image.png, size=300, title=Thumbnail)}}</pre> " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      macro  :thumbnail  do  | obj ,  args | 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        args ,  options  =  extract_macro_options ( args ,  :size ,  :title ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        filename  =  args . first 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        raise  'Filename required'  unless  filename . present? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        size  =  options [ :size ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        raise  'Invalid size parameter'  unless  size . nil?  ||  size . match ( / ^ \ d+$ / ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        size  =  size . to_i 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        size  =  nil  unless  size  >  0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  obj  &&  obj . respond_to? ( :attachments )  &&  attachment  =  Attachment . latest_attach ( obj . attachments ,  filename ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          title  =  options [ :title ]  ||  attachment . title 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          img  =  image_tag ( url_for ( :controller  = >  'attachments' ,  :action  = >  'thumbnail' ,  :id  = >  attachment ,  :size  = >  size ) ,  :alt  = >  attachment . filename ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          link_to ( img ,  url_for ( :controller  = >  'attachments' ,  :action  = >  'show' ,  :id  = >  attachment ) ,  :class  = >  'thumbnail' ,  :title  = >  title ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								          raise  " Attachment  #{ filename }  not found " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      end 
							 
						 
					
						
							
								
									
										
										
										
											2007-11-12 14:36:33 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  end 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								end