aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorfhemberger <mail@frederic-hemberger.de>2011-09-04 14:25:04 +0200
committerfhemberger <mail@frederic-hemberger.de>2011-09-04 14:25:04 +0200
commitf03c4cdb2abe524e097fdfc67194e8d9fc0d19ab (patch)
tree00fbfdd14572dfafa44054e675edb9c977a1846c
parent80f8a609f6e2d7349ab76c7bee662024bdf2aa94 (diff)
downloadmy_new_personal_website-f03c4cdb2abe524e097fdfc67194e8d9fc0d19ab.tar.xz
my_new_personal_website-f03c4cdb2abe524e097fdfc67194e8d9fc0d19ab.zip
install: Adds confirmation before overwriting existing source_dir
-rw-r--r--Rakefile17
1 files changed, 17 insertions, 0 deletions
diff --git a/Rakefile b/Rakefile
index 702292a8..59a6b196 100644
--- a/Rakefile
+++ b/Rakefile
@@ -27,6 +27,9 @@ server_port = "4000" # port for preview server eg. localhost:4000
desc "Initial setup for Octopress: copies the default theme into the path of Jekyll's generator. Rake install defaults to rake install[classic] to install a different theme run rake install[some_theme_name]"
task :install, :theme do |t, args|
+ if File.directory?(source_dir) || File.directory?("sass")
+ abort("rake aborted!") if ask("A theme is already installed, proceeding will overwrite existing files. Are you sure?", ['y', 'n']) == 'n'
+ end
# copy theme into working Jekyll directories
theme = args.theme || 'classic'
puts "## Copying "+theme+" theme into ./#{source_dir} and ./sass"
@@ -293,6 +296,20 @@ def ok_failed(condition)
end
end
+def get_stdin(message)
+ print message
+ STDIN.gets.chomp
+end
+
+def ask(message, valid_options)
+ if valid_options
+ answer = get_stdin("#{message} #{valid_options.to_s.gsub(/"/, '').gsub(/, /,'/')} ") while !valid_options.include?(answer)
+ else
+ answer = get_stdin(message)
+ end
+ answer
+end
+
desc "list tasks"
task :list do
puts "Tasks: #{(Rake::Task.tasks - [Rake::Task[:list]]).join(', ')}"