-
Notifications
You must be signed in to change notification settings - Fork 23
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
Comments
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, |
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. |
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. |
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. |
Cool, I'll try it out and comment if need be.
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. |
I've personally completely change my own lispy keybindings to be more like vim (e.g. 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. |
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.
That's be great. |
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. |
For insert, I get: lispyville-insert-enter: Symbol’s function definition is void: lispyville--after-left-p |
Thanks; it should be fixed now. |
Thanks works for me. I've created a topic for the lispy key theme. |
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. |
Just thought I'd request this from evil-cleverparens.
May or may not be appropriate for this package but that was one thing I missed transitioning over from evil-cleverparens to lispyville.
The text was updated successfully, but these errors were encountered: