dsl/liveblog.rb in livetext-0.8.16 vs dsl/liveblog.rb in livetext-0.8.17
- old
+ new
@@ -41,15 +41,10 @@
def views
_debug "data = #{_args}"
@meta.views = _args # + ["main"]
end
-def readmore
- @meta.teaser = @dest + "<br>"
- @dest = @dest + @body
-end
-
def liveblog_version
end
def list
@dest << "<ul>"
@@ -77,130 +72,9 @@
# @meta.slug = make_slug(@meta.title)
@meta.body = @dest
@meta
end
-#####
-
-def generate(view)
- dir = "views/#{view}"
- _errout("dir = #{dir}")
- out = "#{dir}/compiled/#{@meta.slug}.html"
- @post_header = ::File.read("#{dir}/post_header.html")
- @post_trailer = ::File.read("#{dir}/post_trailer.html")
- @template = ::File.read("#{dir}/template.html")
-
- title = @meta.title
- title.gsub!("'",''')
- title.gsub!('"','_')
- teaser = @meta.teaser
- server, dir = @deployment[view]
- url = "http://#{server}/#{server}/#{@meta.slug}.html"
- tweet = ""#{title}"\n"
- tweet.gsub!("'",''')
-
- text = eval("<<HEREDOC\n#@template\nHEREDOC")
- _errout "Writing #{text.size} bytes to #{out}"
- ::File.write(out, text)
-
- metaname = out.sub(/html/, "yaml")
- _errout "Writing #{@meta.to_yaml.size} bytes to #{metaname}"
- ::File.write(metaname, @meta.to_yaml)
- @list[view] ||= []
- @list[view] << out << metaname
- generate_index(view)
-rescue => err
- ::STDERR.puts "#{err}\n#{err.backtrace.map {|x| " " + x }.join("\n") }"
-end
-
-def generate_index(view) # FIXME
- dir = "views/#{view}"
- cdir = "views/#{view}/compiled"
- posts = ::Dir["#{cdir}/*.yaml"].sort {|a,b| b <=> a }
- out = ::File.read("#{dir}/blogheader.html")
-
- server, destdir = @deployment[view]
-
- posts.each do |fname|
- meta = ::YAML.load(::File.read(fname))
-# name2 = fname.sub("compiled",) # FIXME
- name2 = fname.sub("compiled",destdir)
- html = name2.sub(/yaml/, "html")
- out << <<-HTML
- <br>
- <font size=+1>#{meta["pubdate"]} </font>
- <font size=+2 color=blue><a href=../#{html} style="text-decoration: none">#{meta["title"]}</font></a>
- <br>
- #{meta["teaser"]}
- <a href=../#{html} style="text-decoration: none"><br>Read more...</a>
- <br><br>
- <hr>
- HTML
- end
-
- out << <<-HTML
- </body>
- </html>
- HTML
- ::File.write("#{cdir}/index.html", out)
- @list[view] << "#{cdir}/index.html"
- _errout @list.inspect
-end
-
def teaser
@meta.teaser = _body_text
# FIXME
end
-
-def deploy # FIXME
- if @list.empty?
- puts "No changes to deploy."
- return
- end
- puts "Want to deploy? (y/N):"
- inp = ::File.open("/dev/tty")
- resp = inp.gets.chomp
- return unless resp == "y"
-
- puts "Deploying:"
- @list.each_pair do |per, files|
- server, dir = @deployment[per]
- cmd = "scp #{files.join(' ')} root@#{server}:#{dir}"
- puts cmd
- # system cmd
- end
-end
-
-def redeploy(per)
- puts "Redeploying:"
- server, dir = @deployment[per]
- cmd = "scp #{files.join(' ')} root@#{server}:#{dir}"
- puts cmd
-# system cmd
-end
-
-################ Logic...
-
-=begin
- New post:
- specify file name
- output metadata (yaml), html
- output task list??
- How handle views?
- Generate indices
- Deploy
-
-Handling views:
- Each view has its own index
- Separate boilerplate (header/trailer)
- Separate deployments (separate host info)
- 'main' linked to default?
- 'test' view
- generate is now dependent on view
-
-Under view dir:
- header/trailer
- index
- host info? (only for deploy)
- separate compiled/ directory??
-=end
-