mirror of
https://github.com/oh-my-fish/oh-my-fish.git
synced 2024-11-27 02:34:13 +08:00
Merge pull request #417 from oneKelvinSmith/add_emacs_plugin
Add emacs plugin
This commit is contained in:
commit
8afbfe2e42
|
@ -7,6 +7,7 @@
|
||||||
* [__ccache__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/ccache) – Enable [ccache](http://ccache.samba.org/) to speed up compilation.
|
* [__ccache__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/ccache) – Enable [ccache](http://ccache.samba.org/) to speed up compilation.
|
||||||
* [__django__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/django) – Helper for Django Unit tests. Cleans the cached modules as well.
|
* [__django__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/django) – Helper for Django Unit tests. Cleans the cached modules as well.
|
||||||
* [__ec2__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/ec2) – Exports env variables for Amazon's EC2 management.
|
* [__ec2__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/ec2) – Exports env variables for Amazon's EC2 management.
|
||||||
|
* [__emacs__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/emacs) – Wrapper for [daemon](http://www.emacswiki.org/emacs/EmacsAsDaemon) functionality of [Emacs](https://www.gnu.org/software/emacs/).
|
||||||
* [__emoji-clock__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/emoji-clock) – The current time with half hour accuracy as an emoji symbol.
|
* [__emoji-clock__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/emoji-clock) – The current time with half hour accuracy as an emoji symbol.
|
||||||
* [__extract__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/extract) – Plugin to expand or extract bundled & compressed files.
|
* [__extract__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/extract) – Plugin to expand or extract bundled & compressed files.
|
||||||
* [__fish-spec__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/fish-spec) - Unit testing as simple as fish. See the [README](fish-spec/README.markdown) for usage instructions.
|
* [__fish-spec__](https://github.com/bpinto/oh-my-fish/tree/master/plugins/fish-spec) - Unit testing as simple as fish. See the [README](fish-spec/README.markdown) for usage instructions.
|
||||||
|
|
30
plugins/emacs/README.md
Normal file
30
plugins/emacs/README.md
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
# Emacs Plugin
|
||||||
|
|
||||||
|
This plugin replicates the functionality of the [emacs](https://www.gnu.org/software/emacs/) plugin for [oh-my-zsh](http://ohmyz.sh/).
|
||||||
|
It is essentially a wrapper around the very useful [emacs daemon](http://www.emacswiki.org/emacs/EmacsAsDaemon) capability.
|
||||||
|
|
||||||
|
Below is an extract from the original plugin source file:
|
||||||
|
|
||||||
|
"Emacs 23 daemon capability is a killing feature.
|
||||||
|
One emacs process handles all your frames whether
|
||||||
|
you use a frame opened in a terminal via a ssh connection or X frames
|
||||||
|
opened on the same host.
|
||||||
|
Benefits are multiple
|
||||||
|
|
||||||
|
* You don't have the cost of starting Emacs all the time anymore
|
||||||
|
* Opening a file is as fast as Emacs does not have anything else to do.
|
||||||
|
* You can share opened buffered across opened frames.
|
||||||
|
* Configuration changes made at runtime are applied to all frames."
|
||||||
|
|
||||||
|
|
||||||
|
### Usage
|
||||||
|
|
||||||
|
To use this plugin add `emacs` to `fish_plugins` in you fish config file:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
set fish_plugins emacs
|
||||||
|
```
|
||||||
|
|
||||||
|
### Requirements
|
||||||
|
|
||||||
|
Emacs 23 or later is required for this plugin.
|
39
plugins/emacs/emacs.load
Normal file
39
plugins/emacs/emacs.load
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
function __major_version
|
||||||
|
if test -n "$argv"
|
||||||
|
set -l full_metadata (eval $argv --version)
|
||||||
|
set -l full_version (echo $full_metadata | grep -o "[0-9]\+.[0-9]\+.[0-9]\+.[0-9]\+")
|
||||||
|
set -l major_version (echo $full_version | sed "s/\..*//")
|
||||||
|
end
|
||||||
|
|
||||||
|
echo $major_version
|
||||||
|
end
|
||||||
|
|
||||||
|
function __set_editor
|
||||||
|
if not set -q EDITOR
|
||||||
|
set -gx EDITOR emacs
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function __add_functions_to_path
|
||||||
|
set emacs_functions $fish_path/plugins/emacs/functions
|
||||||
|
set fish_function_path $emacs_functions $fish_function_path
|
||||||
|
end
|
||||||
|
|
||||||
|
if not set -q __emacs
|
||||||
|
set __emacs (which emacs)
|
||||||
|
end
|
||||||
|
if not set -q __emacs_version
|
||||||
|
set __emacs_version (__major_version $__emacs)
|
||||||
|
end
|
||||||
|
|
||||||
|
if test "$__emacs_version" -gt 23
|
||||||
|
__set_editor
|
||||||
|
__add_functions_to_path
|
||||||
|
end
|
||||||
|
|
||||||
|
set -e emacs
|
||||||
|
set -e emacs_version
|
||||||
|
functions -e __major_version
|
||||||
|
functions -e __plugins_path
|
||||||
|
functions -e __set_editor
|
||||||
|
functions -e __add_functions_to_path
|
3
plugins/emacs/functions/__kill_emacs.fish
Normal file
3
plugins/emacs/functions/__kill_emacs.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function __kill_emacs
|
||||||
|
emacsclient --alternate-editor '' --eval '(kill-emacs)' 2>/dev/null
|
||||||
|
end
|
9
plugins/emacs/functions/__launch_emacs.fish
Normal file
9
plugins/emacs/functions/__launch_emacs.fish
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
function __launch_emacs
|
||||||
|
set -l x (emacsclient --alternate-editor '' --eval '(x-display-list)' 2>/dev/null)
|
||||||
|
|
||||||
|
if test -z "$x" -o "$x" = nil
|
||||||
|
emacsclient $argv --alternate-editor '' --create-frame
|
||||||
|
else
|
||||||
|
emacsclient $argv --alternate-editor ''
|
||||||
|
end
|
||||||
|
end
|
3
plugins/emacs/functions/e.fish
Normal file
3
plugins/emacs/functions/e.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function e
|
||||||
|
__launch_emacs $argv --no-wait
|
||||||
|
end
|
3
plugins/emacs/functions/ec.fish
Normal file
3
plugins/emacs/functions/ec.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function ec
|
||||||
|
__launch_emacs $argv --create-frame --no-wait
|
||||||
|
end
|
11
plugins/emacs/functions/ecd.fish
Normal file
11
plugins/emacs/functions/ecd.fish
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
function ecd
|
||||||
|
set -l cmd '(let ((buf-name (buffer-file-name (window-buffer))))
|
||||||
|
(if buf-name (file-name-directory buf-name)))'
|
||||||
|
set -l dir (__launch_emacs --eval $cmd | tr -d '\"')
|
||||||
|
|
||||||
|
if test -n "$dir"
|
||||||
|
echo $dir
|
||||||
|
else
|
||||||
|
echo 'cannot deduce current buffer filename.' >/dev/stderr
|
||||||
|
end
|
||||||
|
end
|
3
plugins/emacs/functions/eeval.fish
Normal file
3
plugins/emacs/functions/eeval.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function eeval
|
||||||
|
__launch_emacs --eval $argv
|
||||||
|
end
|
5
plugins/emacs/functions/efile.fish
Normal file
5
plugins/emacs/functions/efile.fish
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
function efile
|
||||||
|
set -l cmd '(buffer-file-name (window-buffer))'
|
||||||
|
|
||||||
|
__launch_emacs --eval $cmd | tr -d '\"'
|
||||||
|
end
|
3
plugins/emacs/functions/eframe.fish
Normal file
3
plugins/emacs/functions/eframe.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function eframe
|
||||||
|
__launch_emacs $argv --create-frame --no-wait
|
||||||
|
end
|
3
plugins/emacs/functions/ek.fish
Normal file
3
plugins/emacs/functions/ek.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function ek
|
||||||
|
__kill_emacs
|
||||||
|
end
|
3
plugins/emacs/functions/emacs.fish
Normal file
3
plugins/emacs/functions/emacs.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function emacs
|
||||||
|
__launch_emacs $argv --no-wait
|
||||||
|
end
|
3
plugins/emacs/functions/emasc.fish
Normal file
3
plugins/emacs/functions/emasc.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function emasc
|
||||||
|
__launch_emacs $argv --no-wait
|
||||||
|
end
|
3
plugins/emacs/functions/emcas.fish
Normal file
3
plugins/emacs/functions/emcas.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function emcas
|
||||||
|
__launch_emacs $argv --no-wait
|
||||||
|
end
|
3
plugins/emacs/functions/et.fish
Normal file
3
plugins/emacs/functions/et.fish
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
function et
|
||||||
|
__launch_emacs $argv --tty
|
||||||
|
end
|
118
plugins/emacs/spec/emacs.spec.fish
Normal file
118
plugins/emacs/spec/emacs.spec.fish
Normal file
|
@ -0,0 +1,118 @@
|
||||||
|
import plugins/fish-spec
|
||||||
|
|
||||||
|
|
||||||
|
function describe_emacs
|
||||||
|
|
||||||
|
function before_all
|
||||||
|
set -g __emacs_current_editor $EDITOR
|
||||||
|
set -g __emacs_load_file $fish_path/plugins/emacs/emacs.load
|
||||||
|
set -g __emacs_functions e ec ek et ecd eeval efile eframe emacs emasc emcas
|
||||||
|
end
|
||||||
|
|
||||||
|
function before_each
|
||||||
|
set -e EDITOR
|
||||||
|
set -g __emacs '/bin/emacs'
|
||||||
|
set -g __emacs_version 25
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_sets_editor_on_load
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect $EDITOR --to-equal "emacs"
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_does_not_set_editor_when_it_is_already_set
|
||||||
|
set EDITOR 'vim'
|
||||||
|
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect $EDITOR --to-equal "vim"
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_does_not_set_editor_when_emacs_is_not_found
|
||||||
|
emacs_is_not_found
|
||||||
|
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect "$EDITOR" --to-equal ""
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_does_not_set_editor_when_emacs_version_is_lower_than_23
|
||||||
|
set __emacs_version 22
|
||||||
|
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect "$EDITOR" --to-equal ""
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_adds_functions_to_fish_function_path
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect (functions) --to-contain-all $__emacs_functions
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_has_a_test_helper_that_removes_emacs_functions
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect (functions) --to-contain-all $__emacs_functions
|
||||||
|
|
||||||
|
remove_emacs_functions
|
||||||
|
|
||||||
|
expect (functions) --to-not-contain-all $__emacs_functions
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function it_does_not_add_functions_when_emacs_is_not_found
|
||||||
|
remove_emacs_functions
|
||||||
|
emacs_is_not_found
|
||||||
|
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect (functions) --to-not-contain-all $__emacs_functions
|
||||||
|
end
|
||||||
|
|
||||||
|
function it_does_not_add_functions_when_emacs_version_is_lower_than_23
|
||||||
|
set __emacs_version 22
|
||||||
|
|
||||||
|
expect (functions) --to-not-contain-all $__emacs_functions
|
||||||
|
|
||||||
|
load_emacs_plugin
|
||||||
|
|
||||||
|
expect (functions) --to-not-contain-all $__emacs_functions
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function emacs_is_not_found
|
||||||
|
set __emacs ""
|
||||||
|
set __emacs_version ""
|
||||||
|
end
|
||||||
|
|
||||||
|
function load_emacs_plugin
|
||||||
|
source $__emacs_load_file
|
||||||
|
end
|
||||||
|
|
||||||
|
function remove_emacs_functions
|
||||||
|
for path in $fish_function_path
|
||||||
|
set match (echo $path | grep emacs)
|
||||||
|
if test -z "$match"
|
||||||
|
set -g __new_fish_function_path $__new_fish_function_path $path
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
set fish_function_path $__new_fish_function_path
|
||||||
|
set -e __new_fish_function_path
|
||||||
|
end
|
||||||
|
|
||||||
|
function after_all
|
||||||
|
set EDITOR $__emacs_current_editor
|
||||||
|
|
||||||
|
set -e __emacs
|
||||||
|
set -e __emacs_version
|
||||||
|
set -e __emacs_load_file
|
||||||
|
set -e __emacs_functions
|
||||||
|
set -e __emacs_current_editor
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
spec.run $argv
|
Loading…
Reference in New Issue
Block a user