-
Notifications
You must be signed in to change notification settings - Fork 525
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add JOSS and JOSE format #229
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
BTW, have you run optipng
on PNG images?
Thank you!
R/joss_article.R
Outdated
"Journal of Open Source Software", | ||
"Journal of Open Source Education") | ||
|
||
template_variables <- c( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How about setting these variables in the YAML frontmatter of the Rmd document? That way, you won't have to worry about escaping certain special characters in the values of these variables (although I guess it would be unlikely that these values could contain characters like double quotes). It will also make the R function much simpler.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wanted to avoid needing these variables in the YAML so that a standard paper.md
would compile without setting them, but now I realized that the document will compile without most of them. The logo and journal name still make sense to define here, but I can drop the rest.
R/joss_article.R
Outdated
base$knitr$opts_chunk$fig.width <- 6 | ||
base$knitr$opts_chunk$fig.height <- 4.15 | ||
base$keep_md <- keep_md | ||
base$clean_supporting <- !keep_md |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All above options can be passed to pdf_document_format()
so you don't need to hack the base
object.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Will do, except keep_md
, which is not supported in pdf_document()
(rstudio/rmarkdown#1001)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I just added support for keep_md
in rmarkdown, so you can get rid of this hack, too.
R/joss_article.R
Outdated
|
||
pandoc_args <- c( | ||
template_variables, | ||
"--csl", find_resource("joss_article", "apa.csl") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I hope the csl
option could be set in the YAML metadata of the Rmd document, too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wanted to avoid doing this because I wanted the format to compile correctly on a standard paper.md
without modifying the YAML.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All other templates in this package include csl
under the skeleton/
directory (instead of resources/
) so the csl file will be copied over when creating a new article using rticles::draft()
, e.g. https://github.com/rstudio/rticles/tree/master/inst/rmarkdown/templates/acm_article/skeleton Then in Rmd: https://github.com/rstudio/rticles/blob/master/inst/rmarkdown/templates/acm_article/skeleton/skeleton.Rmd#L15
I'm aware of the potential disadvantages of this approach (e.g. the csl
file may change in the upstream), but I'd like this template to be consistent with other templates. Similarly, I hope logo_path
, journal_name
, and graphics
variables could all be set in the YAML frontmatter of skeleton.Rmd
(the png logos need to be moved to skeleton/
accordingly).
OK, optimized the images, and simplified the function now that I realize that the article will compile without all those variable set. I have left the |
Just checking in. Is this version mergable? |
Sorry, I haven't had a chance to look at the revision yet. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there is a good chance that this format can be simplified and moved to https://github.com/rstudio/rticles/blob/master/R/article.R. Thanks!
R/joss_article.R
Outdated
pandoc_args = pandoc_args, | ||
citation_package = "none", | ||
fig_width = 6, fig_height = 4.15, | ||
dev = "png" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since you hard-coded these options, are users not supposed to customize fig_width
, fig_height
, or dev
?
BTW, it seems you forgot to pass the ...
argument here.
R/joss_article.R
Outdated
|
||
pandoc_args <- c( | ||
template_variables, | ||
"--csl", find_resource("joss_article", "apa.csl") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All other templates in this package include csl
under the skeleton/
directory (instead of resources/
) so the csl file will be copied over when creating a new article using rticles::draft()
, e.g. https://github.com/rstudio/rticles/tree/master/inst/rmarkdown/templates/acm_article/skeleton Then in Rmd: https://github.com/rstudio/rticles/blob/master/inst/rmarkdown/templates/acm_article/skeleton/skeleton.Rmd#L15
I'm aware of the potential disadvantages of this approach (e.g. the csl
file may change in the upstream), but I'd like this template to be consistent with other templates. Similarly, I hope logo_path
, journal_name
, and graphics
variables could all be set in the YAML frontmatter of skeleton.Rmd
(the png logos need to be moved to skeleton/
accordingly).
R/joss_article.R
Outdated
base$knitr$opts_chunk$fig.width <- 6 | ||
base$knitr$opts_chunk$fig.height <- 4.15 | ||
base$keep_md <- keep_md | ||
base$clean_supporting <- !keep_md |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I just added support for keep_md
in rmarkdown, so you can get rid of this hack, too.
R/joss_article.R
Outdated
paste(metadata$authors[[1]]$name, "et. al."), | ||
metadata$authors[[1]]$name | ||
) | ||
return(c("-V", paste0("citation_author=", citation_author))) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Again, I wish this variable could be set in YAML. I'm definitely being selfish here: I want the R source code of this package to be as simple as possible, and I guess the price for users to pay is not that high (typing out a name).
It's not the upstream that I'm concerned with here as the downstream. With JOSS, the |
Arfon will have to weigh in but yes setting csl in the yaml will not be used in the automated build system. It's hard coded here |
Since
|
Yep, we don't support custom CSL definitions for JOSS papers. |
033a19f
to
d98786f
Compare
I've moved |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you!
While JOSS and JOSE take markdown submissions, this seemed the best place to put the pipeline so that R authors could locally preview the rendered PDF.
@karthik @arfon @eveskew
To contribute a new article template to this package, please make sure you have done the following things (note that
journalname_article
below is only an example name):Previously signed
Add the
journalname_article()
function toR/article.R
if the output format is simple enough, otherwise create a separateR/journalname_article.R
.Add the Pandoc LaTeX template
inst/rmarkdown/templates/journalname_article/resources/template.tex
.Add a skeleton article
inst/rmarkdown/templates/journalname_article/skeleton/skeleton.Rmd
.Add a description of the template
inst/rmarkdown/templates/journalname_article/template.yaml
.Please include the document class file (
*.cls
) if needed, but please do not include standard LaTeX packages (*.sty
) that can be downloaded from CTAN. Please keep the number of new files absolutely minimal, and also make examples minimal (e.g., if you need a.bib
example, try to only leave one or two bibliography entries in it, and don't include one hundred items in it without using all of them).Update Rd and namespace (could be done by
devtools::document()
).Update NEWS.
Update README with a link to the newly supported journal.
Add a test to
tests/testit/test-formats.R
.Add your name to the list of authors
Authors@R
in DESCRIPTION. You don't need to bump the package version in DESCRIPTION.Lastly, please try your best to do only one thing per pull request (e.g., if you want to add two output formats, do them in two separate pull requests), and refrain from making cosmetic changes in the code base: https://yihui.name/en/2018/02/bite-sized-pull-requests/
Thank you!