Title: | Build a Package from Rmarkdown Files |
---|---|
Description: | Use Rmarkdown First method to build your package. Start your package with documentation, functions, examples and tests in the same unique file. Everything can be set from the Rmarkdown template file provided in your project, then inflated as a package. Inflating the template copies the relevant chunks and sections in the appropriate files required for package development. |
Authors: | Sebastien Rochette [aut, cre] , ThinkR [cph] |
Maintainer: | Sebastien Rochette <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.6.0.9003 |
Built: | 2024-11-26 05:55:33 UTC |
Source: | https://github.com/ThinkR-open/fusen |
Add flat Rmd file that drives package development
add_additional( pkg = ".", dev_dir = "dev", flat_name = "additional", overwrite = FALSE, open = TRUE ) add_minimal_flat( pkg = ".", dev_dir = "dev", flat_name = "minimal", overwrite = FALSE, open = TRUE ) add_minimal_package( pkg = ".", dev_dir = "dev", flat_name = "minimal", overwrite = FALSE, open = TRUE ) add_full( pkg = ".", dev_dir = "dev", flat_name = "full", overwrite = FALSE, open = TRUE ) add_dev_history(pkg = ".", dev_dir = "dev", overwrite = FALSE, open = TRUE) add_flat_template( template = c("full", "minimal_package", "minimal_flat", "additional", "teaching", "dev_history"), pkg = ".", dev_dir = "dev", flat_name = NULL, overwrite = FALSE, open = TRUE )
add_additional( pkg = ".", dev_dir = "dev", flat_name = "additional", overwrite = FALSE, open = TRUE ) add_minimal_flat( pkg = ".", dev_dir = "dev", flat_name = "minimal", overwrite = FALSE, open = TRUE ) add_minimal_package( pkg = ".", dev_dir = "dev", flat_name = "minimal", overwrite = FALSE, open = TRUE ) add_full( pkg = ".", dev_dir = "dev", flat_name = "full", overwrite = FALSE, open = TRUE ) add_dev_history(pkg = ".", dev_dir = "dev", overwrite = FALSE, open = TRUE) add_flat_template( template = c("full", "minimal_package", "minimal_flat", "additional", "teaching", "dev_history"), pkg = ".", dev_dir = "dev", flat_name = NULL, overwrite = FALSE, open = TRUE )
pkg |
Path where to save file |
dev_dir |
Name of directory for development Rmarkdown files. Default to "dev". |
flat_name |
Name of the file to write in dev. Use the name of the main function of your template to get chunks pre-filled with this function name. |
overwrite |
Whether to overwrite existing flat Rmd template file with same name |
open |
Logical. Whether to open file after creation |
template |
Name of the template to use. See details. |
Choose template
among the different templates available:
"full": The full template with a reproducible package that can directly be inflated. It comes along with the "dev_history" template. Default.
"minimal_package": Minimal template to start a new package when you already know 'fusen', along with the "dev_history" template. Note that this is called "minimal" in create_fusen()
.
"minimal_flat" or "additional": Template for a new minimal flat file only.
"teaching": Template with a reproducible package, simpler than "full", but everything to teach the minimal structure of a package.
"dev_history": Template with functions commonly used during package development. This does not contain chunks to write your own functions.
Abbreviated names can also be used for the different templates: "add" for additional, "minflat" for minimal_flat, "minpkg" for minimal_package "teach" for teaching, "dev" for "dev_history".
add_additional()
, add_minimal_flat()
, add_dev_history()
, add_minimal_package()
, add_full()
are wrapper around add_flat_template("additional")
, ...
Create flat Rmd file(s) template(s) and return its (their) path
# Create a new project dummypackage <- tempfile("dummy.package.flat") dir.create(dummypackage) # Add add_flat_template(template = "teaching", pkg = dummypackage) # Delete dummy package unlink(dummypackage, recursive = TRUE) # For classical use in your package ## Not run: # first time ever using 'fusen' add_flat_template("full") # first time in your new package add_flat_template("minimal_package") # add new flat file for new functions add_flat_template("add") add_additional() add_minimal_flat() # add only the dev_history file in an existing package add_dev_history() # add new flat template for teaching (a reduced full template) add_flat_template("teaching") ## End(Not run)
# Create a new project dummypackage <- tempfile("dummy.package.flat") dir.create(dummypackage) # Add add_flat_template(template = "teaching", pkg = dummypackage) # Delete dummy package unlink(dummypackage, recursive = TRUE) # For classical use in your package ## Not run: # first time ever using 'fusen' add_flat_template("full") # first time in your new package add_flat_template("minimal_package") # add new flat file for new functions add_flat_template("add") add_additional() add_minimal_flat() # add only the dev_history file in an existing package add_dev_history() # add new flat template for teaching (a reduced full template) add_flat_template("teaching") ## End(Not run)
Create 'fusen' chunks inside your Rmd
add_fusen_chunks( function_name = NULL, export = getOption("fusen.export.functions") )
add_fusen_chunks( function_name = NULL, export = getOption("fusen.export.functions") )
function_name |
Name of the function to create. If NULL (the default), the user will be prompted to enter it. |
export |
Should the function be exported?
Default is |
A list with the context and the content, invisibly.
## Not run: add_fusen_chunks("this", export = TRUE) ## End(Not run)
## Not run: add_fusen_chunks("this", export = TRUE) ## End(Not run)
If user start their package without 'fusen' or with version < 0.4, they need to create the config file, with already existing functions.
check_not_registered_files( path = ".", config_file, guess = TRUE, to_csv = TRUE, open = FALSE )
check_not_registered_files( path = ".", config_file, guess = TRUE, to_csv = TRUE, open = FALSE )
path |
Path to package to check for not registered files |
config_file |
Path to the configuration file |
guess |
Logical. Guess if the file was inflated by a specific flat file |
to_csv |
Logical. Whether to store along the config file, the outputs in a csv for the user to clean it manually |
open |
Logical. Whether to open the csv of unregistered files. |
Path to csv file if to_csv
is TRUE. dput()
of the dataframe otherwise.
register_all_to_config()
for automatically registering all files already present in the project,
inflate_all()
to inflate every flat files according to the configuration file.
## Not run: # Run this on the current package in development out_csv <- check_not_registered_files() file.edit(out_csv) ## End(Not run) # Or you can try on the reproducible example dummypackage <- tempfile("clean") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages(add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE)) flat_file <- dev_file[grepl("flat_", dev_file)] # Inflate once usethis::with_project(dummypackage, { suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) # Add a not registered file to the package cat("# test R file\n", file = file.path(dummypackage, "R", "to_keep.R")) # Use the function to check the list of files out_csv <- check_not_registered_files(dummypackage) out_csv # Read the csv to see what is going on content_csv <- read.csv(out_csv, stringsAsFactors = FALSE) content_csv # Keep it all or delete some files, and then register all remaining out_config <- register_all_to_config() out_config # Open the out_config file to see what's going on yaml::read_yaml(out_config) }) unlink(dummypackage, recursive = TRUE)
## Not run: # Run this on the current package in development out_csv <- check_not_registered_files() file.edit(out_csv) ## End(Not run) # Or you can try on the reproducible example dummypackage <- tempfile("clean") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages(add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE)) flat_file <- dev_file[grepl("flat_", dev_file)] # Inflate once usethis::with_project(dummypackage, { suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) # Add a not registered file to the package cat("# test R file\n", file = file.path(dummypackage, "R", "to_keep.R")) # Use the function to check the list of files out_csv <- check_not_registered_files(dummypackage) out_csv # Read the csv to see what is going on content_csv <- read.csv(out_csv, stringsAsFactors = FALSE) content_csv # Keep it all or delete some files, and then register all remaining out_config <- register_all_to_config() out_config # Open the out_config file to see what's going on yaml::read_yaml(out_config) }) unlink(dummypackage, recursive = TRUE)
Create a new fusen project
create_fusen( path, template = c("full", "minimal", "teaching", "dev_history"), flat_name = template, open = TRUE, overwrite = FALSE, with_git = FALSE )
create_fusen( path, template = c("full", "minimal", "teaching", "dev_history"), flat_name = template, open = TRUE, overwrite = FALSE, with_git = FALSE )
path |
Character. Path where to create the new fusen project. |
template |
Character. Name of the template to be used among "full", "minimal", "teaching" and "dev_history". |
flat_name |
Character. Filename of the flat file created.
This is also used to name the first function of the file in |
open |
Logical. Should the newly created project be opened ? |
overwrite |
Logical. Allow to overwrite 'dev/' files if path exists. |
with_git |
Logical. Should git be initialized in the newly created project ? |
See add_flat_template
for details about the different options for template
.
Template "additional" is not available here as it is meant to be used with an already
existing 'fusen'.
Path to dev and flat files. Side-effect: Create a new directory to build a package
my_path <- tempfile("mypkg") create_fusen(path = my_path, template = "full", open = FALSE)
my_path <- tempfile("mypkg") create_fusen(path = my_path, template = "full", open = FALSE)
It is not inflated again during [inflate_all()]
as it is
identified as deprecated in the config file.
Previously generated files get "do not edit by hand" message removed.
The flat file is moved to "dev/flat_history".
deprecate_flat_file(flat_file)
deprecate_flat_file(flat_file)
flat_file |
Path to the flat file to deprecate |
Used for side effect. Move flat file to "dev/flat_history", update config file, and remove "do not edit by hand" message.
## Not run: # These functions change the current user workspace dev_file <- suppressMessages( add_flat_template( template = "add", pkg = dummypackage, overwrite = TRUE, open = FALSE ) ) deprecate_flat_file(flat_file = "dev/flat_additional.Rmd") ## End(Not run)
## Not run: # These functions change the current user workspace dev_file <- suppressMessages( add_flat_template( template = "add", pkg = dummypackage, overwrite = TRUE, open = FALSE ) ) deprecate_flat_file(flat_file = "dev/flat_additional.Rmd") ## End(Not run)
Fill DESCRIPTION file of the package
fill_description(pkg = ".", fields, overwrite = FALSE)
fill_description(pkg = ".", fields, overwrite = FALSE)
pkg |
Path to package |
fields |
A named list of fields to add to DESCRIPTION, potentially
overriding default values. See |
overwrite |
Whether to overwrite existing DESCRIPTION |
Fill DESCRIPTION file with fields. Return path to file.
# Create a new project dummypackage <- tempfile("dummy.package.desc") dir.create(dummypackage) fill_description( pkg = dummypackage, fields = list( Title = "Build A Package From Rmarkdown file", Description = paste( "Use Rmd First method to build your package.", "Start your package with documentation.", "Everything can be set from a Rmarkdown file in your project." ), `Authors@R` = c( person("John", "Doe", email = "[email protected]", role = c("aut", "cre"), comment = c(ORCID = "0000-0000-0000-0000") ) ) ) ) # Delete dummy package unlink(dummypackage, recursive = TRUE)
# Create a new project dummypackage <- tempfile("dummy.package.desc") dir.create(dummypackage) fill_description( pkg = dummypackage, fields = list( Title = "Build A Package From Rmarkdown file", Description = paste( "Use Rmd First method to build your package.", "Start your package with documentation.", "Everything can be set from a Rmarkdown file in your project." ), `Authors@R` = c( person("John", "Doe", email = "[email protected]", role = c("aut", "cre"), comment = c(ORCID = "0000-0000-0000-0000") ) ) ) ) # Delete dummy package unlink(dummypackage, recursive = TRUE)
Get all functions created in a R file
get_all_created_funs(file)
get_all_created_funs(file)
file |
A R file |
A character vector of function names
file_path <- tempfile(fileext = ".R") cat( "my_fun <- function() {1}", "my_fun2 <- function() {2}", sep = "\n", file = file_path ) get_all_created_funs(file_path)
file_path <- tempfile(fileext = ".R") cat( "my_fun <- function() {1}", "my_fun2 <- function() {2}", sep = "\n", file = file_path ) get_all_created_funs(file_path)
Get structure and information of a 'fusen' built package for developers
Draw a tree of the package structure in the console
get_package_structure(config_file, emoji = TRUE, silent = FALSE) draw_package_structure(structure_list, silent = FALSE)
get_package_structure(config_file, emoji = TRUE, silent = FALSE) draw_package_structure(structure_list, silent = FALSE)
config_file |
Path to a source configuration file to get the structure from |
emoji |
Add emojis to the output |
silent |
Whether to print messages |
structure_list |
A list of information about the package as issued
from |
A list of information about the package
## Not run: # This only works inside a 'fusen' built package pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) ## End(Not run) # Example with a dummy package dummypackage <- tempfile("drawpkg.structure") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages( add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE) ) flat_file <- dev_file[grepl("flat_", dev_file)] usethis::with_project(dummypackage, { # Add an extra R file with internal function # to list in "keep" dir.create("R") cat("extra_fun <- function() {1}\n", file = "R/my_extra_fun.R") # Works with classical package pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) }) usethis::with_project(dummypackage, { # Works with 'fusen' package suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) })
## Not run: # This only works inside a 'fusen' built package pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) ## End(Not run) # Example with a dummy package dummypackage <- tempfile("drawpkg.structure") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages( add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE) ) flat_file <- dev_file[grepl("flat_", dev_file)] usethis::with_project(dummypackage, { # Add an extra R file with internal function # to list in "keep" dir.create("R") cat("extra_fun <- function() {1}\n", file = "R/my_extra_fun.R") # Works with classical package pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) }) usethis::with_project(dummypackage, { # Works with 'fusen' package suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) pkg_structure <- get_package_structure() draw_package_structure(pkg_structure) })
Inflate Rmd to package
inflate( pkg = ".", flat_file, vignette_name = "Get started", open_vignette = TRUE, check = TRUE, document = TRUE, overwrite = "ask", clean = "ask", update_params = TRUE, codecov = FALSE, ... )
inflate( pkg = ".", flat_file, vignette_name = "Get started", open_vignette = TRUE, check = TRUE, document = TRUE, overwrite = "ask", clean = "ask", update_params = TRUE, codecov = FALSE, ... )
pkg |
Path to package |
flat_file |
Path to Rmarkdown file to inflate |
vignette_name |
Character. Title of the resulting vignette.
Use |
open_vignette |
Logical. Whether to open vignette file at the end of the process |
check |
Logical. Whether to check package after Rmd inflating |
document |
Logical. Whether to document your package using
|
overwrite |
Logical (TRUE, FALSE) or character ("ask", "yes", "no). Whether to overwrite vignette and functions if already exists. |
clean |
Logical (TRUE, FALSE) or character ("ask", "yes", "no) Whether to delete files that are not anymore created by the current flat file. Typically, if you have deleted or renamed a function in the flat file. Default to "ask". |
update_params |
Logical. Whether to update the inflate parameters in the configuration file. |
codecov |
Logical. Whether to compute code coverage (with |
... |
Arguments passed to |
Package structure. Return path to current package.
inflate_all()
to inflate every flat files according to the configuration file.
# Create a new project dummypackage <- tempfile("dummy.package") dir.create(dummypackage) # {fusen} steps dev_file <- add_flat_template(template = "full", pkg = dummypackage, overwrite = TRUE) flat_file <- dev_file[grepl("flat", dev_file)] fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Exploration of my Data", check = FALSE ) # Explore directory of the package # browseURL(dummypackage) # Try pkgdown build # usethis::use_pkgdown() # pkgdown::build_site(dummypackage) # Delete dummy package unlink(dummypackage, recursive = TRUE)
# Create a new project dummypackage <- tempfile("dummy.package") dir.create(dummypackage) # {fusen} steps dev_file <- add_flat_template(template = "full", pkg = dummypackage, overwrite = TRUE) flat_file <- dev_file[grepl("flat", dev_file)] fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Exploration of my Data", check = FALSE ) # Explore directory of the package # browseURL(dummypackage) # Try pkgdown build # usethis::use_pkgdown() # pkgdown::build_site(dummypackage) # Delete dummy package unlink(dummypackage, recursive = TRUE)
Inflate all the flat files stored in "dev/" and starting with "flat_"
inflate_all( pkg = ".", document = TRUE, check = TRUE, open_vignette = FALSE, overwrite = TRUE, check_unregistered = TRUE, codecov = FALSE, stylers, ... ) inflate_all_no_check( pkg = ".", document = TRUE, open_vignette = FALSE, overwrite = TRUE, check_unregistered = TRUE, codecov = FALSE, stylers, ... )
inflate_all( pkg = ".", document = TRUE, check = TRUE, open_vignette = FALSE, overwrite = TRUE, check_unregistered = TRUE, codecov = FALSE, stylers, ... ) inflate_all_no_check( pkg = ".", document = TRUE, open_vignette = FALSE, overwrite = TRUE, check_unregistered = TRUE, codecov = FALSE, stylers, ... )
pkg |
Path to package |
document |
Logical. Whether to document your package using
|
check |
Logical. Whether to check package after Rmd inflating |
open_vignette |
Logical. Whether to open vignette file at the end of the process |
overwrite |
Logical (TRUE, FALSE) or character ("ask", "yes", "no). Whether to overwrite vignette and functions if already exists. |
check_unregistered |
Logical. Whether to help detect unregistered files. Typically files not created from a flat file and added manually in the repository. |
codecov |
Logical. Whether to compute code coverage (with |
stylers |
Function to be run at the end of the process,
like |
... |
Arguments passed to |
This requires to inflate()
all flat files
individually at least once, so that their specific
inflate configurations are stored.
This also requires to register all R,
tests and vignettes files of your package,
even if not created with an inflate.
Run inflate_all()
once and read the messages.
The first time, you will probably need to run
register_all_to_config()
if your package is not new.
For more information, read the
vignette("inflate-all-your-flat-files", package = "fusen")
side effect. Inflates all your flat files that can be inflated.
inflate()
for the options of a single file inflate,
check_not_registered_files()
for the list of files
not already associated with a flat file in the config file,
register_all_to_config()
for automatically registering
all files already present in the project before the first inflate_all()
## Not run: # Usually, in the current package run inflate_all() directly # These functions change the current user workspace inflate_all() # Or inflate_all_no_check() to prevent checks to run inflate_all_no_check() # Or inflate with the styler you want inflate_all(stylers = styler::style_pkg) ## End(Not run) # You can also inflate_all flats of another package as follows # Example with a dummy package with a flat file dummypackage <- tempfile("inflateall.otherpkg") dir.create(dummypackage) fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) flat_files <- add_minimal_package( pkg = dummypackage, overwrite = TRUE, open = FALSE ) flat_file <- flat_files[grep("flat", basename(flat_files))] # Inflate the flat file once usethis::with_project(dummypackage, { # if you are starting from a brand new package, inflate_all() will crash # it's because of the absence of a fusen config file # # inflate_all() # will crash # Add licence usethis::use_mit_license("John Doe") # you need to inflate manually your flat file first inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) # your config file has been created config_yml_ref <- yaml::read_yaml(getOption("fusen.config_file", default = "dev/config_fusen.yaml")) }) # Next time, you can run inflate_all() directly usethis::with_project(dummypackage, { # now you can run inflate_all() inflate_all(check = FALSE, document = TRUE) }) # If you wish, the code coverage can be computed usethis::with_project(dummypackage, { # now you can run inflate_all() inflate_all(check = FALSE, document = TRUE, codecov = TRUE) }) # Clean the temporary directory unlink(dummypackage, recursive = TRUE)
## Not run: # Usually, in the current package run inflate_all() directly # These functions change the current user workspace inflate_all() # Or inflate_all_no_check() to prevent checks to run inflate_all_no_check() # Or inflate with the styler you want inflate_all(stylers = styler::style_pkg) ## End(Not run) # You can also inflate_all flats of another package as follows # Example with a dummy package with a flat file dummypackage <- tempfile("inflateall.otherpkg") dir.create(dummypackage) fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) flat_files <- add_minimal_package( pkg = dummypackage, overwrite = TRUE, open = FALSE ) flat_file <- flat_files[grep("flat", basename(flat_files))] # Inflate the flat file once usethis::with_project(dummypackage, { # if you are starting from a brand new package, inflate_all() will crash # it's because of the absence of a fusen config file # # inflate_all() # will crash # Add licence usethis::use_mit_license("John Doe") # you need to inflate manually your flat file first inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) # your config file has been created config_yml_ref <- yaml::read_yaml(getOption("fusen.config_file", default = "dev/config_fusen.yaml")) }) # Next time, you can run inflate_all() directly usethis::with_project(dummypackage, { # now you can run inflate_all() inflate_all(check = FALSE, document = TRUE) }) # If you wish, the code coverage can be computed usethis::with_project(dummypackage, { # now you can run inflate_all() inflate_all(check = FALSE, document = TRUE, codecov = TRUE) }) # Clean the temporary directory unlink(dummypackage, recursive = TRUE)
Search for flat files listed in fusen config file, and for rmd and qmd files starting with "flat_" in dev/ folder, and dev/flat_history folder
list_flat_files(pkg = ".")
list_flat_files(pkg = ".")
pkg |
Path to package |
a vector of flat files paths
Load the code of all 'function' chunk in a flat file
load_flat_functions(flat_file, envir = globalenv())
load_flat_functions(flat_file, envir = globalenv())
flat_file |
Path to the flat to load functions from |
envir |
the |
Path to flat file loaded. Used for side effect: Load functions in the global environment.
## Not run: # Use this command directly in the console fusen::load_flat_functions() # Or choose a flat file to load functions from load_flat_functions(flat_file = "dev/flat_full.Rmd") load_flat_functions(flat_file = "dev/flat_clean_fusen_files.Rmd") ## End(Not run)
## Not run: # Use this command directly in the console fusen::load_flat_functions() # Or choose a flat file to load functions from load_flat_functions(flat_file = "dev/flat_full.Rmd") load_flat_functions(flat_file = "dev/flat_clean_fusen_files.Rmd") ## End(Not run)
Helps transition from non-fusen packages or made with earlier version
register_all_to_config(pkg = ".", config_file)
register_all_to_config(pkg = ".", config_file)
pkg |
Path to the package from which to add file to configuration file |
config_file |
Path to the configuration file |
Invisible path to 'fusen' configuration file
check_not_registered_files()
for the list of files not already associated with a flat file in the config file,
## Not run: # Usually run this one inside the current project # Note: running this will write "dev/config_fusen.yaml" in your working directory register_all_to_config() ## End(Not run) # Or you can try on the reproducible example dummypackage <- tempfile("register") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages(add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE)) flat_file <- dev_file[grepl("flat_", dev_file)] # Inflate once usethis::with_project(dummypackage, { suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) out_path <- register_all_to_config(dummypackage) # Look at the output yaml::read_yaml(out_path) })
## Not run: # Usually run this one inside the current project # Note: running this will write "dev/config_fusen.yaml" in your working directory register_all_to_config() ## End(Not run) # Or you can try on the reproducible example dummypackage <- tempfile("register") dir.create(dummypackage) # {fusen} steps fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) dev_file <- suppressMessages(add_flat_template(pkg = dummypackage, overwrite = TRUE, open = FALSE)) flat_file <- dev_file[grepl("flat_", dev_file)] # Inflate once usethis::with_project(dummypackage, { suppressMessages( inflate( pkg = dummypackage, flat_file = flat_file, vignette_name = "Get started", check = FALSE, open_vignette = FALSE ) ) out_path <- register_all_to_config(dummypackage) # Look at the output yaml::read_yaml(out_path) })
Rename a flat file
rename_flat_file(flat_file, new_name)
rename_flat_file(flat_file, new_name)
flat_file |
Path to the flat file to rename |
new_name |
New name for the flat file |
Used for side effect. Flat file renamed, config file updated, inflated files modified when needed.
## Not run: # These functions change the current user workspace dev_file <- suppressMessages( add_flat_template( template = "add", pkg = ".", overwrite = TRUE, open = FALSE ) ) rename_flat_file( flat_file = "dev/flat_additional.Rmd", new_name = "flat_new.Rmd" ) ## End(Not run)
## Not run: # These functions change the current user workspace dev_file <- suppressMessages( add_flat_template( template = "add", pkg = ".", overwrite = TRUE, open = FALSE ) ) rename_flat_file( flat_file = "dev/flat_additional.Rmd", new_name = "flat_new.Rmd" ) ## End(Not run)
This function will delete all the flat files (i.e files listed in the fusen configuration file, as well as rmd or qmd files starting with "flat" in the "dev/" and "dev/flat_history" folders). It will also remove the fusen-related tags added by calls to fusen::inflate()
in files located in the "R/", "tests/" and "vignettes/" folders. Finally, it will also remove the fusen configuration file if it exists.
sepuku(pkg = ".", force = FALSE, verbose = FALSE)
sepuku(pkg = ".", force = FALSE, verbose = FALSE)
pkg |
Character. Path of the current package |
force |
logical. whether to force the cleaning or not, without asking if the user is sure about making this operation (default: FALSE) |
verbose |
logical. whether to display the files that will be deleted or modified (default: FALSE) |
side effect. A package cleaned from fusen-related files or tags
## Not run: sepuku() # If you want to force the cleaning, you can use the force argument sepuku(force = TRUE) # Example with a dummy package dummypackage <- tempfile("sepuku.example") dir.create(dummypackage) fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) usethis::with_project(dummypackage, { # Add licence usethis::use_mit_license("John Doe") dir.create(file.path(dummypackage, "dev")) dir.create(file.path(dummypackage, "dev", "flat_history")) # We add 2 flat files in the package and inflate them dev_file1 <- add_minimal_flat( pkg = dummypackage, flat_name = "flat1.Rmd", open = FALSE ) dev_file2 <- add_minimal_flat( pkg = dummypackage, flat_name = "flat2.Rmd", open = FALSE ) inflate( pkg = dummypackage, flat_file = dev_file1, vignette_name = "Get started", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) inflate( pkg = dummypackage, flat_file = dev_file2, vignette_name = "Get started 2", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) # We deprecate the first flat file, which will be moved to the flat_history folder deprecate_flat_file( file.path(dummypackage, "dev", "flat_flat1.Rmd") ) # We create 2 flat files with the qmd extension file.create(file.path(dummypackage, "dev", "flat_history", "flat_old.qmd")) file.create(file.path(dummypackage, "dev", "flat_qmd.qmd")) sepuku(force = TRUE) # We check that the fusen configuration file has been deleted file.exists( file.path(dummypackage, "dev", "config_fusen.yaml") ) # We check that all the flat files have been deleted length( list.files(file.path(dummypackage, "dev"), pattern = "^flat.*\\.Rmd" ) ) length( list.files(file.path(dummypackage, "dev"), pattern = "^flat.*\\.qmd" ) ) length( list.files(file.path(dummypackage, "dev", "flat_history"), pattern = "^flat.*\\.Rmd" ) ) length( list.files(file.path(dummypackage, "dev", "flat_history"), pattern = "^flat.*\\.qmd" ) ) # We check that all the files with fusen tags have been cleaned length(fusen:::find_files_with_fusen_tags(pkg = dummypackage)) }) # Clean the temporary directory unlink(dummypackage, recursive = TRUE) ## End(Not run)
## Not run: sepuku() # If you want to force the cleaning, you can use the force argument sepuku(force = TRUE) # Example with a dummy package dummypackage <- tempfile("sepuku.example") dir.create(dummypackage) fill_description(pkg = dummypackage, fields = list(Title = "Dummy Package")) usethis::with_project(dummypackage, { # Add licence usethis::use_mit_license("John Doe") dir.create(file.path(dummypackage, "dev")) dir.create(file.path(dummypackage, "dev", "flat_history")) # We add 2 flat files in the package and inflate them dev_file1 <- add_minimal_flat( pkg = dummypackage, flat_name = "flat1.Rmd", open = FALSE ) dev_file2 <- add_minimal_flat( pkg = dummypackage, flat_name = "flat2.Rmd", open = FALSE ) inflate( pkg = dummypackage, flat_file = dev_file1, vignette_name = "Get started", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) inflate( pkg = dummypackage, flat_file = dev_file2, vignette_name = "Get started 2", check = FALSE, open_vignette = FALSE, document = TRUE, overwrite = "yes" ) # We deprecate the first flat file, which will be moved to the flat_history folder deprecate_flat_file( file.path(dummypackage, "dev", "flat_flat1.Rmd") ) # We create 2 flat files with the qmd extension file.create(file.path(dummypackage, "dev", "flat_history", "flat_old.qmd")) file.create(file.path(dummypackage, "dev", "flat_qmd.qmd")) sepuku(force = TRUE) # We check that the fusen configuration file has been deleted file.exists( file.path(dummypackage, "dev", "config_fusen.yaml") ) # We check that all the flat files have been deleted length( list.files(file.path(dummypackage, "dev"), pattern = "^flat.*\\.Rmd" ) ) length( list.files(file.path(dummypackage, "dev"), pattern = "^flat.*\\.qmd" ) ) length( list.files(file.path(dummypackage, "dev", "flat_history"), pattern = "^flat.*\\.Rmd" ) ) length( list.files(file.path(dummypackage, "dev", "flat_history"), pattern = "^flat.*\\.qmd" ) ) # We check that all the files with fusen tags have been cleaned length(fusen:::find_files_with_fusen_tags(pkg = dummypackage)) }) # Clean the temporary directory unlink(dummypackage, recursive = TRUE) ## End(Not run)