Skip to content

Commit 844cd55

Browse files
authored
增强 Java recipe #278 from BingChunMoLi/dev
2 parents 64b5df6 + b98a616 commit 844cd55

File tree

7 files changed

+120
-44
lines changed

7 files changed

+120
-44
lines changed

README.md

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -474,7 +474,7 @@ chsrc set rust | cargo | crate
474474
chsrc set rustup
475475

476476
chsrc set go
477-
chsrc set java | maven | mvn | gradle
477+
chsrc set java | maven | mvn | maven-daemon | mvnd | gradle
478478
chsrc set clojure | clojars
479479
chsrc set dart | pub
480480
chsrc set flutter
@@ -595,4 +595,4 @@ chsrc set conda | anaconda
595595
[@Efterklang]: https://github.com/Efterklang
596596
[@wickdynex]: https://github.com/wickdynex
597597
[@YU-7]: https://github.com/YU-7
598-
[@sanchuanhehe]: https://github.com/sanchuanhehe
598+
[@sanchuanhehe]: https://github.com/sanchuanhehe

lib/xy.h

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -770,7 +770,7 @@ _xy_log_brkt (int level, const char *prompt1, const char *prompt2, const char *c
770770
* 由于目标行会被返回出来,所以 `func` 并不执行目标行,只会执行遍历过的行
771771
*/
772772
static char *
773-
xy_run_iter_lines (const char *cmd, unsigned long n, void (*func) (const char *))
773+
xy_run_iter_lines (const char *cmd, unsigned long n, bool (*func) (const char *))
774774
{
775775
const int size = 512;
776776
char *buf = (char *) malloc (size);
@@ -796,7 +796,10 @@ xy_run_iter_lines (const char *cmd, unsigned long n, void (*func) (const char
796796
break;
797797
if (func)
798798
{
799-
func (buf);
799+
if (func (buf)) {
800+
pclose (stream);
801+
return ret;
802+
}
800803
}
801804
}
802805

@@ -1497,7 +1500,6 @@ xy_map_get (XyMap_t *map, const char *key)
14971500
return NULL;
14981501
}
14991502

1500-
15011503
/**
15021504
* @flavor Ruby: Hash#each
15031505
*/
@@ -1521,5 +1523,4 @@ xy_map_each (
15211523
}
15221524
}
15231525

1524-
1525-
#endif
1526+
#endif

src/framework/core.c

Lines changed: 14 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -127,12 +127,14 @@ struct
127127

128128
/* 此时 chsrc_run() 不再是recipe中指定要运行的一个外部命令,而是作为一个功能实现的支撑 */
129129
bool chsrc_run_faas;
130+
char *user_agent;
130131
}
131132
ProgStatus =
132133
{
133134
.leader_selected_index = -1,
134135
.chgtype = ChgType_Auto,
135-
.chsrc_run_faas = false
136+
.chsrc_run_faas = false,
137+
.user_agent = "chsrc/" Chsrc_Version,
136138
};
137139

138140

@@ -642,15 +644,13 @@ measure_speed_for_url (void *url)
642644
/**
643645
* @note 我们用 —L,因为部分链接会跳转到其他地方,比如: RubyChina, npmmirror
644646
*/
645-
char *curl_cmd = xy_strcat (8, "curl -qsL ", ipv6,
646-
" -o ", os_devnull,
647-
" -w \"%{http_code} %{speed_download}\" -m", time_sec,
648-
" -A chsrc/" Chsrc_Version " ", url);
649-
650-
// chsrc_info (xy_2strcat ("测速命令 ", curl_cmd));
647+
char *curl_cmd = xy_strcat (10, "curl -qsL ", ipv6,
648+
" -o ", os_devnull,
649+
" -w \"%{http_code} %{speed_download}\" -m", time_sec,
650+
" -A ", ProgStatus.user_agent, " ", url);
651651

652+
// chsrc_note2 (xy_2strcat ("测速命令 ", curl_cmd));
652653
char *curl_buf = xy_run (curl_cmd, 0);
653-
654654
return curl_buf;
655655
}
656656

@@ -1111,7 +1111,11 @@ chsrc_determine_chgtype (ChgType_t type)
11111111
ProgStatus.chgtype = chsrc_in_reset_mode() ? ChgType_Reset : type;
11121112
}
11131113

1114-
1114+
void
1115+
chsrc_custom_user_agent (char *user_agent)
1116+
{
1117+
ProgStatus.user_agent = user_agent;
1118+
}
11151119

11161120
#define MSG_EN_PUBLIC_URL "If the URL you specify is a public service, you are invited to contribute: chsrc issue"
11171121
#define MSG_CN_PUBLIC_URL "若您指定的URL为公有服务,邀您参与贡献: chsrc issue"
@@ -1845,4 +1849,4 @@ chsrc_get_cpucore ()
18451849
#endif
18461850

18471851
return cores;
1848-
}
1852+
}

src/framework/mirror.c

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -260,6 +260,13 @@ Huawei =
260260
{NotSkip, NA, NA, "https://mirrors.huaweicloud.com/ubuntu-releases" Big_File_ubuntu, ROUGH}
261261
},
262262

263+
HuaweiCdn =
264+
{
265+
IS_GeneralMirrorSite,
266+
"huaweiCdn", "Huawei Cloud", "华为开源镜像站", "https://repo.huaweicloud.com/",
267+
{NotSkip, NA, NA, "https://repo.huaweicloud.com/ubuntu-releases" Big_File_ubuntu, ROUGH}
268+
},
269+
263270
Volcengine =
264271
{
265272
IS_GeneralMirrorSite,
@@ -294,4 +301,4 @@ Sohu =
294301
IS_GeneralMirrorSite,
295302
"sohu", "SOHU", "搜狐开源镜像站", "https://mirrors.sohu.com/",
296303
{NotSkip, NA, NA, "https://mirrors.sohu.com/deepin-cd" Big_File_deepin, ROUGH}
297-
};
304+
};

src/recipe/lang/Java.c

Lines changed: 86 additions & 23 deletions
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@
22
* SPDX-License-Identifier: GPL-3.0-or-later
33
* ------------------------------------------------------------*/
44

5-
def_target(pl_java, "java/maven/mvn/gradle");
5+
def_target(pl_java, "java/maven/mvn/maven-daemon/mvnd/gradle");
66

77
void
88
pl_java_prelude ()
@@ -20,65 +20,118 @@ pl_java_prelude ()
2020
chef_allow_local_mode (this, CanNot, NULL, NULL);
2121
chef_forbid_english(this);
2222
chef_allow_user_define(this);
23+
chsrc_custom_user_agent("Maven/3.9.11");
2324

2425
def_sources_begin()
25-
{&UpstreamProvider, "https://repo1.maven.org/maven2/", DelegateToUpstream},
26-
{&Ali, "https://maven.aliyun.com/repository/public/", DelegateToMirror},
27-
{&Huawei, "https://mirrors.huaweicloud.com/repository/maven/", DelegateToMirror},
28-
26+
{&UpstreamProvider, "https://repo1.maven.org/maven2/", DelegateToUpstream},
27+
{&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"},
28+
{&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"},
29+
{&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"},
30+
{&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"},
2931
// 网易的24小时更新一次
30-
{&Netease, "http://mirrors.163.com/maven/repository/maven-public/", DelegateToMirror}
32+
{&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"}
3133
def_sources_end()
3234
}
3335

3436

3537
void
36-
pl_java_check_cmd (bool *maven_exist, bool *gradle_exist)
38+
pl_java_check_cmd (bool *maven_exist, bool *gradle_exist, bool *maven_daemon_exist)
3739
{
3840
*maven_exist = chsrc_check_program ("mvn");
3941
*gradle_exist = chsrc_check_program ("gradle");
42+
*maven_daemon_exist = chsrc_check_program ("mvnd");
4043

41-
if (! *maven_exist && ! *gradle_exist)
44+
if (! *maven_exist && ! *gradle_exist && ! *maven_daemon_exist)
4245
{
43-
chsrc_error ("maven 与 gradle 命令均未找到,请检查是否存在其一");
46+
chsrc_error ("maven(maven-daemon) 与 gradle 命令均未找到,请检查是否存在其一");
4447
exit (Exit_UserCause);
4548
}
4649
}
4750

51+
bool
52+
pl_java_is_home (const char *str)
53+
{
54+
return (xy_str_start_with (str, "Maven home:"));
55+
}
56+
57+
bool
58+
pl_java_find_maven_home (const char *line)
59+
{
60+
if(pl_java_is_home(line))
61+
{
62+
return true;
63+
}
64+
return false;
65+
}
4866

4967
char *
5068
pl_java_find_maven_config ()
5169
{
52-
char *buf = xy_run ("mvn -v", 2);
53-
char *maven_home = xy_str_delete_prefix (buf, "Maven home: ");
54-
maven_home = xy_str_strip (maven_home);
70+
char *output;
71+
int status = xy_run_capture ("mvn -v", &output);
72+
if (0==status)
73+
{
74+
char *maven_home_line = xy_run_iter_lines ("mvn -v", 0, pl_java_find_maven_home);
75+
char *maven_home = xy_str_delete_prefix (maven_home_line, "Maven home: ");
76+
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
77+
return maven_config;
78+
}
79+
else
80+
{
81+
printf("no find maven home\n");
82+
}
83+
return "~/.m2/settings.xml";
84+
}
5585

56-
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
57-
return maven_config;
86+
char *
87+
pl_java_find_maven_daemon_config ()
88+
{
89+
char *output;
90+
int status = xy_run_capture ("mvnd -v", &output);
91+
if (0==status)
92+
{
93+
char *maven_home_line = xy_run_iter_lines ("mvnd -v", 0, pl_java_find_maven_home);
94+
char *maven_home = xy_str_delete_prefix (maven_home_line, "Maven home: ");
95+
char *maven_config = xy_normalize_path (xy_2strcat (maven_home, "/conf/settings.xml"));
96+
return maven_config;
97+
}
98+
else
99+
{
100+
printf ("no find maven home\n");
101+
}
102+
return "~/.m2/settings.xml";
58103
}
59104

60105

61106
void
62107
pl_java_getsrc (char *option)
63108
{
64-
bool maven_exist, gradle_exist;
65-
pl_java_check_cmd (&maven_exist, &gradle_exist);
66-
char *maven_config = pl_java_find_maven_config ();
67-
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
109+
bool maven_exist, gradle_exist, maven_daemon_exist;
110+
pl_java_check_cmd (&maven_exist, &gradle_exist, &maven_daemon_exist);
111+
if (maven_exist)
112+
{
113+
char *maven_config = pl_java_find_maven_config ();
114+
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
115+
}
116+
if(maven_daemon_exist)
117+
{
118+
char *maven_config = pl_java_find_maven_daemon_config ();
119+
chsrc_note2 (xy_2strcat ("请查看 ", maven_config));
120+
}
68121
}
69122

70123

124+
71125
/**
72126
* @consult https://developer.aliyun.com/mirror/maven
73127
*/
74128
void
75129
pl_java_setsrc (char *option)
76130
{
77-
bool maven_exist, gradle_exist;
78-
pl_java_check_cmd (&maven_exist, &gradle_exist);
79-
80-
chsrc_use_this_source (pl_java);
131+
bool maven_exist, gradle_exist, maven_daemon_exist;
132+
pl_java_check_cmd (&maven_exist, &gradle_exist, &maven_daemon_exist);
81133

134+
chsrc_use_this_source(pl_java);
82135
if (maven_exist)
83136
{
84137
char *file = xy_str_gsub (RAWSTR_pl_java_maven_config, "@1@", source.mirror->code);
@@ -89,6 +142,16 @@ pl_java_setsrc (char *option)
89142
println (file);
90143
}
91144

145+
if (maven_daemon_exist)
146+
{
147+
char *file = xy_str_gsub (RAWSTR_pl_java_maven_config, "@1@", source.mirror->code);
148+
file = xy_str_gsub (file, "@name@", source.mirror->name);
149+
file = xy_str_gsub (file, "@url@", source.url);
150+
char *maven_config = pl_java_find_maven_daemon_config ();
151+
chsrc_note2 (xy_strcat (3, "请在 maven 配置文件 ", maven_config, " 中添加:"));
152+
println (file);
153+
}
154+
92155
if (gradle_exist)
93156
{
94157
if (maven_exist) br();
@@ -105,4 +168,4 @@ void
105168
pl_java_resetsrc (char *option)
106169
{
107170
pl_java_setsrc (option);
108-
}
171+
}

src/recipe/lang/Ruby/Ruby.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -50,7 +50,7 @@ pl_ruby_getsrc (char *option)
5050
chsrc_run ("bundle config get mirror.https://rubygems.org", RunOpt_Default);
5151
}
5252

53-
void
53+
bool
5454
pl_ruby_remove_gem_source (const char *source)
5555
{
5656
char *cmd = NULL;
@@ -59,6 +59,7 @@ pl_ruby_remove_gem_source (const char *source)
5959
cmd = xy_2strcat ("gem sources -r ", source);
6060
chsrc_run (cmd, RunOpt_Default);
6161
}
62+
return false;
6263
}
6364

6465
/**
@@ -103,4 +104,4 @@ void
103104
pl_ruby_resetsrc (char *option)
104105
{
105106
pl_ruby_setsrc (option);
106-
}
107+
}

src/recipe/menu.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -222,4 +222,4 @@ chsrc_available_mirrors[] = {
222222

223223
/* ------------------------ chsrc 内部实现 ------------------------ */
224224
/* 不要列出 &UpstreamProvider 和 &UserDefinedProvider */
225-
};
225+
};

0 commit comments

Comments
 (0)