---
title: 'Using RProtoBufLib'
output:
  html_document:
    fig_height: 2
    fig_width: 2
    keep_md: yes
    toc: yes
    toc_float: true
vignette: >    
  %\VignetteEngine{knitr::rmarkdown}
  %\VignetteIndexEntry{Using RProtoBufLib}
---

```{r, echo=FALSE}
library(knitr)
opts_chunk$set(message = FALSE, warning = FALSE, fig.height= 3, fig.width= 5)
```

The existing CRAN package [RProtoBuf](https://cran.r-project.org/web/packages/RProtoBuf/index.html) implements the R interface to `protobuf` library. However it does not provide the c++ header and library file. So users are required to install the `protobuf` C++ library properly before they can install the packages that use `protobuf` C++ library directly. 

To eliminate this system-wise library dependency and ease the installation process for the R end users, We provide **RProtoBufLib** package as a utility for package developers. It bundles [ProtoBuf C++ library](https://developers.google.com/protocol-buffers/)  and exposes the c++ headers and static library so that user packages can compile and link against it once it is installed.

The **RProtoBufLib** package is installed in the normal `R` manner without the need of any user efforts.

All packages wishing to use the libraries in `RProtoBufLib` only need to:

- add `RProtoBufLib` to **LinkingTo** field in **DESCRIPTION** file so that the compiler knows where to find the headers when user package is complied
e.g.
```
Imports: RProtoBufLib
LinkingTo: Rcpp, RProtoBufLib
```

- set **PKG_LIBS** in **src/Makevars** file so that linker can find and linked to the **libprotobuf.a** file 
e.g.
```bash
PKG_LIBS =`${R_HOME}/bin/Rscript -e "RProtoBufLib::LdFlags()"`
```

See **flowWorkspace** package for the example of using `RProtoBufLib`.