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

[Request] evil-cleverparens insert functionality #29

Open
jojojames opened this issue Dec 14, 2017 · 12 comments
Open

[Request] evil-cleverparens insert functionality #29

jojojames opened this issue Dec 14, 2017 · 12 comments

Comments

@jojojames
Copy link

Just thought I'd request this from evil-cleverparens.

Insert

When entering insert-state via i in a situation where the point is between a round opening parentheses and a symbol, evil-cleverparens will automatically insert a space and then move the cursor back for you. The rationale is that when you are in this situation, it's much more likely that you are inserting a new word at the beginning of the list rather than modifying the beginning of the current head of the list, and therefore it would be nice if the two words were already separated so that your auto-completion mode can do its thing. This behavior can be disabled by setting evil-cleverparens-use-regular-insert to t.

May or may not be appropriate for this package but that was one thing I missed transitioning over from evil-cleverparens to lispyville.

@noctuid
Copy link
Owner

noctuid commented Dec 14, 2017

I could add this as an option or new key theme (probably off by default). It's probably also worth pointing out that this is less of an issue if you use lispy for navigation as you will usually get directly to the prior paren already in insert/emacs state. If you are after an opening paren, SPC will also insert a space after the point instead of before.

@jojojames
Copy link
Author

jojojames commented Dec 15, 2017

That's be great to have it as a key theme.

As for lispy itself, it was on my todo list at some point to check it out, but then it seemed like another 'mode' to have to manage in and out of. The vim ones are enough for me so I just use lispyville as a more stable evil-[clever/smart]parens.

noctuid added a commit that referenced this issue Apr 6, 2018
@noctuid
Copy link
Owner

noctuid commented Apr 6, 2018

Sorry for the late response. I've gone ahead and committed what I have (no tests or documentation yet). I wanted to make it work in visual block mode, but I'll look into that possibility later. For consistency it just won't do anything from visual state for now. Unlike cleverparens which defines new insert/append keys, the insert key theme just uses the insert enter/exit hooks. Let me know if you have any issues or suggestions.

@noctuid
Copy link
Owner

noctuid commented Apr 6, 2018

As for lispy, usage of lispy is kind of orthogonal of usage of evil; they don't really get in each other's way. I really recommend looking into it if you get the chance; even the basic operations can make lisp editing a lot more efficient.

@jojojames
Copy link
Author

Let me know if you have any issues or suggestions.

Cool, I'll try it out and comment if need be.

I really recommend looking into it if you get the chance; even the basic operations can make lisp editing a lot more efficient.

Yeah, I have some uncommited lispy code in my dotemacs at your suggestion. Mostly trying to futz around with the single-key lispy bindings to make them a little more vim-y.

One thing (polish item) that I'd like is an explicit tag change (or at least some way to change the evil tag when it gets into lispy-state). I know it's implicit for emacs but it just seems a little weird for the mode-line to say 'insert' (or whatever the default insert state tag is) when it's really in implicit-lispy state.

That's something I like about https://github.com/sp3ctum/evil-lispy. You can change its tag since it's tied to a new evil state.

@noctuid
Copy link
Owner

noctuid commented Apr 6, 2018

I've personally completely change my own lispy keybindings to be more like vim (e.g. o to switch to other delimiter, d for delete, y for copying, p for paste, / for occur, etc.). I haven't provided anything like that for this package because I think it should be added as a key theme to lispy if anyone wants rebindings like this. My personal setup is pretty heavily modified in other ways and isn't as all suitable as a general vim key theme, but discussion on the evil-collection or lispy repo about making a vim/evil key theme might be useful in the future.

I don't use evil state tags at all personally; I just go by the color/shape of the cursor. Even if I did, I don't think it makes sense to add an extra state for lispy just for this purpose. It doesn't make sense to think of lispy's special exactly like an evil state. Evil states are manually changed which is why visual indication is required to distinguish between insert and normal state for example. Since lispy is based entirely on the location of the point (or whether there is an active region), it's always clear whether lispy's keybindings are active. Adding a new state just to show when lispy's keybindings are active would be a pretty poor workaround (e.g. it would require code to automatically switch between insert and the lispy insert states).

If you still would rather have a visual indicator for lispy, I can add it as an entirely separate modeline indicator if you'd like. I'd rather do that than try to reuse evil's tags for this purpose.

@jojojames
Copy link
Author

(e.g. o to switch to other delimiter, d for delete, y for copying, p for paste, / for occur, etc.).

Yeah, I've tried to do some rebindings to achieve something similar. I'll post something on evil-collection to see if a new key-theme can be created.

If you still would rather have a visual indicator for lispy, I can add it as an entirely separate modeline indicator if you'd like. I'd rather do that than try to reuse evil's tags for this purpose.

That's be great.

@noctuid
Copy link
Owner

noctuid commented Apr 6, 2018

I've added a function that can be used in the mode line or as the lighter. The face and text are customizable. See here for details.

@jojojames
Copy link
Author

For insert, I get:

lispyville-insert-enter: Symbol’s function definition is void: lispyville--after-left-p

noctuid added a commit that referenced this issue Apr 6, 2018
@noctuid
Copy link
Owner

noctuid commented Apr 6, 2018

Thanks; it should be fixed now.

@jojojames
Copy link
Author

Thanks works for me. I've created a topic for the lispy key theme.

@noctuid
Copy link
Owner

noctuid commented Apr 7, 2018

Great. I'm going to leave this open until I've added documentation/tests. I'm also going to add an option to insert a space before the point when inserting just before a closing delimiter and potentially add support for visual block state.

@noctuid noctuid reopened this Apr 7, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants