Merge branch 'master' into 3836-remove-collection-from-project-bug
[arvados.git] / docker / build_tools / config.rb
index 8b9bb73249012a22b069b543a56ca441190e96b2..d8bf256124eeeb387f6af39128b47b4ab35f9aac 100755 (executable)
@@ -18,7 +18,7 @@ config = YAML.load_file('config.yml')
 # doesn't change if config.yml doesn't change. Otherwise, keys won't
 # match any more if (say) keep's files get regenerated but apiserver's
 # don't.
-config.each_key do |var|
+config.sort.map do |var,val|
   if (var.end_with?('_PW') || var.end_with?('_SECRET')) && (config[var].nil? || config[var].empty?)
     config[var] = Digest::SHA1.hexdigest(`hostname` + var + config.to_yaml)
   end
@@ -40,16 +40,15 @@ else
   globdir = '*'
 end
 
-Dir.glob(globdir + '/generated/*') do |stale_file|
-  File.delete(stale_file)
-end
+FileUtils.rm_r Dir.glob(globdir + '/generated/*')
 
 File.umask(022)
 Dir.glob(globdir + '/*.in') do |template_file|
   generated_dir = File.join(File.dirname(template_file), 'generated')
   Dir.mkdir(generated_dir) unless Dir.exists? generated_dir
   output_path = File.join(generated_dir, File.basename(template_file, '.in'))
-  File.open(output_path, "w") do |output|
+  output_mode = (File.stat(template_file).mode & 0100) ? 0755 : 0644
+  File.open(output_path, "w", output_mode) do |output|
     File.open(template_file) do |input|
       input.each_line do |line|