001 /* 002 * Sonar, open source software quality management tool. 003 * Copyright (C) 2008-2011 SonarSource 004 * mailto:contact AT sonarsource DOT com 005 * 006 * Sonar is free software; you can redistribute it and/or 007 * modify it under the terms of the GNU Lesser General Public 008 * License as published by the Free Software Foundation; either 009 * version 3 of the License, or (at your option) any later version. 010 * 011 * Sonar is distributed in the hope that it will be useful, 012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 014 * Lesser General Public License for more details. 015 * 016 * You should have received a copy of the GNU Lesser General Public 017 * License along with Sonar; if not, write to the Free Software 018 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 019 */ 020 package org.sonar.plugins.core.batch; 021 022 import java.util.Arrays; 023 import java.util.List; 024 025 import org.slf4j.Logger; 026 import org.slf4j.LoggerFactory; 027 import org.sonar.api.batch.Initializer; 028 import org.sonar.api.resources.Project; 029 import org.sonar.api.resources.ProjectFileSystem; 030 031 public class ProjectFileSystemLogger extends Initializer { 032 033 private static final Logger LOG = LoggerFactory.getLogger(ProjectFileSystemLogger.class); 034 035 @Override 036 public void execute(Project project) { 037 String[] exclusionPatterns = project.getExclusionPatterns(); 038 if (exclusionPatterns != null && exclusionPatterns.length > 0) { 039 LOG.info("Excluded sources: {}", Arrays.toString(exclusionPatterns)); 040 } 041 ProjectFileSystem projectFileSystem = project.getFileSystem(); 042 logDirectories("Source directories:", projectFileSystem.getSourceDirs()); 043 logDirectories("Test directories:", projectFileSystem.getTestDirs()); 044 } 045 046 private void logDirectories(String name, List<java.io.File> dirs) { 047 if (!dirs.isEmpty()) { 048 LOG.info(name); 049 for (java.io.File dir : dirs) { 050 LOG.info(" {}", dir); 051 } 052 } 053 } 054 055 }