-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathREADME.Rmd
86 lines (60 loc) · 4.94 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# chores <img src="man/figures/logo.png" align="right" height="240" alt="The package logo, a small yellow blob happily holding a clipboard." />
<!-- badges: start -->
[data:image/s3,"s3://crabby-images/b1188/b118805435842f11524232186ba827bd737e812b" alt="Lifecycle: experimental"](https://lifecycle.r-lib.org/articles/stages.html#experimental)
[data:image/s3,"s3://crabby-images/7ca2d/7ca2dc3bd6895788fbd7800e45506aa2d8fb58c0" alt="CRAN status"](https://CRAN.R-project.org/package=chores)
[data:image/s3,"s3://crabby-images/11a2f/11a2f42b2d00cbf3e8b0fe3fce90c88260b58760" alt="R-CMD-check"](https://github.com/simonpcouch/chores/actions/workflows/R-CMD-check.yaml)
<!-- badges: end -->
The chores package provides a library of ergonomic LLM assistants designed to help you complete repetitive, hard-to-automate tasks quickly. After selecting some code, press the keyboard shortcut you've chosen to trigger the chores addin (we suggest `Ctrl+Cmd+C`), select the helper, and watch your code be rewritten.
> This package used to be called pal.
## Installation
Getting started with chores takes three steps.
**1)** Install the chores package like so:
``` r
pak::pak("simonpcouch/chores")
```
**2)** Then, you need to configure chores with an [ellmer](https://ellmer.tidyverse.org/) model. chores uses ellmer under the hood, so any model that you can chat with through ellmer is also supported by chores. To configure chores with ellmer, set the option `.chores_chat` to any ellmer Chat. For example, to use Claude, you'd write `options(.chores_chat = ellmer::chat_claude())`, possibly in your `.Rprofile` so that chores is ready to go every time you start R. To learn more, see the [Getting started with chores](https://simonpcouch.github.io/chores/articles/chores.html) vignette.
**3)** Chore helpers are interfaced with the via the chores addin. For easiest access, we recommend registering the chores addin to a keyboard shortcut.
**In RStudio**, navigate to `Tools > Modify Keyboard Shortcuts > Search "Chores"`---we suggest `Ctrl+Alt+C` (or `Ctrl+Cmd+C` on macOS).
**In Positron**, you'll need to open the command palette, run "Open Keyboard Shortcuts (JSON)", and paste the following into your `keybindings.json`:
```json
{
"key": "Ctrl+Cmd+C",
"command": "workbench.action.executeCode.console",
"when": "editorTextFocus",
"args": {
"langId": "r",
"code": "chores::.init_addin()",
"focus": true
}
}
```
The analogous keybinding on non-macOS is `Ctrl+Alt+C`. That said, change the `"key"` entry to any keybinding you wish!
Once those steps are completed, you're ready to use helpers with a keyboard shortcut.
## Example
Chore helpers are created automatically when users interact with the chores addin. Just highlight some code, open the addin, begin typing the "chore" of your chores and press "Return", and watch your code be rewritten:
```{r}
#| label: addin-gif
#| echo: false
#| fig-alt: "A screencast of an RStudio session. An .R file is open in the editor with a function definition. The user selects various subsets of the function and, after selecting from a dropdown menu, the helper assistant converts erroring code and drafts function documentation."
knitr::include_graphics("https://raw.githubusercontent.com/simonpcouch/chores/refs/heads/main/inst/figs/addin.gif")
```
As-is, the package provides ergonomic LLM assistants for R package development:
* `"cli"`: [Convert to cli](https://simonpcouch.github.io/chores/reference/cli_helper.html)
* `"testthat"`: [Convert to testthat 3](https://simonpcouch.github.io/chores/reference/testthat_helper.html)
* `"roxygen"`: [Document functions with roxygen](https://simonpcouch.github.io/chores/reference/roxygen_helper.html)
Users have also contributed a number of helpers for a wide range of tasks--see `vignette("gallery", package = "chores")` for a gallery of user-contributed helpers!
That said, all you need to create your own chore helper is a markdown file with some instructions on how you'd like it to work. See `prompt_new()` and `directory_load()` for more information, and [chorespable](https://github.com/simonpcouch/chorespable) for an example chores extension package.
## How much do helpers cost?
The cost of using helpers depends on 1) the length of the underlying prompt for a given helper and 2) the cost per token of the chosen model. Using the cli helper with Anthropic's Claude Sonnet 3.5, for example, [costs something like](https://simonpcouch.github.io/chores/reference/cli_helper.html#cost) \$15 per 1,000 code refactorings, while using the testthat helper with OpenAI's GPT 4o-mini would cost something like \$1 per 1,000 refactorings. Chore helpers using a locally-served LLM are "free" (in the usual sense of code execution, ignoring the cost of increased battery usage).