-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathREADME.Rmd
212 lines (155 loc) · 11.2 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
<!-- badges: start -->
[![fusen status badge](https://thinkr-open.r-universe.dev/badges/fusen)](https://thinkr-open.r-universe.dev)
[![CRAN status](https://www.r-pkg.org/badges/version/fusen)](https://CRAN.R-project.org/package=fusen)
[![R-CMD-check](https://github.com/ThinkR-open/fusen/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/ThinkR-open/fusen/actions/workflows/R-CMD-check.yaml)
[![codecov](https://codecov.io/gh/ThinkR-open/fusen/branch/main/graph/badge.svg)](https://app.codecov.io/gh/ThinkR-open/fusen)
[![](https://cranlogs.r-pkg.org/badges/fusen)](https://cran.r-project.org/package=fusen)
<!-- badges: end -->
# fusen <img src="man/figures/logo.png" align="right" alt="" width="120" />
{fusen} inflates a Rmarkdown file to magically create a package.
> If you know how to create a Rmarkdown file, then you know how to build a package.
```{r echo=FALSE, out.width="75%", fig.align='center'}
knitr::include_graphics("man/figures/fusen_inflate_functions.png")
```
_Fill the flat Rmd (or qmd) template with everything in one place and {fusen} will inflate the identified parts in the correct package files and directories._
> The {fusen} Rmarkdown template encourages users to fill their documentation and tests at the same time of writing their functions code. Thanks to the R package structure used by {fusen}, you can build a robust workflow or R package. {fusen} simplifies and reduces the number of steps towards a full R package.
> After that, your {pkgdown} documentation website is one command away to be shared with all your users.
This {fusen} package is a real-world example of {fusen} use as it is itself created from the flat templates available in `"dev/"` folder in its GitHub repository. You can have a look at its architecture in the [Readme of the "dev" directory](https://github.com/ThinkR-open/fusen/blob/main/dev/README.md).
## Installation
You can install the released CRAN version:
```{r, eval=FALSE}
install.packages("fusen")
```
> *Full documentation for the CRAN version is here: https://thinkr-open.github.io/fusen/*
You can install the development version of {fusen} from r-universe or GitHub:
```{r, eval=FALSE}
# From r-universe.dev (No need for GITHUB_PAT)
install.packages("fusen", repos = c("https://thinkr-open.r-universe.dev", "https://cloud.r-project.org"))
# Or with {pak} using GitHub API - Need for GITHUB_PAT
# install.packages("pak")
pak::pak("ThinkR-open/fusen")
```
> *Full documentation for the development version is here: https://thinkr-open.github.io/fusen/dev/*
## You are one Rmd away from building a package!
*{fusen} is all about correctly separating and naming chunks.*
- Create a new directory / new project with
- RStudio template: File > New Project > New directory > Package using {fusen}
```{r echo=FALSE, out.width="50%"}
knitr::include_graphics("man/figures/fusen_rstudio_project.png")
```
- Choose the template
- Choose the template `teaching` the first time to see how {fusen} works,
- Choose the template `full` the second time to answer most of your questions
```{r echo=FALSE, out.width="50%"}
knitr::include_graphics("man/figures/create_fusen_rstudio.png")
```
- *Or command line: `create_fusen("path/to/new/project", template = "teaching")`*
- Open the "dev/flat_teaching.Rmd" to start setting up the package
- In this flat Rmd template, run the first chunks named `description` asking to describe your package and license it
+ They look like these lines of code:
```{r, eval=FALSE}
fill_description(fields = list(Title = "My Awesome Package"))
usethis::use_mit_license("John Doe")
```
- Write your analysis and functionalities following the Rmd template
+ You probably develop them with a few examples and tests
+ *For the first time, you can let the code as is, this is already the content for a working package*
- Run the following code to **transform the flat Rmd as an inflated package**
+ This will open the vignette created
```{r, eval=FALSE}
fusen::inflate(
flat_file = "dev/flat_teaching.Rmd",
vignette_name = "Get started",
check = TRUE
)
```
- Share it on a website on GitHub
```{r eval=FALSE}
fusen::init_share_on_github()
```
**That's it! You built a package! A documented and tested package!**
**You even have a website for it!**
Let's test it now:
- Install your package locally
```{r, eval=FALSE}
remotes::install_local()
```
- Restart your R session to clean environment
+ You can restart your RStudio session to let appear the "Build" tab panel
- Test functions of your package
```{r, eval=FALSE}
my.package::my_median(1:12)
```
## Description of the Rmd template
As I said earlier, this is all about using the correct split and name for your chunks.
- Follow the `"dev/flat_template.Rmd"` template to write your documentation and build your functions and test your examples.
- Chunk named `function` gets the code of a function
- Chunk named `example` gets the code for examples of using the function. This will be used for function `@examples` and will be kept for the vignette.
+ As chunk names should be unique in the future vignette, you can add function names like `example-myfunction`, `example-myotherfunction`, ...
- Chunk named `tests` gets the code for unit testing
- Chunk named `development` gets the code for development purposes, usually only used once like {usethis} functions
- **Inflate** the flat Rmd template to transform it as a package with functions, unit tests and the current Rmd transformed as a vignette. And check.
_Note that the `"flat*.Rmd"` files created with templates `full` and `teaching` are indeed working examples that can directly be inflated._
> You can also have a look at [{squirrels.fusen}](https://github.com/statnmap/squirrels.fusen) that has been built to present the method. Follow the commits: https://github.com/statnmap/squirrels.fusen/commits/main
## How to maintain a {fusen}? Can I use {fusen} with old-way packages?
There is a dedicated vignette to answer this: https://thinkr-open.github.io/fusen/articles/Maintain-packages-with-fusen.html
- **Option 1**: After a first inflate of your flat file, you can continue developing in the "flat_template.Rmd" file, and then inflate it using `fusen::inflate_all()`
- **Option 2**: After you're done with inflating, you can decide to deprecate your flat file with `fusen::deprecate_flat_file()` and develop in the package files directly, as for any other R package. 'fusen' has no impact on the structure of a classical package once inflated.
> Advice: Use git as soon as possible, this will avoid losing your work if you made some modifications in the wrong place
> Advice: Show the package structure with `fusen::draw_package_structure()` in a "dev/Readme.md" file to help developers
## Who is {fusen} for?
If you mind about documentation for your users and tests for your maintainers, {fusen} is for you. Start writing documentation and tests while you conceive your functionalities, so that there are directly available for your users and maintainers.
Indeed, when you write a Rmarkdown file (or a vignette), you create a documentation for your analysis (or package). When you write some functions, you check your functions with examples and you maybe write some unit tests to verify the outputs. This is even more true if you follow this guide : ['Rmd first': When development starts with documentation](https://rtask.thinkr.fr/when-development-starts-with-documentation/)
Write them all in the same file while you explore the possibilities and let {fusen} store them in the right place for you!
*{fusen} was first addressed to people who never wrote a package before* and know how to write a Rmarkdown file. Understanding package infrastructure and correctly settling it can be frightening. This package may help them do the first step!
*{fusen} is also addressed to more advanced developers who care about their users and the sustainability of their products, and are fed up with switching* between R files, tests files, vignettes while they prototype their functions. In particular, when changing arguments of a function, we need to change examples, unit tests in multiple places. Here, you can do it in one place. No risk to forget one. Think also about code review: everything related to one function is at the same place.
## Q&A : All tips and tricks of a {fusen} template
- Can I be lazy in names used?
- Can I knit the content of the flat template ?
- How to declare packages with library() for the future vignette ?
- How to include examples that cannot be run ?
- Document your internal datasets in a function chunk as usual
- How to ignore some chunks ?
- How to create a vignette with different title and Index Entry?
- How not to create a vignette ?
- How to get a pre-filled template for a specific function name ?
- How to inflate multiple flat files ?
- How to store multiple functions in a unique R file ?
- How to read dataset that I usually put in “tests/testthat/” for my unit tests?
- Can I load all functions of the current flat file during development without having to `inflate()`?
- Can I inflate a Quarto qmd file?
- Can I use {fusen} with {golem}?
- How can I know if R files were created from a flat or not ?
=> See vignette Tips and Tricks: https://thinkr-open.github.io/fusen/articles/tips-and-tricks.html
## Why is this package named {fusen} ?
A fusen is an origami. It is a flat piece of paper that you fold in a specific way so that at the end, you can magically inflate it to let a nice box appear.
```{r, echo=FALSE, out.width="25%"}
knitr::include_graphics("man/figures/fusen_seb_crop_small.jpg")
```
Similarly, the {fusen} package uses a flat Rmd template, that you fill in a specific way so that at the end, you can magically `inflate()` it to let a nice package appear.
<details><summary> Click here to fold your {fusen}…</summary><img src="man/figures/fusen-fold-origami.gif" />
</details>
## Contributing
'fusen' is partially built using 'fusen' itself.
If you're not sure on how to contribute using 'fusen', you can contribute as for any other package:
a package made with the help of 'fusen' does have exactly the same structure as a classical package.
Knowing that, if you want to contribute to 'fusen', you can follow the instructions in the CONTRIBUTING.md file.
## Acknowledgments
- Thanks to Deemah who asked me to go further 'Rmd first' after my presentation at useR 2019 in Toulouse: ['The "Rmd first" method: when projects start with documentation'](https://github.com/statnmap/prez/blob/master/2019-07_useR_Toulouse.pdf) (Video on Youtube: https://youtu.be/cB1BCxFbhtk).
- Thanks to @rundel and its package {parsermd} who helped me get back in this project with ease : https://github.com/rundel/parsermd
+ Now replaced with {lightparser} : https://github.com/ThinkR-open/lightparser
- Thanks to the [ThinkR team](https://rtask.thinkr.fr) who adopted this package for its daily production.
## Code of Conduct
Please note that the {fusen} project is released with a [Contributor Code of Conduct](https://contributor-covenant.org/version/2/0/CODE_OF_CONDUCT.html). By contributing to this project, you agree to abide by its terms.