This is intended as a living codebase for useful custom R functions for our single cell analysis workflows downstream of generating UMI count tables (e.g. via cellranger).
It's structured as an R package to keep things tidy, well documented and version controlled.
You can install this package using devtools
or remotes
.
devtools::install_github('yerkes-gencore/gencoreSC')
Some dependencies don't automatically install for various reasons. If you have issues installing the package due to missing dependencies, try installing them directly,
then reinstalling the package. For example, the S4Vectors
seems to throw issues occasionally. Run BiocManager::install("S4Vectors")
then reinstall gencoreSC.
The package has been tested to install with the docker image
https://hub.docker.com/r/yerkesgencore/gencore-singlecell-rstudio
Before making changes, please also review tutorials on developing/maintaining simple R packages, such as this one: https://kbroman.org/pkg_primer/. The essential stuff is maybe a 30 min read and if we all familiarize with the basics, then it shouldn't be too hard to keep this simple and useful.
If you want to make any changes, follow this workflow
- clone this repo into an isolated working directory (we suggest
.../illumina/runs/analyst/<your_name>
) - Fetch updates from the github repo via
git pull
- Create a new branch from the
devel
branch viagit branch <new_branch> origin/devel
. Be sure to switch to the new branch to make changes viagit switch <new_branch>
. - When you're finished making changes, be sure to run
devtools::check()
to ensure the documentation is updated and their are no major issues. When you're satisfied with the changes, push the changes to Github. - Open a pull request to merge your new branch into the devel branch. Ideally someone else should review the changes before merging, and the RMD Check action should pass.
- Once the feature has been merged into the devel branch, you should safely delete that branch with
git branch -d <your-branch>
. You can always recover it withgit checkout <your-branch> <sha>
, where<sha>
is the identifying SHA string for the commit at the tip of that branch (you can always find that in your git history). - Once sufficient changes have been made to the devel branch to prompt an update to the package, modify the package description to update the version
- Release a new version of the package
See this writeup on the git flow workflow
https://nvie.com/posts/a-successful-git-branching-model/
We could switch to other workflows as well, but for now we'll use git flow since we don't really need continuous deployment. See the link below for alternatives.
https://medium.com/@patrickporto/4-branching-workflows-for-git-30d0aaee7bf