001/*
002 * JDrupes Builder
003 * Copyright (C) 2025 Michael N. Lipp
004 * 
005 * This program is free software: you can redistribute it and/or modify
006 * it under the terms of the GNU Affero General Public License as
007 * published by the Free Software Foundation, either version 3 of the
008 * License, or (at your option) any later version.
009 *
010 * This program is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
013 * GNU Affero General Public License for more details.
014 *
015 * You should have received a copy of the GNU Affero General Public License
016 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
017 */
018
019package org.jdrupes.builder.java;
020
021import java.nio.file.Path;
022import org.jdrupes.builder.api.Project;
023import org.jdrupes.builder.api.ResourceFile;
024import org.jdrupes.builder.core.ResourceCollector;
025import static org.jdrupes.builder.java.JavaTypes.*;
026
027/// A [ResourceCollector] for [ResourceFile]s that should be included
028/// the resources provided by a Java project.
029///
030public class JavaResourceCollector
031        extends ResourceCollector<JavaResourceTree> {
032
033    /// Instantiates a new Java resources collector.
034    ///
035    /// @param project the project
036    ///
037    public JavaResourceCollector(Project project) {
038        super(project, JavaResourceTreeType);
039    }
040
041    /// Adds the files from the given directory matching the given pattern.
042    /// Short for
043    /// `add(project().newFileTree(JavaResourceTreeType, directory, pattern))`.
044    ///
045    /// @param directory the directory
046    /// @param pattern the pattern
047    /// @return the resources collector
048    ///
049    public final ResourceCollector<JavaResourceTree> add(Path directory,
050            String pattern) {
051        add(project().newResource(JavaResourceTreeType, directory, pattern));
052        return this;
053    }
054
055}