From ceb76e719059841198a652b7bd10fa0df1c8fccf Mon Sep 17 00:00:00 2001 From: YunaiV Date: Wed, 20 Apr 2022 12:52:13 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BC=98=E5=8C=96=E6=B3=A8=E9=87=8A=EF=BC=8C?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D=20mac=20=E7=9A=84=E5=85=BC=E5=AE=B9=E6=80=A7?= =?UTF-8?q?=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/cn/iocoder/yudao/ProjectReactor.java | 26 ++++++++++--------- 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/yudao-server/src/test/java/cn/iocoder/yudao/ProjectReactor.java b/yudao-server/src/test/java/cn/iocoder/yudao/ProjectReactor.java index 0961c9252..75b22cea0 100644 --- a/yudao-server/src/test/java/cn/iocoder/yudao/ProjectReactor.java +++ b/yudao-server/src/test/java/cn/iocoder/yudao/ProjectReactor.java @@ -11,6 +11,8 @@ import java.util.Collection; import java.util.regex.Matcher; import java.util.stream.Collectors; +import static java.io.File.separator; + /** * 项目修改器,一键替换 Maven 的 groupId、artifactId,项目的 package 等 *

@@ -39,9 +41,9 @@ public class ProjectReactor { log.info("[main][新项目路径地址]projectBaseDirNew: " + projectBaseDirNew); // 获得需要复制的文件 - log.info("[main][开始获得需要重写的文件]"); + log.info("[main][开始获得需要重写的文件,预计需要 10-20 秒]"); Collection files = listFiles(projectBaseDir); - log.info("[main][需要重写的文件数量:{},预计需要 5-10 秒]", files.size()); + log.info("[main][需要重写的文件数量:{},预计需要 15-30 秒]", files.size()); // 写入文件 files.forEach(file -> { String content = replaceFileContent(file, groupIdNew, artifactIdNew, packageNameNew, titleNew); @@ -51,19 +53,19 @@ public class ProjectReactor { } private static String getProjectBaseDir() { - return StrUtil.subBefore(new File(ProjectReactor.class.getClassLoader().getResource(File.separator).getFile()).getPath(), File.separator + "yudao-server", false); + return StrUtil.subBefore(ProjectReactor.class.getClassLoader().getResource("").getFile(), + separator + "yudao-server", false); } private static Collection listFiles(String projectBaseDir) { Collection files = FileUtils.listFiles(new File(projectBaseDir), null, true); - // 移除 IDEA Git GitHub 自身的文件; Node 编译出来的文件 + // 移除 IDEA、Git 自身的文件、Node 编译出来的文件 files = files.stream() - .filter(file -> !file.getPath().contains(File.separator + "target" + File.separator) - && !file.getPath().contains(File.separator + "node_modules" + File.separator) - && !file.getPath().contains(File.separator + ".idea" + File.separator) - && !file.getPath().contains(File.separator + ".git" + File.separator) - && !file.getPath().contains(File.separator + ".github" + File.separator) - && !file.getPath().contains(File.separator + "dist" + File.separator) + .filter(file -> !file.getPath().contains(separator + "target" + separator) + && !file.getPath().contains(separator + "node_modules" + separator) + && !file.getPath().contains(separator + ".idea" + separator) + && !file.getPath().contains(separator + ".git" + separator) + && !file.getPath().contains(separator + "dist" + separator) && !file.getPath().contains(".iml") && !file.getPath().contains(".html.gz")) .collect(Collectors.toList()); @@ -84,8 +86,8 @@ public class ProjectReactor { private static void writeFile(File file, String fileContent, String projectBaseDir, String projectBaseDirNew, String packageNameNew, String artifactIdNew) { String newPath = file.getPath().replace(projectBaseDir, projectBaseDirNew) // 新目录 - .replace(PACKAGE_NAME.replaceAll("\\.", Matcher.quoteReplacement(File.separator)), - packageNameNew.replaceAll("\\.", Matcher.quoteReplacement(File.separator))) + .replace(PACKAGE_NAME.replaceAll("\\.", Matcher.quoteReplacement(separator)), + packageNameNew.replaceAll("\\.", Matcher.quoteReplacement(separator))) .replace(ARTIFACT_ID, artifactIdNew) // .replaceAll(StrUtil.upperFirst(ARTIFACT_ID), StrUtil.upperFirst(artifactIdNew)); FileUtil.writeUtf8String(fileContent, newPath);