mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2026-03-27 03:14:56 +01:00
Updated bgnotify plugin to match external repo
This commit is contained in:
parent
192de6bcff
commit
1f79e96cab
2 changed files with 61 additions and 23 deletions
|
|
@ -1,20 +1,32 @@
|
|||
# bgnotify zsh plugin
|
||||
# zsh-background-notify
|
||||
|
||||
cross-platform background notifications for long running commands! Supports OSX and Ubuntu linux.
|
||||
|
||||
Standalone homepage: [t413/zsh-background-notify](https://github.com/t413/zsh-background-notify)
|
||||
|
||||

|
||||
----------------------------------
|
||||
|
||||
## Do you use `oh-my-zsh`?
|
||||
|
||||
RobbyRussel [merged](https://github.com/robbyrussell/oh-my-zsh/pull/3301) (and [tweeted](https://twitter.com/ohmyzsh/status/569566134984265729) about it) this plugin to the main-line oh-my-zsh. If that's what you're running then just add 'bgnotify' to your `.zshrc` plugins list and you're all set!
|
||||
|
||||
## Do you use `Prezto`?
|
||||
|
||||
I do too! [Prezto](https://github.com/sorin-ionescu/prezto) rocks-- and works great with bg-notify! (although there's no included plugin (yet?)).
|
||||
|
||||
## How to use!
|
||||
|
||||
Just add bgnotify to your plugins list in your `.zshrc`
|
||||
1. Clone the repository:
|
||||
* `git clone https://github.com/t413/zsh-background-notify.git ~/.zsh-background-notify`
|
||||
2. And add one line your `.zshrc`:
|
||||
* `source $HOME/.zsh-background-notify/bgnotify.plugin.zsh`
|
||||
3. Done!
|
||||
|
||||
## Requirements:
|
||||
|
||||
- On OS X you'll need [terminal-notifer](https://github.com/alloy/terminal-notifier)
|
||||
* `brew install terminal-notifier` (or `gem install terminal-notifier`)
|
||||
- On ubuntu you're already all set!
|
||||
- On windows you can use [notifu](http://www.paralint.com/projects/notifu/) or the Cygwin Ports libnotify package
|
||||
|
||||
- On windows you can use [notifu](http://www.paralint.com/projects/notifu/) or the Cygwin Ports `libnotify` package
|
||||
|
||||
## Screenshots
|
||||
|
||||
|
|
@ -36,19 +48,35 @@ Just add bgnotify to your plugins list in your `.zshrc`
|
|||
One can configure a few things:
|
||||
|
||||
- `bgnotify_threshold` sets the notification threshold time (default 6 seconds)
|
||||
- `function bgnotify_formatted` lets you change the notification
|
||||
- `function notify_formatted` lets you change the notification
|
||||
|
||||
Use these by adding a function definition before the your call to source. Example:
|
||||
|
||||
~~~ sh
|
||||
bgnotify_threshold=4 ## set your own notification threshold
|
||||
|
||||
function bgnotify_formatted {
|
||||
function notify_formatted {
|
||||
## $1=exit_status, $2=command, $3=elapsed_time
|
||||
[ $1 -eq 0 ] && title="Holy Smokes Batman!" || title="Holy Graf Zeppelin!"
|
||||
bgnotify "$title -- after $3 s" "$2";
|
||||
}
|
||||
|
||||
plugins=(git bgnotify) ## add to plugins list
|
||||
source $ZSH/oh-my-zsh.sh ## existing source call
|
||||
source $HOME/.zsh/zsh-background-notify/bgnotify.plugin.zsh
|
||||
~~~
|
||||
|
||||
|
||||
## How it works
|
||||
|
||||
In zsh you can add a user-hook `preexec` that runs before executing a command and `precmd` that runs just before re-prompting. Timing the difference between them gives you execution time!
|
||||
|
||||
To check if you're in the background we can use xprop to find the NET_ACTIVE_WINDOW in ubuntu and osascript to run a simple apple script to get the same thing (although slower).
|
||||
|
||||
|
||||
## Alternatives:
|
||||
|
||||
I like linking.. So here are a few similar alternatives to this script. Most are platform-specific and buggy in some way. (Sure is great to use one script on all of your systems!)
|
||||
|
||||
- This [reddit post](http://www.reddit.com/r/linux/comments/1pooe6/zsh_tip_notify_after_long_processes/)
|
||||
- [zsh-notify](https://github.com/marzocchi/zsh-notify) plugin for Mac OS X
|
||||
- [dotzsh notify](https://github.com/dotphiles/dotzsh/tree/master/modules/notify)
|
||||
- [zbell](https://gist.github.com/jpouellet/5278239)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue