Compare commits
11 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d0097eb5b6 | ||
|
|
71303376ee | ||
|
|
8dbd5a9b21 | ||
|
|
f82dc905a2 | ||
|
|
bfbabc05d5 | ||
|
|
58767454b3 | ||
|
|
4776651b27 | ||
|
|
832eade857 | ||
|
|
44ff9a8b4b | ||
|
|
3f26a74c71 | ||
|
|
1041cb5160 |
2
Gemfile
2
Gemfile
@@ -9,7 +9,7 @@ group :development do
|
||||
gem "rake"
|
||||
gem "rspec", ">= 1.2.9"
|
||||
gem "bundler", ">= 0.9.5"
|
||||
gem "jeweler", ">= 1.5.0.pre"
|
||||
gem "jeweler", ">= 1.5.0.pre2"
|
||||
gem "rcov", ">= 0"
|
||||
gem "test-construct"
|
||||
end
|
||||
|
||||
@@ -2,8 +2,8 @@ GEM
|
||||
remote: http://rubygems.org/
|
||||
specs:
|
||||
git (1.2.5)
|
||||
jeweler (1.5.0.pre)
|
||||
bundler (>= 1.0.0.rc.5)
|
||||
jeweler (1.5.0.pre3)
|
||||
bundler (~> 1.0.0)
|
||||
git (>= 1.2.5)
|
||||
rake
|
||||
rake (0.8.7)
|
||||
@@ -17,7 +17,7 @@ PLATFORMS
|
||||
|
||||
DEPENDENCIES
|
||||
bundler (>= 0.9.5)
|
||||
jeweler (>= 1.5.0.pre)
|
||||
jeweler (>= 1.5.0.pre2)
|
||||
rake
|
||||
rcov
|
||||
rspec (>= 1.2.9)
|
||||
|
||||
2
Rakefile
2
Rakefile
@@ -22,7 +22,7 @@ Jeweler::Tasks.new do |gem|
|
||||
gem.email = "josh@technicalpickles.com"
|
||||
gem.homepage = "http://github.com/technicalpickles/homesick"
|
||||
gem.authors = ["Joshua Nichols"]
|
||||
gem.version = "0.5.3"
|
||||
gem.version = "0.6.0"
|
||||
# Have dependencies? Add them to Gemfile
|
||||
|
||||
# gem is a Gem::Specification... see http://www.rubygems.org/read/chapter/20 for additional settings
|
||||
|
||||
@@ -5,11 +5,11 @@
|
||||
|
||||
Gem::Specification.new do |s|
|
||||
s.name = %q{homesick}
|
||||
s.version = "0.5.3"
|
||||
s.version = "0.6.0"
|
||||
|
||||
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
||||
s.authors = ["Joshua Nichols"]
|
||||
s.date = %q{2010-08-19}
|
||||
s.date = %q{2010-10-27}
|
||||
s.default_executable = %q{homesick}
|
||||
s.description = %q{
|
||||
A man's home (directory) is his castle, so don't leave home with out it.
|
||||
@@ -60,7 +60,7 @@ Gem::Specification.new do |s|
|
||||
s.add_development_dependency(%q<rake>, [">= 0"])
|
||||
s.add_development_dependency(%q<rspec>, [">= 1.2.9"])
|
||||
s.add_development_dependency(%q<bundler>, [">= 0.9.5"])
|
||||
s.add_development_dependency(%q<jeweler>, [">= 1.5.0.pre"])
|
||||
s.add_development_dependency(%q<jeweler>, [">= 1.5.0.pre2"])
|
||||
s.add_development_dependency(%q<rcov>, [">= 0"])
|
||||
s.add_development_dependency(%q<test-construct>, [">= 0"])
|
||||
else
|
||||
@@ -68,7 +68,7 @@ Gem::Specification.new do |s|
|
||||
s.add_dependency(%q<rake>, [">= 0"])
|
||||
s.add_dependency(%q<rspec>, [">= 1.2.9"])
|
||||
s.add_dependency(%q<bundler>, [">= 0.9.5"])
|
||||
s.add_dependency(%q<jeweler>, [">= 1.5.0.pre"])
|
||||
s.add_dependency(%q<jeweler>, [">= 1.5.0.pre2"])
|
||||
s.add_dependency(%q<rcov>, [">= 0"])
|
||||
s.add_dependency(%q<test-construct>, [">= 0"])
|
||||
end
|
||||
@@ -77,7 +77,7 @@ Gem::Specification.new do |s|
|
||||
s.add_dependency(%q<rake>, [">= 0"])
|
||||
s.add_dependency(%q<rspec>, [">= 1.2.9"])
|
||||
s.add_dependency(%q<bundler>, [">= 0.9.5"])
|
||||
s.add_dependency(%q<jeweler>, [">= 1.5.0.pre"])
|
||||
s.add_dependency(%q<jeweler>, [">= 1.5.0.pre2"])
|
||||
s.add_dependency(%q<rcov>, [">= 0"])
|
||||
s.add_dependency(%q<test-construct>, [">= 0"])
|
||||
end
|
||||
|
||||
@@ -43,6 +43,19 @@ class Homesick < Thor
|
||||
git_submodule_update
|
||||
end
|
||||
end
|
||||
|
||||
homesickrc = destination.join('.homesickrc').expand_path
|
||||
if homesickrc.exist?
|
||||
proceed = shell.yes?("#{uri} has a .homesickrc. Proceed with evaling it? (This could be destructive)")
|
||||
if proceed
|
||||
shell.say_status "eval", homesickrc
|
||||
inside destination do
|
||||
eval homesickrc.read, binding, homesickrc.expand_path
|
||||
end
|
||||
else
|
||||
shell.say_status "eval skip", "not evaling #{homesickrc}, #{destination} may need manual configuration", :blue
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -75,6 +88,23 @@ class Homesick < Thor
|
||||
end
|
||||
end
|
||||
|
||||
desc "track FILE CASTLE", "add a file to a castle"
|
||||
def track(file, castle)
|
||||
castle = Pathname.new(castle)
|
||||
file = Pathname.new(file)
|
||||
check_castle_existance(castle, 'track')
|
||||
|
||||
absolute_path = file.expand_path
|
||||
castle_path = castle_dir(castle)
|
||||
mv absolute_path, castle_path
|
||||
|
||||
inside home_dir do
|
||||
absolute_path = castle_dir(castle) + file.basename
|
||||
home_path = home_dir + file
|
||||
ln_s absolute_path, home_path
|
||||
end
|
||||
end
|
||||
|
||||
desc "list", "List cloned castles"
|
||||
def list
|
||||
#require 'ruby-debug'; breakpoint
|
||||
@@ -94,7 +124,6 @@ class Homesick < Thor
|
||||
github_user = nil if github_user == ""
|
||||
github_repo = castle.basename
|
||||
|
||||
|
||||
empty_directory castle
|
||||
inside castle do
|
||||
git_init
|
||||
@@ -107,6 +136,7 @@ class Homesick < Thor
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
protected
|
||||
|
||||
def home_dir
|
||||
|
||||
@@ -59,6 +59,22 @@ class Homesick
|
||||
system "git pull --quiet" unless options[:pretend]
|
||||
end
|
||||
|
||||
def mv(source, destination, config = {})
|
||||
source = Pathname.new(source)
|
||||
destination = Pathname.new(destination + source.basename)
|
||||
|
||||
if destination.exist?
|
||||
say_status :conflict, "#{destination} exists", :red unless options[:quiet]
|
||||
|
||||
if options[:force] || shell.file_collision(destination) { source }
|
||||
system "mv #{source} #{destination}" unless options[:pretend]
|
||||
end
|
||||
else
|
||||
# this needs some sort of message here.
|
||||
system "mv #{source} #{destination}" unless options[:pretend]
|
||||
end
|
||||
end
|
||||
|
||||
def ln_s(source, destination, config = {})
|
||||
source = Pathname.new(source)
|
||||
destination = Pathname.new(destination)
|
||||
@@ -69,14 +85,14 @@ class Homesick
|
||||
else
|
||||
say_status :conflict, "#{destination} exists and points to #{destination.readlink}", :red unless options[:quiet]
|
||||
|
||||
if shell.file_collision(destination) { source }
|
||||
if options[:force] || shell.file_collision(destination) { source }
|
||||
system "ln -sf #{source} #{destination}" unless options[:pretend]
|
||||
end
|
||||
end
|
||||
elsif destination.exist?
|
||||
say_status :conflict, "#{destination} exists", :red unless options[:quiet]
|
||||
|
||||
if shell.file_collision(destination) { source }
|
||||
if options[:force] || shell.file_collision(destination) { source }
|
||||
system "ln -sf #{source} #{destination}" unless options[:pretend]
|
||||
end
|
||||
else
|
||||
|
||||
@@ -84,12 +84,30 @@ describe Homesick do
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@homesick.should_receive(:say_status).with("zomg", "git://github.com/technicalpickles/zomg.git", :cyan)
|
||||
@homesick.should_receive(:say_status).with("wtf/zomg", "git://github.com/technicalpickles/zomg.git", :cyan)
|
||||
|
||||
@homesick.list
|
||||
end
|
||||
end
|
||||
|
||||
describe "track" do
|
||||
it "should move the tracked file into the castle" do
|
||||
some_rc_file = @user_dir.file '.some_rc_file'
|
||||
homesickrepo = @user_dir.directory('.homesick').directory('repos').directory('castle_repo')
|
||||
castle_path = homesickrepo.directory 'home'
|
||||
|
||||
# There is some hideous thing going on with construct; rming the file I'm moving works on this test.
|
||||
# Otherwise when track ln_s's it back out, it sees a conflict. Its as if file operations don't
|
||||
# actually effect this thing, or something.
|
||||
system "rm #{some_rc_file.to_s}"
|
||||
Dir.chdir homesickrepo do
|
||||
system "git init >/dev/null 2>&1"
|
||||
end
|
||||
|
||||
@homesick.should_receive(:mv).with(some_rc_file, castle_path)
|
||||
@homesick.should_receive(:ln_s).with(castle_path + some_rc_file.basename, some_rc_file)
|
||||
@homesick.track(some_rc_file.to_s, 'castle_repo')
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user