All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.api.scan.filesystem.PathResolver Maven / Gradle / Ivy

/*
 * SonarQube
 * Copyright (C) 2009-2018 SonarSource SA
 * mailto:info AT sonarsource DOT com
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or (at your option) any later version.
 *
 * 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser 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.
 */
package org.sonar.api.scan.filesystem;

import java.io.File;
import java.nio.file.Path;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Optional;
import javax.annotation.CheckForNull;
import javax.annotation.concurrent.Immutable;
import org.apache.commons.io.FilenameUtils;
import org.sonar.api.batch.ScannerSide;
import org.sonar.api.utils.PathUtils;

import static java.util.stream.Collectors.joining;

/**
 * @since 3.5
 */
@ScannerSide
@Immutable
public class PathResolver {

  public File relativeFile(File dir, String path) {
    return dir.toPath().resolve(path).normalize().toFile();
  }

  public List relativeFiles(File dir, List paths) {
    List result = new ArrayList<>();
    for (String path : paths) {
      result.add(relativeFile(dir, path));
    }
    return result;
  }

  /**
   * @deprecated since 6.0 was used when component keys were relative to source dirs
   */
  @Deprecated
  @CheckForNull
  public RelativePath relativePath(Collection dirs, File file) {
    List stack = new ArrayList<>();
    File cursor = file;
    while (cursor != null) {
      File parentDir = parentDir(dirs, cursor);
      if (parentDir != null) {
        return new RelativePath(parentDir, stack.stream().collect(joining("/")));
      }
      stack.add(0, cursor.getName());
      cursor = cursor.getParentFile();
    }
    return null;
  }

  /**
   * Similar to {@link Path#relativize(Path)} except that:
   *   
    *
  • null is returned if file is not a child of dir *
  • the resulting path is converted to use Unix separators *
* @since 6.0 */ @CheckForNull public String relativePath(Path dir, Path file) { Path baseDir = dir.normalize(); Path path = file.normalize(); if (!path.startsWith(baseDir)) { return null; } try { Path relativized = baseDir.relativize(path); return FilenameUtils.separatorsToUnix(relativized.toString()); } catch (IllegalArgumentException e) { return null; } } /** * Similar to {@link Path#relativize(Path)} except that: *
    *
  • Empty is returned if file is not a child of dir *
  • the resulting path is converted to use Unix separators *
* @since 6.6 */ public static Optional relativize(Path dir, Path file) { Path baseDir = dir.normalize(); Path path = file.normalize(); if (!path.startsWith(baseDir)) { return Optional.empty(); } try { Path relativized = baseDir.relativize(path); return Optional.of(FilenameUtils.separatorsToUnix(relativized.toString())); } catch (IllegalArgumentException e) { return Optional.empty(); } } @CheckForNull public String relativePath(File dir, File file) { return relativePath(dir.toPath(), file.toPath()); } @CheckForNull private static File parentDir(Collection dirs, File cursor) { for (File dir : dirs) { if (PathUtils.canonicalPath(dir).equals(PathUtils.canonicalPath(cursor))) { return dir; } } return null; } /** * @deprecated since 6.0 was used when component keys were relative to source dirs */ @Deprecated public static final class RelativePath { private File dir; private String path; public RelativePath(File dir, String path) { this.dir = dir; this.path = path; } public File dir() { return dir; } public String path() { return path; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy