Creates classes with reference semantics, similar to R's built-in reference classes. Compared to reference classes, R6 classes are simpler and lighter-weight, and they are not built on S4 classes so they do not require the methods package. These classes allow public and private members, and they support inheritance, even when the classes are defined in different packages.
R6 is an implemention of classical object-oriented programming for R, and is a simpler, faster, lighter-weight alternative to R's built-in reference classes.
Some features of R6:
In contrast to R's reference classes, R6 is not built on the S4 class system, so it does not require the methods package. Unlike reference classes, R6 classes can be cleanly inherited across different packages.
See the Introduction article for usage examples.
To install R6 from CRAN:
To install the development version (requires the devtools package):
devtools::install_github('r-lib/R6', build_vignettes = FALSE)
Why the name R6? When R's reference classes were introduced, some users, following the names of R's existing class systems S3 and S4, called the new class system R5 in jest. Although reference classes are not actually called R5, the name of this package and its classes takes inspiration from that name.
The name R5 was also a code-name used for a different object system started by Simon Urbanek, meant to solve some issues with S4 relating to syntax and performance. However, the R5 branch was shelved after a little development, and it was never released.
Vignettes are no longer included as part of the source package because of their large size. Documentation is now at https://r6.r-lib.org/.
Fixed #125: The
print.R6 method now always returns the object that was passed to it.
Fixed #94, #133: When cloning an object which contained a function that is not a method, the corresponding function in the new object would have its environment changed, as though it were a method. Now it no longer has a changed environment. (#156)
Fixed #121: If a
finalize method was present, it would prevent objects passed to
initialize from getting GC'd.
Fixed #158: If a
$set method of an R6 generator object is given the value
NULL, it previously removed the named item. Now it adds the named item with the value
Fixed #159: Printing an R6 object containing a large vector was slow.
Fixed #108: When an object with a
super object and an active binding in the
super object was cloned, the new object's
super object did not get the active binding -- it was a normal function.
Fixed #119: When a class had two levels of inheritance, an instance of that class's
super object could contain methods that had an incorrect enclosing environment.
Vignettes now only try use the microbenchmark package if it is present. This is so that the package builds properly on platforms where microbenchmark is not present, like Solaris.
Fixed ending position for
Fixed #96: R6 now avoids using
[[ after the class has been assigned to the object. This allows the user to provide their own methods for
[[ without causing problems to R6's operation.
plot S3 method for R6 objects will call
$plot on the object if present. (#77)
Fixed printing of members that are R6 objects. (#88)
Fixed deep cloning for non-portable classes. (#85)
as.list.R6 method. (#91)
format.R6ClassGenerator, the former calls a public
format method if defined. This might change the functionality of existing classes that define a public
format method intended for other purposes (#73. Thanks to Kirill Müller)
Functions are shown with their interface in
format, limited to one line (#76. Thanks to Kirill Müller)
R6 objects and generators print out which class they inherit from. (#67)
Fixed a bug with printing R6 objects when a
[[ method is defined for the class. (#70)
Fixed cloning of objects that call a
super method which accesses
Added support for making clones of R6 objects with a
clone() method on R6 objects. The
deep=TRUE option allows for making clones that have copies of fields with reference semantics (like other R6 objects). (#27)
Allow adding public or private members when there were no public or private members to begin with. (#51)
Previously, when an R6 object was printed, it accessed (and called) active bindings. Now it simply reports that a field is an active binding. (#37, #38. Thanks to Oscar de Lama)
Printing private members now works correctly for portable R6 objects. (#26)
The 'lock' argument has been renamed to 'lock_objects'. Also, there is a new argument, 'lock_class', which can prevent changes to the class. (#52)
Fixed printing of NULL fields.
A superclass is validated on object instantation, not on class creation.
undebug methods to generator object.
[BREAKING CHANGE] Added
portable option, which allows inheritance across different package namespaces, and made it the default.
set() method on class generator object, so new fields and methods can be added after the generator has been created.
All of the functions involved in instantiating objects are encapsulated in an environment separate from the R6 namespace. This means that if a generator is created with one version of R6, saved, then restored in a new R session that has a different version of R6, there shouldn't be any problems with compatibility.
Methods are locked so that they can't be changed. (Fixes #19)
Inheritance of superclasses is dynamic; instead of reading in the superclass when a class is created, this happens each time an object is instantiated. (Fixes #12)
Added trailing newline when printing R6 objects. (Thanks to Gabor Csardi)
First release on CRAN.
Removed pryr from suggested packages.