Skip to content

Commit 97ea2df

Browse files
committed
Move to a dedicated file
1 parent 6e4fca5 commit 97ea2df

File tree

3 files changed

+64
-57
lines changed

3 files changed

+64
-57
lines changed

xtask/src/lib.rs

Lines changed: 2 additions & 55 deletions
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
55
pub mod not_bash;
66
pub mod install;
7+
pub mod release;
78
pub mod dist;
89
pub mod pre_commit;
910

@@ -19,7 +20,7 @@ use walkdir::{DirEntry, WalkDir};
1920

2021
use crate::{
2122
codegen::Mode,
22-
not_bash::{date_iso, fs2, pushd, pushenv, rm_rf, run},
23+
not_bash::{fs2, pushd, pushenv, rm_rf, run},
2324
};
2425

2526
pub use anyhow::{bail, Context as _, Result};
@@ -153,60 +154,6 @@ pub fn run_pre_cache() -> Result<()> {
153154
Ok(())
154155
}
155156

156-
pub fn run_release(dry_run: bool) -> Result<()> {
157-
if !dry_run {
158-
run!("git switch release")?;
159-
run!("git fetch upstream --tags --force")?;
160-
run!("git reset --hard tags/nightly")?;
161-
run!("git push")?;
162-
}
163-
codegen::generate_assists_docs(Mode::Overwrite)?;
164-
codegen::generate_feature_docs(Mode::Overwrite)?;
165-
166-
let website_root = project_root().join("../rust-analyzer.github.io");
167-
let changelog_dir = website_root.join("./thisweek/_posts");
168-
169-
let today = date_iso()?;
170-
let commit = run!("git rev-parse HEAD")?;
171-
let changelog_n = fs2::read_dir(changelog_dir.as_path())?.count();
172-
173-
let contents = format!(
174-
"\
175-
= Changelog #{}
176-
:sectanchors:
177-
:page-layout: post
178-
179-
Commit: commit:{}[] +
180-
Release: release:{}[]
181-
182-
== New Features
183-
184-
* pr:[] .
185-
186-
== Fixes
187-
188-
== Internal Improvements
189-
",
190-
changelog_n, commit, today
191-
);
192-
193-
let path = changelog_dir.join(format!("{}-changelog-{}.adoc", today, changelog_n));
194-
fs2::write(&path, &contents)?;
195-
196-
for &adoc in ["manual.adoc", "generated_features.adoc", "generated_assists.adoc"].iter() {
197-
let src = project_root().join("./docs/user/").join(adoc);
198-
let dst = website_root.join(adoc);
199-
fs2::copy(src, dst)?;
200-
}
201-
202-
let tags = run!("git tag --list"; echo = false)?;
203-
let prev_tag = tags.lines().filter(|line| is_release_tag(line)).last().unwrap();
204-
205-
println!("\n git log {}..HEAD --merges --reverse", prev_tag);
206-
207-
Ok(())
208-
}
209-
210157
fn is_release_tag(tag: &str) -> bool {
211158
tag.len() == "2020-02-24".len() && tag.starts_with(|c: char| c.is_ascii_digit())
212159
}

xtask/src/main.rs

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,8 +16,9 @@ use xtask::{
1616
dist::run_dist,
1717
install::{ClientOpt, InstallCmd, ServerOpt},
1818
not_bash::pushd,
19-
pre_commit, project_root, run_clippy, run_fuzzer, run_pre_cache, run_release, run_rustfmt,
20-
Result,
19+
pre_commit, project_root,
20+
release::run_release,
21+
run_clippy, run_fuzzer, run_pre_cache, run_rustfmt, Result,
2122
};
2223

2324
fn main() -> Result<()> {

xtask/src/release.rs

Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
use crate::{
2+
codegen, is_release_tag,
3+
not_bash::{date_iso, fs2, run},
4+
project_root, Mode, Result,
5+
};
6+
7+
pub fn run_release(dry_run: bool) -> Result<()> {
8+
if !dry_run {
9+
run!("git switch release")?;
10+
run!("git fetch upstream --tags --force")?;
11+
run!("git reset --hard tags/nightly")?;
12+
run!("git push")?;
13+
}
14+
codegen::generate_assists_docs(Mode::Overwrite)?;
15+
codegen::generate_feature_docs(Mode::Overwrite)?;
16+
17+
let website_root = project_root().join("../rust-analyzer.github.io");
18+
let changelog_dir = website_root.join("./thisweek/_posts");
19+
20+
let today = date_iso()?;
21+
let commit = run!("git rev-parse HEAD")?;
22+
let changelog_n = fs2::read_dir(changelog_dir.as_path())?.count();
23+
24+
let contents = format!(
25+
"\
26+
= Changelog #{}
27+
:sectanchors:
28+
:page-layout: post
29+
30+
Commit: commit:{}[] +
31+
Release: release:{}[]
32+
33+
== New Features
34+
35+
* pr:[] .
36+
37+
== Fixes
38+
39+
== Internal Improvements
40+
",
41+
changelog_n, commit, today
42+
);
43+
44+
let path = changelog_dir.join(format!("{}-changelog-{}.adoc", today, changelog_n));
45+
fs2::write(&path, &contents)?;
46+
47+
for &adoc in ["manual.adoc", "generated_features.adoc", "generated_assists.adoc"].iter() {
48+
let src = project_root().join("./docs/user/").join(adoc);
49+
let dst = website_root.join(adoc);
50+
fs2::copy(src, dst)?;
51+
}
52+
53+
let tags = run!("git tag --list"; echo = false)?;
54+
let prev_tag = tags.lines().filter(|line| is_release_tag(line)).last().unwrap();
55+
56+
println!("\n git log {}..HEAD --merges --reverse", prev_tag);
57+
58+
Ok(())
59+
}

0 commit comments

Comments
 (0)