Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generator object should provide completions for instances of the class #47

Open
wch opened this issue Mar 4, 2015 · 10 comments
Open

Generator object should provide completions for instances of the class #47

wch opened this issue Mar 4, 2015 · 10 comments
Labels
feature a feature request or enhancement

Comments

@wch
Copy link
Member

wch commented Mar 4, 2015

As discussed in rstudio/shiny#657, it would be helpful if a generator object had a way of providing completions for instances of the class.

@kevinushey if you have any recommendations for the interface, please let me know.

@kevinushey
Copy link

Just to set the stage -- we want to get the set of completions valid for the various binary operators, e.g. $, [, [[, or even ?, ~, @ if their use ever gained some meaning for R6.

We could have a function like R6::.instanceCompletions(generator, operator) which takes a generator and the operator that we want completions for ("$", "[", and so on.)

Does that sound appropriate? Are there other contexts where we might want R6 completions for an instance object, or other 'special symbols' in R6 we might want to provide completions for (e.g. self)?

It would be excellent if the returned completions could also give the type of object returned -- in RStudio, we have icons that denote the 'type' of completion and if we were to query completions in this manner it would be good to get those types as well. We have this in RStudio: https://github.com/rstudio/rstudio/blob/master/src/cpp/session/modules/SessionRCompletions.R#L38-L69, but we could also just simply convert whatever type R6 returns to that set of types.

@wch
Copy link
Member Author

wch commented Jun 24, 2015

@kevinushey A tangential issue for completions: A generator object has a method called $new(...), which in turn invokes $public_methods$initialize(...).

For example, to get the set of useful completions for shiny:::ShinySession$new(), you'd really want to get the completions for shiny:::ShinySession$public_methods$initialize()

@wch
Copy link
Member Author

wch commented May 4, 2017

I was just playing around with .DollarNames, and it seems to work with an R6 class in R at the console, but not in RStudio. For example:

library(R6)
MyClass <- R6Class("MyClass",
  public = list(x = 1, y = 2, z = 3)
)

.DollarNames.MyClass <- function(x, pattern = "") {
  all_names <- ls(x, all.names, pattern = pattern)
  
  # Filter out "z"
  setdiff(all_names, "z")
}

m <- MyClass$new()
# Press tab after typing the following:
m$
# In R at the terminal, it prints "m$clone  m$x      m$y"
# In RStudio, it shows clone, x, y, z, and .__enclos_env__

@kevinushey Do you know why it's not working in RStudio?

@hadley
Copy link
Member

hadley commented Jul 17, 2017

I think you can close this issue in favour of #122

@wch
Copy link
Member Author

wch commented Jul 17, 2017

@hadley This is slightly different, I think. The issue is when you want to have completions for an object that's not actually instantiated yet. For example, in Shiny, the session object is only instantiated when you run an app, but it would still be useful to have completions when working on the code (and the app isn't running).

@hadley
Copy link
Member

hadley commented Jul 17, 2017

How would you declare that the yet-to-be-created session object is of class Session?

@wch
Copy link
Member Author

wch commented Jul 17, 2017

Shiny's a bit of a special case -- RStudio would just know that a session inside a Shiny app's server function would be a ShinySession object.

But in the general case, it would be nice to have completions for this when you're editing code but not running it:

A <- mypkg::MyClass$new()
A$ <tab>

@hadley
Copy link
Member

hadley commented Jul 17, 2017

@wch I already get completions for that case

@hadley
Copy link
Member

hadley commented Jul 17, 2017

For this to work, RStudio would need someway to recognise that a <- foo$new() implies that a has class foo$classname.

@kevinushey is there any existing support for this sort of inference? (it would also be straightforward to implement for S4 slot. Implementing for S3 would require some sort of annotation.)

@kevinushey
Copy link

Unfortunately no, this is not supported yet.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature a feature request or enhancement
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants