Title: | Turn Your Git Commit Messages into a HTML Book |
---|---|
Description: | Read all commit messages of your local git repository and sort them according to tags or specific text pattern into chapters of a HTML book using 'bookdown'. The git history book presentation helps organisms required to testify for every changes in their source code, in relation to features requests. |
Authors: | Sébastien Rochette [aut, cre] , Cervan Girard [aut] , ThinkR [cph], Institut de Recherches Internationales Servier [spn] |
Maintainer: | Sébastien Rochette <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.1.6 |
Built: | 2024-10-25 03:46:56 UTC |
Source: | https://github.com/ThinkR-open/gitdown |
Creates and updates a vignette in the 'vignette/' directory of a package with last modification time of tracked files
create_vignette_last_modif( repo = ".", path = "R", recursive = TRUE, untracked = TRUE ) update_vignette_last_modif( repo = ".", path = "R", recursive = TRUE, untracked = TRUE )
create_vignette_last_modif( repo = ".", path = "R", recursive = TRUE, untracked = TRUE ) update_vignette_last_modif( repo = ".", path = "R", recursive = TRUE, untracked = TRUE )
repo |
git repository |
path |
Default to R folder. Use "" for the complete directory |
recursive |
Logical. Should the listing recurse into directories? |
untracked |
Logical. Should the not tracked files be included? |
No return value, called for side effect. Creates and updates the content of the "modification_files.Rmd" vignette
# Creates vignette repo <- fake_repo(as.package = TRUE) if (rmarkdown::pandoc_available("2.0.0")) { create_vignette_last_modif(repo, path = "R") } # update vignette repo <- fake_repo(as.package = TRUE) if (rmarkdown::pandoc_available("2.0.0")) { update_vignette_last_modif(repo, path = "R") rmarkdown::render(file.path(repo, "vignettes", "modification_files.Rmd")) }
# Creates vignette repo <- fake_repo(as.package = TRUE) if (rmarkdown::pandoc_available("2.0.0")) { create_vignette_last_modif(repo, path = "R") } # update vignette repo <- fake_repo(as.package = TRUE) if (rmarkdown::pandoc_available("2.0.0")) { update_vignette_last_modif(repo, path = "R") rmarkdown::render(file.path(repo, "vignettes", "modification_files.Rmd")) }
Create the text to add in a markdown file to present each pattern as a chapter of the book
each_pattern(nest_commits, pattern.type)
each_pattern(nest_commits, pattern.type)
nest_commits |
commits as nested with nest_commits_by_pattern |
pattern.type |
Character name of the pattern to filter |
A tibble with a row for each different pattern found and a 'text' column to be included in a markdown file:
pattern.content: pattern found in the commit message
link_pattern: internal url of the pattern in the future HTML gitbook
text: list of vectors of markdown text to present commits of each pattern in the HTML gitbook output
pattern.type: name of the pattern found in the commit message
pattern.title: pattern.content or title used in the pattern.table a nested 'data' column with all related commits
pattern_numeric: extraction of numeric value in pattern.content
data: a nested list of tibbles with commits content as issued from get_commits_pattern()
repo <- fake_repo() res_commits <- nest_commits_by_pattern( repo, pattern = c("Tickets" = "ticket[[:digit:]]+"), ref = "main", silent = TRUE ) each_pattern(res_commits, "Tickets")
repo <- fake_repo() res_commits <- nest_commits_by_pattern( repo, pattern = c("Tickets" = "ticket[[:digit:]]+"), ref = "main", silent = TRUE ) each_pattern(res_commits, "Tickets")
A fake repository allows to create reproducible examples for this package functions
fake_repo(path = tempfile(pattern = "git2r-"), as.package = FALSE)
fake_repo(path = tempfile(pattern = "git2r-"), as.package = FALSE)
path |
Path to fake repository |
as.package |
Logical. Whether to add R/ and vignettes/ directories to fake a package |
Character. Path of a fake repository used for reproducible examples. Fake repository contains a few files with an initiated git repository.
# Fake repository with git fake_repo() # Fake repository that looks like package with git fake_repo(as.package = TRUE)
# Fake repository with git fake_repo() # Fake repository that looks like package with git fake_repo(as.package = TRUE)
Get commits associated with a text pattern
get_commits_pattern( repo = ".", pattern = c(Ticket = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", path = NULL, silent = FALSE )
get_commits_pattern( repo = ".", pattern = c(Ticket = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", path = NULL, silent = FALSE )
repo |
a path to a repository or a |
pattern |
Named vector with regex pattern to expose commits, like |
pattern.table |
data.frame with two columns: pattern and description of the pattern. This is used as correspondence table to add some names to existing patterns. |
ref |
The name of a reference to list commits from e.g. a tag or a branch. The default is NULL for the current branch. |
path |
The path to a file. If not NULL, only commits modifying
this file will be returned. Note that modifying commits that
occurred before the file was given its present name are not
returned; that is, the output of |
silent |
Logical. Whether to hide messages. |
A tibble with one line for each commit, duplicated if associated with multiple patterns and the following columns:
sha: sha of the commit
summary: First line of the commit message
message: Full content of the commit message
author: author of the commit
email: email of the author
when: commit time
order: order of commit messages. 1 is the oldest.
tag.name: name of tag associated with all commits since the last tag
tag.message: message of the tagged commit
pattern.type: name of the pattern found in the commit message
pattern.content: pattern found in the commit message
repo <- fake_repo() get_commits_pattern(repo = repo, pattern = c("Ticket" = "#[[:digit:]]+")) get_commits_pattern(repo = repo, pattern = c("Ticket" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"))
repo <- fake_repo() get_commits_pattern(repo = repo, pattern = c("Ticket" = "#[[:digit:]]+")) get_commits_pattern(repo = repo, pattern = c("Ticket" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"))
Get commits associated chronologically with tags
get_commits_tags(repo = ".", ref = "main", path = NULL, silent = FALSE)
get_commits_tags(repo = ".", ref = "main", path = NULL, silent = FALSE)
repo |
a path to a repository or a |
ref |
The name of a reference to list commits from e.g. a tag or a branch. The default is NULL for the current branch. |
path |
The path to a file. If not NULL, only commits modifying
this file will be returned. Note that modifying commits that
occurred before the file was given its present name are not
returned; that is, the output of |
silent |
Logical. Whether to hide messages. |
A tibble with one line for each commit and the following columns:
sha: sha of the commit
summary: First line of the commit message
message: Full content of the commit message
author: author of the commit
email: email of the author
when: commit time
order: order of commit messages. 1 is the oldest.
tag.name: name of tag associated with all commits since the last tag
tag.message: message of the tagged commit
repo <- fake_repo() get_commits_tags(repo = repo)
repo <- fake_repo() get_commits_tags(repo = repo)
Get the first and last modification time for a specific file, based on git2r::blame().
get_info(path, repo = ".")
get_info(path, repo = ".")
path |
path to the file |
repo |
repo of the git project |
A list with information of the selected file:
file: file name
in_repository: Logical. Whether the file has already been commit once in the git repository
first_modif: time of first modification. Commit time if in the git repository, system date of creation otherwise.
last_modif: time of last modification. Commit time if in the git repository, system date of last modification otherwise.
repo <- fake_repo() get_info(list.files(repo)[1], repo = repo)
repo <- fake_repo() get_info(list.files(repo)[1], repo = repo)
Get the first and last modification time of files of a directory
get_last_modif(repo = ".", path = "R", recursive = TRUE, untracked = TRUE)
get_last_modif(repo = ".", path = "R", recursive = TRUE, untracked = TRUE)
repo |
git repository |
path |
Default to R folder. Use "" for the complete directory |
recursive |
Logical. Should the listing recurse into directories? |
untracked |
Logical. Should the not tracked files be included? |
A list of files with information of each file:
file: file name
in_repository: Logical. Whether the file has already been commit once in the git repository
first_modif: time of first modification. Commit time if in the git repository, system date of creation otherwise.
last_modif: time of last modification. Commit time if in the git repository, system date of last modification otherwise.
repo <- fake_repo() # Complete repository get_last_modif(repo = repo, path = "") repo <- fake_repo(as.package = TRUE) # Complete repository get_last_modif(repo = repo, path = "")
repo <- fake_repo() # Complete repository get_last_modif(repo = repo, path = "") repo <- fake_repo(as.package = TRUE) # Complete repository get_last_modif(repo = repo, path = "")
Read all commit messages of your local git repository and sort them according to tags or specific text pattern into chapters of a HTML book using 'bookdown'. Each chapter is a group of commits. The first page gives a summary of all the groups.
git_down( repo = ".", book_path = "gitdown", open = TRUE, author = "John Doe", pattern = c(Issues = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", ... )
git_down( repo = ".", book_path = "gitdown", open = TRUE, author = "John Doe", pattern = c(Issues = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", ... )
repo |
The path to a repository. Default is |
book_path |
The path to the bookdown output. Default is |
open |
Should the bookdown be opened once compiled? Default is TRUE. |
author |
Author of the bookdown |
pattern |
Named vector with regex pattern to expose commits, like |
pattern.table |
data.frame with two columns: pattern and description of the pattern. This is used as correspondence table to add some names to existing patterns. |
ref |
the name of the branch, by default main |
... |
Other parameters to pass to |
Path of the HTML gitbook saved in the repo/book_path directory.
repo <- fake_repo() if (rmarkdown::pandoc_available("2.0.0")) { res <- git_down(repo, pattern = c("Tickets" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"), open = FALSE) } ## Not run: # Open the book browseURL(res) ## End(Not run) # With table of correspondence pattern.table <- data.frame(number = c("#2", "#1"), title = c("#2 A second issue to illustrate a blog post", "#1 An example of issue")) if (rmarkdown::pandoc_available("2.0.0")) { res <- git_down(repo, pattern = c("Issues" = "#[[:digit:]]+"), pattern.table = pattern.table, open = FALSE) } ## Not run: # Open the book browseURL(res) ## End(Not run)
repo <- fake_repo() if (rmarkdown::pandoc_available("2.0.0")) { res <- git_down(repo, pattern = c("Tickets" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"), open = FALSE) } ## Not run: # Open the book browseURL(res) ## End(Not run) # With table of correspondence pattern.table <- data.frame(number = c("#2", "#1"), title = c("#2 A second issue to illustrate a blog post", "#1 An example of issue")) if (rmarkdown::pandoc_available("2.0.0")) { res <- git_down(repo, pattern = c("Issues" = "#[[:digit:]]+"), pattern.table = pattern.table, open = FALSE) } ## Not run: # Open the book browseURL(res) ## End(Not run)
Nest all commits by each pattern found in the commit messages
nest_commits_by_pattern( repo, pattern = c(Issues = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", silent = TRUE )
nest_commits_by_pattern( repo, pattern = c(Issues = "#[[:digit:]]+"), pattern.table = NULL, ref = "main", silent = TRUE )
repo |
a path to a repository or a |
pattern |
Named vector with regex pattern to expose commits, like |
pattern.table |
data.frame with two columns: pattern and description of the pattern. This is used as correspondence table to add some names to existing patterns. |
ref |
The name of a reference to list commits from e.g. a tag or a branch. The default is NULL for the current branch. |
silent |
Logical. Whether to hide messages. |
A tibble with a row for each different pattern found in commit messages and following columns:
pattern.type: name of the pattern found in the commit message
pattern.content: pattern found in the commit message
pattern.title: pattern.content or title used in the pattern.table a nested 'data' column with all related commits
pattern_numeric: extraction of numeric value in pattern.content
link_pattern: internal url of the pattern in the future HTML gitbook
data: a nested list of tibbles with commits content as issued from get_commits_pattern()
repo <- fake_repo() nest_commits_by_pattern(repo) # With table of correspondence pattern.table <- data.frame( number = c("#2", "#1", "#1000"), title = c("#2 A second issue to illustrate a blog post", "#1 An example of issue", "#1000 issue with no commit")) nest_commits_by_pattern( repo, pattern.table = pattern.table, pattern = c("Tickets" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"))
repo <- fake_repo() nest_commits_by_pattern(repo) # With table of correspondence pattern.table <- data.frame( number = c("#2", "#1", "#1000"), title = c("#2 A second issue to illustrate a blog post", "#1 An example of issue", "#1000 issue with no commit")) nest_commits_by_pattern( repo, pattern.table = pattern.table, pattern = c("Tickets" = "ticket[[:digit:]]+", "Issues" = "#[[:digit:]]+"))
Presenting results of files and last modification time in a printed table using 'kable()'
present_files(repo = ".", path = "R", recursive = TRUE, untracked = TRUE)
present_files(repo = ".", path = "R", recursive = TRUE, untracked = TRUE)
repo |
git repository |
path |
Default to R folder. Use "" for the complete directory |
recursive |
Logical. Should the listing recurse into directories? |
untracked |
Logical. Should the not tracked files be included? |
A 'kable()' output to be included in a markdown file
repo <- fake_repo(as.package = TRUE) cat(present_files(repo))
repo <- fake_repo(as.package = TRUE) cat(present_files(repo))