mirror of
https://github.com/RubyMetric/chsrc
synced 2025-10-20 09:51:39 +08:00
增强 Java recipe #278 from BingChunMoLi/dev
This commit is contained in:
@@ -2,7 +2,7 @@
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
* ------------------------------------------------------------*/
|
||||
|
||||
def_target(pl_java, "java/maven/mvn/gradle");
|
||||
def_target(pl_java, "java/maven/mvn/maven-daemon/mvnd/gradle");
|
||||
|
||||
void
|
||||
pl_java_prelude ()
|
||||
@@ -20,65 +20,118 @@ pl_java_prelude ()
|
||||
chef_allow_local_mode (this, CanNot, NULL, NULL);
|
||||
chef_forbid_english(this);
|
||||
chef_allow_user_define(this);
|
||||
chsrc_custom_user_agent("Maven/3.9.11");
|
||||
|
||||
def_sources_begin()
|
||||
{&UpstreamProvider, "https://repo1.maven.org/maven2/", DelegateToUpstream},
|
||||
{&Ali, "https://maven.aliyun.com/repository/public/", DelegateToMirror},
|
||||
{&Huawei, "https://mirrors.huaweicloud.com/repository/maven/", DelegateToMirror},
|
||||
|
||||
{&UpstreamProvider, "https://repo1.maven.org/maven2/", DelegateToUpstream},
|
||||
{&Ali, "https://maven.aliyun.com/repository/public/", "https://maven.aliyun.com/repository/public/com/tencentcloudapi/tencentcloud-sdk-java/3.1.1033/tencentcloud-sdk-java-3.1.1033-javadoc.jar"},
|
||||
{&Huawei, "https://mirrors.huaweicloud.com/repository/maven/", "https://mirrors.huaweicloud.com/repository/maven/com/tencentcloudapi/tencentcloud-sdk-java/3.1.1033/tencentcloud-sdk-java-3.1.1033-javadoc.jar"},
|
||||
{&HuaweiCdn, "https://repo.huaweicloud.com/repository/maven/", "https://repo.huaweicloud.com/repository/maven/com/tencentcloudapi/tencentcloud-sdk-java/3.1.1033/tencentcloud-sdk-java-3.1.1033-javadoc.jar"},
|
||||
{&Tencent, "https://mirrors.cloud.tencent.com/nexus/repository/maven-public/", "https://mirrors.cloud.tencent.com/nexus/repository/maven-public/com/tencentcloudapi/tencentcloud-sdk-java/3.1.1033/tencentcloud-sdk-java-3.1.1033-javadoc.jar"},
|
||||
// 网易的24小时更新一次
|
||||
{&Netease, "http://mirrors.163.com/maven/repository/maven-public/", DelegateToMirror}
|
||||
{&Netease, "http://mirrors.163.com/maven/repository/maven-public/", "https://mirrors.163.com/maven/repository/maven-public/com/tencentcloudapi/tencentcloud-sdk-java/3.1.1033/tencentcloud-sdk-java-3.1.1033-javadoc.jar"}
|
||||
def_sources_end()
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
pl_java_check_cmd (bool *maven_exist, bool *gradle_exist)
|
||||
pl_java_check_cmd (bool *maven_exist, bool *gradle_exist, bool *maven_daemon_exist)
|
||||
{
|
||||
*maven_exist = chsrc_check_program ("mvn");
|
||||
*gradle_exist = chsrc_check_program ("gradle");
|
||||
*maven_daemon_exist = chsrc_check_program ("mvnd");
|
||||
|
||||
if (! *maven_exist && ! *gradle_exist)
|
||||
if (! *maven_exist && ! *gradle_exist && ! *maven_daemon_exist)
|
||||
{
|
||||
chsrc_error ("maven 与 gradle 命令均未找到,请检查是否存在其一");
|
||||
chsrc_error ("maven(maven-daemon) 与 gradle 命令均未找到,请检查是否存在其一");
|
||||
exit (Exit_UserCause);
|
||||
}
|
||||
}
|
||||
|
||||
bool
|
||||
pl_java_is_home (const char *str)
|
||||
{
|
||||
return (xy_str_start_with (str, "Maven home:"));
|
||||
}
|
||||
|
||||
bool
|
||||
pl_java_find_maven_home (const char *line)
|
||||
{
|
||||
if(pl_java_is_home(line))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
char *
|
||||
pl_java_find_maven_config ()
|
||||
{
|
||||
char *buf = xy_run ("mvn -v", 2);
|
||||
char *maven_home = xy_str_delete_prefix (buf, "Maven home: ");
|
||||
maven_home = xy_str_strip (maven_home);
|
||||
char *output;
|
||||
int status = xy_run_capture ("mvn -v", &output);
|
||||
if (0==status)
|
||||
{
|
||||
char *maven_home_line = xy_run_iter_lines ("mvn -v", 0, pl_java_find_maven_home);
|
||||
char *maven_home = xy_str_delete_prefix (maven_home_line, "Maven home: ");
|
||||
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
|
||||
return maven_config;
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("no find maven home\n");
|
||||
}
|
||||
return "~/.m2/settings.xml";
|
||||
}
|
||||
|
||||
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
|
||||
return maven_config;
|
||||
char *
|
||||
pl_java_find_maven_daemon_config ()
|
||||
{
|
||||
char *output;
|
||||
int status = xy_run_capture ("mvnd -v", &output);
|
||||
if (0==status)
|
||||
{
|
||||
char *maven_home_line = xy_run_iter_lines ("mvnd -v", 0, pl_java_find_maven_home);
|
||||
char *maven_home = xy_str_delete_prefix (maven_home_line, "Maven home: ");
|
||||
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
|
||||
return maven_config;
|
||||
}
|
||||
else
|
||||
{
|
||||
printf ("no find maven home\n");
|
||||
}
|
||||
return "~/.m2/settings.xml";
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
pl_java_getsrc (char *option)
|
||||
{
|
||||
bool maven_exist, gradle_exist;
|
||||
pl_java_check_cmd (&maven_exist, &gradle_exist);
|
||||
char *maven_config = pl_java_find_maven_config ();
|
||||
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
|
||||
bool maven_exist, gradle_exist, maven_daemon_exist;
|
||||
pl_java_check_cmd (&maven_exist, &gradle_exist, &maven_daemon_exist);
|
||||
if (maven_exist)
|
||||
{
|
||||
char *maven_config = pl_java_find_maven_config ();
|
||||
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
|
||||
}
|
||||
if(maven_daemon_exist)
|
||||
{
|
||||
char *maven_config = pl_java_find_maven_daemon_config ();
|
||||
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* @consult https://developer.aliyun.com/mirror/maven
|
||||
*/
|
||||
void
|
||||
pl_java_setsrc (char *option)
|
||||
{
|
||||
bool maven_exist, gradle_exist;
|
||||
pl_java_check_cmd (&maven_exist, &gradle_exist);
|
||||
|
||||
chsrc_use_this_source (pl_java);
|
||||
bool maven_exist, gradle_exist, maven_daemon_exist;
|
||||
pl_java_check_cmd (&maven_exist, &gradle_exist, &maven_daemon_exist);
|
||||
|
||||
chsrc_use_this_source(pl_java);
|
||||
if (maven_exist)
|
||||
{
|
||||
char *file = xy_str_gsub (RAWSTR_pl_java_maven_config, "@1@", source.mirror->code);
|
||||
@@ -89,6 +142,16 @@ pl_java_setsrc (char *option)
|
||||
println (file);
|
||||
}
|
||||
|
||||
if (maven_daemon_exist)
|
||||
{
|
||||
char *file = xy_str_gsub (RAWSTR_pl_java_maven_config, "@1@", source.mirror->code);
|
||||
file = xy_str_gsub (file, "@name@", source.mirror->name);
|
||||
file = xy_str_gsub (file, "@url@", source.url);
|
||||
char *maven_config = pl_java_find_maven_daemon_config ();
|
||||
chsrc_note2 (xy_strcat (3, "请在 maven 配置文件 ", maven_config, " 中添加:"));
|
||||
println (file);
|
||||
}
|
||||
|
||||
if (gradle_exist)
|
||||
{
|
||||
if (maven_exist) br();
|
||||
@@ -105,4 +168,4 @@ void
|
||||
pl_java_resetsrc (char *option)
|
||||
{
|
||||
pl_java_setsrc (option);
|
||||
}
|
||||
}
|
@@ -50,7 +50,7 @@ pl_ruby_getsrc (char *option)
|
||||
chsrc_run ("bundle config get mirror.https://rubygems.org", RunOpt_Default);
|
||||
}
|
||||
|
||||
void
|
||||
bool
|
||||
pl_ruby_remove_gem_source (const char *source)
|
||||
{
|
||||
char *cmd = NULL;
|
||||
@@ -59,6 +59,7 @@ pl_ruby_remove_gem_source (const char *source)
|
||||
cmd = xy_2strcat ("gem sources -r ", source);
|
||||
chsrc_run (cmd, RunOpt_Default);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -103,4 +104,4 @@ void
|
||||
pl_ruby_resetsrc (char *option)
|
||||
{
|
||||
pl_ruby_setsrc (option);
|
||||
}
|
||||
}
|
@@ -222,4 +222,4 @@ chsrc_available_mirrors[] = {
|
||||
|
||||
/* ------------------------ chsrc 内部实现 ------------------------ */
|
||||
/* 不要列出 &UpstreamProvider 和 &UserDefinedProvider */
|
||||
};
|
||||
};
|
Reference in New Issue
Block a user