Michael,

meanwhile the "bibentry" class that Kurt mentioned back in the discussion in 2010 is fully implemented in R. Hence the code can be simplified when working with the "bibentry" objects directly (instead of the "Bibtex" objects derived from them).

I've quickly hacked some code to illustrate how the function needs to be modified but I didn't have the time to integrate it into the function
(I'm currently traveling).

  ## query packages and their bibentries
  pkgs <- unique(installed.packages()[,1])
  bibs <- lapply(pkgs, function(x) try(citation(x)))

  ## exclude those with errors
  ok <- !(sapply(bibs, class) == "try-error")
  pkgs <- pkgs[ok]
  bibs <- bibs[ok]

  ## number of bibentries per package
  nref <- sapply(bibs, length)

  ## merge all bibentries
  bibs <- do.call("c", bibs)

  ## add citation keys
  bibkeys <- lapply(1:length(nref), function(i)
    if(nref[i] > 1) paste(pkgs[i], 1:nref[i], sep = ":") else pkgs[i])
  bibs$key <- as.list(unlist(bibkeys))

And then you just need to say toBibtex(bibs) or writeLines(toBibtex(bibs)) or something along those lines.

For more details on the new classes, see this recent working paper by Kurt Duncan and myself: http://epub.wu.ac.at/3269/.

So much for today.
Best wishes,
Z

On Fri, 16 Dec 2011, Michael Friendly wrote:

Back in 2010 I raised this issue, and there was some discussion,

https://stat.ethz.ch/pipermail/r-devel/2010-November/058987.html

The goal, then, as now is to have a way to produce a bibtex-clean .bib file
(i.e., not requiring
manual editing except in unusual circumstances) reflecting installed
packages
for use in writing where one often needs/wants to cite all packages used in
a given article.

Achim wrote the function below  which largely does this job, quite nicely
now that most
DESCRIPTION files now contain Authors@R fields.  However, something changed
since
R 2.11.1 when I tried this last, so that the function no longer generates
keys for packages
which contain more than one citation.

I've tried debugging with browser(), but can't figure out how to make the
lines around FIXME
work.  Can someone help?

You can see the result from this at
http://euclid.psych.yorku.ca/SCS/Private/Rbibs/Rpackages-2.14.0.bib
The function is also at:

# Original code by Achim Zeileis, 16 Dec 2009, R-help
# Added: support header and preamble

Rpackages.bib <- function(filename = paste("Rpackages-",getRversion(),
".bib", sep=""),
        header=TRUE, preamble=NULL, suppress.warnings=TRUE, verbose = TRUE)
{
  ## installed packages
  pkgs <- unique(installed.packages()[,1])
  if (suppress.warnings) warn <- options(warn=-1)
  bibs <- lapply(pkgs, function(x) try(toBibtex(citation(x))))
  if (suppress.warnings) options(warn)
 
  n.installed <- length(bibs)

  ## omit failed citation calls
  ok <- !(sapply(bibs, class) == "try-error")
  pkgs <- pkgs[ok]
  bibs <- bibs[ok]
  n.converted <- sum(ok)
  ## unify to list of Bibtex
  bibs <- lapply(bibs, function(x) if(inherits(x, "Bibtex")) list(x) else x)

  ## FIXME: add bibtex keys to each entry [the line below does not work!!]
  pkgs <- lapply(seq_along(pkgs), function(i) if(length(bibs[[i]]) > 1)
    paste(pkgs[i], 1:length(bibs[[i]]), sep = "") else pkgs[i])
  pkgs <- do.call("c", pkgs)
  bibs <- do.call("c", bibs)
  for(i in seq_along(pkgs)) bibs[[i]][1] <-
    gsub("{,", paste("{", pkgs[i], ",", sep = ""), bibs[[i]][1], fixed =
TRUE)

    if(header) header <- gsub("^", "%", toLatex(sessionInfo()))
    output <- file(filename, "a")
    cat(header, preamble, sep='\n', file=output, append=TRUE)
  ## write everything to a single .bib file
  writeLines(do.call("c", lapply(bibs, as.character)), con=output)
  close(output)
  if(verbose) cat("Converted", n.converted, "of", n.installed,
    "package citations to BibTeX",
    "\nResults written to file", filename, "\n")

  ## return Bibtex items invisibly
  invisible(bibs)
}






--
Michael Friendly Email: friendly AT yorku DOT ca Professor, Psychology Dept.
York University      Voice: 416 736-5115 x66249 Fax: 416 736-5814
4700 Keele Street    Web:   http://www.datavis.ca
Toronto, ONT  M3J 1P3 CANADA

______________________________________________
R-devel@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel

Reply via email to