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

Smarter snippet holes #445

Open
8 tasks
Tracked by #446
pokey opened this issue Jan 11, 2022 · 6 comments
Open
8 tasks
Tracked by #446

Smarter snippet holes #445

pokey opened this issue Jan 11, 2022 · 6 comments
Labels
enhancement New feature or request

Comments

@pokey
Copy link
Member

pokey commented Jan 11, 2022

The goal

We'd like to enhance the ability for snippets to be used to perform high-level syntactic transformations. To this end we'd like to add the following abilities:

  • To indicate that a particular hole can accept a list, and indicate a snippet that should be used to wrap each element of the list before being inserted as into the snippet hole. The two primary applications of this mechanism are Add snippet wrapper support to "repack" action #444 and "bring as" syntax transformation #60
    • The ability to indicate that a list valued snippet should join its elements using a particular string
    • On insertion, these list-valued holes should support a workflow where you can instantiate the snippet with n instances of the hole snippet
    • These list-valued holes should support a command to insert another instance of the hole
  • To indicate a transformation written in typescript that should be applied to the input to a particular hole

Some examples

  • Converting an if-else statement to a switch statement: "switch repack if state"
  • "bring air past bat as list"

Examples we'd like to support

  • Transform a dictionary to just a list consisting of its keys
  • Transform a list to a dictionary

Questions

  • Could we get a lot of this stuff for free by switching to a proper templating engine like handlebars?

References

@pokey pokey added the enhancement New feature or request label Jan 11, 2022
@pokey pokey changed the title Vector-valued snippet holes Smarter snippet holes Jan 11, 2022
@AndreasArvidsson
Copy link
Member

One really smart thing we probably could do with snippets is to support repeating it. For example if you issued the "next" command on "$0" it would insert the snippet once again and put the cursor in the new "$1". This would be really useful for inserting a large number of items in a map/dictionary. Cases in a switch state and so on.

@pokey
Copy link
Member Author

pokey commented Jan 24, 2022

I think you definitely want this kind of functionality when you're in a list-valued snippet hole, to indicate you'd like to create another element of the list, which would then insert a new instance of the snippet defined for elements of that list

I wonder how useful it is in other situations. Because for example how does it know where to put the new snippet instance? At the cursor? After the current scope instance?

@AndreasArvidsson
Copy link
Member

AndreasArvidsson commented Jan 24, 2022

We probably need add a lot more boilerplate to our snippet definitions ;)

We definitely want to be able to enabled this only on particular snippets and in those cases we need to instruct it how it should add the next one.

@pokey
Copy link
Member Author

pokey commented Jan 24, 2022

I don't think we're actually too far off. On the insert snippet PR we can already specify the default insertion scope for a snippet, so that eg "snip foo after this" will insert after current if statement.

@AndreasArvidsson
Copy link
Member

I know. But I'm not sure inserting the snippet in relation to a token or selection is the same thing as inserting the next snippet in relation to the previous snippet. I'm just saying we probably need to add some more information anyway.

@pokey
Copy link
Member Author

pokey commented Jan 24, 2022

I'd be inclined to restrict that kinda thing to nested snippets in list-valued snippet holes at the start and see if that gets us what we need

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

No branches or pull requests

2 participants