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}