https://github.com/Dschaykib/newsmd
A package to create and update the NEWS.md file
https://github.com/Dschaykib/newsmd
Last synced: 3 months ago
JSON representation
A package to create and update the NEWS.md file
- Host: GitHub
- URL: https://github.com/Dschaykib/newsmd
- Owner: Dschaykib
- License: other
- Created: 2018-07-21T14:44:57.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-01-19T10:05:24.000Z (about 1 year ago)
- Last Synced: 2024-08-13T07:11:18.759Z (6 months ago)
- Language: R
- Homepage:
- Size: 205 KB
- Stars: 5
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - Dschaykib/newsmd - A package to create and update the NEWS.md file (R)
README
# newsmd - 0.5.1
| branch | master | dev |
| ------------- | ------ | ---- |
| R CMD check | [data:image/s3,"s3://crabby-images/02d09/02d09b3ef7ae7ec6ba59ff2f7805687516ac0da4" alt="master-branch"](https://github.com/Dschaykib/newsmd/actions?query=workflow%3AR-CMD-check-fix+branch%3Amaster) | [data:image/s3,"s3://crabby-images/a95c8/a95c8a2c37852409e6ad0956d083b482e7919ebc" alt="dev-branch"](https://github.com/Dschaykib/newsmd/actions?query=workflow%3AR-CMD-check-fix+branch%3Adev) |
| test coverage | [data:image/s3,"s3://crabby-images/19ec5/19ec56be3db1238ac0d0e6a412ca152b2610e57c" alt="master-test-coverage"](https://codecov.io/gh/Dschaykib/newsmd/branch/master) | [data:image/s3,"s3://crabby-images/9df9d/9df9decdb6de7cfadf64b64ba0c8476e9c51565c" alt="dev-test-coverage"](https://codecov.io/gh/Dschaykib/newsmd/branch/dev) |
| lints | [data:image/s3,"s3://crabby-images/5f75a/5f75a2ad183baf88c40d21d2b3cb438560eca7aa" alt="master-lints"](https://github.com/Dschaykib/newsmd/actions?query=workflow%3Alints+branch%3Amaster) | [data:image/s3,"s3://crabby-images/46a0c/46a0c78b1d67fbc55725636626e9a9eee0748749" alt="dev-lints"](https://github.com/Dschaykib/newsmd/actions?query=workflow%3Alints+branch%3Adev) |
| CRAN | [data:image/s3,"s3://crabby-images/f0cdd/f0cdd5ed5e40157089a15ccbbdad49f81c1b377a" alt="CRAN"](https://cran.r-project.org/web/packages/newsmd/index.html) | data:image/s3,"s3://crabby-images/0a246/0a246f02bee30bd8a6877f5c4384e181d86243b1" alt="DevVersion" |----
A package to create and update the `NEWS.md` file.
## Installation
``` R
install.packages("newsmd")
# for dev version use
devtools::install_github("Dschaykib/newsmd", ref = "dev")
library(newsmd)
```## Usage of `newsmd`
The main part of the package is the `news` object, which is an R6 class object and contains the text for the `NEWS.md` file. You can add versions, subtitles and bullet points to it via the objects' methods. If you want to create the `NEWS.md` file from your git commits, then have a look at these packages: [fledge](https://github.com/cynkra/fledge) or [autonewsmd](https://github.com/kapsner/autonewsmd).
### Initialise a new object
To initialise a new object you can use two different ways:
```R
my_news <- news$new()
my_news <- newsmd()
```The default text contains markdown code and looks like this:
```
## version 0.0.0.9000---
### NEWS.md setup
- added NEWS.md creation with newsmd
```From version 0.4.0, you can also start with an existing `NEWS.md` file. In this case, the file is checked for the last version and adds a new dev version to it.
### Adding a the next version
With `add_version` you can update the version number.
```R
my_news$add_version("0.0.1")
```### Adding a new subtitle
With `add_subtitle` you can add a new subtitle, where the following bullet points will be under.
```R
my_news$add_subtitle("Bugfixes")
```### Adding more bullets
With `add_bullet` you can add more bullet points to the latest version and latest subtitle.
```R
my_news$add_bullet(c("this is point 1", "this is point 2"))
```### Getting the whole text
After these few changes, let's see how the file looks. The `get_text` method will return each single line of the file. Alternatively you can just use `print(my_news)`.
```R
my_news$get_text()
``````
[1] "## version 0.0.1"
[2] ""
[3] "---"
[4] ""
[5] ""
[6] "### Bugfixes"
[7] ""
[8] "- this is point 1"
[9] "- this is point 2"
[10] ""
[11] ""
[12] "## version 0.0.0.9000"
[13] ""
[14] "---"
[15] ""
[16] "### NEWS.md setup"
[17] ""
[18] "- added NEWS.md creation with newsmd"
[19] ""
```### Writing the NEWS.md file
At last, with `write` you can save all your changes into the `NEWS.md` file.
```R
my_news$write()
```## Combination with the `desc` package
The goal of this package was to update the `NEWS.md` file in addition to the `DESCRIPTION` file. To optimize the workflow I suggest the `desc` package. For example instead of manually defining the version number, you can use `desc_bump_version()` and `get_version()` of the `desc` package:
```R
my_desc$bump_version("patch")
my_news$add_version(my_desc$get_version())my_news$add_bullet("added automated creation for DESCRIPTION and NEWS.md")
```The full example script I used for this package's NEWS file, can be found [here](https://github.com/Dschaykib/newsmd/blob/master/misc/update_DESCRIPTION_NEWS.R).