More templating, lint
This commit is contained in:
parent
42f43db2b1
commit
2eb20aa09b
@ -1,2 +1,2 @@
|
|||||||
name: hello
|
name: {{ name }}
|
||||||
runtime: crystal
|
runtime: crystal
|
@ -1,4 +1,4 @@
|
|||||||
name: function
|
name: {{ name }}
|
||||||
version: 0.1.0
|
version: 0.1.0
|
||||||
|
|
||||||
targets:
|
targets:
|
@ -23,12 +23,12 @@ module Faaso
|
|||||||
end
|
end
|
||||||
|
|
||||||
# Get runtime template files list
|
# Get runtime template files list
|
||||||
template_base = ""
|
template_base = ""
|
||||||
template_files = [] of String
|
template_files = [] of String
|
||||||
if @@known.includes? "./runtimes/#{runtime}"
|
if @@known.includes? "./runtimes/#{runtime}"
|
||||||
Log.info { "Using known runtime #{runtime}" }
|
Log.info { "Using known runtime #{runtime}" }
|
||||||
template_base = "./runtimes/#{runtime}/template"
|
template_base = "./runtimes/#{runtime}/template"
|
||||||
template_files = @@filelist.select { |f| f.starts_with? template_base }
|
template_files = @@filelist.select(&.starts_with?(template_base))
|
||||||
elsif File.exists? runtime
|
elsif File.exists? runtime
|
||||||
Log.info { "Using directory #{runtime} as runtime" }
|
Log.info { "Using directory #{runtime} as runtime" }
|
||||||
template_base = "#{runtime}/template"
|
template_base = "#{runtime}/template"
|
||||||
@ -38,8 +38,6 @@ module Faaso
|
|||||||
return 1
|
return 1
|
||||||
end
|
end
|
||||||
|
|
||||||
pp! template_files
|
|
||||||
|
|
||||||
# Create new folder
|
# Create new folder
|
||||||
if Dir.exists? folder
|
if Dir.exists? folder
|
||||||
Log.error { "Folder #{folder} already exists" }
|
Log.error { "Folder #{folder} already exists" }
|
||||||
@ -48,28 +46,28 @@ module Faaso
|
|||||||
|
|
||||||
Dir.mkdir_p folder
|
Dir.mkdir_p folder
|
||||||
|
|
||||||
template_files.each do |f|
|
template_files.each do |t_file|
|
||||||
content = IO::Memory.new
|
content = IO::Memory.new
|
||||||
# We need to use RUCKSACK_MODE=0 so it
|
# We need to use RUCKSACK_MODE=0 so it
|
||||||
# fallbacks to the filesystem
|
# fallbacks to the filesystem
|
||||||
rucksack(f).read(content)
|
rucksack(t_file).read(content)
|
||||||
if content.nil?
|
if content.nil?
|
||||||
Log.error { "Can't find file #{f}" }
|
Log.error { "Can't find file #{t_file}" }
|
||||||
return 1
|
return 1
|
||||||
end
|
end
|
||||||
|
|
||||||
# f is like "#{template_base}/foo"
|
# t_file is like "#{template_base}/foo"
|
||||||
# dst is like #{folder}/foo
|
# dst is like #{folder}/foo
|
||||||
dst = Path[folder] / Path[f].relative_to(template_base)
|
dst = Path[folder] / Path[t_file].relative_to(template_base)
|
||||||
# Render templated files
|
# Render templated files
|
||||||
if f.ends_with? ".j2"
|
if t_file.ends_with? ".j2"
|
||||||
dst = dst.sibling(dst.stem)
|
dst = dst.sibling(dst.stem)
|
||||||
Log.info { "Creating file #{dst} from #{f}" }
|
Log.info { " Creating file #{dst} from #{t_file}" }
|
||||||
File.open(dst, "w") do |file|
|
File.open(dst, "w") do |file|
|
||||||
file << Crinja.render(content.to_s, {"name" => Path[folder].basename})
|
file << Crinja.render(content.to_s, {"name" => Path[folder].basename})
|
||||||
end
|
end
|
||||||
else # Just copy the file
|
else # Just copy the file
|
||||||
Log.info { "Creating file #{dst} from #{f}" }
|
Log.info { " Creating file #{dst} from #{t_file}" }
|
||||||
File.open(dst, "w") do |file|
|
File.open(dst, "w") do |file|
|
||||||
file << content.to_s
|
file << content.to_s
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user