# Licensed to the Apache Software Foundation (ASF) under one or more # contributor license agreements. See the NOTICE file distributed with this # work for additional information regarding copyright ownership. The ASF # licenses this file to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations under # the License. module Buildr # Provides the checkstyle:html and checkstyle:xml tasks. # Require explicitly using require "buildr/checkstyle". module Checkstyle class << self # The specs for requirements def dependencies [ 'com.puppycrawl.tools:checkstyle:jar:5.7', 'commons-cli:commons-cli:jar:1.2', 'antlr:antlr:jar:2.7.7', 'com.google.guava:guava-jdk5:jar:16.0', 'com.google.guava:guava-bootstrap-jdk5:jar:16.0', 'com.google.collections:google-collections:jar:1.0', 'commons-beanutils:commons-beanutils-core:jar:1.8.3', 'commons-logging:commons-logging:jar:1.1.1' ] end def checkstyle(configuration_file, format, output_file, source_paths, options = {}) dependencies = self.dependencies + (options[:dependencies] || []) cp = Buildr.artifacts(dependencies).each { |a| a.invoke() if a.respond_to?(:invoke) }.map(&:to_s) args = [] if options[:properties_file] args << "-p" args << options[:properties_file] end args << "-c" args << configuration_file args << "-f" args << format args << "-o" args << output_file source_paths.each do |source_path| args << "-r" args << source_path end begin Java::Commands.java 'com.puppycrawl.tools.checkstyle.Main', *(args + [{:classpath => cp, :properties => options[:properties], :java_args => options[:java_args]}]) rescue => e raise e if options[:fail_on_error] end end end class Config def enabled? File.exist?(self.configuration_file) end def html_enabled? File.exist?(self.style_file) end attr_writer :config_directory def config_directory @config_directory || project._(:source, :main, :etc, :checkstyle) end attr_writer :report_dir def report_dir @report_dir || project._(:reports, :checkstyle) end attr_writer :configuration_file def configuration_file @configuration_file || "#{self.config_directory}/checks.xml" end attr_writer :fail_on_error def fail_on_error? @fail_on_error.nil? ? false : @fail_on_error end attr_writer :format def format @format || 'xml' end attr_writer :xml_output_file def xml_output_file @xml_output_file || "#{self.report_dir}/checkstyle.xml" end attr_writer :html_output_file def html_output_file @html_output_file || "#{self.report_dir}/checkstyle.html" end attr_writer :style_file def style_file unless @style_file project_xsl = "#{self.config_directory}/checkstyle-report.xsl" if File.exist?(project_xsl) @style_file = project_xsl else @style_file = "#{File.dirname(__FILE__)}/checkstyle-report.xsl" end end @style_file end attr_writer :suppressions_file def suppressions_file @suppressions_file || "#{self.config_directory}/suppressions.xml" end attr_writer :import_control_file def import_control_file @import_control_file || "#{self.config_directory}/import-control.xml" end def properties unless @properties @properties = {:basedir => self.project.base_dir} @properties['checkstyle.suppressions.file'] = self.suppressions_file if File.exist?(self.suppressions_file) @properties['checkstyle.import-control.file'] = self.import_control_file if File.exist?(self.import_control_file) end @properties end def source_paths @source_paths ||= [self.project.compile.sources, self.project.test.compile.sources] end def extra_dependencies @extra_dependencies ||= [self.project.compile.dependencies, self.project.test.compile.dependencies].flatten end protected def initialize(project) @project = project end attr_reader :project end module ProjectExtension include Extension def checkstyle @checkstyle ||= Buildr::Checkstyle::Config.new(project) end after_define do |project| if project.checkstyle.enabled? desc "Generate checkstyle xml report." project.task("checkstyle:xml") do puts "Checkstyle: Analyzing source code..." mkdir_p File.dirname(project.checkstyle.xml_output_file) Buildr::Checkstyle.checkstyle(project.checkstyle.configuration_file, project.checkstyle.format, project.checkstyle.xml_output_file, project.checkstyle.source_paths.flatten.compact, :properties => project.checkstyle.properties, :fail_on_error => project.checkstyle.fail_on_error?, :dependencies => project.checkstyle.extra_dependencies) end if project.checkstyle.html_enabled? xml_task = project.task("checkstyle:xml") desc "Generate checkstyle html report." project.task("checkstyle:html" => xml_task) do puts "Checkstyle: Generating report" mkdir_p File.dirname(project.checkstyle.html_output_file) Buildr.ant "checkstyle" do |ant| ant.xslt :in => project.checkstyle.xml_output_file, :out => project.checkstyle.html_output_file, :style => project.checkstyle.style_file end end end end end end end end class Buildr::Project include Buildr::Checkstyle::ProjectExtension end