Chris@909: require 'source_annotation_extractor' Chris@909: Chris@909: # Modified version of the SourceAnnotationExtractor in railties Chris@909: # Will search for runable code that uses call_hook Chris@909: class PluginSourceAnnotationExtractor < SourceAnnotationExtractor Chris@909: # Returns a hash that maps filenames under +dir+ (recursively) to arrays Chris@909: # with their annotations. Only files with annotations are included, and only Chris@909: # those with extension +.builder+, +.rb+, +.rxml+, +.rjs+, +.rhtml+, and +.erb+ Chris@909: # are taken into account. Chris@909: def find_in(dir) Chris@909: results = {} Chris@909: Chris@909: Dir.glob("#{dir}/*") do |item| Chris@909: next if File.basename(item)[0] == ?. Chris@909: Chris@909: if File.directory?(item) Chris@909: results.update(find_in(item)) Chris@909: elsif item =~ /(hook|test)\.rb/ Chris@909: # skip Chris@909: elsif item =~ /\.(builder|(r(?:b|xml|js)))$/ Chris@909: results.update(extract_annotations_from(item, /\s*(#{tag})\(?\s*(.*)$/)) Chris@909: elsif item =~ /\.(rhtml|erb)$/ Chris@909: results.update(extract_annotations_from(item, /<%=\s*\s*(#{tag})\(?\s*(.*?)\s*%>/)) Chris@909: end Chris@909: end Chris@909: Chris@909: results Chris@909: end Chris@909: end Chris@909: Chris@909: namespace :redmine do Chris@909: namespace :plugins do Chris@909: desc "Enumerate all Redmine plugin hooks and their context parameters" Chris@909: task :hook_list do Chris@909: PluginSourceAnnotationExtractor.enumerate 'call_hook' Chris@909: end Chris@909: end Chris@909: end