- More tests added (#94)
- Fix encoding in parsing of XML data in
plos_fulltext()
to avoid unicode problems (#93)
- Now importing non-Base R functions from
utils
,stats
, andmethods
packages (#90)
- Fixes for
httr
v1
that brokerplos
when length 0 list passed toquery
parameter (#89)
- New function
citations()
for querying the PLOS Rich Citations API (#88)
- Added
vignettes/figure
to.Rbuildignore
as requested by CRAN admin (#87)
- API key no longer required (#86)
searchplos()
now returns a list of length two,meta
anddata
, andmeta
is a data.frame of metadata for the search.- Switched from CC0 to MIT license.
- No longer importing libraries
RCurl
,data.table
,googleVis
,assertthat
,RJSONIO
, andstringr
(#79) (#82) (#84) - Now importing
dplyr
. - Moved
jsonlite
from Suggests to Imports. Replaces use ofRJSONIO
. (#80) crossref()
now defunct. See packagercrossref
https://github.com/ropensci/rcrossref. (#83)highplos()
now usessolr::solr_highlight()
to do highlight searches.searchplos()
,plosabstract()
, and other functions that wrapsearchplos()
now use...
to pass in curl options tohttr::GET()
. You'll now get an error on usingcallopts
parameter.- Added manual file entry for the dataset
isocodes
. - Reworked both
plosword()
andplot_throughtime()
to have far less code, useshttr
now instead ofRCurl
, but to the user, everything should be the same. - Made documentation more clear on discrepancy between PLOS website behavior and
rplos
behavior, and how to make them match, or match more closely (#76) - Added package level man file to allow
?rplos
to go to help page.
- Removed some examples from
searchplos()
that are now not working for some unknown reason. (#81) - Previously when user set
limit=0
, we still gave back data, this is fixed, and now themeta
slot given back, and thedata
slot gives anNA
(#85)
- Fixed some broken tests.
- Errors from the data provider are reported now. At least we attempt to do so when they are given, for example if you specify
asc
ordesc
incorrectly with thesort
parameter. See thecheck_response()
function for examples. - New functions
facetplos()
andhighplos()
using thesolr
R wrapper to the Solr indexing engine. The PLOS API just exposes the Solr endpoints, so we can use the general Solr wrapper packagesolr
to allow more flexible Solr searching. - New function
highbrow()
to visualize highlighting results in a browser. - New function
plos_fulltext()
to get full text xml of PLOS articles. Helper functionfull_text_urls()
constructs the URL's for full text xml.
- Fixed bug in tests where we forgot to give a key. No key is required per se, but PLOS encourages it so we prevent a call from happening without at least a dumby key.
- Added function
check_response()
to check responses from the PLOS API, deals with capturing server error messages, and checking for correct content type, etc.
- Removed function
crossref_r()
as we are working on a package for the CrossRef API. - Parameter arguments in
searchplos()
,plosauthor()
,plosfigtabcaps()
,plossubject()
, andplostitle()
were changed to match closer the Solr parameter names.terms
toq
.fields
tofl
.toquery
tofq
. - Multiple values passed to
fields
returndf
parameter is gone fromsearchplos()
,plosauthor()
,plosfigtabcaps()
,plossubject()
, andplostitle()
. You can easily get raw JSON, etc. data using thesolr
package.- Now using
httr
instead ofRCurl
inplosviews()
function.
- All search functions (searchplos(), plosabstract(), plosauthor(), plosfigtabcaps(), plossubject(), and plostitle()) gain highlighting argument, setting to TRUE (default=FALSE) returns matching sentence fragments that were matched. NOTE that if highlighting=TRUE the output can be a list of data.frame's if returndf=TRUE, with two named elements 'data' and 'highlighting', or a list of lists if returndf=FALSE.
- All search functions (searchplos(), plosabstract(), plosauthor(), plosfigtabcaps(), plossubject(), and plostitle()) gain sort argument. You can pass a field to sort by even if you don't return that field in the output, e.g., sort='counter_total_month desc'.
- A tiny function parsehighlight() added to parse out html code from highlighting output.
- Some examples in docs didn't work - fixed them.
- Fixed bug in searchplos() that was causing elements of a return field to cause failure because they were longer than 1 (e.g., authors). Now concatenating elements of length > 1.
- Fixed bug in searchplos() that was causing elements of length 0 to cause failure. Now removing elements of length 0.
- Fixed parsehighlight function to return NA if highlighting return of length 0.
- Fixed broken test for plosauthor(), plosabstract(), and plot_throughtime().
- Added httr::stop_for_status() calls to a few functions to give informative http status errors when they happen
- Fixed bug in plot_throughtime() that was throwing errors and preventing fxn from working, thanks to Ben Bolker for the fix.
- Simplified code in many functions to have cleaner and simpler code.
- ... parameter in many functions changed to callopts=list(), which passes in curl options to a call to either RCurl::getForm() or httr::GET()
- Fixed bug in function plosviews() that caused errors in some calls. Now forces full document searches, so that you get views data back for full papers only, not sections of papers. See package alm (https://github.com/ropensci/alm) for more in depth PLOS article-level metrics.
- All functions for interacting with the PLOS ALM (altmetrics) API have been removed, and are now in a separate package called alm (http://github.com/ropensci/alm).
- Convenience functions
plosabstract
,plosauthor
,plosfigtabcaps
,plossubject
, andplostitle
, that search specifically within those sections of papers now wrapsearchplos
, so they should behave the same way. - ldfast() fxn added as an attempt to do ldply faster
- performance improvements in searchplos
- Dependency on assertthat removed since it's not on CRAN.
- Fixed namespace conflicts by importing only functions needed from some packages.
- searchplos() now removes leading, trailing, and internal whitespace from character strings
- remove alm*() functions so that this package now only wraps the PLoS search API.
-
The
almdateupdated
function has been deprecated - usealmupdated
instead. -
The
articlelength
function has been deprecated - didn't see the usefulness any longer. -
In general simplified and prettified code.
-
Changed from using RCurl to httr in many functions, but not all.
-
Added more examples for many functions.
-
Added three internal functions:
concat_todf
,addmissing
, andgetkey
. -
Added Karthik Ram as a package author.
-
All
url
arguments in functions put inside functions as they are not likely to change that often. -
Fixed
crossref
function, and added more examples.
-
The
alm
function (previouslyalmplosallviews
) gains many ### new features: now allows up to 50 DOIs per call; you can specify the source you want to get alm data from as an argument; you can specify the year you want to get alm data from as an argument. -
Added the plosfields data file to get all the possible fields to use in function calls.
-
almplosallviews
changed toalm
. -
almplotallviews
changed toalmplot
. -
almevents
added to specifically search and get detailed events data for a specific source or N sources. -
crossref_r
gets 20 random DOIs from Crossref.org. -
Added package startup message.
-
journalnamekey
function to get the short name keys for each PLoS Journal.
-
ALM functions (any functions starting with alm) received updated arguments/parameters according to the ALM API version 3.0 changes.
-
Added tests.
-
almplosallviews
now outputs different output - two data.frames, one total metrics (summed across time), and history (for metrics for each time period specified in the search) -
crossref
function returns R's native bibtype format. See examples incrossref
function documentation
-
almpub
changed toalmdatepub
-
changed help file
rplos
tohelp
- use help('rplos') in R -
changed URL from http://ropensci.org/ to https://github.com/ropensci/rplos
-
added sleep argument to
plosallviews
function to allow pauses between API calls when runningplosallviews
in a loop - this is an attempt to limit hitting the PLoS API too hard -
various other fixed to functions
-
more examples added to some functions
- added function
journalnamekey
to get short keys for journals to use in searching for specific journals
- released to CRAN