Skip to content

Commit

Permalink
changelog creator
Browse files Browse the repository at this point in the history
Signed-off-by: Ali Caglayan <alizter@gmail.com>
  • Loading branch information
Alizter committed Aug 19, 2023
1 parent d7fc655 commit 72cae15
Show file tree
Hide file tree
Showing 6 changed files with 201 additions and 0 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -30,3 +30,6 @@ nix/profiles/
# dkml desktop CI
/msys64
/.ci

# changelog username
doc/changes/username
8 changes: 8 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -91,6 +91,14 @@ dev-switch:
opam switch create -y . $(TEST_OCAMLVERSION) --deps-only --with-test
opam install -y --update-invariant ocaml.$(TEST_OCAMLVERSION) $(TEST_DEPS) $(DEV_DEPS)

.PHONY: changelog
changelog:
$(BIN) exec -- doc/changes/add.exe

.PHONY: compile-changelog
compile-changelog:
$(BIN) build @doc/changes/compile-changelog

.PHONY: test
test: $(BIN)
$(BIN) runtest
Expand Down
62 changes: 62 additions & 0 deletions doc/changes/add.ml
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
open Stdune
module Console = Dune_console

(** This script generates a changelog entry for a PR. It asks the user for information
about the pull request and then generates a file in the [changes_directory]. *)

let changes_directory = Path.source (Path.Source.of_string "doc/changes")
let username_file = Path.append_local changes_directory (Path.Local.of_string "username")

let () =
let description =
Console.printf "What is the change about?";
read_line ()
in
let pr_number =
Console.printf "PR number? (Leave blank if you don't know)";
match read_line () with
| "" -> "????"
| s -> s
in
let username =
match Path.stat username_file with
| Ok { st_kind = Unix.S_REG; _ } ->
Console.printf "Using username from %s." (Path.to_string_maybe_quoted username_file);
let raw_username = Io.read_file username_file in
String.trim raw_username
| _ ->
Console.printf "What is your username? (This will be saved for later)";
let username = read_line () in
Path.mkdir_p changes_directory;
Io.write_file username_file username;
username
in
let issues =
Console.printf "Which issue numbers does this change fix?";
match read_line () with
| "" -> ""
| s ->
String.split ~on:' ' s
|> List.map ~f:(fun s -> "#" ^ s)
|> String.enumerate_and
|> fun x -> ", fixes " ^ x
in
let pp =
Pp.concat
[ Pp.verbatim "- "
; Pp.box (Pp.textf "%s (#%s%s, @%s)" description pr_number issues username)
; Pp.newline
]
in
let entry_file =
Path.append_source changes_directory (Path.Source.of_string (pr_number ^ ".md"))
in
if Path.exists entry_file
then (
Console.print_user_message
(User_error.make
[ Pp.textf "File %s already exists." (Path.to_string_maybe_quoted entry_file) ]);
exit 1)
else Console.printf "Changelog entry in: %s" (Path.to_string_maybe_quoted entry_file);
Io.write_lines entry_file [ Format.asprintf "%a" Pp.to_fmt pp ]
;;
91 changes: 91 additions & 0 deletions doc/changes/add.t
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
Testing the changelog adding script

$ cat > user_response << EOF
> Changelog description that is long enough to be wrapped to the next line
> 1234
> SomeGitHubUser
> 123 456 789
> EOF

$ ./add.exe < user_response
What is the change about?
PR number? (Leave blank if you don't know)
What is your username? (This will be saved for later)
Which issue numbers does this change fix?
Changelog entry in: doc/changes/1234.md

$ ls doc/changes/
1234.md
username
$ cat doc/changes/*.md
- Changelog description that is long enough to be wrapped to the next line
(#1234, fixes #123, #456 and #789, @SomeGitHubUser)


The username gets recorded in doc/changes/username

$ cat doc/changes/username
SomeGitHubUser

Omitted the PR number and issues. Also reusing the saved username.

$ cat > user_response << EOF
> Changelog description that is long enough to be wrapped to the next line. \
> This one takes the cake for being especially long and wrappable.
>
>
> EOF

$ ./add.exe < user_response
What is the change about?
PR number? (Leave blank if you don't know)
Using username from doc/changes/username.
Which issue numbers does this change fix?
Changelog entry in: doc/changes/????.md

$ ls doc/changes/
1234.md
????.md
username
$ cat doc/changes/*.md
- Changelog description that is long enough to be wrapped to the next line
(#1234, fixes #123, #456 and #789, @SomeGitHubUser)

- Changelog description that is long enough to be wrapped to the next line.
This one takes the cake for being especially long and wrappable. (#????,
@SomeGitHubUser)

To use another username, simply delete the doc/changes/username file.

$ rm doc/changes/username

This time we also omit the PR number and give the same username to cause a
conflict with the entry.

$ cat > user_response << EOF
> Another really long changelog description with some information that makes \
> it long enough to wrap to the next line.
>
> SomeGitHubUser
> 1234 7809
> EOF

$ ./add.exe < user_response
What is the change about?
PR number? (Leave blank if you don't know)
What is your username? (This will be saved for later)
Which issue numbers does this change fix?
Error: File doc/changes/????.md already exists.
[1]

In this case, the ????_SomeGithubUser file should have already been renamed
since the PR should be known by now. (? should be quoted in the shell)
$ (cd doc/changes/ && mv "????.md" 7890.md)

$ ./add.exe < user_response
What is the change about?
PR number? (Leave blank if you don't know)
Using username from doc/changes/username.
Which issue numbers does this change fix?
Changelog entry in: doc/changes/????.md

25 changes: 25 additions & 0 deletions doc/changes/dune
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
(executable
(name add)
(libraries stdune pp dune_console))

(cram
(deps add.exe))

(rule
(alias compile-changelog)
(deps
(glob_files *.md))
(action
(with-stdout-to
changes-new.md
(progn
(echo "Unreleased\n")
(echo "----------\n")
(echo "\n")
(cat %{deps})
(cat ../../CHANGES.md)))))

(rule
(alias compile-changelog)
(action
(diff ../../CHANGES.md changes-new.md)))
12 changes: 12 additions & 0 deletions doc/hacking.rst
Original file line number Diff line number Diff line change
Expand Up @@ -406,6 +406,18 @@ For project names, use the following capitalization:
- **PPX,** rather than ppx or Ppx; ``ppxlib``
- **UTop,** rather than utop or Utop.
Changelog
=========
All changes observable by the user should be documented in the changelog.
Use ``make changelog`` to run an interactive script for adding a changelog
entry. Unreleased changes are collected in their own files in the
``doc/changes/`` directory.
During the release process, the changelog entries will be compiled into
``CHANGES.md``.
Vendoring
=========
Expand Down

0 comments on commit 72cae15

Please sign in to comment.