{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.
Indeed, this {fusen} package is a real-world example of {fusen} use as
it was itself created from the "dev_history.Rmd"
templates available
in "dev/"
folder in its GitHub repository.
You can install the development version of {fusen} from GitHub:
# install.packages("remotes")
remotes::install_github("ThinkR-open/fusen")
{fusen} is all about correctly separating and naming chunks.
- Create and open a new directory or a new RStudio project
- Choose your directory/package name like
my.package
for instance
- Choose your directory/package name like
- Run the following code directly in the console to add the template Rmd in the project and open it:
dev_file <- fusen::add_dev_history(open = TRUE)
- In the Rmd template, run the first chunks asking to describe your
package and license it
- They look like these lines of code:
fill_description(fields = list(Title = "My Awesome Package"))
usethis::use_mit_license("Sébastien Rochette")
- Write your analysis and functionnalities 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 template Rmd as a
package
- This will open the vignette created
fusen::inflate(rmd = dev_file, name = "my-functionnality", check = TRUE)
That’s it! You built a package!
Let’s test it now:
- Install your package locally
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
my.package::my_median(1:12)
- Test the correct documentation of the package with its dedicated website
# Build {pkgdown} to test it
pkgdown::build_site()
# > See references and articles
# Hide output from package and git
usethis::use_build_ignore("docs")
usethis::use_git_ignore("docs")
As I said earlier, this is all about using the correct split and name for your chunks.
- Follow the
"dev/dev_history.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 numbers like
example-1
,example-2
, …
- As chunk names should be unique in the future vignette, you
can add numbers like
- 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
- Chunk named
- Inflate the template to transform it as a package with functions, unit tests and the current Rmd transformed as a vignette. And check.
Note that the "dev_history.Rmd"
template is indeed a working
example.
- Build a package from Rmd template in a temporary directory
- This is for testing purposes
# Create a new project
tmpdir <- tempdir()
dummypackage <- file.path(tmpdir, "dummypackage")
dir.create(dummypackage)
# {fusen} steps
# Add the template in your package
dev_file <- fusen::add_dev_history(pkg = dummypackage, overwrite = TRUE)
# Description
fusen::fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package"))
# Define License with use_*_license()
usethis::use_mit_license("Sébastien Rochette")
# You may need to execute inflate() in the console directly
fusen::inflate(pkg = dummypackage, rmd = dev_file, name = "exploration")
There is a dedicated vignette to answer this: https://thinkr-open.github.io/fusen/articles/Maintain-packages-with-fusen.html
- Option 1: Modifications are only added to the “dev_history.Rmd” file, which then is inflated to update all packages files
- Option 2: Modifications are realized in the package files directly, and the “dev_history.Rmd” file must be protected from any use.
Advice : Use git as soon as possible, this will avoid losing your work if you made some modifications in the wrong place
When you write a RMarkdown file (or a vignette), you create a documentation for your analysis (or package). Inside, you write some functions, you test 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 After that, you need to move your functions and scripts in the correct place. Let {fusen} do that for you!
{fusen} is first addressed to people who never wrote a package before but 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 are fed up with switching between R files, tests files, vignettes. 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.
A fusen is an origami. It is a 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.
Similarly, the {fusen} package uses one page of RMarkdown, that you fill
in a specific way so that at the end, you can magically inflate()
it
to let a nice package appear.
- 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’ (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
Please note that the {fusen} project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.