mirror of
				https://github.com/ohmyzsh/ohmyzsh.git
				synced 2025-10-25 21:22:15 +08:00 
			
		
		
		
	 abf73bb626
			
		
	
	
		abf73bb626
		
	
	
	
	
		
			
			This solves a problem of using the variable name `$path' which then smashes the environment variable `$PATH' and messes up the session. See https://github.com/robbyrussell/oh-my-zsh/pull/5343#issuecomment-243043098
		
			
				
	
	
		
			44 lines
		
	
	
		
			842 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			842 B
		
	
	
	
		
			Bash
		
	
	
	
	
	
| _rake_does_task_list_need_generating () {
 | |
|   [[ ! -f .rake_tasks ]] || [[ Rakefile -nt .rake_tasks ]] || { _is_rails_app && _tasks_changed }
 | |
| }
 | |
| 
 | |
| _is_rails_app () {
 | |
|   [[ -e "bin/rails" ]] || [[ -e "script/rails" ]]
 | |
| }
 | |
| 
 | |
| _tasks_changed () {
 | |
|   local -a files
 | |
|   files=(lib/tasks lib/tasks/**/*(N))
 | |
| 
 | |
|   for file in $files; do
 | |
|     if [[ "$file" -nt .rake_tasks ]]; then
 | |
|       return 0
 | |
|     fi
 | |
|   done
 | |
| 
 | |
|   return 1
 | |
| }
 | |
| 
 | |
| _rake_generate () {
 | |
|   rake --silent --tasks | cut -d " " -f 2 > .rake_tasks
 | |
| }
 | |
| 
 | |
| _rake () {
 | |
|   if [[ -f Rakefile ]]; then
 | |
|     if _rake_does_task_list_need_generating; then
 | |
|       echo "\nGenerating .rake_tasks..." >&2
 | |
|       _rake_generate
 | |
|     fi
 | |
|     compadd $(cat .rake_tasks)
 | |
|   fi
 | |
| }
 | |
| compdef _rake rake
 | |
| 
 | |
| rake_refresh () {
 | |
|   [[ -f .rake_tasks ]] && rm -f .rake_tasks
 | |
| 
 | |
|   echo "Generating .rake_tasks..." >&2
 | |
|   _rake_generate
 | |
|   cat .rake_tasks
 | |
| }
 |